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

Side by Side Diff: media/audio/android/audio_manager_android.cc

Issue 15217002: Using native sampling rate and optimal buffer size for audio on Android. (Closed) Base URL: https://src.chromium.org/svn/trunk/src/
Patch Set: Created 7 years, 7 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 "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 "jni/AudioManagerAndroid_jni.h" 8 #include "jni/AudioManagerAndroid_jni.h"
9 #include "media/audio/android/opensles_input.h" 9 #include "media/audio/android/opensles_input.h"
10 #include "media/audio/android/opensles_output.h" 10 #include "media/audio/android/opensles_output.h"
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after
49 49
50 void AudioManagerAndroid::GetAudioInputDeviceNames( 50 void AudioManagerAndroid::GetAudioInputDeviceNames(
51 media::AudioDeviceNames* device_names) { 51 media::AudioDeviceNames* device_names) {
52 DCHECK(device_names->empty()); 52 DCHECK(device_names->empty());
53 device_names->push_front( 53 device_names->push_front(
54 media::AudioDeviceName(kDefaultDeviceName, kDefaultDeviceId)); 54 media::AudioDeviceName(kDefaultDeviceName, kDefaultDeviceId));
55 } 55 }
56 56
57 AudioParameters AudioManagerAndroid::GetInputStreamParameters( 57 AudioParameters AudioManagerAndroid::GetInputStreamParameters(
58 const std::string& device_id) { 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; 59 static const int kDefaultBufferSize = 1024;
60 int size = GetMinInputBufferSize(GetNativeOutputSampleRate(), 2);
64 return AudioParameters( 61 return AudioParameters(
65 AudioParameters::AUDIO_PCM_LOW_LATENCY, CHANNEL_LAYOUT_STEREO, 62 AudioParameters::AUDIO_PCM_LOW_LATENCY, CHANNEL_LAYOUT_STEREO,
66 kDefaultSampleRate, 16, kDefaultBufferSize); 63 GetNativeOutputSampleRate(), 16, size <= 0 ? kDefaultBufferSize : size);
67 } 64 }
68 65
69 AudioOutputStream* AudioManagerAndroid::MakeAudioOutputStream( 66 AudioOutputStream* AudioManagerAndroid::MakeAudioOutputStream(
70 const AudioParameters& params) { 67 const AudioParameters& params) {
71 AudioOutputStream* stream = 68 AudioOutputStream* stream =
72 AudioManagerBase::MakeAudioOutputStream(params); 69 AudioManagerBase::MakeAudioOutputStream(params);
73 if (stream && output_stream_count() == 1) 70 if (stream && output_stream_count() == 1)
74 RegisterHeadsetReceiver(); 71 RegisterHeadsetReceiver();
75 return stream; 72 return stream;
76 } 73 }
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
113 DCHECK_EQ(AudioParameters::AUDIO_PCM_LINEAR, params.format()); 110 DCHECK_EQ(AudioParameters::AUDIO_PCM_LINEAR, params.format());
114 return new OpenSLESInputStream(this, params); 111 return new OpenSLESInputStream(this, params);
115 } 112 }
116 113
117 AudioInputStream* AudioManagerAndroid::MakeLowLatencyInputStream( 114 AudioInputStream* AudioManagerAndroid::MakeLowLatencyInputStream(
118 const AudioParameters& params, const std::string& device_id) { 115 const AudioParameters& params, const std::string& device_id) {
119 DCHECK_EQ(AudioParameters::AUDIO_PCM_LOW_LATENCY, params.format()); 116 DCHECK_EQ(AudioParameters::AUDIO_PCM_LOW_LATENCY, params.format());
120 return new OpenSLESInputStream(this, params); 117 return new OpenSLESInputStream(this, params);
121 } 118 }
122 119
120 int AudioManagerAndroid::GetAudioOptimalOutputFrameSize(int sample_rate,
121 int channels) {
122 if (IsAudioLowLatencySupported()) {
123 const int kTargetFrameSize = 2048;
124 int frame_size = GetAudioLowLatencyFrameSize();
125 // Return the optimal size as a multiple of the low latency frame
126 // size that is close to the target frame size.
127 return ((kTargetFrameSize + frame_size / 2) / frame_size) * frame_size;
128 } else
129 return GetMinOutputBufferSize(sample_rate, channels);
Raymond Toy (Google) 2013/05/16 04:32:28 I wonder if we should return the max of GetMinOutp
leozwang2 2013/05/16 20:56:18 All devices I have tested have "LowLatency", this
130 }
131
123 AudioParameters AudioManagerAndroid::GetPreferredOutputStreamParameters( 132 AudioParameters AudioManagerAndroid::GetPreferredOutputStreamParameters(
124 const AudioParameters& input_params) { 133 const AudioParameters& input_params) {
125 // TODO(xians): figure out the right output sample rate and buffer size to
126 // achieve the best audio performance for Android devices.
127 static const int kDefaultSampleRate = 44100;
128 static const int kDefaultBufferSize = 2048; 134 static const int kDefaultBufferSize = 2048;
129
130 ChannelLayout channel_layout = CHANNEL_LAYOUT_STEREO; 135 ChannelLayout channel_layout = CHANNEL_LAYOUT_STEREO;
131 int sample_rate = kDefaultSampleRate; 136 int sample_rate = GetNativeOutputSampleRate();
132 int buffer_size = kDefaultBufferSize; 137 int buffer_size = GetAudioOptimalOutputFrameSize(sample_rate, 2);
133 int bits_per_sample = 16; 138 int bits_per_sample = 16;
134 int input_channels = 0; 139 int input_channels = 0;
135 if (input_params.IsValid()) { 140 if (input_params.IsValid()) {
136 // Use the client's input parameters if they are valid. 141 // Use the client's input parameters if they are valid.
137 sample_rate = input_params.sample_rate(); 142 sample_rate = input_params.sample_rate();
138 bits_per_sample = input_params.bits_per_sample(); 143 bits_per_sample = input_params.bits_per_sample();
139 channel_layout = input_params.channel_layout(); 144 channel_layout = input_params.channel_layout();
140 input_channels = input_params.input_channels(); 145 input_channels = input_params.input_channels();
141 146 buffer_size = buffer_size <= 0 ? kDefaultBufferSize : buffer_size;
142 // TODO(leozwang): Android defines the minimal buffer size requirment
143 // we should follow it. From Android 4.1, a new audio low latency api
144 // set was introduced and is under development, we want to take advantage
145 // of it.
146 buffer_size = std::min(buffer_size, input_params.frames_per_buffer());
147 } 147 }
148 148
149 int user_buffer_size = GetUserBufferSize(); 149 int user_buffer_size = GetUserBufferSize();
150 if (user_buffer_size) 150 if (user_buffer_size)
151 buffer_size = user_buffer_size; 151 buffer_size = user_buffer_size;
152 152
153 return AudioParameters( 153 return AudioParameters(
154 AudioParameters::AUDIO_PCM_LOW_LATENCY, channel_layout, input_channels, 154 AudioParameters::AUDIO_PCM_LOW_LATENCY, channel_layout, input_channels,
155 sample_rate, bits_per_sample, buffer_size); 155 sample_rate, bits_per_sample, buffer_size);
156 } 156 }
(...skipping 14 matching lines...) Expand all
171 base::android::AttachCurrentThread(), 171 base::android::AttachCurrentThread(),
172 j_audio_manager_.obj()); 172 j_audio_manager_.obj());
173 } 173 }
174 174
175 void AudioManagerAndroid::UnregisterHeadsetReceiver() { 175 void AudioManagerAndroid::UnregisterHeadsetReceiver() {
176 Java_AudioManagerAndroid_unregisterHeadsetReceiver( 176 Java_AudioManagerAndroid_unregisterHeadsetReceiver(
177 base::android::AttachCurrentThread(), 177 base::android::AttachCurrentThread(),
178 j_audio_manager_.obj()); 178 j_audio_manager_.obj());
179 } 179 }
180 180
181 int AudioManagerAndroid::GetNativeOutputSampleRate() {
182 return Java_AudioManagerAndroid_getNativeOutputSampleRate(
183 base::android::AttachCurrentThread(),
184 j_audio_manager_.obj());
185 }
186
187 int AudioManagerAndroid::GetMinInputBufferSize(int rate, int channels) {
188 return Java_AudioManagerAndroid_getMinInputBufSize(
189 base::android::AttachCurrentThread(),
190 rate, channels);
191 }
192
193 int AudioManagerAndroid::GetMinOutputBufferSize(int rate, int channels) {
194 int min_buffer_size_bytes = Java_AudioManagerAndroid_getMinOutputBufSize(
195 base::android::AttachCurrentThread(), rate, channels);
196 // Get buffer size in frames, assuming 16-bit pcm samples.
197 return min_buffer_size_bytes / channels / 2;
198 }
199
200 bool AudioManagerAndroid::IsAudioLowLatencySupported() {
201 return Java_AudioManagerAndroid_isAudioLowLatencySupported(
202 base::android::AttachCurrentThread(),
203 j_audio_manager_.obj());
204 }
205
206 int AudioManagerAndroid::GetAudioLowLatencyFrameSize() {
207 return Java_AudioManagerAndroid_getAudioLowLatencyFrameSize(
208 base::android::AttachCurrentThread(),
209 j_audio_manager_.obj());
210 }
211
181 } // namespace media 212 } // namespace media
OLDNEW
« no previous file with comments | « media/audio/android/audio_manager_android.h ('k') | media/base/android/java/src/org/chromium/media/AudioManagerAndroid.java » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698