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:
parent
b846ed31db
commit
397e17ba99
|
@ -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
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
||||||
|
}
|
||||||
|
//----------------------------------------------------
|
|
@ -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);
|
||||||
|
|
||||||
|
};
|
|
@ -293,6 +293,8 @@ InitConfig()
|
||||||
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", "");
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue