OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "content/renderer/media/render_audiosourceprovider.h" | 5 #include "content/renderer/media/render_audiosourceprovider.h" |
6 | 6 |
7 #include <vector> | 7 #include <vector> |
8 | 8 |
9 #include "base/basictypes.h" | 9 #include "base/basictypes.h" |
10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
11 #include "base/logging.h" | 11 #include "base/logging.h" |
12 #include "content/renderer/media/audio_device_factory.h" | 12 #include "content/renderer/media/audio_message_filter.h" |
13 #include "content/renderer/media/audio_renderer_mixer_manager.h" | 13 #include "content/renderer/media/audio_renderer_mixer_manager.h" |
14 #include "content/renderer/render_thread_impl.h" | 14 #include "content/renderer/render_thread_impl.h" |
15 #include "media/audio/audio_output_device.h" | |
15 #include "media/base/audio_renderer_mixer_input.h" | 16 #include "media/base/audio_renderer_mixer_input.h" |
16 #include "media/base/media_switches.h" | 17 #include "media/base/media_switches.h" |
17 #include "third_party/WebKit/Source/WebKit/chromium/public/WebAudioSourceProvide rClient.h" | 18 #include "third_party/WebKit/Source/WebKit/chromium/public/WebAudioSourceProvide rClient.h" |
18 | 19 |
19 using std::vector; | 20 using std::vector; |
20 using WebKit::WebVector; | 21 using WebKit::WebVector; |
21 | 22 |
22 namespace content { | 23 namespace content { |
23 | 24 |
24 RenderAudioSourceProvider::RenderAudioSourceProvider() | 25 RenderAudioSourceProvider::RenderAudioSourceProvider(int source_render_view_id) |
25 : is_initialized_(false), | 26 : is_initialized_(false), |
26 channels_(0), | 27 channels_(0), |
27 sample_rate_(0), | 28 sample_rate_(0), |
28 is_running_(false), | 29 is_running_(false), |
29 renderer_(NULL), | 30 renderer_(NULL), |
30 client_(NULL) { | 31 client_(NULL) { |
31 // We create an AudioRendererSink here, but we don't yet know the audio format | 32 // We create an AudioRendererSink here, but we don't yet know the audio format |
32 // (sample-rate, etc.) at this point. Later, when Initialize() is called, we | 33 // (sample-rate, etc.) at this point. Later, when Initialize() is called, we |
33 // have the audio format information and call AudioRendererSink::Initialize() | 34 // have the audio format information and call AudioRendererSink::Initialize() |
34 // to fully initialize it. | 35 // to fully initialize it. |
35 const CommandLine* cmd_line = CommandLine::ForCurrentProcess(); | 36 const CommandLine* cmd_line = CommandLine::ForCurrentProcess(); |
36 #if defined(OS_WIN) || defined(OS_MAC) | 37 #if defined(OS_WIN) || defined(OS_MAC) |
37 const bool use_mixing = | 38 const bool use_mixing = |
38 !cmd_line->HasSwitch(switches::kDisableRendererSideMixing); | 39 !cmd_line->HasSwitch(switches::kDisableRendererSideMixing); |
39 #else | 40 #else |
40 const bool use_mixing = | 41 const bool use_mixing = |
41 cmd_line->HasSwitch(switches::kEnableRendererSideMixing); | 42 cmd_line->HasSwitch(switches::kEnableRendererSideMixing); |
42 #endif | 43 #endif |
43 | 44 |
44 if (use_mixing) { | 45 if (use_mixing) { |
45 default_sink_ = RenderThreadImpl::current()-> | 46 default_sink_ = RenderThreadImpl::current()-> |
46 GetAudioRendererMixerManager()->CreateInput(); | 47 GetAudioRendererMixerManager()->CreateInput(); |
48 // TODO(miu): Partition mixer instances per RenderView. | |
47 } else { | 49 } else { |
48 default_sink_ = AudioDeviceFactory::NewOutputDevice(); | 50 RenderThreadImpl* const render_thread = RenderThreadImpl::current(); |
tommi (sloooow) - chröme
2012/11/29 13:08:38
the convention is:
const RenderThreadImpl* render_
miu
2012/11/30 02:40:35
Actually, that has totally different meaning:
c
| |
51 scoped_refptr<media::AudioOutputDevice> device = | |
52 new media::AudioOutputDevice(render_thread->audio_message_filter(), | |
53 render_thread->GetIOMessageLoopProxy()); | |
Chris Rogers
2012/11/29 11:14:32
I don't understand why the factory has been remove
tommi (sloooow) - chröme
2012/11/29 13:08:38
Maybe I'm misunderstanding your point, but AudioOu
tommi (sloooow) - chröme
2012/11/29 15:30:38
Chris, Henrik and I just talked about this. I und
miu
2012/11/30 02:40:35
Done.
tommi (sloooow) - chröme
2012/11/30 06:51:31
I can't think of a reason for why at least the sta
| |
54 // The RenderView creating RenderAudioSourceProvider will be the source of | |
55 // the audio (WebMediaPlayer is always associated with a single frame). | |
56 // | |
57 // TODO(miu): Unfortunately, there is one use case where this is not true: | |
58 // JavaScript code can call new Audio() and pass the object around. The | |
59 // RenderAudioSourceProvider is not instantiated until the "src" attribute | |
60 // has been set. | |
61 render_thread->audio_message_filter()->AssociateStreamWithProducer( | |
62 device->stream_id(), source_render_view_id); | |
63 default_sink_ = device; | |
49 } | 64 } |
50 } | 65 } |
51 | 66 |
52 void RenderAudioSourceProvider::setClient( | 67 void RenderAudioSourceProvider::setClient( |
53 WebKit::WebAudioSourceProviderClient* client) { | 68 WebKit::WebAudioSourceProviderClient* client) { |
54 // Synchronize with other uses of client_ and default_sink_. | 69 // Synchronize with other uses of client_ and default_sink_. |
55 base::AutoLock auto_lock(sink_lock_); | 70 base::AutoLock auto_lock(sink_lock_); |
56 | 71 |
57 if (client && client != client_) { | 72 if (client && client != client_) { |
58 // Detach the audio renderer from normal playback. | 73 // Detach the audio renderer from normal playback. |
(...skipping 93 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
152 // Inform WebKit about the audio stream format. | 167 // Inform WebKit about the audio stream format. |
153 client_->setFormat(channels_, sample_rate_); | 168 client_->setFormat(channels_, sample_rate_); |
154 } | 169 } |
155 | 170 |
156 is_initialized_ = true; | 171 is_initialized_ = true; |
157 } | 172 } |
158 | 173 |
159 RenderAudioSourceProvider::~RenderAudioSourceProvider() {} | 174 RenderAudioSourceProvider::~RenderAudioSourceProvider() {} |
160 | 175 |
161 } // namespace content | 176 } // namespace content |
OLD | NEW |