OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef MEDIA_MOJO_SERVICES_MOJO_RENDERER_SERVICE_H_ | 5 #ifndef MEDIA_MOJO_SERVICES_MOJO_RENDERER_SERVICE_H_ |
6 #define MEDIA_MOJO_SERVICES_MOJO_RENDERER_SERVICE_H_ | 6 #define MEDIA_MOJO_SERVICES_MOJO_RENDERER_SERVICE_H_ |
7 | 7 |
8 #include <stdint.h> | 8 #include <stdint.h> |
9 #include <memory> | 9 #include <memory> |
10 | 10 |
(...skipping 19 matching lines...) Expand all Loading... |
30 class MojoCdmServiceContext; | 30 class MojoCdmServiceContext; |
31 class Renderer; | 31 class Renderer; |
32 class VideoRendererSink; | 32 class VideoRendererSink; |
33 | 33 |
34 // A mojom::Renderer implementation that use a media::Renderer to render | 34 // A mojom::Renderer implementation that use a media::Renderer to render |
35 // media streams. | 35 // media streams. |
36 class MEDIA_MOJO_EXPORT MojoRendererService | 36 class MEDIA_MOJO_EXPORT MojoRendererService |
37 : NON_EXPORTED_BASE(public mojom::Renderer), | 37 : NON_EXPORTED_BASE(public mojom::Renderer), |
38 public RendererClient { | 38 public RendererClient { |
39 public: | 39 public: |
| 40 using InitiateSurfaceRequestCB = base::Callback<uint64_t()>; |
| 41 |
40 // |mojo_cdm_service_context| can be used to find the CDM to support | 42 // |mojo_cdm_service_context| can be used to find the CDM to support |
41 // encrypted media. If null, encrypted media is not supported. | 43 // encrypted media. If null, encrypted media is not supported. |
42 MojoRendererService( | 44 MojoRendererService( |
43 base::WeakPtr<MojoCdmServiceContext> mojo_cdm_service_context, | 45 base::WeakPtr<MojoCdmServiceContext> mojo_cdm_service_context, |
44 scoped_refptr<AudioRendererSink> audio_sink, | 46 scoped_refptr<AudioRendererSink> audio_sink, |
45 std::unique_ptr<VideoRendererSink> video_sink, | 47 std::unique_ptr<VideoRendererSink> video_sink, |
46 std::unique_ptr<media::Renderer> renderer, | 48 std::unique_ptr<media::Renderer> renderer, |
47 mojo::InterfaceRequest<mojom::Renderer> request); | 49 mojo::InterfaceRequest<mojom::Renderer> request, |
| 50 InitiateSurfaceRequestCB initiate_surface_request_cb); |
48 ~MojoRendererService() final; | 51 ~MojoRendererService() final; |
49 | 52 |
50 // mojom::Renderer implementation. | 53 // mojom::Renderer implementation. |
51 void Initialize(mojom::RendererClientPtr client, | 54 void Initialize(mojom::RendererClientPtr client, |
52 mojom::DemuxerStreamPtr audio, | 55 mojom::DemuxerStreamPtr audio, |
53 mojom::DemuxerStreamPtr video, | 56 mojom::DemuxerStreamPtr video, |
54 const base::Optional<GURL>& url, | 57 const base::Optional<GURL>& url, |
55 const InitializeCallback& callback) final; | 58 const InitializeCallback& callback) final; |
56 void Flush(const FlushCallback& callback) final; | 59 void Flush(const FlushCallback& callback) final; |
57 void StartPlayingFrom(base::TimeDelta time_delta) final; | 60 void StartPlayingFrom(base::TimeDelta time_delta) final; |
58 void SetPlaybackRate(double playback_rate) final; | 61 void SetPlaybackRate(double playback_rate) final; |
59 void SetVolume(float volume) final; | 62 void SetVolume(float volume) final; |
60 void SetCdm(int32_t cdm_id, const SetCdmCallback& callback) final; | 63 void SetCdm(int32_t cdm_id, const SetCdmCallback& callback) final; |
| 64 void InitiateScopedSurfaceRequest( |
| 65 const InitiateScopedSurfaceRequestCallback& callback) final; |
61 | 66 |
62 private: | 67 private: |
63 enum State { | 68 enum State { |
64 STATE_UNINITIALIZED, | 69 STATE_UNINITIALIZED, |
65 STATE_INITIALIZING, | 70 STATE_INITIALIZING, |
66 STATE_FLUSHING, | 71 STATE_FLUSHING, |
67 STATE_PLAYING, | 72 STATE_PLAYING, |
68 STATE_ERROR | 73 STATE_ERROR |
69 }; | 74 }; |
70 | 75 |
(...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
122 // May be null if underlying |renderer_| does not use them. | 127 // May be null if underlying |renderer_| does not use them. |
123 scoped_refptr<AudioRendererSink> audio_sink_; | 128 scoped_refptr<AudioRendererSink> audio_sink_; |
124 std::unique_ptr<VideoRendererSink> video_sink_; | 129 std::unique_ptr<VideoRendererSink> video_sink_; |
125 | 130 |
126 // Note: Destroy |renderer_| first to avoid access violation into other | 131 // Note: Destroy |renderer_| first to avoid access violation into other |
127 // members, e.g. |stream_provider_|, |cdm_|, |audio_sink_|, and | 132 // members, e.g. |stream_provider_|, |cdm_|, |audio_sink_|, and |
128 // |video_sink_|. | 133 // |video_sink_|. |
129 // Must use "media::" because "Renderer" is ambiguous. | 134 // Must use "media::" because "Renderer" is ambiguous. |
130 std::unique_ptr<media::Renderer> renderer_; | 135 std::unique_ptr<media::Renderer> renderer_; |
131 | 136 |
| 137 // Registers a new request in the ScopedSurfaceRequestManager. |
| 138 // Returns the token to be used to fulfill the request. |
| 139 InitiateSurfaceRequestCB initiate_surface_request_cb_; |
| 140 |
132 base::WeakPtr<MojoRendererService> weak_this_; | 141 base::WeakPtr<MojoRendererService> weak_this_; |
133 base::WeakPtrFactory<MojoRendererService> weak_factory_; | 142 base::WeakPtrFactory<MojoRendererService> weak_factory_; |
134 | 143 |
135 DISALLOW_COPY_AND_ASSIGN(MojoRendererService); | 144 DISALLOW_COPY_AND_ASSIGN(MojoRendererService); |
136 }; | 145 }; |
137 | 146 |
138 } // namespace media | 147 } // namespace media |
139 | 148 |
140 #endif // MEDIA_MOJO_SERVICES_MOJO_RENDERER_SERVICE_H_ | 149 #endif // MEDIA_MOJO_SERVICES_MOJO_RENDERER_SERVICE_H_ |
OLD | NEW |