oboe_sink: specify additional required parameters
This commit is contained in:
parent
797e8fdbc3
commit
a7731abb72
@ -29,7 +29,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
~OboeSinkStream() override {
|
~OboeSinkStream() override {
|
||||||
LOG_DEBUG(Audio_Sink, "Destructing Oboe stream {}", name);
|
LOG_INFO(Audio_Sink, "Destroyed Oboe stream");
|
||||||
}
|
}
|
||||||
|
|
||||||
void Finalize() override {
|
void Finalize() override {
|
||||||
@ -66,12 +66,7 @@ public:
|
|||||||
std::shared_ptr<oboe::AudioStream> temp_stream;
|
std::shared_ptr<oboe::AudioStream> temp_stream;
|
||||||
oboe::AudioStreamBuilder builder;
|
oboe::AudioStreamBuilder builder;
|
||||||
|
|
||||||
const auto result = builder.setDirection(direction)
|
const auto result = ConfigureBuilder(builder, direction)->openStream(temp_stream);
|
||||||
->setPerformanceMode(oboe::PerformanceMode::LowLatency)
|
|
||||||
->setSampleRate(TargetSampleRate)
|
|
||||||
->setFormat(oboe::AudioFormat::I16)
|
|
||||||
->setFormatConversionAllowed(true)
|
|
||||||
->openStream(temp_stream);
|
|
||||||
ASSERT(result == oboe::Result::OK);
|
ASSERT(result == oboe::Result::OK);
|
||||||
|
|
||||||
return temp_stream->getChannelCount() >= 6 ? 6 : 2;
|
return temp_stream->getChannelCount() >= 6 ? 6 : 2;
|
||||||
@ -106,6 +101,20 @@ protected:
|
|||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
static oboe::AudioStreamBuilder* ConfigureBuilder(oboe::AudioStreamBuilder& builder,
|
||||||
|
oboe::Direction direction) {
|
||||||
|
// TODO: investigate callback delay issues when using AAudio
|
||||||
|
return builder.setPerformanceMode(oboe::PerformanceMode::LowLatency)
|
||||||
|
->setAudioApi(oboe::AudioApi::OpenSLES)
|
||||||
|
->setDirection(direction)
|
||||||
|
->setSampleRate(TargetSampleRate)
|
||||||
|
->setSampleRateConversionQuality(oboe::SampleRateConversionQuality::High)
|
||||||
|
->setFormat(oboe::AudioFormat::I16)
|
||||||
|
->setFormatConversionAllowed(true)
|
||||||
|
->setUsage(oboe::Usage::Game)
|
||||||
|
->setBufferCapacityInFrames(TargetSampleCount * 2);
|
||||||
|
}
|
||||||
|
|
||||||
bool OpenStream() {
|
bool OpenStream() {
|
||||||
const auto direction = [&]() {
|
const auto direction = [&]() {
|
||||||
switch (type) {
|
switch (type) {
|
||||||
@ -136,13 +145,10 @@ private:
|
|||||||
}();
|
}();
|
||||||
|
|
||||||
oboe::AudioStreamBuilder builder;
|
oboe::AudioStreamBuilder builder;
|
||||||
const auto result = builder.setDirection(direction)
|
const auto result = ConfigureBuilder(builder, direction)
|
||||||
->setPerformanceMode(oboe::PerformanceMode::LowLatency)
|
|
||||||
->setSampleRate(TargetSampleRate)
|
|
||||||
->setChannelCount(expected_channels)
|
->setChannelCount(expected_channels)
|
||||||
->setChannelMask(expected_mask)
|
->setChannelMask(expected_mask)
|
||||||
->setFormat(oboe::AudioFormat::I16)
|
->setChannelConversionAllowed(true)
|
||||||
->setFormatConversionAllowed(true)
|
|
||||||
->setDataCallback(this)
|
->setDataCallback(this)
|
||||||
->setErrorCallback(this)
|
->setErrorCallback(this)
|
||||||
->openStream(m_stream);
|
->openStream(m_stream);
|
||||||
@ -153,8 +159,16 @@ private:
|
|||||||
bool SetStreamProperties() {
|
bool SetStreamProperties() {
|
||||||
ASSERT(m_stream);
|
ASSERT(m_stream);
|
||||||
|
|
||||||
|
m_stream->setBufferSizeInFrames(TargetSampleCount * 2);
|
||||||
device_channels = m_stream->getChannelCount();
|
device_channels = m_stream->getChannelCount();
|
||||||
LOG_INFO(Audio_Sink, "Opened Oboe stream with {} channels", device_channels);
|
|
||||||
|
const auto sample_rate = m_stream->getSampleRate();
|
||||||
|
const auto buffer_capacity = m_stream->getBufferCapacityInFrames();
|
||||||
|
const auto stream_backend =
|
||||||
|
m_stream->getAudioApi() == oboe::AudioApi::AAudio ? "AAudio" : "OpenSLES";
|
||||||
|
|
||||||
|
LOG_INFO(Audio_Sink, "Opened Oboe {} stream with {} channels sample rate {} capacity {}",
|
||||||
|
stream_backend, device_channels, sample_rate, buffer_capacity);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user