Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(96)

Side by Side Diff: media/mojo/services/mojo_renderer_service.h

Issue 2282633002: Integrate Surface requests with MediaPlayerRenderer (Closed)
Patch Set: Fixed punctuation. Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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
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_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698