Qt: Disable menu items in multiplayer that don't make sense to have enabled

This commit is contained in:
Jeffrey Pfau 2015-09-14 20:21:16 -07:00
parent b4d5540304
commit 28c53fb3f2
6 changed files with 45 additions and 1 deletions

View File

@ -17,6 +17,7 @@ Misc:
- GBA Audio: Allow GBAAVStream to have no video callback
- ARM7: Force disable LTO on two files to work around a GCC bug
- Qt: Prevent savestate window from opening while in multiplayer
- Qt: Disable menu items in multiplayer that don't make sense to have enabled
0.3.0: (2015-08-16)
Features:

View File

@ -75,6 +75,7 @@ GBAApp::GBAApp(int& argc, char* argv[])
w->show();
w->controller()->setMultiplayerController(&m_multiplayer);
w->multiplayerChanged();
}
bool GBAApp::event(QEvent* event) {
@ -99,6 +100,7 @@ Window* GBAApp::newWindow() {
w->loadConfig();
w->show();
w->controller()->setMultiplayerController(&m_multiplayer);
w->multiplayerChanged();
return w;
}

View File

@ -35,6 +35,7 @@ bool MultiplayerController::attachGame(GameController* controller) {
}
thread->sioDrivers.multiplayer = &node->d;
controller->threadContinue();
emit gameAttached();
return true;
}
@ -60,6 +61,7 @@ void MultiplayerController::detachGame(GameController* controller) {
}
MutexUnlock(&m_lockstep.mutex);
controller->threadContinue();
emit gameDetached();
}
int MultiplayerController::attached() {

View File

@ -6,6 +6,8 @@
#ifndef QGBA_MULTIPLAYER_CONTROLLER
#define QGBA_MULTIPLAYER_CONTROLLER
#include <QObject>
extern "C" {
#include "gba/sio/lockstep.h"
}
@ -14,7 +16,9 @@ namespace QGBA {
class GameController;
class MultiplayerController {
class MultiplayerController : public QObject {
Q_OBJECT
public:
MultiplayerController();
~MultiplayerController();
@ -24,6 +28,10 @@ public:
int attached();
signals:
void gameAttached();
void gameDetached();
private:
GBASIOLockstep m_lockstep;
};

View File

@ -270,6 +270,22 @@ void Window::replaceROM() {
}
}
void Window::multiplayerChanged() {
disconnect(nullptr, this, SLOT(multiplayerChanged()));
int attached = 1;
MultiplayerController* multiplayer = m_controller->multiplayerController();
if (multiplayer) {
attached = multiplayer->attached();
connect(multiplayer, SIGNAL(gameAttached()), this, SLOT(multiplayerChanged()));
connect(multiplayer, SIGNAL(gameDetached()), this, SLOT(multiplayerChanged()));
}
if (m_controller->isLoaded()) {
for (QAction* action : m_nonMpActions) {
action->setDisabled(attached > 1);
}
}
}
void Window::selectBIOS() {
QString filename = GBAApp::app()->getOpenFileName(this, tr("Select BIOS"));
if (!filename.isEmpty()) {
@ -560,6 +576,7 @@ void Window::gameStarted(GBAThread* context) {
foreach (QAction* action, m_gameActions) {
action->setDisabled(false);
}
multiplayerChanged();
if (context->fname) {
setWindowFilePath(context->fname);
appendMRU(context->fname);
@ -731,12 +748,14 @@ void Window::setupMenu(QMenuBar* menubar) {
loadState->setShortcut(tr("F10"));
connect(loadState, &QAction::triggered, [this]() { this->openStateWindow(LoadSave::LOAD); });
m_gameActions.append(loadState);
m_nonMpActions.append(loadState);
addControlledAction(fileMenu, loadState, "loadState");
QAction* saveState = new QAction(tr("&Save state"), fileMenu);
saveState->setShortcut(tr("Shift+F10"));
connect(saveState, &QAction::triggered, [this]() { this->openStateWindow(LoadSave::SAVE); });
m_gameActions.append(saveState);
m_nonMpActions.append(saveState);
addControlledAction(fileMenu, saveState, "saveState");
QMenu* quickLoadMenu = fileMenu->addMenu(tr("Quick load"));
@ -747,11 +766,13 @@ void Window::setupMenu(QMenuBar* menubar) {
QAction* quickLoad = new QAction(tr("Load recent"), quickLoadMenu);
connect(quickLoad, SIGNAL(triggered()), m_controller, SLOT(loadState()));
m_gameActions.append(quickLoad);
m_nonMpActions.append(quickLoad);
addControlledAction(quickLoadMenu, quickLoad, "quickLoad");
QAction* quickSave = new QAction(tr("Save recent"), quickSaveMenu);
connect(quickSave, SIGNAL(triggered()), m_controller, SLOT(saveState()));
m_gameActions.append(quickSave);
m_nonMpActions.append(quickSave);
addControlledAction(quickSaveMenu, quickSave, "quickSave");
quickLoadMenu->addSeparator();
@ -761,12 +782,14 @@ void Window::setupMenu(QMenuBar* menubar) {
undoLoadState->setShortcut(tr("F11"));
connect(undoLoadState, SIGNAL(triggered()), m_controller, SLOT(loadBackupState()));
m_gameActions.append(undoLoadState);
m_nonMpActions.append(undoLoadState);
addControlledAction(quickLoadMenu, undoLoadState, "undoLoadState");
QAction* undoSaveState = new QAction(tr("Undo save state"), quickSaveMenu);
undoSaveState->setShortcut(tr("Shift+F11"));
connect(undoSaveState, SIGNAL(triggered()), m_controller, SLOT(saveBackupState()));
m_gameActions.append(undoSaveState);
m_nonMpActions.append(undoSaveState);
addControlledAction(quickSaveMenu, undoSaveState, "undoSaveState");
quickLoadMenu->addSeparator();
@ -778,12 +801,14 @@ void Window::setupMenu(QMenuBar* menubar) {
quickLoad->setShortcut(tr("F%1").arg(i));
connect(quickLoad, &QAction::triggered, [this, i]() { m_controller->loadState(i); });
m_gameActions.append(quickLoad);
m_nonMpActions.append(quickLoad);
addControlledAction(quickLoadMenu, quickLoad, QString("quickLoad.%1").arg(i));
quickSave = new QAction(tr("State &%1").arg(i), quickSaveMenu);
quickSave->setShortcut(tr("Shift+F%1").arg(i));
connect(quickSave, &QAction::triggered, [this, i]() { m_controller->saveState(i); });
m_gameActions.append(quickSave);
m_nonMpActions.append(quickSave);
addControlledAction(quickSaveMenu, quickSave, QString("quickSave.%1").arg(i));
}
@ -852,6 +877,7 @@ void Window::setupMenu(QMenuBar* menubar) {
frameAdvance->setShortcut(tr("Ctrl+N"));
connect(frameAdvance, SIGNAL(triggered()), m_controller, SLOT(frameAdvance()));
m_gameActions.append(frameAdvance);
m_nonMpActions.append(frameAdvance);
addControlledAction(emulationMenu, frameAdvance, "frameAdvance");
emulationMenu->addSeparator();
@ -892,6 +918,7 @@ void Window::setupMenu(QMenuBar* menubar) {
rewind->setShortcut(tr("`"));
connect(rewind, SIGNAL(triggered()), m_controller, SLOT(rewind()));
m_gameActions.append(rewind);
m_nonMpActions.append(rewind);
addControlledAction(emulationMenu, rewind, "rewind");
QAction* frameRewind = new QAction(tr("Step backwards"), emulationMenu);
@ -900,6 +927,7 @@ void Window::setupMenu(QMenuBar* menubar) {
m_controller->rewind(1);
});
m_gameActions.append(frameRewind);
m_nonMpActions.append(frameRewind);
addControlledAction(emulationMenu, frameRewind, "frameRewind");
ConfigOption* videoSync = m_config->addOption("videoSync");

View File

@ -69,6 +69,8 @@ public slots:
void replaceROM();
void multiplayerChanged();
void importSharkport();
void exportSharkport();
@ -149,6 +151,7 @@ private:
GameController* m_controller;
Display* m_display;
QList<QAction*> m_gameActions;
QList<QAction*> m_nonMpActions;
QMap<int, QAction*> m_frameSizes;
LogController m_log;
LogView* m_logView;