mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-13 05:40:42 +01:00

This is a sibling CL to a similar one for EchoCancellation: https://webrtc-review.googlesource.com/c/src/+/97603 - EchoControlMobileImpl will no longer inherit EchoControlMobile. - Removes usage of AudioProcessing::echo_control_mobile() inside most of the audio processing module and unit tests. The CL breaks audioproc_f backwards compatibility: It can no longer use all recorded settings (comfort noise, routing mode), but prints an error message when unsupported settings are encountered. Tested: audioproc_f with .wav and aecdump inputs. Bug: webrtc:9535 Change-Id: I63c3c81bcaf44021315978e1a0f3e42173b988ce Reviewed-on: https://webrtc-review.googlesource.com/101621 Reviewed-by: Alex Loiko <aleloi@webrtc.org> Commit-Queue: Sam Zackrisson <saza@webrtc.org> Cr-Commit-Position: refs/heads/master@{#24888}
116 lines
4.2 KiB
C++
116 lines
4.2 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 MODULES_AUDIO_PROCESSING_ECHO_CONTROL_MOBILE_IMPL_H_
|
|
#define MODULES_AUDIO_PROCESSING_ECHO_CONTROL_MOBILE_IMPL_H_
|
|
|
|
#include <memory>
|
|
#include <vector>
|
|
|
|
#include "modules/audio_processing/include/audio_processing.h"
|
|
#include "modules/audio_processing/render_queue_item_verifier.h"
|
|
#include "rtc_base/constructormagic.h"
|
|
#include "rtc_base/criticalsection.h"
|
|
#include "rtc_base/swap_queue.h"
|
|
|
|
namespace webrtc {
|
|
|
|
class AudioBuffer;
|
|
|
|
class EchoControlMobileImpl {
|
|
public:
|
|
EchoControlMobileImpl(rtc::CriticalSection* crit_render,
|
|
rtc::CriticalSection* crit_capture);
|
|
|
|
~EchoControlMobileImpl();
|
|
|
|
int Enable(bool enable);
|
|
bool is_enabled() const;
|
|
|
|
// Recommended settings for particular audio routes. In general, the louder
|
|
// the echo is expected to be, the higher this value should be set. The
|
|
// preferred setting may vary from device to device.
|
|
enum RoutingMode {
|
|
kQuietEarpieceOrHeadset,
|
|
kEarpiece,
|
|
kLoudEarpiece,
|
|
kSpeakerphone,
|
|
kLoudSpeakerphone
|
|
};
|
|
|
|
// Sets echo control appropriate for the audio routing |mode| on the device.
|
|
// It can and should be updated during a call if the audio routing changes.
|
|
int set_routing_mode(RoutingMode mode);
|
|
RoutingMode routing_mode() const;
|
|
|
|
// Comfort noise replaces suppressed background noise to maintain a
|
|
// consistent signal level.
|
|
int enable_comfort_noise(bool enable);
|
|
bool is_comfort_noise_enabled() const;
|
|
|
|
// A typical use case is to initialize the component with an echo path from a
|
|
// previous call. The echo path is retrieved using |GetEchoPath()|, typically
|
|
// at the end of a call. The data can then be stored for later use as an
|
|
// initializer before the next call, using |SetEchoPath()|.
|
|
//
|
|
// Controlling the echo path this way requires the data |size_bytes| to match
|
|
// the internal echo path size. This size can be acquired using
|
|
// |echo_path_size_bytes()|. |SetEchoPath()| causes an entire reset, worth
|
|
// noting if it is to be called during an ongoing call.
|
|
//
|
|
// It is possible that version incompatibilities may result in a stored echo
|
|
// path of the incorrect size. In this case, the stored path should be
|
|
// discarded.
|
|
int SetEchoPath(const void* echo_path, size_t size_bytes);
|
|
int GetEchoPath(void* echo_path, size_t size_bytes) const;
|
|
|
|
// The returned path size is guaranteed not to change for the lifetime of
|
|
// the application.
|
|
static size_t echo_path_size_bytes();
|
|
|
|
void ProcessRenderAudio(rtc::ArrayView<const int16_t> packed_render_audio);
|
|
int ProcessCaptureAudio(AudioBuffer* audio, int stream_delay_ms);
|
|
|
|
void Initialize(int sample_rate_hz,
|
|
size_t num_reverse_channels,
|
|
size_t num_output_channels);
|
|
|
|
static void PackRenderAudioBuffer(const AudioBuffer* audio,
|
|
size_t num_output_channels,
|
|
size_t num_channels,
|
|
std::vector<int16_t>* packed_buffer);
|
|
|
|
static size_t NumCancellersRequired(size_t num_output_channels,
|
|
size_t num_reverse_channels);
|
|
|
|
private:
|
|
class Canceller;
|
|
struct StreamProperties;
|
|
|
|
int Configure();
|
|
|
|
rtc::CriticalSection* const crit_render_ RTC_ACQUIRED_BEFORE(crit_capture_);
|
|
rtc::CriticalSection* const crit_capture_;
|
|
|
|
bool enabled_ = false;
|
|
|
|
RoutingMode routing_mode_ RTC_GUARDED_BY(crit_capture_);
|
|
bool comfort_noise_enabled_ RTC_GUARDED_BY(crit_capture_);
|
|
unsigned char* external_echo_path_ RTC_GUARDED_BY(crit_render_)
|
|
RTC_GUARDED_BY(crit_capture_);
|
|
|
|
std::vector<std::unique_ptr<Canceller>> cancellers_;
|
|
std::unique_ptr<StreamProperties> stream_properties_;
|
|
|
|
RTC_DISALLOW_IMPLICIT_CONSTRUCTORS(EchoControlMobileImpl);
|
|
};
|
|
} // namespace webrtc
|
|
|
|
#endif // MODULES_AUDIO_PROCESSING_ECHO_CONTROL_MOBILE_IMPL_H_
|