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

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

Issue 1525863002: Remove renderer_service -> media_client dependency. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: fixed compile error Created 5 years 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
« no previous file with comments | « media/mojo/services/mojo_media_client.cc ('k') | media/mojo/services/mojo_renderer_service.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 "base/callback.h"
9 #include "base/compiler_specific.h"
10 #include "base/macros.h" 8 #include "base/macros.h"
11 #include "base/memory/scoped_ptr.h" 9 #include "base/memory/scoped_ptr.h"
12 #include "base/memory/weak_ptr.h" 10 #include "base/memory/weak_ptr.h"
13 #include "base/timer/timer.h" 11 #include "base/timer/timer.h"
14 #include "media/base/audio_decoder_config.h"
15 #include "media/base/buffering_state.h" 12 #include "media/base/buffering_state.h"
16 #include "media/base/media_export.h"
17 #include "media/base/pipeline_status.h" 13 #include "media/base/pipeline_status.h"
18 #include "media/mojo/interfaces/renderer.mojom.h" 14 #include "media/mojo/interfaces/renderer.mojom.h"
19 #include "media/mojo/services/mojo_cdm_service_context.h"
20 #include "mojo/public/cpp/bindings/strong_binding.h" 15 #include "mojo/public/cpp/bindings/strong_binding.h"
21 16
22 namespace mojo { 17 namespace mojo {
23 class ApplicationConnection; 18 class ApplicationConnection;
24 } 19 }
25 20
26 namespace media { 21 namespace media {
27 22
28 class AudioRendererSink;
29 class DemuxerStreamProviderShim; 23 class DemuxerStreamProviderShim;
30 class CdmContextProvider; 24 class CdmContextProvider;
31 class MediaLog;
32 class Renderer; 25 class Renderer;
33 class RendererFactory;
34 class VideoRendererSink;
35 26
36 // A interfaces::Renderer implementation that uses media::AudioRenderer to 27 // A interfaces::Renderer implementation that uses media::AudioRenderer to
37 // decode and render audio to a sink obtained from the ApplicationConnection. 28 // decode and render audio to a sink obtained from the ApplicationConnection.
38 class MojoRendererService : interfaces::Renderer { 29 class MojoRendererService : interfaces::Renderer {
39 public: 30 public:
40 // |cdm_context_provider| can be used to find the CdmContext to support 31 // |cdm_context_provider| can be used to find the CdmContext to support
41 // encrypted media. If null, encrypted media is not supported. 32 // encrypted media. If null, encrypted media is not supported.
42 MojoRendererService(base::WeakPtr<CdmContextProvider> cdm_context_provider, 33 MojoRendererService(base::WeakPtr<CdmContextProvider> cdm_context_provider,
43 RendererFactory* renderer_factory, 34 scoped_ptr<media::Renderer> renderer,
44 const scoped_refptr<MediaLog>& media_log,
45 mojo::InterfaceRequest<interfaces::Renderer> request); 35 mojo::InterfaceRequest<interfaces::Renderer> request);
46 ~MojoRendererService() final; 36 ~MojoRendererService() final;
47 37
48 // interfaces::Renderer implementation. 38 // interfaces::Renderer implementation.
49 void Initialize(interfaces::RendererClientPtr client, 39 void Initialize(interfaces::RendererClientPtr client,
50 interfaces::DemuxerStreamPtr audio, 40 interfaces::DemuxerStreamPtr audio,
51 interfaces::DemuxerStreamPtr video, 41 interfaces::DemuxerStreamPtr video,
52 const mojo::Callback<void(bool)>& callback) final; 42 const mojo::Callback<void(bool)>& callback) final;
53 void Flush(const mojo::Closure& callback) final; 43 void Flush(const mojo::Closure& callback) final;
54 void StartPlayingFrom(int64_t time_delta_usec) final; 44 void StartPlayingFrom(int64_t time_delta_usec) final;
(...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after
95 85
96 // Callback executed once Flush() completes. 86 // Callback executed once Flush() completes.
97 void OnFlushCompleted(const mojo::Closure& callback); 87 void OnFlushCompleted(const mojo::Closure& callback);
98 88
99 // Callback executed once SetCdm() completes. 89 // Callback executed once SetCdm() completes.
100 void OnCdmAttached(const mojo::Callback<void(bool)>& callback, bool success); 90 void OnCdmAttached(const mojo::Callback<void(bool)>& callback, bool success);
101 91
102 mojo::StrongBinding<interfaces::Renderer> binding_; 92 mojo::StrongBinding<interfaces::Renderer> binding_;
103 93
104 base::WeakPtr<CdmContextProvider> cdm_context_provider_; 94 base::WeakPtr<CdmContextProvider> cdm_context_provider_;
95 scoped_ptr<media::Renderer> renderer_;
105 96
106 State state_; 97 State state_;
107 98
108 // Note: |renderer_| should be destructed before these objects to avoid access 99 // Note: stream_provider_ must be destructed after renderer_ to avoid access
109 // violation. 100 // violation.
110 scoped_ptr<DemuxerStreamProviderShim> stream_provider_; 101 scoped_ptr<DemuxerStreamProviderShim> stream_provider_;
111 scoped_refptr<AudioRendererSink> audio_renderer_sink_;
112 scoped_ptr<VideoRendererSink> video_renderer_sink_;
113
114 scoped_ptr<media::Renderer> renderer_;
115 102
116 base::RepeatingTimer time_update_timer_; 103 base::RepeatingTimer time_update_timer_;
117 uint64_t last_media_time_usec_; 104 uint64_t last_media_time_usec_;
118 105
119 interfaces::RendererClientPtr client_; 106 interfaces::RendererClientPtr client_;
120 107
121 base::WeakPtr<MojoRendererService> weak_this_; 108 base::WeakPtr<MojoRendererService> weak_this_;
122 base::WeakPtrFactory<MojoRendererService> weak_factory_; 109 base::WeakPtrFactory<MojoRendererService> weak_factory_;
123 110
124 DISALLOW_COPY_AND_ASSIGN(MojoRendererService); 111 DISALLOW_COPY_AND_ASSIGN(MojoRendererService);
125 }; 112 };
126 113
127 } // namespace media 114 } // namespace media
128 115
129 #endif // MEDIA_MOJO_SERVICES_MOJO_RENDERER_SERVICE_H_ 116 #endif // MEDIA_MOJO_SERVICES_MOJO_RENDERER_SERVICE_H_
OLDNEW
« no previous file with comments | « media/mojo/services/mojo_media_client.cc ('k') | media/mojo/services/mojo_renderer_service.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698