| 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 |