| 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/win/wavein_input_win.h" | 5 #include "media/audio/win/wavein_input_win.h" |
| 6 | 6 |
| 7 #pragma comment(lib, "winmm.lib") | 7 #pragma comment(lib, "winmm.lib") |
| 8 | 8 |
| 9 #include "base/logging.h" | 9 #include "base/logging.h" |
| 10 #include "media/audio/audio_io.h" | 10 #include "media/audio/audio_io.h" |
| 11 #include "media/audio/win/audio_manager_win.h" | 11 #include "media/audio/win/audio_manager_win.h" |
| 12 #include "media/audio/win/device_enumeration_win.h" | 12 #include "media/audio/win/device_enumeration_win.h" |
| 13 #include "media/base/audio_bus.h" | |
| 14 | 13 |
| 15 namespace media { | 14 namespace media { |
| 16 | 15 |
| 17 // Our sound buffers are allocated once and kept in a linked list using the | 16 // Our sound buffers are allocated once and kept in a linked list using the |
| 18 // the WAVEHDR::dwUser variable. The last buffer points to the first buffer. | 17 // the WAVEHDR::dwUser variable. The last buffer points to the first buffer. |
| 19 static WAVEHDR* GetNextBuffer(WAVEHDR* current) { | 18 static WAVEHDR* GetNextBuffer(WAVEHDR* current) { |
| 20 return reinterpret_cast<WAVEHDR*>(current->dwUser); | 19 return reinterpret_cast<WAVEHDR*>(current->dwUser); |
| 21 } | 20 } |
| 22 | 21 |
| 23 PCMWaveInAudioInputStream::PCMWaveInAudioInputStream( | 22 PCMWaveInAudioInputStream::PCMWaveInAudioInputStream( |
| 24 AudioManagerWin* manager, | 23 AudioManagerWin* manager, const AudioParameters& params, int num_buffers, |
| 25 const AudioParameters& params, | |
| 26 int num_buffers, | |
| 27 const std::string& device_id) | 24 const std::string& device_id) |
| 28 : state_(kStateEmpty), | 25 : state_(kStateEmpty), |
| 29 manager_(manager), | 26 manager_(manager), |
| 30 device_id_(device_id), | 27 device_id_(device_id), |
| 31 wavein_(NULL), | 28 wavein_(NULL), |
| 32 callback_(NULL), | 29 callback_(NULL), |
| 33 num_buffers_(num_buffers), | 30 num_buffers_(num_buffers), |
| 34 buffer_(NULL), | 31 buffer_(NULL), |
| 35 channels_(params.channels()), | 32 channels_(params.channels()) { |
| 36 audio_bus_(media::AudioBus::Create(params)) { | |
| 37 DCHECK_GT(num_buffers_, 0); | 33 DCHECK_GT(num_buffers_, 0); |
| 38 format_.wFormatTag = WAVE_FORMAT_PCM; | 34 format_.wFormatTag = WAVE_FORMAT_PCM; |
| 39 format_.nChannels = params.channels() > 2 ? 2 : params.channels(); | 35 format_.nChannels = params.channels() > 2 ? 2 : params.channels(); |
| 40 format_.nSamplesPerSec = params.sample_rate(); | 36 format_.nSamplesPerSec = params.sample_rate(); |
| 41 format_.wBitsPerSample = params.bits_per_sample(); | 37 format_.wBitsPerSample = params.bits_per_sample(); |
| 42 format_.cbSize = 0; | 38 format_.cbSize = 0; |
| 43 format_.nBlockAlign = (format_.nChannels * format_.wBitsPerSample) / 8; | 39 format_.nBlockAlign = (format_.nChannels * format_.wBitsPerSample) / 8; |
| 44 format_.nAvgBytesPerSec = format_.nBlockAlign * format_.nSamplesPerSec; | 40 format_.nAvgBytesPerSec = format_.nBlockAlign * format_.nSamplesPerSec; |
| 45 buffer_size_ = params.frames_per_buffer() * format_.nBlockAlign; | 41 buffer_size_ = params.frames_per_buffer() * format_.nBlockAlign; |
| 46 // If we don't have a packet size we use 100ms. | 42 // If we don't have a packet size we use 100ms. |
| (...skipping 240 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 287 if (msg == WIM_DATA) { | 283 if (msg == WIM_DATA) { |
| 288 // The WIM_DATA message is sent when waveform-audio data is present in | 284 // The WIM_DATA message is sent when waveform-audio data is present in |
| 289 // the input buffer and the buffer is being returned to the application. | 285 // the input buffer and the buffer is being returned to the application. |
| 290 // The message can be sent when the buffer is full or after the | 286 // The message can be sent when the buffer is full or after the |
| 291 // waveInReset function is called. | 287 // waveInReset function is called. |
| 292 if (obj->callback_) { | 288 if (obj->callback_) { |
| 293 // TODO(henrika): the |volume| parameter is always set to zero since | 289 // TODO(henrika): the |volume| parameter is always set to zero since |
| 294 // there is currently no support for controlling the microphone volume | 290 // there is currently no support for controlling the microphone volume |
| 295 // level. | 291 // level. |
| 296 WAVEHDR* buffer = reinterpret_cast<WAVEHDR*>(param1); | 292 WAVEHDR* buffer = reinterpret_cast<WAVEHDR*>(param1); |
| 297 obj->audio_bus_->FromInterleaved(reinterpret_cast<uint8*>(buffer->lpData), | 293 obj->callback_->OnData(obj, |
| 298 obj->audio_bus_->frames(), | 294 reinterpret_cast<const uint8*>(buffer->lpData), |
| 299 obj->format_.wBitsPerSample / 8); | 295 buffer->dwBytesRecorded, |
| 300 obj->callback_->OnData( | 296 buffer->dwBytesRecorded, |
| 301 obj, obj->audio_bus_.get(), buffer->dwBytesRecorded, 0.0); | 297 0.0); |
| 302 | 298 |
| 303 // Queue the finished buffer back with the audio driver. Since we are | 299 // Queue the finished buffer back with the audio driver. Since we are |
| 304 // reusing the same buffers we can get away without calling | 300 // reusing the same buffers we can get away without calling |
| 305 // waveInPrepareHeader. | 301 // waveInPrepareHeader. |
| 306 obj->QueueNextPacket(buffer); | 302 obj->QueueNextPacket(buffer); |
| 307 } else { | 303 } else { |
| 308 // Main thread has called Stop() and set |callback_| to NULL and is | 304 // Main thread has called Stop() and set |callback_| to NULL and is |
| 309 // now waiting to issue waveInReset which will kill this thread. | 305 // now waiting to issue waveInReset which will kill this thread. |
| 310 // We should not call AudioSourceCallback code anymore. | 306 // We should not call AudioSourceCallback code anymore. |
| 311 ::SetEvent(obj->stopped_event_); | 307 ::SetEvent(obj->stopped_event_); |
| 312 } | 308 } |
| 313 } else if (msg == WIM_CLOSE) { | 309 } else if (msg == WIM_CLOSE) { |
| 314 // Intentionaly no-op for now. | 310 // Intentionaly no-op for now. |
| 315 } else if (msg == WIM_OPEN) { | 311 } else if (msg == WIM_OPEN) { |
| 316 // Intentionaly no-op for now. | 312 // Intentionaly no-op for now. |
| 317 } | 313 } |
| 318 } | 314 } |
| 319 | 315 |
| 320 } // namespace media | 316 } // namespace media |
| OLD | NEW |