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