#ifndef MEDIA_AUDIO_ANDROID_AAUDIO_STREAM_WRAPPER_H_
#define MEDIA_AUDIO_ANDROID_AAUDIO_STREAM_WRAPPER_H_
#include <aaudio/AAudio.h>
#include "base/android/requires_api.h"
#include "base/memory/raw_ptr.h"
#include "base/memory/raw_ptr_exclusion.h"
#include "base/sequence_checker.h"
#include "base/synchronization/lock.h"
#include "media/audio/android/audio_device.h"
#include "media/base/audio_parameters.h"
namespace media {
class AAudioDestructionHelper;
class AAudioStreamWrapper {
public:
enum class StreamType {
kInput,
kOutput,
};
class DataCallback {
public:
virtual ~DataCallback() = default;
virtual bool OnAudioDataRequested(void* audio_data, int32_t num_frames) = 0;
virtual void OnError() = 0;
virtual void OnDeviceChange() = 0;
};
AAudioStreamWrapper(DataCallback* callback,
StreamType stream_type,
const AudioParameters& params,
android::AudioDevice device,
aaudio_usage_t usage);
AAudioStreamWrapper(const AAudioStreamWrapper&) = delete;
AAudioStreamWrapper& operator=(const AAudioStreamWrapper&) = delete;
~AAudioStreamWrapper();
bool Open();
bool Start();
bool Stop();
void Close();
aaudio_data_callback_result_t OnAudioDataRequested(void* audio_data,
int32_t num_frames);
void OnStreamError(aaudio_result_t error);
std::optional<android::AudioDeviceId> GetActualDeviceId();
base::TimeDelta GetOutputDelay(base::TimeTicks delay_timestamp);
base::TimeTicks GetCaptureTimestamp();
private:
SEQUENCE_CHECKER(sequence_checker_);
void EmitSetDeviceIdResultToHistogram(bool success);
void LogFramesPerBurstChangesToUma();
const AudioParameters params_;
const android::AudioDevice requested_device_;
int32_t frames_per_burst_on_open_;
StreamType stream_type_;
aaudio_usage_t usage_;
aaudio_performance_mode_t performance_mode_;
const raw_ptr<DataCallback> callback_;
bool is_closed_ = false;
raw_ptr<AAudioStream> aaudio_stream_ = nullptr;
const double ns_per_frame_;
std::unique_ptr<AAudioDestructionHelper> destruction_helper_;
};
}
#endif