mirror of https://github.com/mgba-emu/mgba.git
Qt: Fix unpausing
This commit is contained in:
parent
899a74d1c0
commit
dc8c5fe0f2
|
@ -340,16 +340,7 @@ void GameController::openGame(bool biosOnly) {
|
|||
m_gameOpen = false;
|
||||
emit gameFailed();
|
||||
} else if (m_audioProcessor) {
|
||||
bool started = false;
|
||||
QMetaObject::invokeMethod(m_audioProcessor, "start", Qt::BlockingQueuedConnection, Q_RETURN_ARG(bool, started));
|
||||
if (!started) {
|
||||
LOG(ERROR) << tr("Failed to start audio processor");
|
||||
// Don't freeze!
|
||||
m_audioSync = false;
|
||||
m_videoSync = true;
|
||||
m_threadContext.sync.audioWait = false;
|
||||
m_threadContext.sync.videoFrameWait = true;
|
||||
}
|
||||
startAudio();
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -479,6 +470,7 @@ void GameController::setPaused(bool paused) {
|
|||
m_pauseAfterFrame.testAndSetRelaxed(false, true);
|
||||
} else {
|
||||
GBAThreadUnpause(&m_threadContext);
|
||||
startAudio();
|
||||
emit gameUnpaused(&m_threadContext);
|
||||
}
|
||||
}
|
||||
|
@ -658,6 +650,19 @@ void GameController::setAudioChannelEnabled(int channel, bool enable) {
|
|||
}
|
||||
}
|
||||
|
||||
void GameController::startAudio() {
|
||||
bool started = false;
|
||||
QMetaObject::invokeMethod(m_audioProcessor, "start", Qt::BlockingQueuedConnection, Q_RETURN_ARG(bool, started));
|
||||
if (!started) {
|
||||
LOG(ERROR) << tr("Failed to start audio processor");
|
||||
// Don't freeze!
|
||||
m_audioSync = false;
|
||||
m_videoSync = true;
|
||||
m_threadContext.sync.audioWait = false;
|
||||
m_threadContext.sync.videoFrameWait = true;
|
||||
}
|
||||
}
|
||||
|
||||
void GameController::setVideoLayerEnabled(int layer, bool enable) {
|
||||
if (layer > 4 || layer < 0) {
|
||||
return;
|
||||
|
@ -912,16 +917,7 @@ void GameController::reloadAudioDriver() {
|
|||
connect(this, SIGNAL(gamePaused(GBAThread*)), m_audioProcessor, SLOT(pause()));
|
||||
if (isLoaded()) {
|
||||
m_audioProcessor->setInput(&m_threadContext);
|
||||
bool started = false;
|
||||
QMetaObject::invokeMethod(m_audioProcessor, "start", Qt::BlockingQueuedConnection, Q_RETURN_ARG(bool, started));
|
||||
if (!started) {
|
||||
LOG(ERROR) << tr("Failed to start audio processor");
|
||||
// Don't freeze!
|
||||
m_audioSync = false;
|
||||
m_videoSync = true;
|
||||
m_threadContext.sync.audioWait = false;
|
||||
m_threadContext.sync.videoFrameWait = true;
|
||||
}
|
||||
startAudio();
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -122,6 +122,7 @@ public slots:
|
|||
void setAudioBufferSamples(int samples);
|
||||
void setAudioSampleRate(unsigned rate);
|
||||
void setAudioChannelEnabled(int channel, bool enable = true);
|
||||
void startAudio();
|
||||
void setVideoLayerEnabled(int layer, bool enable = true);
|
||||
void setFPSTarget(float fps);
|
||||
void loadState(int slot = 0);
|
||||
|
|
Loading…
Reference in New Issue