Chromium Code Reviews| 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 |