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

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: rebase 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/gurl.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 return NewOutputDevice(render_frame_id, std::string(), GURL());
23 }
24
25 // static
26 scoped_refptr<media::AudioOutputDevice> AudioDeviceFactory::NewOutputDevice(
27 int render_frame_id,
28 int session_id) {
21 if (factory_) { 29 if (factory_) {
22 media::AudioOutputDevice* const device = 30 media::AudioOutputDevice* const device =
23 factory_->CreateOutputDevice(render_frame_id); 31 factory_->CreateOutputDevice(render_frame_id, session_id);
24 if (device) 32 if (device)
25 return device; 33 return device;
26 } 34 }
27 35
28 AudioMessageFilter* const filter = AudioMessageFilter::Get(); 36 AudioMessageFilter* const filter = AudioMessageFilter::Get();
29 return new media::AudioOutputDevice( 37 scoped_refptr<media::AudioOutputDevice> device = new media::AudioOutputDevice(
30 filter->CreateAudioOutputIPC(render_frame_id), filter->io_task_runner()); 38 filter->CreateAudioOutputIPC(render_frame_id), filter->io_task_runner(),
39 session_id, std::string(), GURL());
40 device->RequestDeviceAuthorization();
41 return device;
31 } 42 }
32 43
33 // static 44 // static
45 scoped_refptr<media::AudioOutputDevice> AudioDeviceFactory::NewOutputDevice(
46 int render_frame_id,
47 const std::string& device_id,
48 const GURL& security_origin) {
49 if (factory_) {
50 media::AudioOutputDevice* const device = factory_->CreateOutputDevice(
51 render_frame_id, device_id, security_origin);
52 if (device)
53 return device;
54 }
55
56 AudioMessageFilter* const filter = AudioMessageFilter::Get();
57 scoped_refptr<media::AudioOutputDevice> device = new media::AudioOutputDevice(
58 filter->CreateAudioOutputIPC(render_frame_id), filter->io_task_runner(),
59 0, device_id, security_origin);
60 device->RequestDeviceAuthorization();
61 return device;
62 }
63
64 // static
34 scoped_refptr<media::AudioInputDevice> AudioDeviceFactory::NewInputDevice( 65 scoped_refptr<media::AudioInputDevice> AudioDeviceFactory::NewInputDevice(
35 int render_frame_id) { 66 int render_frame_id) {
36 if (factory_) { 67 if (factory_) {
37 media::AudioInputDevice* const device = 68 media::AudioInputDevice* const device =
38 factory_->CreateInputDevice(render_frame_id); 69 factory_->CreateInputDevice(render_frame_id);
39 if (device) 70 if (device)
40 return device; 71 return device;
41 } 72 }
42 73
43 AudioInputMessageFilter* const filter = AudioInputMessageFilter::Get(); 74 AudioInputMessageFilter* const filter = AudioInputMessageFilter::Get();
44 return new media::AudioInputDevice( 75 return new media::AudioInputDevice(
45 filter->CreateAudioInputIPC(render_frame_id), filter->io_task_runner()); 76 filter->CreateAudioInputIPC(render_frame_id), filter->io_task_runner());
46 } 77 }
47 78
48 AudioDeviceFactory::AudioDeviceFactory() { 79 AudioDeviceFactory::AudioDeviceFactory() {
49 DCHECK(!factory_) << "Can't register two factories at once."; 80 DCHECK(!factory_) << "Can't register two factories at once.";
50 factory_ = this; 81 factory_ = this;
51 } 82 }
52 83
53 AudioDeviceFactory::~AudioDeviceFactory() { 84 AudioDeviceFactory::~AudioDeviceFactory() {
54 factory_ = NULL; 85 factory_ = NULL;
55 } 86 }
56 87
57 } // namespace content 88 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698