aboutsummaryrefslogtreecommitdiff
path: root/src/libui_sdl/DlgVideoSettings.cpp
diff options
context:
space:
mode:
authorArisotura <thetotalworm@gmail.com>2020-05-30 02:40:51 +0200
committerArisotura <thetotalworm@gmail.com>2020-05-30 02:40:51 +0200
commit5eb01f1f15d81fc908b9ed3819213442b8c4bd3e (patch)
tree0566df9ba03eff43361c06981b8730416ff78714 /src/libui_sdl/DlgVideoSettings.cpp
parentf9ac26078b7d88803ea7079490f419b4a0bfe660 (diff)
parente8f4735c7fb4d9fc142a4571e99672ca750be66b (diff)
begin renovating melonDSi
Diffstat (limited to 'src/libui_sdl/DlgVideoSettings.cpp')
-rw-r--r--src/libui_sdl/DlgVideoSettings.cpp32
1 files changed, 31 insertions, 1 deletions
diff --git a/src/libui_sdl/DlgVideoSettings.cpp b/src/libui_sdl/DlgVideoSettings.cpp
index 7d876e2..ff88ba8 100644
--- a/src/libui_sdl/DlgVideoSettings.cpp
+++ b/src/libui_sdl/DlgVideoSettings.cpp
@@ -39,12 +39,14 @@ uiWindow* win;
uiRadioButtons* rbRenderer;
uiCheckbox* cbGLDisplay;
+uiCheckbox* cbVSync;
uiCheckbox* cbThreaded3D;
uiCombobox* cbResolution;
uiCheckbox* cbAntialias;
int old_renderer;
int old_gldisplay;
+int old_vsync;
int old_threaded3D;
int old_resolution;
int old_antialias;
@@ -89,6 +91,11 @@ void RevertSettings()
{
Config::ScreenUseGL = old_gldisplay;
}
+ if (old_vsync != Config::ScreenVSync)
+ {
+ Config::ScreenVSync = old_vsync;
+ //ApplyNewSettings(4);
+ }
if (old_usegl != new_usegl)
{
apply2 = true;
@@ -130,21 +137,33 @@ void OnRendererChanged(uiRadioButtons* rb, void* blarg)
UpdateControls();
bool new_usegl = (Config::ScreenUseGL != 0) || (Config::_3DRenderer != 0);
+
+ if (new_usegl) uiControlEnable(uiControl(cbVSync));
+ else uiControlDisable(uiControl(cbVSync));
+
if (new_usegl != old_usegl)
ApplyNewSettings(2);
else
ApplyNewSettings(3);
-
+
uiControlSetFocus(uiControl(win));
}
void OnGLDisplayChanged(uiCheckbox* cb, void* blarg)
{
Config::ScreenUseGL = uiCheckboxChecked(cb);
+ if (Config::ScreenUseGL) uiControlEnable(uiControl(cbVSync));
+ else uiControlDisable(uiControl(cbVSync));
ApplyNewSettings(2);
uiControlSetFocus(uiControl(win));
}
+void OnVSyncChanged(uiCheckbox* cb, void* blarg)
+{
+ Config::ScreenVSync = uiCheckboxChecked(cb);
+ //ApplyNewSettings(4);
+}
+
void OnThreaded3DChanged(uiCheckbox* cb, void* blarg)
{
Config::Threaded3D = uiCheckboxChecked(cb);
@@ -232,6 +251,10 @@ void Open()
cbGLDisplay = uiNewCheckbox("OpenGL display");
uiCheckboxOnToggled(cbGLDisplay, OnGLDisplayChanged, NULL);
uiBoxAppend(in_ctrl, uiControl(cbGLDisplay), 0);
+
+ cbVSync = uiNewCheckbox("VSync");
+ uiCheckboxOnToggled(cbVSync, OnVSyncChanged, NULL);
+ uiBoxAppend(in_ctrl, uiControl(cbVSync), 0);
}
{
@@ -300,17 +323,24 @@ void Open()
old_renderer = Config::_3DRenderer;
old_gldisplay = Config::ScreenUseGL;
+ old_vsync = Config::ScreenVSync;
old_threaded3D = Config::Threaded3D;
old_resolution = Config::GL_ScaleFactor;
old_antialias = Config::GL_Antialias;
uiCheckboxSetChecked(cbGLDisplay, Config::ScreenUseGL);
+ uiCheckboxSetChecked(cbVSync, Config::ScreenVSync);
uiCheckboxSetChecked(cbThreaded3D, Config::Threaded3D);
uiComboboxSetSelected(cbResolution, Config::GL_ScaleFactor-1);
//uiCheckboxSetChecked(cbAntialias, Config::GL_Antialias);
uiRadioButtonsSetSelected(rbRenderer, Config::_3DRenderer);
UpdateControls();
+ if (Config::ScreenUseGL || Config::_3DRenderer != 0)
+ uiControlEnable(uiControl(cbVSync));
+ else
+ uiControlDisable(uiControl(cbVSync));
+
uiControlShow(uiControl(win));
}