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 |
11 #include "base/callback.h" | 11 #include "base/callback.h" |
12 #include "base/compiler_specific.h" | 12 #include "base/compiler_specific.h" |
13 #include "base/macros.h" | 13 #include "base/macros.h" |
14 #include "base/memory/ref_counted.h" | 14 #include "base/memory/ref_counted.h" |
15 #include "base/memory/weak_ptr.h" | 15 #include "base/memory/weak_ptr.h" |
16 #include "base/timer/timer.h" | 16 #include "base/timer/timer.h" |
17 #include "base/unguessable_token.h" | |
17 #include "media/base/buffering_state.h" | 18 #include "media/base/buffering_state.h" |
18 #include "media/base/demuxer_stream_provider.h" | 19 #include "media/base/demuxer_stream_provider.h" |
19 #include "media/base/pipeline_status.h" | 20 #include "media/base/pipeline_status.h" |
20 #include "media/base/renderer_client.h" | 21 #include "media/base/renderer_client.h" |
21 #include "media/mojo/interfaces/renderer.mojom.h" | 22 #include "media/mojo/interfaces/renderer.mojom.h" |
22 #include "media/mojo/services/media_mojo_export.h" | 23 #include "media/mojo/services/media_mojo_export.h" |
24 #include "mojo/public/cpp/bindings/strong_binding.h" | |
23 | 25 |
24 namespace media { | 26 namespace media { |
25 | 27 |
26 class AudioRendererSink; | 28 class AudioRendererSink; |
27 class DemuxerStreamProviderShim; | 29 class DemuxerStreamProviderShim; |
28 class MediaKeys; | 30 class MediaKeys; |
29 class MojoCdmServiceContext; | 31 class MojoCdmServiceContext; |
30 class Renderer; | 32 class Renderer; |
31 class VideoRendererSink; | 33 class VideoRendererSink; |
32 | 34 |
33 // A mojom::Renderer implementation that use a media::Renderer to render | 35 // A mojom::Renderer implementation that use a media::Renderer to render |
34 // media streams. | 36 // media streams. |
35 class MEDIA_MOJO_EXPORT MojoRendererService | 37 class MEDIA_MOJO_EXPORT MojoRendererService |
36 : NON_EXPORTED_BASE(public mojom::Renderer), | 38 : NON_EXPORTED_BASE(public mojom::Renderer), |
37 public RendererClient { | 39 public RendererClient { |
38 public: | 40 public: |
41 using InitiateSurfaceRequestCB = base::Callback<base::UnguessableToken()>; | |
42 | |
39 // |mojo_cdm_service_context| can be used to find the CDM to support | 43 // |mojo_cdm_service_context| can be used to find the CDM to support |
40 // encrypted media. If null, encrypted media is not supported. | 44 // encrypted media. If null, encrypted media is not supported. |
41 MojoRendererService( | 45 // NOTE: The MojoRendererService will be uniquely owned by the returned |
dcheng
2016/10/05 22:37:12
StrongBindingPtr is actually a WeakPtr. The create
tguilbert
2016/10/05 23:46:21
Clarified the comment.
| |
46 // StrongBinding. | |
47 static mojo::StrongBindingPtr<mojom::Renderer> Create( | |
42 base::WeakPtr<MojoCdmServiceContext> mojo_cdm_service_context, | 48 base::WeakPtr<MojoCdmServiceContext> mojo_cdm_service_context, |
43 scoped_refptr<AudioRendererSink> audio_sink, | 49 scoped_refptr<AudioRendererSink> audio_sink, |
44 std::unique_ptr<VideoRendererSink> video_sink, | 50 std::unique_ptr<VideoRendererSink> video_sink, |
45 std::unique_ptr<media::Renderer> renderer); | 51 std::unique_ptr<media::Renderer> renderer, |
52 InitiateSurfaceRequestCB initiate_surface_request_cb, | |
53 mojo::InterfaceRequest<mojom::Renderer> request); | |
54 | |
46 ~MojoRendererService() final; | 55 ~MojoRendererService() final; |
47 | 56 |
48 // mojom::Renderer implementation. | 57 // mojom::Renderer implementation. |
49 void Initialize(mojom::RendererClientAssociatedPtrInfo client, | 58 void Initialize(mojom::RendererClientAssociatedPtrInfo client, |
50 mojom::DemuxerStreamPtr audio, | 59 mojom::DemuxerStreamPtr audio, |
51 mojom::DemuxerStreamPtr video, | 60 mojom::DemuxerStreamPtr video, |
52 const base::Optional<GURL>& url, | 61 const base::Optional<GURL>& url, |
53 const InitializeCallback& callback) final; | 62 const InitializeCallback& callback) final; |
54 void Flush(const FlushCallback& callback) final; | 63 void Flush(const FlushCallback& callback) final; |
55 void StartPlayingFrom(base::TimeDelta time_delta) final; | 64 void StartPlayingFrom(base::TimeDelta time_delta) final; |
56 void SetPlaybackRate(double playback_rate) final; | 65 void SetPlaybackRate(double playback_rate) final; |
57 void SetVolume(float volume) final; | 66 void SetVolume(float volume) final; |
58 void SetCdm(int32_t cdm_id, const SetCdmCallback& callback) final; | 67 void SetCdm(int32_t cdm_id, const SetCdmCallback& callback) final; |
68 void InitiateScopedSurfaceRequest( | |
69 const InitiateScopedSurfaceRequestCallback& callback) final; | |
59 | 70 |
60 private: | 71 private: |
61 enum State { | 72 enum State { |
62 STATE_UNINITIALIZED, | 73 STATE_UNINITIALIZED, |
63 STATE_INITIALIZING, | 74 STATE_INITIALIZING, |
64 STATE_FLUSHING, | 75 STATE_FLUSHING, |
65 STATE_PLAYING, | 76 STATE_PLAYING, |
66 STATE_ERROR | 77 STATE_ERROR |
67 }; | 78 }; |
68 | 79 |
80 MojoRendererService( | |
81 base::WeakPtr<MojoCdmServiceContext> mojo_cdm_service_context, | |
82 scoped_refptr<AudioRendererSink> audio_sink, | |
83 std::unique_ptr<VideoRendererSink> video_sink, | |
84 std::unique_ptr<media::Renderer> renderer, | |
85 InitiateSurfaceRequestCB initiate_surface_request_cb); | |
86 | |
87 // |binding| is be the binding that uniquely owns |this|. | |
88 void SetBinding(mojo::StrongBindingPtr<mojom::Renderer> binding); | |
89 | |
69 // RendererClient implementation. | 90 // RendererClient implementation. |
70 void OnError(PipelineStatus status) final; | 91 void OnError(PipelineStatus status) final; |
71 void OnEnded() final; | 92 void OnEnded() final; |
72 void OnStatisticsUpdate(const PipelineStatistics& stats) final; | 93 void OnStatisticsUpdate(const PipelineStatistics& stats) final; |
73 void OnBufferingStateChange(BufferingState state) final; | 94 void OnBufferingStateChange(BufferingState state) final; |
74 void OnWaitingForDecryptionKey() final; | 95 void OnWaitingForDecryptionKey() final; |
75 void OnVideoNaturalSizeChange(const gfx::Size& size) final; | 96 void OnVideoNaturalSizeChange(const gfx::Size& size) final; |
76 void OnVideoOpacityChange(bool opaque) final; | 97 void OnVideoOpacityChange(bool opaque) final; |
77 void OnDurationChange(base::TimeDelta duration) final; | 98 void OnDurationChange(base::TimeDelta duration) final; |
78 | 99 |
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
120 // May be null if underlying |renderer_| does not use them. | 141 // May be null if underlying |renderer_| does not use them. |
121 scoped_refptr<AudioRendererSink> audio_sink_; | 142 scoped_refptr<AudioRendererSink> audio_sink_; |
122 std::unique_ptr<VideoRendererSink> video_sink_; | 143 std::unique_ptr<VideoRendererSink> video_sink_; |
123 | 144 |
124 // Note: Destroy |renderer_| first to avoid access violation into other | 145 // Note: Destroy |renderer_| first to avoid access violation into other |
125 // members, e.g. |stream_provider_|, |cdm_|, |audio_sink_|, and | 146 // members, e.g. |stream_provider_|, |cdm_|, |audio_sink_|, and |
126 // |video_sink_|. | 147 // |video_sink_|. |
127 // Must use "media::" because "Renderer" is ambiguous. | 148 // Must use "media::" because "Renderer" is ambiguous. |
128 std::unique_ptr<media::Renderer> renderer_; | 149 std::unique_ptr<media::Renderer> renderer_; |
129 | 150 |
151 // Registers a new request in the ScopedSurfaceRequestManager. | |
152 // Returns the token to be used to fulfill the request. | |
153 InitiateSurfaceRequestCB initiate_surface_request_cb_; | |
154 | |
155 // WeakPtr to the binding that owns |this|. | |
156 // Used to forcefully close the connection (which also safely destroy |this|). | |
157 mojo::StrongBindingPtr<mojom::Renderer> binding_; | |
158 | |
130 base::WeakPtr<MojoRendererService> weak_this_; | 159 base::WeakPtr<MojoRendererService> weak_this_; |
131 base::WeakPtrFactory<MojoRendererService> weak_factory_; | 160 base::WeakPtrFactory<MojoRendererService> weak_factory_; |
132 | 161 |
133 DISALLOW_COPY_AND_ASSIGN(MojoRendererService); | 162 DISALLOW_COPY_AND_ASSIGN(MojoRendererService); |
134 }; | 163 }; |
135 | 164 |
136 } // namespace media | 165 } // namespace media |
137 | 166 |
138 #endif // MEDIA_MOJO_SERVICES_MOJO_RENDERER_SERVICE_H_ | 167 #endif // MEDIA_MOJO_SERVICES_MOJO_RENDERER_SERVICE_H_ |
OLD | NEW |