Qt: improve VFS dialog a bit

- use normal selection instead of doubleclick
- move SaveSettings out of the tabs to reduce file access
- translate EmptyPath as well
- some other minor refactors to reduce lines of code
This commit is contained in:
Megamouse 2018-02-08 23:01:43 +01:00 committed by Ivan
parent 4c6ceeff11
commit bda466c3bd
4 changed files with 31 additions and 61 deletions

View File

@ -1,10 +1,5 @@
#include "vfs_dialog.h" #include "vfs_dialog.h"
#include "Emu/System.h"
#include "vfs_dialog_tab.h"
#include <QVBoxLayout>
#include <QPushButton> #include <QPushButton>
inline std::string sstr(const QString& _in) { return _in.toStdString(); } inline std::string sstr(const QString& _in) { return _in.toStdString(); }
@ -69,8 +64,9 @@ vfs_dialog::vfs_dialog(std::shared_ptr<gui_settings> guiSettings, std::shared_pt
{ {
for (int i = 0; i < tabs->count(); ++i) for (int i = 0; i < tabs->count(); ++i)
{ {
static_cast<vfs_dialog_tab*>(tabs->widget(i))->SaveSettings(); static_cast<vfs_dialog_tab*>(tabs->widget(i))->SetSettings();
} }
m_emu_settings->SaveSettings();
accept(); accept();
}); });
@ -86,6 +82,6 @@ vfs_dialog::vfs_dialog(std::shared_ptr<gui_settings> guiSettings, std::shared_pt
vbox->addLayout(buttons); vbox->addLayout(buttons);
setLayout(vbox); setLayout(vbox);
setWindowTitle("Virtual File System"); setWindowTitle(tr("Virtual File System"));
setWindowFlags(windowFlags() & ~Qt::WindowContextHelpButtonHint); setWindowFlags(windowFlags() & ~Qt::WindowContextHelpButtonHint);
} }

View File

@ -1,7 +1,6 @@
#pragma once #pragma once
#include "gui_settings.h" #include "vfs_dialog_tab.h"
#include "emu_settings.h"
#include <QTabWidget> #include <QTabWidget>
#include <QDialog> #include <QDialog>

View File

@ -2,8 +2,6 @@
#include <QFileDialog> #include <QFileDialog>
#include <QCoreApplication> #include <QCoreApplication>
#include <QHBoxLayout>
#include <QVBoxLayout>
inline std::string sstr(const QString& _in) { return _in.toStdString(); } inline std::string sstr(const QString& _in) { return _in.toStdString(); }
@ -13,27 +11,29 @@ vfs_dialog_tab::vfs_dialog_tab(const vfs_settings_info& settingsInfo, std::share
m_dirList = new QListWidget(this); m_dirList = new QListWidget(this);
QStringList alldirs = m_gui_settings->GetValue(m_info.listLocation).toStringList(); QStringList alldirs = m_gui_settings->GetValue(m_info.listLocation).toStringList();
const QString current_dir = qstr(m_info.cfg_node->to_string());
QListWidgetItem* selected_item = nullptr;
// We must show the currently selected config.
if (alldirs.contains(EmuConfigDir()) == false)
{
new QListWidgetItem(EmuConfigDir(), m_dirList);
}
for (const QString& dir : alldirs) for (const QString& dir : alldirs)
{ {
new QListWidgetItem(dir, m_dirList); QListWidgetItem* item = new QListWidgetItem(dir, m_dirList);
if (dir == current_dir)
selected_item = item;
} }
// We must show the currently selected config.
if (!selected_item)
selected_item = new QListWidgetItem(current_dir, m_dirList);
selected_item->setSelected(true);
m_dirList->setMinimumWidth(m_dirList->sizeHintForColumn(0)); m_dirList->setMinimumWidth(m_dirList->sizeHintForColumn(0));
QHBoxLayout* selectedConfigLayout = new QHBoxLayout; QHBoxLayout* selectedConfigLayout = new QHBoxLayout;
QLabel* selectedMessage = new QLabel(m_info.name + " directory:"); QLabel* selectedMessage = new QLabel(m_info.name + " directory:");
m_selectedConfigLabel = new QLabel(); m_selectedConfigLabel = new QLabel();
m_selectedConfigLabel->setText(EmuConfigDir()); m_selectedConfigLabel->setText(current_dir.isEmpty() ? EmptyPath : current_dir);
if (m_selectedConfigLabel->text() == "")
{
m_selectedConfigLabel->setText(EmptyPath);
}
selectedConfigLayout->addWidget(selectedMessage); selectedConfigLayout->addWidget(selectedMessage);
selectedConfigLayout->addWidget(m_selectedConfigLabel); selectedConfigLayout->addWidget(m_selectedConfigLabel);
selectedConfigLayout->addStretch(); selectedConfigLayout->addStretch();
@ -44,52 +44,34 @@ vfs_dialog_tab::vfs_dialog_tab(const vfs_settings_info& settingsInfo, std::share
setLayout(vbox); setLayout(vbox);
connect(m_dirList, &QListWidget::itemDoubleClicked, [this](QListWidgetItem* item) connect(m_dirList, &QListWidget::currentItemChanged, [this](QListWidgetItem* current, QListWidgetItem*)
{ {
if (item->text() == "") m_selectedConfigLabel->setText(current->text().isEmpty() ? EmptyPath : current->text());
{
m_selectedConfigLabel->setText(EmptyPath);
}
else
{
m_selectedConfigLabel->setText(item->text());
}
}); });
} }
void vfs_dialog_tab::SaveSettings() void vfs_dialog_tab::SetSettings()
{ {
QStringList allDirs; QStringList allDirs;
for (int i = 0; i < m_dirList->count(); ++i) for (int i = 0; i < m_dirList->count(); ++i)
{ {
allDirs += m_dirList->item(i)->text(); allDirs += m_dirList->item(i)->text();
} }
m_gui_settings->SetValue(m_info.listLocation, allDirs); m_gui_settings->SetValue(m_info.listLocation, allDirs);
if (m_selectedConfigLabel->text() == EmptyPath)
{ const std::string new_dir = m_selectedConfigLabel->text() == EmptyPath ? "" : sstr(m_selectedConfigLabel->text());
m_info.cfg_node->from_string(""); m_info.cfg_node->from_string(new_dir);
m_emu_settings->SetSetting(m_info.settingLoc, ""); m_emu_settings->SetSetting(m_info.settingLoc, new_dir);
}
else
{
m_info.cfg_node->from_string(sstr(m_selectedConfigLabel->text()));
m_emu_settings->SetSetting(m_info.settingLoc, sstr(m_selectedConfigLabel->text()));
}
m_emu_settings->SaveSettings();
} }
void vfs_dialog_tab::Reset() void vfs_dialog_tab::Reset()
{ {
const QString current_dir = qstr(m_info.cfg_node->to_string());
m_dirList->clear(); m_dirList->clear();
m_info.cfg_node->from_default(); m_info.cfg_node->from_default();
m_selectedConfigLabel->setText(EmuConfigDir()); m_selectedConfigLabel->setText(current_dir.isEmpty() ? EmptyPath : current_dir);
if (m_selectedConfigLabel->text() == "") m_dirList->addItem(new QListWidgetItem(current_dir));
{ m_gui_settings->SetValue(m_info.listLocation, QStringList(current_dir));
m_selectedConfigLabel->setText(EmptyPath);
}
m_dirList->addItem(new QListWidgetItem(EmuConfigDir()));
m_gui_settings->SetValue(m_info.listLocation, QStringList(EmuConfigDir()));
} }
void vfs_dialog_tab::AddNewDirectory() void vfs_dialog_tab::AddNewDirectory()
@ -102,8 +84,3 @@ void vfs_dialog_tab::AddNewDirectory()
m_selectedConfigLabel->setText(dir); m_selectedConfigLabel->setText(dir);
} }
} }
QString vfs_dialog_tab::EmuConfigDir()
{
return qstr(m_info.cfg_node->to_string());
}

View File

@ -6,7 +6,7 @@
#include "gui_settings.h" #include "gui_settings.h"
#include "emu_settings.h" #include "emu_settings.h"
#include <QWidget> #include <QHBoxLayout>
#include <QListWidget> #include <QListWidget>
#include <QLabel> #include <QLabel>
@ -25,13 +25,11 @@ class vfs_dialog_tab : public QWidget
public: public:
explicit vfs_dialog_tab(const vfs_settings_info& info, std::shared_ptr<gui_settings> guiSettings, std::shared_ptr<emu_settings> emuSettings, QWidget* parent = nullptr); explicit vfs_dialog_tab(const vfs_settings_info& info, std::shared_ptr<gui_settings> guiSettings, std::shared_ptr<emu_settings> emuSettings, QWidget* parent = nullptr);
void SaveSettings(); void SetSettings();
void AddNewDirectory(); void AddNewDirectory();
void Reset(); void Reset();
private: private:
QString EmuConfigDir(); const QString EmptyPath = tr("Empty Path");
const QString EmptyPath = "Empty Path";
vfs_settings_info m_info; vfs_settings_info m_info;
std::shared_ptr<gui_settings> m_gui_settings; std::shared_ptr<gui_settings> m_gui_settings;