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 "media/audio/android/audio_manager_android.h" | 5 #include "media/audio/android/audio_manager_android.h" |
6 | 6 |
7 #include "base/logging.h" | 7 #include "base/logging.h" |
8 #include "media/audio/android/opensles_input.h" | 8 #include "media/audio/android/opensles_input.h" |
9 #include "media/audio/android/opensles_output.h" | 9 #include "media/audio/android/opensles_output.h" |
10 #include "media/audio/audio_manager.h" | 10 #include "media/audio/audio_manager.h" |
11 #include "media/audio/audio_util.h" | 11 #include "media/audio/audio_parameters.h" |
12 #include "media/audio/fake_audio_input_stream.h" | 12 #include "media/audio/fake_audio_input_stream.h" |
13 #include "media/base/channel_layout.h" | |
13 | 14 |
14 namespace media { | 15 namespace media { |
15 | 16 |
16 // Maximum number of output streams that can be open simultaneously. | 17 // Maximum number of output streams that can be open simultaneously. |
17 static const int kMaxOutputStreams = 10; | 18 static const int kMaxOutputStreams = 10; |
18 | 19 |
19 AudioManager* CreateAudioManager() { | 20 AudioManager* CreateAudioManager() { |
20 return new AudioManagerAndroid(); | 21 return new AudioManagerAndroid(); |
21 } | 22 } |
22 | 23 |
(...skipping 13 matching lines...) Expand all Loading... | |
36 return true; | 37 return true; |
37 } | 38 } |
38 | 39 |
39 void AudioManagerAndroid::GetAudioInputDeviceNames( | 40 void AudioManagerAndroid::GetAudioInputDeviceNames( |
40 media::AudioDeviceNames* device_names) { | 41 media::AudioDeviceNames* device_names) { |
41 DCHECK(device_names->empty()); | 42 DCHECK(device_names->empty()); |
42 device_names->push_front( | 43 device_names->push_front( |
43 media::AudioDeviceName(kDefaultDeviceName, kDefaultDeviceId)); | 44 media::AudioDeviceName(kDefaultDeviceName, kDefaultDeviceId)); |
44 } | 45 } |
45 | 46 |
47 AudioParameters AudioManagerAndroid::GetDefaultOutputStreamParameters() { | |
48 // TODO(xians): figure out the right output sample rate and sample rate to | |
49 // achieve the best audio performance for Android devices. | |
50 static const int kDefaultSampleRate = 16000; | |
51 static const int kDefaultBufferSize = 1024 | |
52 return AudioParameters( | |
53 AudioParameters::AUDIO_PCM_LOW_LATENCY, CHANNEL_LAYOUT_STEREO, | |
54 kDefaultSampleRate, 16, kDefaultBufferSize); | |
55 } | |
56 | |
57 AudioParameters AudioManagerAndroid::GetDefaultInputStreamParameters( | |
58 const std::string& device_id) { | |
59 // TODO(xians): figure out the right input sample rate and buffer size to | |
60 // achieve the best audio performance for Android devices. | |
61 // TODO(xians): query the native channel layout for the specific device. | |
62 static const int kDefaultSampleRate = 16000; | |
63 static const int kDefaultBufferSize = 1024 | |
Raymond Toy (Google)
2013/02/28 00:30:45
Didn't this used to be 2048? Is 1024 the desired
no longer working on chromium
2013/03/01 16:44:33
Yes, it used to be 2048, but I think 2048 to 16K i
| |
64 return AudioParameters( | |
65 AudioParameters::AUDIO_PCM_LOW_LATENCY, CHANNEL_LAYOUT_STEREO, | |
66 kDefaultSampleRate, 16, kDefaultBufferSize); | |
67 } | |
68 | |
46 AudioParameters | 69 AudioParameters |
47 AudioManagerAndroid::GetPreferredLowLatencyOutputStreamParameters( | 70 AudioManagerAndroid::GetPreferredLowLatencyOutputStreamParameters( |
48 const AudioParameters& input_params) { | 71 const AudioParameters& input_params) { |
49 // TODO(leozwang): Android defines the minimal buffer size requirment | 72 // TODO(leozwang): Android defines the minimal buffer size requirement |
50 // we should follow it. From Android 4.1, a new audio low latency api | 73 // we should follow it. From Android 4.1, a new audio low latency api |
51 // set was introduced and is under development, we want to take advantage | 74 // set was introduced and is under development, we want to take advantage |
52 // of it. | 75 // of it. |
53 int buffer_size = GetAudioHardwareBufferSize(); | 76 AudioParameters default_params = GetDefaultOutputStreamParameters(); |
54 if (input_params.frames_per_buffer() < buffer_size) | 77 int buffer_size = std::min(input_params.frames_per_buffer(), |
55 buffer_size = input_params.frames_per_buffer(); | 78 default_params.frames_per_buffer()) |
56 | 79 |
57 return AudioParameters( | 80 return AudioParameters( |
58 AudioParameters::AUDIO_PCM_LOW_LATENCY, input_params.channel_layout(), | 81 AudioParameters::AUDIO_PCM_LOW_LATENCY, input_params.channel_layout(), |
59 input_params.sample_rate(), 16, buffer_size); | 82 input_params.sample_rate(), 16, buffer_size); |
60 } | 83 } |
61 | 84 |
62 AudioOutputStream* AudioManagerAndroid::MakeLinearOutputStream( | 85 AudioOutputStream* AudioManagerAndroid::MakeLinearOutputStream( |
63 const AudioParameters& params) { | 86 const AudioParameters& params) { |
64 DCHECK_EQ(AudioParameters::AUDIO_PCM_LINEAR, params.format()); | 87 DCHECK_EQ(AudioParameters::AUDIO_PCM_LINEAR, params.format()); |
65 return new OpenSLESOutputStream(this, params); | 88 return new OpenSLESOutputStream(this, params); |
(...skipping 11 matching lines...) Expand all Loading... | |
77 return new OpenSLESInputStream(this, params); | 100 return new OpenSLESInputStream(this, params); |
78 } | 101 } |
79 | 102 |
80 AudioInputStream* AudioManagerAndroid::MakeLowLatencyInputStream( | 103 AudioInputStream* AudioManagerAndroid::MakeLowLatencyInputStream( |
81 const AudioParameters& params, const std::string& device_id) { | 104 const AudioParameters& params, const std::string& device_id) { |
82 DCHECK_EQ(AudioParameters::AUDIO_PCM_LOW_LATENCY, params.format()); | 105 DCHECK_EQ(AudioParameters::AUDIO_PCM_LOW_LATENCY, params.format()); |
83 return new OpenSLESInputStream(this, params); | 106 return new OpenSLESInputStream(this, params); |
84 } | 107 } |
85 | 108 |
86 } // namespace media | 109 } // namespace media |
OLD | NEW |