Merge pull request #10947 from Zopolis4/opensleuth

Restrict OpenSLES to Android via CMake
This commit is contained in:
Admiral H. Curtiss 2023-01-30 09:02:45 +01:00 committed by GitHub
commit 8edca2039e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 15 additions and 12 deletions

View File

@ -18,6 +18,7 @@ add_library(audiocommon
WaveFile.h WaveFile.h
) )
if(ANDROID)
find_package(OpenSLES) find_package(OpenSLES)
if(OPENSLES_FOUND) if(OPENSLES_FOUND)
message(STATUS "OpenSLES found, enabling OpenSLES sound backend") message(STATUS "OpenSLES found, enabling OpenSLES sound backend")
@ -26,6 +27,8 @@ if(OPENSLES_FOUND)
OpenSLESStream.h OpenSLESStream.h
) )
target_link_libraries(audiocommon PRIVATE OpenSLES::OpenSLES) target_link_libraries(audiocommon PRIVATE OpenSLES::OpenSLES)
target_compile_definitions(audiocommon PRIVATE HAVE_OPENSL_ES=1)
endif()
endif() endif()
if(ENABLE_ALSA) if(ENABLE_ALSA)

View File

@ -1,7 +1,7 @@
// Copyright 2013 Dolphin Emulator Project // Copyright 2013 Dolphin Emulator Project
// SPDX-License-Identifier: GPL-2.0-or-later // SPDX-License-Identifier: GPL-2.0-or-later
#ifdef ANDROID #ifdef HAVE_OPENSL_ES
#include "AudioCommon/OpenSLESStream.h" #include "AudioCommon/OpenSLESStream.h"
#include <cmath> #include <cmath>
@ -143,4 +143,4 @@ void OpenSLESStream::SetVolume(int volume)
volume <= 0 ? SL_MILLIBEL_MIN : static_cast<SLmillibel>(2000 * std::log10(volume / 100.0f)); volume <= 0 ? SL_MILLIBEL_MIN : static_cast<SLmillibel>(2000 * std::log10(volume / 100.0f));
(*bqPlayerVolume)->SetVolumeLevel(bqPlayerVolume, attenuation); (*bqPlayerVolume)->SetVolumeLevel(bqPlayerVolume, attenuation);
} }
#endif #endif // HAVE_OPENSL_ES

View File

@ -10,7 +10,7 @@
class OpenSLESStream final : public SoundStream class OpenSLESStream final : public SoundStream
{ {
#ifdef ANDROID #ifdef HAVE_OPENSL_ES
public: public:
~OpenSLESStream() override; ~OpenSLESStream() override;
bool Init() override; bool Init() override;
@ -21,5 +21,5 @@ public:
private: private:
std::thread thread; std::thread thread;
Common::Event soundSyncEvent; Common::Event soundSyncEvent;
#endif // HAVE_OPENSL #endif // HAVE_OPENSL_ES
}; };