Skip to content

Commit

Permalink
[SettingsMenuState] It's now possible to disable VSync.
Browse files Browse the repository at this point in the history
  • Loading branch information
Unarelith committed Feb 24, 2020
1 parent 7c9b72b commit 7e38907
Show file tree
Hide file tree
Showing 4 changed files with 8 additions and 2 deletions.
1 change: 1 addition & 0 deletions client/include/core/Config.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ namespace Config {
extern bool isAmbientOcclusionEnabled;
extern bool isWireframeModeEnabled;
extern bool isFullscreenModeEnabled;
extern bool isVerticalSyncEnabled;
extern float cameraFOV;
extern u16 screenWidth;
extern u16 screenHeight;
Expand Down
5 changes: 4 additions & 1 deletion client/source/core/ClientApplication.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,7 @@ void ClientApplication::init() {
gk::GamePad::init(m_keyboardHandler);

createWindow(Config::screenWidth, Config::screenHeight, APP_NAME);
m_window.setVerticalSyncEnabled(true);
m_window.setVerticalSyncEnabled(Config::isVerticalSyncEnabled);
m_window.disableView();

initOpenGL();
Expand Down Expand Up @@ -86,6 +86,9 @@ void ClientApplication::handleEvents() {
if (Config::screenWidth != m_window.getSize().x || Config::screenHeight != m_window.getSize().y) {
m_window.resize(Config::screenWidth, Config::screenHeight);
}

if (Config::isVerticalSyncEnabled != m_window.isVerticalSyncEnabled())
m_window.setVerticalSyncEnabled(Config::isVerticalSyncEnabled);
}

void ClientApplication::onEvent(const SDL_Event &event) {
Expand Down
2 changes: 2 additions & 0 deletions client/source/core/Config.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@ bool Config::isSunSmoothLightingEnabled = true;
bool Config::isAmbientOcclusionEnabled = false;
bool Config::isWireframeModeEnabled = false;
bool Config::isFullscreenModeEnabled = false;
bool Config::isVerticalSyncEnabled = true;
float Config::cameraFOV = 70.0f;
u16 Config::screenWidth = 1600;
u16 Config::screenHeight = 1050;
Expand Down Expand Up @@ -68,6 +69,7 @@ void Config::loadConfigFromFile(const char *file) {
isAmbientOcclusionEnabled = lua["isAmbientOcclusionEnabled"].get_or(isAmbientOcclusionEnabled);
isWireframeModeEnabled = lua["isWireframeModeEnabled"].get_or(isWireframeModeEnabled);
isFullscreenModeEnabled = lua["isFullscreenModeEnabled"].get_or(isFullscreenModeEnabled);
isVerticalSyncEnabled = lua["isVerticalSyncEnabled"].get_or(isVerticalSyncEnabled);
cameraFOV = lua["cameraFOV"].get_or(cameraFOV);
screenWidth = lua["screenWidth"].get_or(screenWidth);
screenHeight = lua["screenHeight"].get_or(screenHeight);
Expand Down
2 changes: 1 addition & 1 deletion client/source/states/SettingsMenuState.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -164,7 +164,7 @@ void SettingsMenuState::addGraphicsButtons() {
button.setText("Resolution: " + std::to_string(Config::screenWidth) + "x" + std::to_string(Config::screenHeight));
});

m_menuWidget.addButton("Use VSync: ON", [] (TextButton &) {}).setEnabled(false);
addToggleButton("Use VSync", Config::isVerticalSyncEnabled, false);
}

void SettingsMenuState::addInputButtons() {
Expand Down

0 comments on commit 7e38907

Please sign in to comment.