Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(52)

Side by Side Diff: content/renderer/media/audio_device_factory.cc

Issue 1323403005: Allow AudioOutputDevice objects to be initialized with a specific hardware output device and store … (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Palmer's comments Created 5 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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/audio_device_factory.h" 5 #include "content/renderer/media/audio_device_factory.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "content/renderer/media/audio_input_message_filter.h" 8 #include "content/renderer/media/audio_input_message_filter.h"
9 #include "content/renderer/media/audio_message_filter.h" 9 #include "content/renderer/media/audio_message_filter.h"
10 #include "media/audio/audio_input_device.h" 10 #include "media/audio/audio_input_device.h"
11 #include "media/audio/audio_output_device.h" 11 #include "media/audio/audio_output_device.h"
12 #include "url/origin.h"
12 13
13 namespace content { 14 namespace content {
14 15
15 // static 16 // static
16 AudioDeviceFactory* AudioDeviceFactory::factory_ = NULL; 17 AudioDeviceFactory* AudioDeviceFactory::factory_ = NULL;
17 18
18 // static 19 // static
19 scoped_refptr<media::AudioOutputDevice> AudioDeviceFactory::NewOutputDevice( 20 scoped_refptr<media::AudioOutputDevice> AudioDeviceFactory::NewOutputDevice(
20 int render_frame_id) { 21 int render_frame_id,
22 int session_id,
23 const std::string& device_id,
24 const url::Origin& security_origin) {
21 if (factory_) { 25 if (factory_) {
22 media::AudioOutputDevice* const device = 26 media::AudioOutputDevice* const device = factory_->CreateOutputDevice(
23 factory_->CreateOutputDevice(render_frame_id); 27 render_frame_id, session_id, device_id, security_origin);
24 if (device) 28 if (device)
25 return device; 29 return device;
26 } 30 }
27 31
28 AudioMessageFilter* const filter = AudioMessageFilter::Get(); 32 AudioMessageFilter* const filter = AudioMessageFilter::Get();
29 return new media::AudioOutputDevice( 33 scoped_refptr<media::AudioOutputDevice> device = new media::AudioOutputDevice(
30 filter->CreateAudioOutputIPC(render_frame_id), filter->io_task_runner()); 34 filter->CreateAudioOutputIPC(render_frame_id), filter->io_task_runner(),
35 session_id, device_id, security_origin);
36 device->RequestDeviceAuthorization();
37 return device;
31 } 38 }
32 39
33 // static 40 // static
34 scoped_refptr<media::AudioInputDevice> AudioDeviceFactory::NewInputDevice( 41 scoped_refptr<media::AudioInputDevice> AudioDeviceFactory::NewInputDevice(
35 int render_frame_id) { 42 int render_frame_id) {
36 if (factory_) { 43 if (factory_) {
37 media::AudioInputDevice* const device = 44 media::AudioInputDevice* const device =
38 factory_->CreateInputDevice(render_frame_id); 45 factory_->CreateInputDevice(render_frame_id);
39 if (device) 46 if (device)
40 return device; 47 return device;
41 } 48 }
42 49
43 AudioInputMessageFilter* const filter = AudioInputMessageFilter::Get(); 50 AudioInputMessageFilter* const filter = AudioInputMessageFilter::Get();
44 return new media::AudioInputDevice( 51 return new media::AudioInputDevice(
45 filter->CreateAudioInputIPC(render_frame_id), filter->io_task_runner()); 52 filter->CreateAudioInputIPC(render_frame_id), filter->io_task_runner());
46 } 53 }
47 54
48 AudioDeviceFactory::AudioDeviceFactory() { 55 AudioDeviceFactory::AudioDeviceFactory() {
49 DCHECK(!factory_) << "Can't register two factories at once."; 56 DCHECK(!factory_) << "Can't register two factories at once.";
50 factory_ = this; 57 factory_ = this;
51 } 58 }
52 59
53 AudioDeviceFactory::~AudioDeviceFactory() { 60 AudioDeviceFactory::~AudioDeviceFactory() {
54 factory_ = NULL; 61 factory_ = NULL;
55 } 62 }
56 63
57 } // namespace content 64 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698