Remove code duplication in `onChangeScreenSize` (#968)
This commit is contained in:
parent
a7029aebae
commit
d63f7977f8
|
@ -681,13 +681,13 @@ void ScreenHandler::screenSetupLayout(int w, int h)
|
||||||
numScreens = Frontend::GetScreenTransforms(screenMatrix[0], screenKind);
|
numScreens = Frontend::GetScreenTransforms(screenMatrix[0], screenKind);
|
||||||
}
|
}
|
||||||
|
|
||||||
QSize ScreenHandler::screenGetMinSize()
|
QSize ScreenHandler::screenGetMinSize(int factor = 1)
|
||||||
{
|
{
|
||||||
bool isHori = (Config::ScreenRotation == 1 || Config::ScreenRotation == 3);
|
bool isHori = (Config::ScreenRotation == 1 || Config::ScreenRotation == 3);
|
||||||
int gap = Config::ScreenGap;
|
int gap = Config::ScreenGap;
|
||||||
|
|
||||||
int w = 256;
|
int w = 256 * factor;
|
||||||
int h = 192;
|
int h = 192 * factor;
|
||||||
|
|
||||||
if (Config::ScreenLayout == 0) // natural
|
if (Config::ScreenLayout == 0) // natural
|
||||||
{
|
{
|
||||||
|
@ -2272,43 +2272,8 @@ void MainWindow::onChangeSavestateSRAMReloc(bool checked)
|
||||||
void MainWindow::onChangeScreenSize()
|
void MainWindow::onChangeScreenSize()
|
||||||
{
|
{
|
||||||
int factor = ((QAction*)sender())->data().toInt();
|
int factor = ((QAction*)sender())->data().toInt();
|
||||||
|
|
||||||
bool isHori = (Config::ScreenRotation == 1 || Config::ScreenRotation == 3);
|
|
||||||
int gap = Config::ScreenGap;
|
|
||||||
|
|
||||||
int w = 256*factor;
|
|
||||||
int h = 192*factor;
|
|
||||||
|
|
||||||
QSize diff = size() - panel->size();
|
QSize diff = size() - panel->size();
|
||||||
|
resize(dynamic_cast<ScreenHandler*>(panel)->screenGetMinSize(factor) + diff);
|
||||||
if (Config::ScreenLayout == 0) // natural
|
|
||||||
{
|
|
||||||
if (isHori)
|
|
||||||
resize(QSize(h+gap+h, w) + diff);
|
|
||||||
else
|
|
||||||
resize(QSize(w, h+gap+h) + diff);
|
|
||||||
}
|
|
||||||
else if (Config::ScreenLayout == 1) // vertical
|
|
||||||
{
|
|
||||||
if (isHori)
|
|
||||||
resize(QSize(h, w+gap+w) + diff);
|
|
||||||
else
|
|
||||||
resize(QSize(w, h+gap+h) + diff);
|
|
||||||
}
|
|
||||||
else if (Config::ScreenLayout == 2) // horizontal
|
|
||||||
{
|
|
||||||
if (isHori)
|
|
||||||
resize(QSize(h+gap+h, w) + diff);
|
|
||||||
else
|
|
||||||
resize(QSize(w+gap+w, h) + diff);
|
|
||||||
}
|
|
||||||
else // hybrid
|
|
||||||
{
|
|
||||||
if (isHori)
|
|
||||||
return resize(QSize(h+gap+h, 3*w +(4*gap) / 3) + diff);
|
|
||||||
else
|
|
||||||
return resize(QSize(3*w +(4*gap) / 3, h+gap+h) + diff);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::onChangeScreenRotation(QAction* act)
|
void MainWindow::onChangeScreenRotation(QAction* act)
|
||||||
|
|
|
@ -100,12 +100,11 @@ public:
|
||||||
QTimer* setupMouseTimer();
|
QTimer* setupMouseTimer();
|
||||||
void updateMouseTimer();
|
void updateMouseTimer();
|
||||||
QTimer* mouseTimer;
|
QTimer* mouseTimer;
|
||||||
|
QSize screenGetMinSize(int factor);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void screenSetupLayout(int w, int h);
|
void screenSetupLayout(int w, int h);
|
||||||
|
|
||||||
QSize screenGetMinSize();
|
|
||||||
|
|
||||||
void screenOnMousePress(QMouseEvent* event);
|
void screenOnMousePress(QMouseEvent* event);
|
||||||
void screenOnMouseRelease(QMouseEvent* event);
|
void screenOnMouseRelease(QMouseEvent* event);
|
||||||
void screenOnMouseMove(QMouseEvent* event);
|
void screenOnMouseMove(QMouseEvent* event);
|
||||||
|
|
Loading…
Reference in New Issue