DolphinQt: Saving and restoring NetPlay Session Browser dialog's settings.

This commit is contained in:
Christian Aguilera 2020-04-13 14:32:10 +02:00
parent 907b1302b0
commit 16f0864a4f
3 changed files with 59 additions and 0 deletions

View File

@ -1162,6 +1162,7 @@ void MainWindow::ShowNetPlaySetupDialog()
void MainWindow::ShowNetPlayBrowser() void MainWindow::ShowNetPlayBrowser()
{ {
auto* browser = new NetPlayBrowser(this); auto* browser = new NetPlayBrowser(this);
browser->setAttribute(Qt::WA_DeleteOnClose, true);
connect(browser, &NetPlayBrowser::Join, this, &MainWindow::NetPlayJoin); connect(browser, &NetPlayBrowser::Join, this, &MainWindow::NetPlayJoin);
browser->exec(); browser->exec();
} }

View File

@ -27,6 +27,7 @@
#include "DolphinQt/QtUtils/ModalMessageBox.h" #include "DolphinQt/QtUtils/ModalMessageBox.h"
#include "DolphinQt/QtUtils/RunOnObject.h" #include "DolphinQt/QtUtils/RunOnObject.h"
#include "DolphinQt/Settings.h"
NetPlayBrowser::NetPlayBrowser(QWidget* parent) : QDialog(parent) NetPlayBrowser::NetPlayBrowser(QWidget* parent) : QDialog(parent)
{ {
@ -44,6 +45,8 @@ NetPlayBrowser::NetPlayBrowser(QWidget* parent) : QDialog(parent)
m_refresh_run.Set(true); m_refresh_run.Set(true);
m_refresh_thread = std::thread([this] { RefreshLoop(); }); m_refresh_thread = std::thread([this] { RefreshLoop(); });
RestoreSettings();
UpdateList(); UpdateList();
Refresh(); Refresh();
} }
@ -54,6 +57,8 @@ NetPlayBrowser::~NetPlayBrowser()
m_refresh_event.Set(); m_refresh_event.Set();
if (m_refresh_thread.joinable()) if (m_refresh_thread.joinable())
m_refresh_thread.join(); m_refresh_thread.join();
SaveSettings();
} }
void NetPlayBrowser::CreateWidgets() void NetPlayBrowser::CreateWidgets()
@ -323,3 +328,53 @@ void NetPlayBrowser::accept()
emit Join(); emit Join();
} }
void NetPlayBrowser::SaveSettings() const
{
auto& settings = Settings::Instance().GetQSettings();
settings.setValue(QStringLiteral("netplaybrowser/geometry"), saveGeometry());
settings.setValue(QStringLiteral("netplaybrowser/region"), m_region_combo->currentText());
settings.setValue(QStringLiteral("netplaybrowser/name"), m_edit_name->text());
settings.setValue(QStringLiteral("netplaybrowser/game_id"), m_edit_game_id->text());
QString visibility(QStringLiteral("all"));
if (m_radio_public->isChecked())
visibility = QStringLiteral("public");
else if (m_radio_private->isChecked())
visibility = QStringLiteral("private");
settings.setValue(QStringLiteral("netplaybrowser/visibility"), visibility);
settings.setValue(QStringLiteral("netplaybrowser/hide_incompatible"),
m_check_hide_incompatible->isChecked());
settings.setValue(QStringLiteral("netplaybrowser/hide_ingame"), m_check_hide_ingame->isChecked());
}
void NetPlayBrowser::RestoreSettings()
{
const auto& settings = Settings::Instance().GetQSettings();
const QByteArray geometry =
settings.value(QStringLiteral("netplaybrowser/geometry")).toByteArray();
if (!geometry.isEmpty())
restoreGeometry(geometry);
const QString region = settings.value(QStringLiteral("netplaybrowser/region")).toString();
const bool valid_region = m_region_combo->findText(region) != -1;
if (valid_region)
m_region_combo->setCurrentText(region);
m_edit_name->setText(settings.value(QStringLiteral("netplaybrowser/name")).toString());
m_edit_game_id->setText(settings.value(QStringLiteral("netplaybrowser/game_id")).toString());
const QString visibility = settings.value(QStringLiteral("netplaybrowser/visibility")).toString();
if (visibility == QStringLiteral("public"))
m_radio_public->setChecked(true);
else if (visibility == QStringLiteral("private"))
m_radio_private->setChecked(true);
m_check_hide_incompatible->setChecked(
settings.value(QStringLiteral("netplaybrowser/hide_incompatible"), true).toBool());
m_check_hide_ingame->setChecked(
settings.value(QStringLiteral("netplaybrowser/hide_ingame")).toBool());
}

View File

@ -46,6 +46,9 @@ private:
void OnSelectionChanged(); void OnSelectionChanged();
void SaveSettings() const;
void RestoreSettings();
QComboBox* m_region_combo; QComboBox* m_region_combo;
QLabel* m_status_label; QLabel* m_status_label;
QPushButton* m_button_refresh; QPushButton* m_button_refresh;