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

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

Issue 680533004: Modify MojoRendererService to host a RendererImpl. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 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 "base/callback.h" 8 #include "base/callback.h"
9 #include "base/macros.h" 9 #include "base/macros.h"
10 #include "base/memory/scoped_ptr.h" 10 #include "base/memory/scoped_ptr.h"
11 #include "base/memory/weak_ptr.h" 11 #include "base/memory/weak_ptr.h"
12 #include "base/timer/timer.h" 12 #include "base/timer/timer.h"
13 #include "media/audio/fake_audio_log_factory.h" 13 #include "media/audio/fake_audio_log_factory.h"
14 #include "media/base/audio_decoder_config.h" 14 #include "media/base/audio_decoder_config.h"
15 #include "media/base/audio_hardware_config.h" 15 #include "media/base/audio_hardware_config.h"
16 #include "media/base/buffering_state.h" 16 #include "media/base/buffering_state.h"
17 #include "media/base/pipeline_status.h" 17 #include "media/base/pipeline_status.h"
18 #include "media/mojo/interfaces/media_renderer.mojom.h" 18 #include "media/mojo/interfaces/media_renderer.mojom.h"
19 #include "mojo/public/cpp/bindings/interface_impl.h" 19 #include "mojo/public/cpp/bindings/interface_impl.h"
20 20
21 namespace mojo { 21 namespace mojo {
22 class ApplicationConnection; 22 class ApplicationConnection;
23 } 23 }
24 24
25 namespace media { 25 namespace media {
26 26
27 class AudioManager; 27 class AudioManager;
28 class AudioRenderer; 28 class DemuxerStreamProviderShim;
29 class MojoDemuxerStreamAdapter; 29 class MojoDemuxerStreamAdapter;
30 class TimeSource; 30 class RendererImpl;
31 31
32 // A mojo::MediaRenderer implementation that uses media::AudioRenderer to 32 // A mojo::MediaRenderer implementation that uses media::AudioRenderer to
33 // decode and render audio to a sink obtained from the ApplicationConnection. 33 // decode and render audio to a sink obtained from the ApplicationConnection.
34 class MojoRendererService : public mojo::InterfaceImpl<mojo::MediaRenderer> { 34 class MojoRendererService : public mojo::InterfaceImpl<mojo::MediaRenderer> {
35 public: 35 public:
36 // |connection| is a pointer to the connection back to our embedder. The 36 // |connection| is a pointer to the connection back to our embedder. The
37 // embedder should have configured it (via ConfigureOutgoingConnection) to 37 // embedder should have configured it (via ConfigureOutgoingConnection) to
38 // allow |this| to connect to a sink that will receive decoded data ready 38 // allow |this| to connect to a sink that will receive decoded data ready
39 // for playback. 39 // for playback.
40 explicit MojoRendererService(mojo::ApplicationConnection* connection); 40 explicit MojoRendererService(mojo::ApplicationConnection* connection);
41 ~MojoRendererService() override; 41 ~MojoRendererService() override;
42 42
43 // mojo::MediaRenderer implementation. 43 // mojo::MediaRenderer implementation.
44 void Initialize(mojo::DemuxerStreamPtr stream, 44 void Initialize(mojo::DemuxerStreamPtr streams,
45 const mojo::Callback<void()>& callback) override; 45 const mojo::Closure& callback) override;
46 void Flush(const mojo::Callback<void()>& callback) override; 46 void Flush(const mojo::Closure& callback) override;
47 void StartPlayingFrom(int64_t time_delta_usec) override; 47 void StartPlayingFrom(int64_t time_delta_usec) override;
48 void SetPlaybackRate(float playback_rate) override; 48 void SetPlaybackRate(float playback_rate) override;
49 void SetVolume(float volume) override; 49 void SetVolume(float volume) override;
50 50
51 private: 51 private:
52 enum State { 52 enum State {
53 STATE_UNINITIALIZED, 53 STATE_UNINITIALIZED,
54 STATE_INITIALIZING, 54 STATE_INITIALIZING,
55 STATE_FLUSHING, 55 STATE_FLUSHING,
56 STATE_PLAYING, 56 STATE_PLAYING,
57 STATE_ERROR 57 STATE_ERROR
58 }; 58 };
59 59
60 // Called when the MojoDemuxerStreamAdapter is ready to go (has a config, 60 // Called when the MojoDemuxerStreamAdapter is ready to go (has a config,
61 // pipe handle, etc) and can be handed off to a renderer for use. 61 // pipe handle, etc) and can be handed off to a renderer for use.
62 void OnStreamReady(); 62 void OnStreamReady(const mojo::Closure& callback);
63 63
64 // Called when |audio_renderer_| initialization has completed. 64 // Called when |audio_renderer_| initialization has completed.
65 void OnAudioRendererInitializeDone(PipelineStatus status); 65 void OnRendererInitializeDone(const mojo::Closure& callback);
66 66
67 // Callback executed by filters to update statistics. 67 // Callback executed by filters to update statistics.
68 void OnUpdateStatistics(const PipelineStatistics& stats); 68 void OnUpdateStatistics(const PipelineStatistics& stats);
69 69
70 void UpdateMediaTime(); 70 void UpdateMediaTime(bool only_if_changed);
71 void SchedulePeriodicMediaTimeUpdates(); 71 void SchedulePeriodicMediaTimeUpdates();
72 72
73 // Callback executed by audio renderer when buffering state changes. 73 // Callback executed by audio renderer when buffering state changes.
74 // TODO(tim): Need old and new. 74 // TODO(tim): Need old and new.
75 void OnBufferingStateChanged(BufferingState new_buffering_state); 75 void OnBufferingStateChanged(BufferingState new_buffering_state);
76 76
77 // Callback executed when a renderer has ended. 77 // Callback executed when a renderer has ended.
78 void OnAudioRendererEnded(); 78 void OnRendererEnded();
79 79
80 // Callback executed when a runtime error happens. 80 // Callback executed when a runtime error happens.
81 void OnError(PipelineStatus error); 81 void OnError(PipelineStatus error);
82 82
83 bool WaitingForEnoughData() const;
84 void StartPlayback();
85 void PausePlayback();
86
87 State state_; 83 State state_;
88 84
89 scoped_ptr<MojoDemuxerStreamAdapter> stream_; 85 scoped_ptr<RendererImpl> renderer_;
xhwang 2014/10/28 17:13:33 Can this be a scoped_ptr<Renderer>?
DaleCurtis 2014/10/28 21:51:29 Done.
90 scoped_ptr<AudioRenderer> audio_renderer_; 86 scoped_ptr<DemuxerStreamProviderShim> stream_provider_;
91
92 TimeSource* time_source_;
93 bool time_ticking_;
94
95 BufferingState buffering_state_;
96
97 mojo::Callback<void()> init_cb_;
98
99 bool ended_;
100 87
101 base::RepeatingTimer<MojoRendererService> time_update_timer_; 88 base::RepeatingTimer<MojoRendererService> time_update_timer_;
89 uint64_t last_media_time_;
xhwang 2014/10/28 17:13:33 Is this in us?
102 90
103 // TODO(xhwang): Currently we are using a default |audio_hardware_config_|. 91 // TODO(xhwang): Currently we are using a default |audio_hardware_config_|.
104 // Do we need different configs on different platforms? 92 // Do we need different configs on different platforms?
105 media::FakeAudioLogFactory fake_audio_log_factory_; 93 media::FakeAudioLogFactory fake_audio_log_factory_;
106 scoped_ptr<media::AudioManager> audio_manager_; 94 scoped_ptr<media::AudioManager> audio_manager_;
107 media::AudioHardwareConfig audio_hardware_config_; 95 media::AudioHardwareConfig audio_hardware_config_;
108 96
109 base::WeakPtrFactory<MojoRendererService> weak_factory_; 97 base::WeakPtrFactory<MojoRendererService> weak_factory_;
110 base::WeakPtr<MojoRendererService> weak_this_; 98 base::WeakPtr<MojoRendererService> weak_this_;
111 99
112 DISALLOW_COPY_AND_ASSIGN(MojoRendererService); 100 DISALLOW_COPY_AND_ASSIGN(MojoRendererService);
113 }; 101 };
114 102
115 } // namespace media 103 } // namespace media
116 104
117 #endif // MEDIA_MOJO_SERVICES_MOJO_RENDERER_SERVICE_H_ 105 #endif // MEDIA_MOJO_SERVICES_MOJO_RENDERER_SERVICE_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698