rework window size/maximized save/restore

This commit is contained in:
Arisotura 2024-05-25 12:57:37 +02:00
parent 7b709e6847
commit 2451f3fed8
4 changed files with 18 additions and 56 deletions

View File

@ -37,10 +37,6 @@ namespace Config
{ {
using namespace melonDS; using namespace melonDS;
int WindowWidth;
int WindowHeight;
bool WindowMaximized;
int ScreenRotation; int ScreenRotation;
int ScreenGap; int ScreenGap;
int ScreenLayout; int ScreenLayout;
@ -206,10 +202,6 @@ LegacyEntry LegacyFile[] =
{"JoystickID", 0, "JoystickID", true}, {"JoystickID", 0, "JoystickID", true},
{"WindowWidth", 0, "Window0.Width", true},
{"WindowHeight", 0, "Window0.Height", true},
{"WindowMax", 1, "Window0.Maximized", true},
{"ScreenRotation", 0, "Window0.ScreenRotation", true}, {"ScreenRotation", 0, "Window0.ScreenRotation", true},
{"ScreenGap", 0, "Window0.ScreenGap", true}, {"ScreenGap", 0, "Window0.ScreenGap", true},
{"ScreenLayout", 0, "Window0.ScreenLayout", true}, {"ScreenLayout", 0, "Window0.ScreenLayout", true},

View File

@ -151,10 +151,6 @@ private:
}; };
extern int WindowWidth;
extern int WindowHeight;
extern bool WindowMaximized;
extern int ScreenRotation; extern int ScreenRotation;
extern int ScreenGap; extern int ScreenGap;
extern int ScreenLayout; extern int ScreenLayout;

View File

@ -227,10 +227,6 @@ MainWindow::MainWindow(int id, EmuInstance* inst, QWidget* parent) :
} }
#endif #endif
oldW = Config::WindowWidth;
oldH = Config::WindowHeight;
oldMax = Config::WindowMaximized;
showOSD = windowCfg.GetBool("ShowOSD"); showOSD = windowCfg.GetBool("ShowOSD");
setWindowTitle("melonDS " MELONDS_VERSION); setWindowTitle("melonDS " MELONDS_VERSION);
@ -598,7 +594,7 @@ MainWindow::MainWindow(int id, EmuInstance* inst, QWidget* parent) :
} }
setMenuBar(menubar); setMenuBar(menubar);
resize(Config::WindowWidth, Config::WindowHeight); //resize(curW, curH);
if (localCfg.GetString("Firmware.Username") == "Arisotura") if (localCfg.GetString("Firmware.Username") == "Arisotura")
actMPNewInstance->setText("Fart"); actMPNewInstance->setText("Fart");
@ -610,10 +606,19 @@ MainWindow::MainWindow(int id, EmuInstance* inst, QWidget* parent) :
move(frameGeo.topLeft()); move(frameGeo.topLeft());
#endif #endif
if (oldMax) /*if (oldMax)
showMaximized(); showMaximized();
else else
show(); show();*/
std::string geom = windowCfg.GetString("Geometry");
if (!geom.empty())
{
QByteArray raw = QByteArray::fromStdString(geom);
QByteArray dec = QByteArray::fromBase64(raw, QByteArray::Base64Encoding | QByteArray::AbortOnBase64DecodingErrors);
if (!dec.isEmpty())
restoreGeometry(dec);
}
show();
createScreenPanel(); createScreenPanel();
@ -720,6 +725,12 @@ void MainWindow::osdAddMessage(unsigned int color, const char* msg)
void MainWindow::closeEvent(QCloseEvent* event) void MainWindow::closeEvent(QCloseEvent* event)
{ {
QByteArray geom = saveGeometry();
QByteArray enc = geom.toBase64(QByteArray::Base64Encoding);
windowCfg.SetString("Geometry", enc.toStdString());
Config::Save();
if (hasOGL) if (hasOGL)
{ {
// we intentionally don't unpause here // we intentionally don't unpause here
@ -808,37 +819,6 @@ void MainWindow::drawScreenGL()
return glpanel->drawScreenGL(); return glpanel->drawScreenGL();
} }
void MainWindow::resizeEvent(QResizeEvent* event)
{
int w = event->size().width();
int h = event->size().height();
if (!isFullScreen())
{
// this is ugly
// thing is, when maximizing the window, we first receive the resizeEvent
// with a new size matching the screen, then the changeEvent telling us that
// the maximized flag was updated
oldW = Config::WindowWidth;
oldH = Config::WindowHeight;
oldMax = isMaximized();
Config::WindowWidth = w;
Config::WindowHeight = h;
}
}
void MainWindow::changeEvent(QEvent* event)
{
if (isMaximized() && !oldMax)
{
Config::WindowWidth = oldW;
Config::WindowHeight = oldH;
}
Config::WindowMaximized = isMaximized() ? 1:0;
}
void MainWindow::keyPressEvent(QKeyEvent* event) void MainWindow::keyPressEvent(QKeyEvent* event)
{ {
if (event->isAutoRepeat()) return; if (event->isAutoRepeat()) return;

View File

@ -127,9 +127,6 @@ public:
void osdAddMessage(unsigned int color, const char* msg); void osdAddMessage(unsigned int color, const char* msg);
protected: protected:
void resizeEvent(QResizeEvent* event) override;
void changeEvent(QEvent* event) override;
void keyPressEvent(QKeyEvent* event) override; void keyPressEvent(QKeyEvent* event) override;
void keyReleaseEvent(QKeyEvent* event) override; void keyReleaseEvent(QKeyEvent* event) override;
@ -241,9 +238,6 @@ private:
bool pauseOnLostFocus; bool pauseOnLostFocus;
bool pausedManually; bool pausedManually;
int oldW, oldH;
bool oldMax;
int test_num; int test_num;
int windowID; int windowID;