From 2ff6084935814c0d90a68dcc3d187e3942c034fa Mon Sep 17 00:00:00 2001 From: harry Date: Thu, 21 Mar 2024 22:29:15 -0400 Subject: [PATCH] Qt netplay host game UI dialog improvements. --- src/drivers/Qt/NetPlay.cpp | 28 ++++++++++++++++++++++++---- src/drivers/Qt/NetPlay.h | 4 +++- 2 files changed, 27 insertions(+), 5 deletions(-) diff --git a/src/drivers/Qt/NetPlay.cpp b/src/drivers/Qt/NetPlay.cpp index b9c0bc47..badce2da 100644 --- a/src/drivers/Qt/NetPlay.cpp +++ b/src/drivers/Qt/NetPlay.cpp @@ -1516,6 +1516,7 @@ NetPlayHostDialog::NetPlayHostDialog(QWidget *parent) passwordEntry = new QLineEdit(); grid->addWidget( passwordEntry, 4, 1 ); + passwordEntry->setEnabled( passwordRequiredCBox->isChecked() ); // Misc Settings grid = new QGridLayout(); @@ -1540,6 +1541,10 @@ NetPlayHostDialog::NetPlayHostDialog(QWidget *parent) g_config->getOption("SDL.NetPlayHostAllowClientStateLoadReq", &stateLoadReqEna); allowClientStateReqCBox->setChecked(stateLoadReqEna); + connect(passwordRequiredCBox, SIGNAL(stateChanged(int)), this, SLOT(passwordRequiredChanged(int))); + connect(allowClientRomReqCBox, SIGNAL(stateChanged(int)), this, SLOT(allowClientRomReqChanged(int))); + connect(allowClientStateReqCBox, SIGNAL(stateChanged(int)), this, SLOT(allowClientStateReqChanged(int))); + startButton = new QPushButton( tr("Start") ); startButton->setIcon(style()->standardIcon(QStyle::SP_DialogApplyButton)); connect(startButton, SIGNAL(clicked(void)), this, SLOT(onStartClicked(void))); @@ -1578,6 +1583,21 @@ void NetPlayHostDialog::closeWindow(void) deleteLater(); } //----------------------------------------------------------------------------- +void NetPlayHostDialog::passwordRequiredChanged(int state) +{ + passwordEntry->setEnabled( state != Qt::Unchecked ); +} +//----------------------------------------------------------------------------- +void NetPlayHostDialog::allowClientRomReqChanged(int state) +{ + g_config->setOption("SDL.NetPlayHostAllowClientRomLoadReq", state != Qt::Unchecked); +} +//----------------------------------------------------------------------------- +void NetPlayHostDialog::allowClientStateReqChanged(int state) +{ + g_config->setOption("SDL.NetPlayHostAllowClientStateLoadReq", state != Qt::Unchecked); +} +//----------------------------------------------------------------------------- void NetPlayHostDialog::onStartClicked(void) { NetPlayServer *server = NetPlayServer::GetInstance(); @@ -1593,14 +1613,14 @@ void NetPlayHostDialog::onStartClicked(void) server = NetPlayServer::GetInstance(); server->setRole( playerRoleBox->currentData().toInt() ); server->sessionName = sessionNameEntry->text(); - server->sessionPasswd = passwordEntry->text(); server->setMaxLeadFrames( frameLeadSpinBox->value() ); server->setAllowClientRomLoadRequest( allowClientRomReqCBox->isChecked() ); server->setAllowClientStateLoadRequest( allowClientStateReqCBox->isChecked() ); - g_config->setOption("SDL.NetPlayHostAllowClientRomLoadReq", allowClientRomReqCBox->isChecked() ); - g_config->setOption("SDL.NetPlayHostAllowClientStateLoadReq", allowClientStateReqCBox->isChecked() ); - + if (passwordRequiredCBox->isChecked()) + { + server->sessionPasswd = passwordEntry->text(); + } bool listenSucceeded = server->listen( QHostAddress::Any, netPort ); if (listenSucceeded) diff --git a/src/drivers/Qt/NetPlay.h b/src/drivers/Qt/NetPlay.h index fcee9458..28af832a 100644 --- a/src/drivers/Qt/NetPlay.h +++ b/src/drivers/Qt/NetPlay.h @@ -341,7 +341,9 @@ protected: public slots: void closeWindow(void); void onStartClicked(void); - + void passwordRequiredChanged(int state); + void allowClientRomReqChanged(int state); + void allowClientStateReqChanged(int state); }; class NetPlayJoinDialog : public QDialog