Bug: b/306637040 Change-Id: I128a498aa307f6d61406ddcf4917a97ba6ae75db Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/325240 Commit-Queue: Per Åhgren <peah@webrtc.org> Reviewed-by: Zoé Lepaul <xalep@webrtc.org> Cr-Commit-Position: refs/heads/main@{#41034}
57 lines
2.0 KiB
Java
57 lines
2.0 KiB
Java
/*
|
|
* Copyright 2018 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.
|
|
*/
|
|
|
|
package org.webrtc.audio;
|
|
|
|
/**
|
|
* This interface is a thin wrapper on top of a native C++ webrtc::AudioDeviceModule (ADM). The
|
|
* reason for basing it on a native ADM instead of a pure Java interface is that we have two native
|
|
* Android implementations (OpenSLES and AAudio) that does not make sense to wrap through JNI.
|
|
*
|
|
* <p>Note: This class is still under development and may change without notice.
|
|
*/
|
|
public interface AudioDeviceModule {
|
|
/**
|
|
* Returns a C++ pointer to a webrtc::AudioDeviceModule. Caller does _not_ take ownership and
|
|
* lifetime is handled through the release() call.
|
|
*/
|
|
long getNativeAudioDeviceModulePointer();
|
|
|
|
/**
|
|
* Release resources for this AudioDeviceModule, including native resources. The object should not
|
|
* be used after this call.
|
|
*/
|
|
void release();
|
|
|
|
/** Control muting/unmuting the speaker. */
|
|
void setSpeakerMute(boolean mute);
|
|
|
|
/** Control muting/unmuting the microphone. */
|
|
void setMicrophoneMute(boolean mute);
|
|
|
|
/**
|
|
* Enable or disable built in noise suppressor. Returns true if the enabling was successful,
|
|
* otherwise false is returned.
|
|
*/
|
|
default boolean setNoiseSuppressorEnabled(boolean enabled) {
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Sets the preferred field dimension for the built-in microphone. Returns
|
|
* true if setting was successful, otherwise false is returned.
|
|
* This functionality can be implemented with
|
|
* {@code android.media.MicrophoneDirection.setPreferredMicrophoneFieldDimension}.
|
|
*/
|
|
default boolean setPreferredMicrophoneFieldDimension(float dimension) {
|
|
return false;
|
|
}
|
|
}
|