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

Side by Side Diff: media/audio/audio_input_device.cc

Issue 10823175: Switch AudioRenderSink::Callback to use AudioBus. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Gotta catch'em all! Created 8 years, 4 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 | Annotate | Revision Log
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/audio_input_device.h" 5 #include "media/audio/audio_input_device.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/message_loop.h" 8 #include "base/message_loop.h"
9 #include "base/threading/thread_restrictions.h" 9 #include "base/threading/thread_restrictions.h"
10 #include "base/time.h" 10 #include "base/time.h"
11 #include "media/audio/audio_manager_base.h" 11 #include "media/audio/audio_manager_base.h"
12 #include "media/audio/audio_util.h" 12 #include "media/audio/audio_util.h"
13 #include "media/base/audio_bus.h"
13 14
14 namespace media { 15 namespace media {
15 16
16 AudioInputDevice::CaptureCallback::~CaptureCallback() {} 17 AudioInputDevice::CaptureCallback::~CaptureCallback() {}
17 AudioInputDevice::CaptureEventHandler::~CaptureEventHandler() {} 18 AudioInputDevice::CaptureEventHandler::~CaptureEventHandler() {}
18 19
19 // Takes care of invoking the capture callback on the audio thread. 20 // Takes care of invoking the capture callback on the audio thread.
20 // An instance of this class is created for each capture stream in 21 // An instance of this class is created for each capture stream in
21 // OnLowLatencyCreated(). 22 // OnLowLatencyCreated().
22 class AudioInputDevice::AudioThreadCallback 23 class AudioInputDevice::AudioThreadCallback
(...skipping 298 matching lines...) Expand 10 before | Expand all | Expand 10 after
321 // actual data buffer containing audio data. Map the memory into this 322 // actual data buffer containing audio data. Map the memory into this
322 // structure and parse out parameters and the data area. 323 // structure and parse out parameters and the data area.
323 AudioInputBuffer* buffer = 324 AudioInputBuffer* buffer =
324 reinterpret_cast<AudioInputBuffer*>(shared_memory_.memory()); 325 reinterpret_cast<AudioInputBuffer*>(shared_memory_.memory());
325 DCHECK_EQ(buffer->params.size, 326 DCHECK_EQ(buffer->params.size,
326 memory_length_ - sizeof(AudioInputBufferParameters)); 327 memory_length_ - sizeof(AudioInputBufferParameters));
327 double volume = buffer->params.volume; 328 double volume = buffer->params.volume;
328 329
329 int audio_delay_milliseconds = pending_data / bytes_per_ms_; 330 int audio_delay_milliseconds = pending_data / bytes_per_ms_;
330 int16* memory = reinterpret_cast<int16*>(&buffer->audio[0]); 331 int16* memory = reinterpret_cast<int16*>(&buffer->audio[0]);
331 const size_t number_of_frames = audio_parameters_.frames_per_buffer();
332 const int bytes_per_sample = sizeof(memory[0]); 332 const int bytes_per_sample = sizeof(memory[0]);
333 333
334 // Deinterleave each channel and convert to 32-bit floating-point 334 // Deinterleave each channel and convert to 32-bit floating-point
335 // with nominal range -1.0 -> +1.0. 335 // with nominal range -1.0 -> +1.0.
336 for (int channel_index = 0; channel_index < audio_parameters_.channels(); 336 for (int channel_index = 0; channel_index < audio_bus_->channels();
337 ++channel_index) { 337 ++channel_index) {
338 DeinterleaveAudioChannel(memory, 338 DeinterleaveAudioChannel(memory,
339 audio_data_[channel_index], 339 audio_bus_->channel(channel_index),
340 audio_parameters_.channels(), 340 audio_bus_->channels(),
341 channel_index, 341 channel_index,
342 bytes_per_sample, 342 bytes_per_sample,
343 number_of_frames); 343 audio_bus_->frames());
344 } 344 }
345 345
346 // Deliver captured data to the client in floating point format 346 // Deliver captured data to the client in floating point format
347 // and update the audio-delay measurement. 347 // and update the audio-delay measurement.
348 capture_callback_->Capture(audio_data_, number_of_frames, 348 capture_callback_->Capture(audio_bus_.get(), audio_bus_->frames(),
349 audio_delay_milliseconds, volume); 349 audio_delay_milliseconds, volume);
350 } 350 }
351 351
352 } // namespace media 352 } // namespace media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698