| 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/renderers/default_renderer_factory.h" | 5 #include "media/renderers/default_renderer_factory.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/single_thread_task_runner.h" | 8 #include "base/single_thread_task_runner.h" |
| 9 #if !defined(MEDIA_DISABLE_FFMPEG) | 9 #if !defined(MEDIA_DISABLE_FFMPEG) |
| 10 #include "media/base/media_log.h" | 10 #include "media/base/media_log.h" |
| 11 #include "media/filters/ffmpeg_audio_decoder.h" | 11 #include "media/filters/ffmpeg_audio_decoder.h" |
| 12 #include "media/filters/ffmpeg_video_decoder.h" | 12 #include "media/filters/ffmpeg_video_decoder.h" |
| 13 #endif | 13 #endif |
| 14 #include "media/filters/gpu_video_decoder.h" | 14 #include "media/filters/gpu_video_decoder.h" |
| 15 #include "media/filters/opus_audio_decoder.h" | 15 #include "media/filters/opus_audio_decoder.h" |
| 16 #include "media/renderers/audio_renderer_impl.h" | 16 #include "media/renderers/audio_renderer_impl.h" |
| 17 #include "media/renderers/gpu_video_accelerator_factories.h" | 17 #include "media/renderers/gpu_video_accelerator_factories.h" |
| 18 #include "media/renderers/renderer_impl.h" | 18 #include "media/renderers/renderer_impl.h" |
| 19 #include "media/renderers/video_renderer_impl.h" | 19 #include "media/renderers/video_renderer_impl.h" |
| 20 #if !defined(MEDIA_DISABLE_LIBVPX) | 20 #if !defined(MEDIA_DISABLE_LIBVPX) |
| 21 #include "media/filters/vpx_video_decoder.h" | 21 #include "media/filters/vpx_video_decoder.h" |
| 22 #endif | 22 #endif |
| 23 | 23 |
| 24 namespace media { | 24 namespace media { |
| 25 | 25 |
| 26 #if !defined(MEDIA_DISABLE_FFMPEG) | |
| 27 | |
| 28 static void AddLogEntry(const scoped_refptr<MediaLog>& media_log, | |
| 29 MediaLog::MediaLogLevel level, | |
| 30 const std::string& message) { | |
| 31 media_log->AddEvent(media_log->CreateLogEvent(level, message)); | |
| 32 } | |
| 33 #endif | |
| 34 | |
| 35 DefaultRendererFactory::DefaultRendererFactory( | 26 DefaultRendererFactory::DefaultRendererFactory( |
| 36 const scoped_refptr<MediaLog>& media_log, | 27 const scoped_refptr<MediaLog>& media_log, |
| 37 const scoped_refptr<GpuVideoAcceleratorFactories>& gpu_factories, | 28 const scoped_refptr<GpuVideoAcceleratorFactories>& gpu_factories, |
| 38 const AudioHardwareConfig& audio_hardware_config) | 29 const AudioHardwareConfig& audio_hardware_config) |
| 39 : media_log_(media_log), | 30 : media_log_(media_log), |
| 40 gpu_factories_(gpu_factories), | 31 gpu_factories_(gpu_factories), |
| 41 audio_hardware_config_(audio_hardware_config) { | 32 audio_hardware_config_(audio_hardware_config) { |
| 42 } | 33 } |
| 43 | 34 |
| 44 DefaultRendererFactory::~DefaultRendererFactory() { | 35 DefaultRendererFactory::~DefaultRendererFactory() { |
| 45 } | 36 } |
| 46 | 37 |
| 47 // TODO(xhwang): Use RendererConfig to customize what decoders we use. | 38 // TODO(xhwang): Use RendererConfig to customize what decoders we use. |
| 48 scoped_ptr<Renderer> DefaultRendererFactory::CreateRenderer( | 39 scoped_ptr<Renderer> DefaultRendererFactory::CreateRenderer( |
| 49 const scoped_refptr<base::SingleThreadTaskRunner>& media_task_runner, | 40 const scoped_refptr<base::SingleThreadTaskRunner>& media_task_runner, |
| 50 AudioRendererSink* audio_renderer_sink) { | 41 AudioRendererSink* audio_renderer_sink) { |
| 51 DCHECK(audio_renderer_sink); | 42 DCHECK(audio_renderer_sink); |
| 52 | 43 |
| 53 // Create our audio decoders and renderer. | 44 // Create our audio decoders and renderer. |
| 54 ScopedVector<AudioDecoder> audio_decoders; | 45 ScopedVector<AudioDecoder> audio_decoders; |
| 55 | 46 |
| 56 #if !defined(MEDIA_DISABLE_FFMPEG) | 47 #if !defined(MEDIA_DISABLE_FFMPEG) |
| 57 audio_decoders.push_back(new FFmpegAudioDecoder( | 48 audio_decoders.push_back(new FFmpegAudioDecoder( |
| 58 media_task_runner, base::Bind(&AddLogEntry, media_log_))); | 49 media_task_runner, base::Bind(&MediaLog::AddLogEvent, media_log_))); |
| 59 #endif | 50 #endif |
| 60 | 51 |
| 61 audio_decoders.push_back(new OpusAudioDecoder(media_task_runner)); | 52 audio_decoders.push_back(new OpusAudioDecoder(media_task_runner)); |
| 62 | 53 |
| 63 scoped_ptr<AudioRenderer> audio_renderer(new AudioRendererImpl( | 54 scoped_ptr<AudioRenderer> audio_renderer(new AudioRendererImpl( |
| 64 media_task_runner, audio_renderer_sink, audio_decoders.Pass(), | 55 media_task_runner, audio_renderer_sink, audio_decoders.Pass(), |
| 65 audio_hardware_config_, media_log_)); | 56 audio_hardware_config_, media_log_)); |
| 66 | 57 |
| 67 // Create our video decoders and renderer. | 58 // Create our video decoders and renderer. |
| 68 ScopedVector<VideoDecoder> video_decoders; | 59 ScopedVector<VideoDecoder> video_decoders; |
| (...skipping 17 matching lines...) Expand all Loading... |
| 86 | 77 |
| 87 scoped_ptr<VideoRenderer> video_renderer(new VideoRendererImpl( | 78 scoped_ptr<VideoRenderer> video_renderer(new VideoRendererImpl( |
| 88 media_task_runner, video_decoders.Pass(), true, media_log_)); | 79 media_task_runner, video_decoders.Pass(), true, media_log_)); |
| 89 | 80 |
| 90 // Create renderer. | 81 // Create renderer. |
| 91 return scoped_ptr<Renderer>(new RendererImpl( | 82 return scoped_ptr<Renderer>(new RendererImpl( |
| 92 media_task_runner, audio_renderer.Pass(), video_renderer.Pass())); | 83 media_task_runner, audio_renderer.Pass(), video_renderer.Pass())); |
| 93 } | 84 } |
| 94 | 85 |
| 95 } // namespace media | 86 } // namespace media |
| OLD | NEW |