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

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: bytes->frames and address Min's comments 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"
11 #include "media/audio/audio_manager.h" 11 #include "media/audio/audio_manager.h"
12 #include "media/audio/audio_parameters.h" 12 #include "media/audio/audio_parameters.h"
13 #include "media/audio/audio_util.h" 13 #include "media/audio/audio_util.h"
14 #include "media/audio/fake_audio_input_stream.h" 14 #include "media/audio/fake_audio_input_stream.h"
15 #include "media/base/channel_layout.h" 15 #include "media/base/channel_layout.h"
16 16
17 namespace media { 17 namespace media {
18 18
19 // Maximum number of output streams that can be open simultaneously. 19 // Maximum number of output streams that can be open simultaneously.
20 static const int kMaxOutputStreams = 10; 20 static const int kMaxOutputStreams = 10;
21 21
22 static const int kAudioModeNormal = 0x00000000; 22 static const int kAudioModeNormal = 0x00000000;
23 static const int kAudioModeInCommunication = 0x00000003; 23 static const int kAudioModeInCommunication = 0x00000003;
24 24
25 static const int kDefaultInputBufferSize = 1024;
26 static const int kDefaultOutputBufferSize = 2048;
27
25 AudioManager* CreateAudioManager() { 28 AudioManager* CreateAudioManager() {
26 return new AudioManagerAndroid(); 29 return new AudioManagerAndroid();
27 } 30 }
28 31
29 AudioManagerAndroid::AudioManagerAndroid() { 32 AudioManagerAndroid::AudioManagerAndroid() {
30 SetMaxOutputStreamsAllowed(kMaxOutputStreams); 33 SetMaxOutputStreamsAllowed(kMaxOutputStreams);
31 34
32 j_audio_manager_.Reset( 35 j_audio_manager_.Reset(
33 Java_AudioManagerAndroid_createAudioManagerAndroid( 36 Java_AudioManagerAndroid_createAudioManagerAndroid(
34 base::android::AttachCurrentThread(), 37 base::android::AttachCurrentThread(),
(...skipping 14 matching lines...) Expand all
49 52
50 void AudioManagerAndroid::GetAudioInputDeviceNames( 53 void AudioManagerAndroid::GetAudioInputDeviceNames(
51 media::AudioDeviceNames* device_names) { 54 media::AudioDeviceNames* device_names) {
52 DCHECK(device_names->empty()); 55 DCHECK(device_names->empty());
53 device_names->push_front( 56 device_names->push_front(
54 media::AudioDeviceName(kDefaultDeviceName, kDefaultDeviceId)); 57 media::AudioDeviceName(kDefaultDeviceName, kDefaultDeviceId));
55 } 58 }
56 59
57 AudioParameters AudioManagerAndroid::GetInputStreamParameters( 60 AudioParameters AudioManagerAndroid::GetInputStreamParameters(
58 const std::string& device_id) { 61 const std::string& device_id) {
59 // TODO(leozwang): Android defines the minimal buffer size requirment 62 int buffer_size = Java_AudioManagerAndroid_getMinInputFrameSize(
60 // we should use it. 63 base::android::AttachCurrentThread(), GetNativeOutputSampleRate(), 2);
61 static const int kDefaultBufferSize = 1024; 64
62 // TODO(xians): query the native channel layout for the specific device.
63 return AudioParameters( 65 return AudioParameters(
64 AudioParameters::AUDIO_PCM_LOW_LATENCY, CHANNEL_LAYOUT_STEREO, 66 AudioParameters::AUDIO_PCM_LOW_LATENCY, CHANNEL_LAYOUT_STEREO,
65 GetNativeOutputSampleRate(), 16, kDefaultBufferSize); 67 GetNativeOutputSampleRate(), 16,
68 buffer_size <= 0 ? kDefaultInputBufferSize : buffer_size);
66 } 69 }
67 70
68 AudioOutputStream* AudioManagerAndroid::MakeAudioOutputStream( 71 AudioOutputStream* AudioManagerAndroid::MakeAudioOutputStream(
69 const AudioParameters& params) { 72 const AudioParameters& params) {
70 AudioOutputStream* stream = 73 AudioOutputStream* stream =
71 AudioManagerBase::MakeAudioOutputStream(params); 74 AudioManagerBase::MakeAudioOutputStream(params);
72 if (stream && output_stream_count() == 1) 75 if (stream && output_stream_count() == 1)
73 RegisterHeadsetReceiver(); 76 RegisterHeadsetReceiver();
74 return stream; 77 return stream;
75 } 78 }
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
112 DCHECK_EQ(AudioParameters::AUDIO_PCM_LINEAR, params.format()); 115 DCHECK_EQ(AudioParameters::AUDIO_PCM_LINEAR, params.format());
113 return new OpenSLESInputStream(this, params); 116 return new OpenSLESInputStream(this, params);
114 } 117 }
115 118
116 AudioInputStream* AudioManagerAndroid::MakeLowLatencyInputStream( 119 AudioInputStream* AudioManagerAndroid::MakeLowLatencyInputStream(
117 const AudioParameters& params, const std::string& device_id) { 120 const AudioParameters& params, const std::string& device_id) {
118 DCHECK_EQ(AudioParameters::AUDIO_PCM_LOW_LATENCY, params.format()); 121 DCHECK_EQ(AudioParameters::AUDIO_PCM_LOW_LATENCY, params.format());
119 return new OpenSLESInputStream(this, params); 122 return new OpenSLESInputStream(this, params);
120 } 123 }
121 124
125 int AudioManagerAndroid::GetOptimalOutputFrameSize(int sample_rate,
126 int channels) {
127 if (IsAudioLowLatencySupported()) {
128 int frame_size = GetAudioLowLatencyFrameSize();
129 // Return the optimal size as a multiple of the low latency frame
130 // size that is close to the target frame size.
131 return ((kDefaultOutputBufferSize + frame_size / 2) / frame_size) *
132 frame_size;
133 } else {
134 return std::max(kDefaultOutputBufferSize,
135 Java_AudioManagerAndroid_getMinOutputFrameSize(
136 base::android::AttachCurrentThread(),
137 sample_rate, channels));
138 }
139 }
140
122 AudioParameters AudioManagerAndroid::GetPreferredOutputStreamParameters( 141 AudioParameters AudioManagerAndroid::GetPreferredOutputStreamParameters(
123 const AudioParameters& input_params) { 142 const AudioParameters& input_params) {
124 // TODO(leozwang): Android defines the minimal buffer size requirment
125 // we should use it.
126 static const int kDefaultBufferSize = 2048;
127
128 ChannelLayout channel_layout = CHANNEL_LAYOUT_STEREO; 143 ChannelLayout channel_layout = CHANNEL_LAYOUT_STEREO;
129 int sample_rate = GetNativeOutputSampleRate(); 144 int sample_rate = GetNativeOutputSampleRate();
130 int buffer_size = kDefaultBufferSize; 145 int buffer_size = GetOptimalOutputFrameSize(sample_rate, 2);
131 int bits_per_sample = 16; 146 int bits_per_sample = 16;
132 int input_channels = 0; 147 int input_channels = 0;
133 if (input_params.IsValid()) { 148 if (input_params.IsValid()) {
134 // Use the client's input parameters if they are valid. 149 // Use the client's input parameters if they are valid.
135 sample_rate = input_params.sample_rate(); 150 sample_rate = input_params.sample_rate();
136 bits_per_sample = input_params.bits_per_sample(); 151 bits_per_sample = input_params.bits_per_sample();
137 channel_layout = input_params.channel_layout(); 152 channel_layout = input_params.channel_layout();
138 input_channels = input_params.input_channels(); 153 input_channels = input_params.input_channels();
139 154 buffer_size = GetOptimalOutputFrameSize(sample_rate, channel_layout);
140 buffer_size = std::min(buffer_size, input_params.frames_per_buffer());
141 } 155 }
142 156
143 int user_buffer_size = GetUserBufferSize(); 157 int user_buffer_size = GetUserBufferSize();
144 if (user_buffer_size) 158 if (user_buffer_size)
145 buffer_size = user_buffer_size; 159 buffer_size = user_buffer_size;
146 160
147 return AudioParameters( 161 return AudioParameters(
148 AudioParameters::AUDIO_PCM_LOW_LATENCY, channel_layout, input_channels, 162 AudioParameters::AUDIO_PCM_LOW_LATENCY, channel_layout, input_channels,
149 sample_rate, bits_per_sample, buffer_size); 163 sample_rate, bits_per_sample, buffer_size);
150 } 164 }
(...skipping 20 matching lines...) Expand all
171 base::android::AttachCurrentThread(), 185 base::android::AttachCurrentThread(),
172 j_audio_manager_.obj()); 186 j_audio_manager_.obj());
173 } 187 }
174 188
175 int AudioManagerAndroid::GetNativeOutputSampleRate() { 189 int AudioManagerAndroid::GetNativeOutputSampleRate() {
176 return Java_AudioManagerAndroid_getNativeOutputSampleRate( 190 return Java_AudioManagerAndroid_getNativeOutputSampleRate(
177 base::android::AttachCurrentThread(), 191 base::android::AttachCurrentThread(),
178 j_audio_manager_.obj()); 192 j_audio_manager_.obj());
179 } 193 }
180 194
195 bool AudioManagerAndroid::IsAudioLowLatencySupported() {
196 return Java_AudioManagerAndroid_isAudioLowLatencySupported(
197 base::android::AttachCurrentThread(),
198 j_audio_manager_.obj());
199 }
200
201 int AudioManagerAndroid::GetAudioLowLatencyFrameSize() {
no longer working on chromium 2013/05/27 16:04:56 Can this GetAudioLowLatencyFrameSize be used by bo
leozwang1 2013/05/27 16:11:37 this low latency mode is for output only now.
202 return Java_AudioManagerAndroid_getAudioLowLatencyFrameSize(
203 base::android::AttachCurrentThread(),
204 j_audio_manager_.obj());
205 }
206
181 } // namespace media 207 } // namespace media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698