mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-12 21:30:45 +01:00

Start introducing ArrayView to AudioFrame and code that flows down from there. In this first step: * Add `data_view()` that returns a read-only ArrayView for the audio buffer. When AudioFrame is not initialized however, data_view() will return a nullptr whereas the current data() method never returns nullptr. * Add `mutable_data()` that requires two arguments for properly setting the samples per channel and number of channels that's required for accurately reserving the returned mutable ArrayView. A notable behavior change is that if the requested number of channels is larger than supported or the calculated buffer size is too large, the function will trigger a check. * Add TODOs for following work. Bug: chromium:335805780 Change-Id: I2937de800422589ebe6a3840b3caadf3d9ff8b00 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/347982 Reviewed-by: Per Åhgren <peah@webrtc.org> Commit-Queue: Tomas Gunnarsson <tommi@webrtc.org> Cr-Commit-Position: refs/heads/main@{#42202}
46 lines
1.7 KiB
C++
46 lines
1.7 KiB
C++
/*
|
|
* Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license
|
|
* that can be found in the LICENSE file in the root of the source
|
|
* tree. An additional intellectual property rights grant can be found
|
|
* in the file PATENTS. All contributing project authors may
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
#ifndef AUDIO_REMIX_RESAMPLE_H_
|
|
#define AUDIO_REMIX_RESAMPLE_H_
|
|
|
|
#include "api/audio/audio_frame.h"
|
|
#include "common_audio/resampler/include/push_resampler.h"
|
|
|
|
namespace webrtc {
|
|
namespace voe {
|
|
|
|
// Note: The RemixAndResample methods assume 10ms buffer sizes.
|
|
|
|
// Upmix or downmix and resample the audio to `dst_frame`. Expects `dst_frame`
|
|
// to have its sample rate and channels members set to the desired values.
|
|
// Updates the `samples_per_channel_` member accordingly.
|
|
//
|
|
// This version has an AudioFrame `src_frame` as input and sets the output
|
|
// `timestamp_`, `elapsed_time_ms_` and `ntp_time_ms_` members equals to the
|
|
// input ones.
|
|
void RemixAndResample(const AudioFrame& src_frame,
|
|
PushResampler<int16_t>* resampler,
|
|
AudioFrame* dst_frame);
|
|
|
|
// This version has a pointer to the samples `src_data` as input and receives
|
|
// `samples_per_channel`, `num_channels` and `sample_rate_hz` of the data as
|
|
// parameters.
|
|
void RemixAndResample(const int16_t* src_data,
|
|
size_t samples_per_channel,
|
|
size_t num_channels,
|
|
int sample_rate_hz,
|
|
PushResampler<int16_t>* resampler,
|
|
AudioFrame* dst_frame);
|
|
|
|
} // namespace voe
|
|
} // namespace webrtc
|
|
|
|
#endif // AUDIO_REMIX_RESAMPLE_H_
|