Added a GUI config window to for misc GUI options. Added an option to use the native OS file browser when looking for files.

This commit is contained in:
Matthew Budd 2020-07-19 18:43:42 -04:00
parent b846ed31db
commit 397e17ba99
6 changed files with 171 additions and 36 deletions

View File

@ -389,6 +389,7 @@ set(SRC_DRIVERS_SDL
${CMAKE_CURRENT_SOURCE_DIR}/drivers/Qt/GamePadConf.cpp ${CMAKE_CURRENT_SOURCE_DIR}/drivers/Qt/GamePadConf.cpp
${CMAKE_CURRENT_SOURCE_DIR}/drivers/Qt/HotKeyConf.cpp ${CMAKE_CURRENT_SOURCE_DIR}/drivers/Qt/HotKeyConf.cpp
${CMAKE_CURRENT_SOURCE_DIR}/drivers/Qt/PaletteConf.cpp ${CMAKE_CURRENT_SOURCE_DIR}/drivers/Qt/PaletteConf.cpp
${CMAKE_CURRENT_SOURCE_DIR}/drivers/Qt/GuiConf.cpp
${CMAKE_CURRENT_SOURCE_DIR}/drivers/Qt/ConsoleVideoConf.cpp ${CMAKE_CURRENT_SOURCE_DIR}/drivers/Qt/ConsoleVideoConf.cpp
${CMAKE_CURRENT_SOURCE_DIR}/drivers/Qt/ConsoleSoundConf.cpp ${CMAKE_CURRENT_SOURCE_DIR}/drivers/Qt/ConsoleSoundConf.cpp
${CMAKE_CURRENT_SOURCE_DIR}/drivers/Qt/AboutWindow.cpp ${CMAKE_CURRENT_SOURCE_DIR}/drivers/Qt/AboutWindow.cpp

View File

@ -20,6 +20,7 @@
#include "Qt/GamePadConf.h" #include "Qt/GamePadConf.h"
#include "Qt/HotKeyConf.h" #include "Qt/HotKeyConf.h"
#include "Qt/PaletteConf.h" #include "Qt/PaletteConf.h"
#include "Qt/GuiConf.h"
#include "Qt/ConsoleSoundConf.h" #include "Qt/ConsoleSoundConf.h"
#include "Qt/ConsoleVideoConf.h" #include "Qt/ConsoleVideoConf.h"
#include "Qt/AboutWindow.h" #include "Qt/AboutWindow.h"
@ -294,6 +295,14 @@ void consoleWin_t::createMainMenu(void)
optMenu->addAction(paletteConfig); optMenu->addAction(paletteConfig);
// Options -> GUI Config
guiConfig = new QAction(tr("GUI Config"), this);
//guiConfig->setShortcut( QKeySequence(tr("Ctrl+C")));
guiConfig->setStatusTip(tr("GUI Configure"));
connect(guiConfig, SIGNAL(triggered()), this, SLOT(openGuiConfWin(void)) );
optMenu->addAction(guiConfig);
// Options -> Auto-Resume // Options -> Auto-Resume
autoResume = new QAction(tr("Auto-Resume Play"), this); autoResume = new QAction(tr("Auto-Resume Play"), this);
//autoResume->setShortcut( QKeySequence(tr("Ctrl+C"))); //autoResume->setShortcut( QKeySequence(tr("Ctrl+C")));
@ -510,7 +519,7 @@ int consoleWin_t::getDirFromFile( const char *path, char *dir )
void consoleWin_t::openROMFile(void) void consoleWin_t::openROMFile(void)
{ {
int ret; int ret, useNativeFileDialogVal;
QString filename; QString filename;
std::string last; std::string last;
char dir[512]; char dir[512];
@ -528,9 +537,10 @@ void consoleWin_t::openROMFile(void)
dialog.setDirectory( tr(dir) ); dialog.setDirectory( tr(dir) );
// the gnome default file dialog is not playing nice with QT. // Check config option to use native file dialog or not
// TODO make this a config option to use native file dialog. g_config->getOption ("SDL.UseNativeFileDialog", &useNativeFileDialogVal);
dialog.setOption(QFileDialog::DontUseNativeDialog, true);
dialog.setOption(QFileDialog::DontUseNativeDialog, !useNativeFileDialogVal);
dialog.show(); dialog.show();
ret = dialog.exec(); ret = dialog.exec();
@ -571,7 +581,7 @@ void consoleWin_t::closeROMCB(void)
void consoleWin_t::loadNSF(void) void consoleWin_t::loadNSF(void)
{ {
int ret; int ret, useNativeFileDialogVal;
QString filename; QString filename;
std::string last; std::string last;
char dir[512]; char dir[512];
@ -589,9 +599,10 @@ void consoleWin_t::loadNSF(void)
dialog.setDirectory( tr(dir) ); dialog.setDirectory( tr(dir) );
// the gnome default file dialog is not playing nice with QT. // Check config option to use native file dialog or not
// TODO make this a config option to use native file dialog. g_config->getOption ("SDL.UseNativeFileDialog", &useNativeFileDialogVal);
dialog.setOption(QFileDialog::DontUseNativeDialog, true);
dialog.setOption(QFileDialog::DontUseNativeDialog, !useNativeFileDialogVal);
dialog.show(); dialog.show();
ret = dialog.exec(); ret = dialog.exec();
@ -622,7 +633,7 @@ void consoleWin_t::loadNSF(void)
void consoleWin_t::loadStateFrom(void) void consoleWin_t::loadStateFrom(void)
{ {
int ret; int ret, useNativeFileDialogVal;
QString filename; QString filename;
std::string last; std::string last;
char dir[512]; char dir[512];
@ -640,9 +651,10 @@ void consoleWin_t::loadStateFrom(void)
dialog.setDirectory( tr(dir) ); dialog.setDirectory( tr(dir) );
// the gnome default file dialog is not playing nice with QT. // Check config option to use native file dialog or not
// TODO make this a config option to use native file dialog. g_config->getOption ("SDL.UseNativeFileDialog", &useNativeFileDialogVal);
dialog.setOption(QFileDialog::DontUseNativeDialog, true);
dialog.setOption(QFileDialog::DontUseNativeDialog, !useNativeFileDialogVal);
dialog.show(); dialog.show();
ret = dialog.exec(); ret = dialog.exec();
@ -673,7 +685,7 @@ void consoleWin_t::loadStateFrom(void)
void consoleWin_t::saveStateAs(void) void consoleWin_t::saveStateAs(void)
{ {
int ret; int ret, useNativeFileDialogVal;
QString filename; QString filename;
std::string last; std::string last;
char dir[512]; char dir[512];
@ -691,9 +703,10 @@ void consoleWin_t::saveStateAs(void)
dialog.setDirectory( tr(dir) ); dialog.setDirectory( tr(dir) );
// the gnome default file dialog is not playing nice with QT. // Check config option to use native file dialog or not
// TODO make this a config option to use native file dialog. g_config->getOption ("SDL.UseNativeFileDialog", &useNativeFileDialogVal);
dialog.setOption(QFileDialog::DontUseNativeDialog, true);
dialog.setOption(QFileDialog::DontUseNativeDialog, !useNativeFileDialogVal);
dialog.show(); dialog.show();
ret = dialog.exec(); ret = dialog.exec();
@ -816,7 +829,7 @@ void consoleWin_t::takeScreenShot(void)
void consoleWin_t::loadLua(void) void consoleWin_t::loadLua(void)
{ {
#ifdef _S9XLUA_H #ifdef _S9XLUA_H
int ret; int ret, useNativeFileDialogVal;
QString filename; QString filename;
std::string last; std::string last;
char dir[512]; char dir[512];
@ -839,9 +852,10 @@ void consoleWin_t::loadLua(void)
dialog.setDirectory( tr(dir) ); dialog.setDirectory( tr(dir) );
// the gnome default file dialog is not playing nice with QT. // Check config option to use native file dialog or not
// TODO make this a config option to use native file dialog. g_config->getOption ("SDL.UseNativeFileDialog", &useNativeFileDialogVal);
dialog.setOption(QFileDialog::DontUseNativeDialog, true);
dialog.setOption(QFileDialog::DontUseNativeDialog, !useNativeFileDialogVal);
dialog.show(); dialog.show();
ret = dialog.exec(); ret = dialog.exec();
@ -956,6 +970,22 @@ void consoleWin_t::openPaletteConfWin(void)
//printf("Palette Config Window Destroyed\n"); //printf("Palette Config Window Destroyed\n");
} }
void consoleWin_t::openGuiConfWin(void)
{
GuiConfDialog_t *guiConfWin;
//printf("Open GUI Config Window\n");
guiConfWin = new GuiConfDialog_t(this);
guiConfWin->show();
guiConfWin->exec();
delete guiConfWin;
//printf("GUI Config Window Destroyed\n");
}
void consoleWin_t::toggleAutoResume(void) void consoleWin_t::toggleAutoResume(void)
{ {
//printf("Auto Resume: %i\n", autoResume->isChecked() ); //printf("Auto Resume: %i\n", autoResume->isChecked() );
@ -1024,7 +1054,7 @@ void consoleWin_t::toggleGameGenie(bool checked)
void consoleWin_t::loadGameGenieROM(void) void consoleWin_t::loadGameGenieROM(void)
{ {
int ret; int ret, useNativeFileDialogVal;
QString filename; QString filename;
std::string last; std::string last;
char dir[512]; char dir[512];
@ -1042,9 +1072,10 @@ void consoleWin_t::loadGameGenieROM(void)
dialog.setDirectory( tr(dir) ); dialog.setDirectory( tr(dir) );
// the gnome default file dialog is not playing nice with QT. // Check config option to use native file dialog or not
// TODO make this a config option to use native file dialog. g_config->getOption ("SDL.UseNativeFileDialog", &useNativeFileDialogVal);
dialog.setOption(QFileDialog::DontUseNativeDialog, true);
dialog.setOption(QFileDialog::DontUseNativeDialog, !useNativeFileDialogVal);
dialog.show(); dialog.show();
ret = dialog.exec(); ret = dialog.exec();
@ -1104,7 +1135,7 @@ void consoleWin_t::fdsEjectDisk(void)
void consoleWin_t::fdsLoadBiosFile(void) void consoleWin_t::fdsLoadBiosFile(void)
{ {
int ret; int ret, useNativeFileDialogVal;
QString filename; QString filename;
std::string last; std::string last;
char dir[512]; char dir[512];
@ -1122,9 +1153,10 @@ void consoleWin_t::fdsLoadBiosFile(void)
dialog.setDirectory( tr(dir) ); dialog.setDirectory( tr(dir) );
// the gnome default file dialog is not playing nice with QT. // Check config option to use native file dialog or not
// TODO make this a config option to use native file dialog. g_config->getOption ("SDL.UseNativeFileDialog", &useNativeFileDialogVal);
dialog.setOption(QFileDialog::DontUseNativeDialog, true);
dialog.setOption(QFileDialog::DontUseNativeDialog, !useNativeFileDialogVal);
dialog.show(); dialog.show();
ret = dialog.exec(); ret = dialog.exec();
@ -1168,7 +1200,7 @@ void consoleWin_t::fdsLoadBiosFile(void)
void consoleWin_t::openMovie(void) void consoleWin_t::openMovie(void)
{ {
int ret; int ret, useNativeFileDialogVal;
QString filename; QString filename;
std::string last; std::string last;
char dir[512]; char dir[512];
@ -1186,9 +1218,10 @@ void consoleWin_t::openMovie(void)
dialog.setDirectory( tr(dir) ); dialog.setDirectory( tr(dir) );
// the gnome default file dialog is not playing nice with QT. // Check config option to use native file dialog or not
// TODO make this a config option to use native file dialog. g_config->getOption ("SDL.UseNativeFileDialog", &useNativeFileDialogVal);
dialog.setOption(QFileDialog::DontUseNativeDialog, true);
dialog.setOption(QFileDialog::DontUseNativeDialog, !useNativeFileDialogVal);
dialog.show(); dialog.show();
ret = dialog.exec(); ret = dialog.exec();
@ -1250,7 +1283,7 @@ void consoleWin_t::recordMovie(void)
void consoleWin_t::recordMovieAs(void) void consoleWin_t::recordMovieAs(void)
{ {
int ret; int ret, useNativeFileDialogVal;
QString filename; QString filename;
std::string last; std::string last;
char dir[512]; char dir[512];
@ -1268,9 +1301,10 @@ void consoleWin_t::recordMovieAs(void)
dialog.setDirectory( tr(dir) ); dialog.setDirectory( tr(dir) );
// the gnome default file dialog is not playing nice with QT. // Check config option to use native file dialog or not
// TODO make this a config option to use native file dialog. g_config->getOption ("SDL.UseNativeFileDialog", &useNativeFileDialogVal);
dialog.setOption(QFileDialog::DontUseNativeDialog, true);
dialog.setOption(QFileDialog::DontUseNativeDialog, !useNativeFileDialogVal);
dialog.show(); dialog.show();
ret = dialog.exec(); ret = dialog.exec();

View File

@ -68,6 +68,7 @@ class consoleWin_t : public QMainWindow
QAction *gameVideoConfig; QAction *gameVideoConfig;
QAction *hotkeyConfig; QAction *hotkeyConfig;
QAction *paletteConfig; QAction *paletteConfig;
QAction *guiConfig;
QAction *autoResume; QAction *autoResume;
QAction *fullscreen; QAction *fullscreen;
QAction *aboutAct; QAction *aboutAct;
@ -118,6 +119,7 @@ class consoleWin_t : public QMainWindow
void openGameVideoConfWin(void); void openGameVideoConfWin(void);
void openHotkeyConfWin(void); void openHotkeyConfWin(void);
void openPaletteConfWin(void); void openPaletteConfWin(void);
void openGuiConfWin(void);
void toggleAutoResume(void); void toggleAutoResume(void);
void toggleFullscreen(void); void toggleFullscreen(void);
void updatePeriodic(void); void updatePeriodic(void);

View File

@ -0,0 +1,59 @@
// PaletteConf.cpp
//
#include <QFileDialog>
#include <QTextEdit>
#include "Qt/GuiConf.h"
#include "Qt/main.h"
#include "Qt/input.h"
#include "Qt/config.h"
#include "Qt/keyscan.h"
#include "Qt/fceuWrapper.h"
//----------------------------------------------------
GuiConfDialog_t::GuiConfDialog_t(QWidget *parent)
: QDialog( parent )
{
int useNativeFileDialogVal;
QVBoxLayout *mainLayout;
//resize( 512, 600 );
// sync with config
g_config->getOption ("SDL.UseNativeFileDialog", &useNativeFileDialogVal);
setWindowTitle( tr("GUI Config") );
mainLayout = new QVBoxLayout();
useNativeFileDialog = new QCheckBox( tr("Use Native File Dialog") );
useNativeFileDialog->setChecked( useNativeFileDialogVal );
connect(useNativeFileDialog , SIGNAL(stateChanged(int)), this, SLOT(useNativeFileDialogChanged(int)) );
mainLayout->addWidget( useNativeFileDialog );
setLayout( mainLayout );
}
//----------------------------------------------------
GuiConfDialog_t::~GuiConfDialog_t(void)
{
}
//----------------------------------------------------
void GuiConfDialog_t::closeWindow(void)
{
//printf("Close Window\n");
done(0);
}
//----------------------------------------------------
void GuiConfDialog_t::useNativeFileDialogChanged(int state)
{
int value = (state == Qt::Unchecked) ? 0 : 1;
g_config->setOption ("SDL.UseNativeFileDialog", value);
}
//----------------------------------------------------

37
src/drivers/Qt/GuiConf.h Normal file
View File

@ -0,0 +1,37 @@
// GuiConf.h
//
#pragma once
#include <QWidget>
#include <QDialog>
#include <QVBoxLayout>
#include <QHBoxLayout>
#include <QComboBox>
#include <QCheckBox>
#include <QPushButton>
#include <QLabel>
#include <QFrame>
#include <QGroupBox>
#include <QLineEdit>
#include "Qt/main.h"
class GuiConfDialog_t : public QDialog
{
Q_OBJECT
public:
GuiConfDialog_t(QWidget *parent = 0);
~GuiConfDialog_t(void);
protected:
QCheckBox *useNativeFileDialog;
private:
public slots:
void closeWindow(void);
private slots:
void useNativeFileDialogChanged(int v);
};

View File

@ -292,6 +292,8 @@ InitConfig()
config->addOption("_lastopennsf", "SDL.LastOpenNSF", home_dir); config->addOption("_lastopennsf", "SDL.LastOpenNSF", home_dir);
config->addOption("_lastsavestateas", "SDL.LastSaveStateAs", home_dir); config->addOption("_lastsavestateas", "SDL.LastSaveStateAs", home_dir);
config->addOption("_lastloadlua", "SDL.LastLoadLua", ""); config->addOption("_lastloadlua", "SDL.LastLoadLua", "");
config->addOption("_useNativeFileDialog", "SDL.UseNativeFileDialog", false);
// fcm -> fm2 conversion // fcm -> fm2 conversion
config->addOption("fcmconvert", "SDL.FCMConvert", ""); config->addOption("fcmconvert", "SDL.FCMConvert", "");