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 #include "media/mojo/services/mojo_renderer_service.h" | 5 #include "media/mojo/services/mojo_renderer_service.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/callback_helpers.h" | 8 #include "base/callback_helpers.h" |
9 #include "base/memory/scoped_vector.h" | 9 #include "base/memory/scoped_vector.h" |
10 #include "base/message_loop/message_loop.h" | 10 #include "base/message_loop/message_loop.h" |
11 #include "media/base/audio_decoder.h" | 11 #include "media/base/audio_decoder.h" |
12 #include "media/base/audio_renderer.h" | 12 #include "media/base/audio_renderer.h" |
13 #include "media/base/audio_renderer_sink.h" | 13 #include "media/base/audio_renderer_sink.h" |
14 #include "media/base/cdm_context.h" | 14 #include "media/base/cdm_context.h" |
15 #include "media/base/decryptor.h" | 15 #include "media/base/decryptor.h" |
16 #include "media/base/media_log.h" | 16 #include "media/base/media_log.h" |
| 17 #include "media/base/renderer_factory.h" |
17 #include "media/base/video_renderer.h" | 18 #include "media/base/video_renderer.h" |
18 #include "media/base/video_renderer_sink.h" | 19 #include "media/base/video_renderer_sink.h" |
19 #include "media/mojo/services/demuxer_stream_provider_shim.h" | 20 #include "media/mojo/services/demuxer_stream_provider_shim.h" |
20 #include "media/mojo/services/mojo_media_client.h" | 21 #include "media/mojo/services/mojo_media_client.h" |
21 #include "media/renderers/audio_renderer_impl.h" | 22 #include "media/renderers/audio_renderer_impl.h" |
22 #include "media/renderers/renderer_impl.h" | 23 #include "media/renderers/renderer_impl.h" |
23 #include "media/renderers/video_renderer_impl.h" | 24 #include "media/renderers/video_renderer_impl.h" |
24 | 25 |
25 namespace media { | 26 namespace media { |
26 | 27 |
27 // Time interval to update media time. | 28 // Time interval to update media time. |
28 const int kTimeUpdateIntervalMs = 50; | 29 const int kTimeUpdateIntervalMs = 50; |
29 | 30 |
30 MojoRendererService::MojoRendererService( | 31 MojoRendererService::MojoRendererService( |
31 CdmContextProvider* cdm_context_provider, | 32 CdmContextProvider* cdm_context_provider, |
| 33 RendererFactory* renderer_factory, |
| 34 const scoped_refptr<MediaLog>& media_log, |
32 mojo::InterfaceRequest<mojo::MediaRenderer> request) | 35 mojo::InterfaceRequest<mojo::MediaRenderer> request) |
33 : binding_(this, request.Pass()), | 36 : binding_(this, request.Pass()), |
34 cdm_context_provider_(cdm_context_provider), | 37 cdm_context_provider_(cdm_context_provider), |
35 state_(STATE_UNINITIALIZED), | 38 state_(STATE_UNINITIALIZED), |
36 last_media_time_usec_(0), | 39 last_media_time_usec_(0), |
37 weak_factory_(this) { | 40 weak_factory_(this) { |
38 weak_this_ = weak_factory_.GetWeakPtr(); | 41 weak_this_ = weak_factory_.GetWeakPtr(); |
39 DVLOG(1) << __FUNCTION__; | 42 DVLOG(1) << __FUNCTION__; |
40 | 43 |
41 scoped_refptr<base::SingleThreadTaskRunner> task_runner( | 44 scoped_refptr<base::SingleThreadTaskRunner> task_runner( |
42 base::MessageLoop::current()->task_runner()); | 45 base::MessageLoop::current()->task_runner()); |
43 scoped_refptr<MediaLog> media_log(new MediaLog()); | |
44 MojoMediaClient* mojo_media_client = MojoMediaClient::Get(); | 46 MojoMediaClient* mojo_media_client = MojoMediaClient::Get(); |
45 audio_renderer_sink_ = mojo_media_client->GetAudioRendererSink(); | 47 audio_renderer_sink_ = mojo_media_client->GetAudioRendererSink(); |
46 video_renderer_sink_ = mojo_media_client->GetVideoRendererSink(task_runner); | 48 video_renderer_sink_ = mojo_media_client->GetVideoRendererSink(task_runner); |
47 | 49 |
48 scoped_ptr<AudioRenderer> audio_renderer(new AudioRendererImpl( | |
49 task_runner, audio_renderer_sink_.get(), | |
50 mojo_media_client->GetAudioDecoders(task_runner, | |
51 base::Bind(&MediaLog::AddLogEvent, | |
52 media_log)).Pass(), | |
53 mojo_media_client->GetAudioHardwareConfig(), media_log)); | |
54 | |
55 scoped_ptr<VideoRenderer> video_renderer(new VideoRendererImpl( | |
56 task_runner, video_renderer_sink_.get(), | |
57 mojo_media_client->GetVideoDecoders(task_runner, | |
58 base::Bind(&MediaLog::AddLogEvent, | |
59 media_log)).Pass(), | |
60 true, nullptr, media_log)); | |
61 | |
62 // Create renderer. | 50 // Create renderer. |
63 renderer_.reset(new RendererImpl( | 51 if (renderer_factory) { |
64 task_runner, audio_renderer.Pass(), video_renderer.Pass())); | 52 renderer_ = renderer_factory->CreateRenderer( |
| 53 task_runner, audio_renderer_sink_.get(), video_renderer_sink_.get()); |
| 54 } else { |
| 55 scoped_ptr<AudioRenderer> audio_renderer(new AudioRendererImpl( |
| 56 task_runner, audio_renderer_sink_.get(), |
| 57 mojo_media_client->GetAudioDecoders(task_runner, media_log).Pass(), |
| 58 mojo_media_client->GetAudioHardwareConfig(), media_log)); |
| 59 scoped_ptr<VideoRenderer> video_renderer(new VideoRendererImpl( |
| 60 task_runner, video_renderer_sink_.get(), |
| 61 mojo_media_client->GetVideoDecoders(task_runner, media_log).Pass(), |
| 62 true, nullptr, media_log)); |
| 63 renderer_.reset(new RendererImpl(task_runner, audio_renderer.Pass(), |
| 64 video_renderer.Pass())); |
| 65 } |
65 } | 66 } |
66 | 67 |
67 MojoRendererService::~MojoRendererService() { | 68 MojoRendererService::~MojoRendererService() { |
68 } | 69 } |
69 | 70 |
70 void MojoRendererService::Initialize(mojo::MediaRendererClientPtr client, | 71 void MojoRendererService::Initialize(mojo::MediaRendererClientPtr client, |
71 mojo::DemuxerStreamPtr audio, | 72 mojo::DemuxerStreamPtr audio, |
72 mojo::DemuxerStreamPtr video, | 73 mojo::DemuxerStreamPtr video, |
73 const mojo::Closure& callback) { | 74 const mojo::Closure& callback) { |
74 DVLOG(1) << __FUNCTION__; | 75 DVLOG(1) << __FUNCTION__; |
(...skipping 137 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
212 } | 213 } |
213 | 214 |
214 void MojoRendererService::OnCdmAttached( | 215 void MojoRendererService::OnCdmAttached( |
215 const mojo::Callback<void(bool)>& callback, | 216 const mojo::Callback<void(bool)>& callback, |
216 bool success) { | 217 bool success) { |
217 DVLOG(1) << __FUNCTION__ << "(" << success << ")"; | 218 DVLOG(1) << __FUNCTION__ << "(" << success << ")"; |
218 callback.Run(success); | 219 callback.Run(success); |
219 } | 220 } |
220 | 221 |
221 } // namespace media | 222 } // namespace media |
OLD | NEW |