mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-26 18:52:44 +01:00
audio/internal/oboe: Bug fix: Not all players should not be suspended
This commit is contained in:
parent
7487222740
commit
ae9e89b814
22
audio/internal/oboe/binding_android.cpp
vendored
22
audio/internal/oboe/binding_android.cpp
vendored
@ -26,24 +26,29 @@ namespace {
|
||||
class Player : public oboe::AudioStreamDataCallback {
|
||||
public:
|
||||
static const char* Suspend() {
|
||||
std::lock_guard<std::mutex> lock(GetPlayersMutex());
|
||||
std::lock_guard<std::mutex> lock(PlayersMutex());
|
||||
for (Player* player : GetPlayers()) {
|
||||
if (!player->IsPlaying()) {
|
||||
continue;
|
||||
}
|
||||
// Close should be called rather than Pause for onPause.
|
||||
// https://github.com/google/oboe/blob/master/docs/GettingStarted.md
|
||||
if (const char* msg = player->Close(); msg) {
|
||||
return msg;
|
||||
}
|
||||
GetPlayersToResume().insert(player);
|
||||
}
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
static const char* Resume() {
|
||||
std::lock_guard<std::mutex> lock(GetPlayersMutex());
|
||||
for (Player* player : GetPlayers()) {
|
||||
std::lock_guard<std::mutex> lock(PlayersMutex());
|
||||
for (Player* player : GetPlayersToResume()) {
|
||||
if (const char* msg = player->Play(); msg) {
|
||||
return msg;
|
||||
}
|
||||
}
|
||||
GetPlayersToResume().clear();
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
@ -54,7 +59,7 @@ public:
|
||||
go_player_{go_player} {
|
||||
std::atomic_store(&volume_, volume);
|
||||
{
|
||||
std::lock_guard<std::mutex> lock(GetPlayersMutex());
|
||||
std::lock_guard<std::mutex> lock(PlayersMutex());
|
||||
GetPlayers().insert(this);
|
||||
}
|
||||
}
|
||||
@ -133,7 +138,7 @@ public:
|
||||
const char* CloseAndRemove() {
|
||||
// Close and remove self from the players atomically.
|
||||
// Otherwise, a removed player might be resumed at Resume unexpectedly.
|
||||
std::lock_guard<std::mutex> lock(GetPlayersMutex());
|
||||
std::lock_guard<std::mutex> lock(PlayersMutex());
|
||||
const char* msg = Close();
|
||||
GetPlayers().erase(this);
|
||||
return msg;
|
||||
@ -176,7 +181,12 @@ private:
|
||||
return players;
|
||||
}
|
||||
|
||||
static std::mutex& GetPlayersMutex() {
|
||||
static std::set<Player*>& GetPlayersToResume() {
|
||||
static std::set<Player*> players_to_resume;
|
||||
return players_to_resume;
|
||||
}
|
||||
|
||||
static std::mutex& PlayersMutex() {
|
||||
static std::mutex mutex;
|
||||
return mutex;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user