1
0
mirror of synced 2025-01-25 15:53:43 +01:00

impr: Cleanup frame rate unlocking code

This commit is contained in:
WerWolv 2025-01-04 23:43:10 +01:00
parent 69ee7ef63c
commit 1190511994

View File

@ -828,25 +828,15 @@ namespace hex {
#endif #endif
}); });
glfwSetCursorPosCallback(m_window, [](GLFWwindow *window, double, double) { static const auto unlockFrameRate = [](GLFWwindow *window, auto ...) {
auto win = static_cast<Window *>(glfwGetWindowUserPointer(window)); auto win = static_cast<Window *>(glfwGetWindowUserPointer(window));
win->m_unlockFrameRate = true; win->m_unlockFrameRate = true;
}); };
glfwSetMouseButtonCallback(m_window, [](GLFWwindow *window, int, int, int) { glfwSetCursorPosCallback(m_window, unlockFrameRate);
auto win = static_cast<Window *>(glfwGetWindowUserPointer(window)); glfwSetMouseButtonCallback(m_window, unlockFrameRate);
win->m_unlockFrameRate = true; glfwSetScrollCallback(m_window, unlockFrameRate);
}); glfwSetWindowFocusCallback(m_window, unlockFrameRate);
glfwSetScrollCallback(m_window, [](GLFWwindow *window, double, double) {
auto win = static_cast<Window *>(glfwGetWindowUserPointer(window));
win->m_unlockFrameRate = true;
});
glfwSetWindowFocusCallback(m_window, [](GLFWwindow *window, int) {
auto win = static_cast<Window *>(glfwGetWindowUserPointer(window));
win->m_unlockFrameRate = true;
});
glfwSetWindowFocusCallback(m_window, [](GLFWwindow *, int focused) { glfwSetWindowFocusCallback(m_window, [](GLFWwindow *, int focused) {
EventWindowFocused::post(focused == GLFW_TRUE); EventWindowFocused::post(focused == GLFW_TRUE);
@ -885,8 +875,7 @@ namespace hex {
key != GLFW_KEY_LEFT_SHIFT && key != GLFW_KEY_RIGHT_SHIFT && key != GLFW_KEY_LEFT_SHIFT && key != GLFW_KEY_RIGHT_SHIFT &&
key != GLFW_KEY_LEFT_SUPER && key != GLFW_KEY_RIGHT_SUPER key != GLFW_KEY_LEFT_SUPER && key != GLFW_KEY_RIGHT_SUPER
) { ) {
auto win = static_cast<Window *>(glfwGetWindowUserPointer(window)); unlockFrameRate(window);
win->m_unlockFrameRate = true;
if (!(mods & GLFW_MOD_NUM_LOCK)) { if (!(mods & GLFW_MOD_NUM_LOCK)) {
if (key == GLFW_KEY_KP_0) key = GLFW_KEY_INSERT; if (key == GLFW_KEY_KP_0) key = GLFW_KEY_INSERT;
@ -900,6 +889,7 @@ namespace hex {
else if (key == GLFW_KEY_KP_9) key = GLFW_KEY_PAGE_UP; else if (key == GLFW_KEY_KP_9) key = GLFW_KEY_PAGE_UP;
} }
auto win = static_cast<Window *>(glfwGetWindowUserPointer(window));
win->m_pressedKeys.push_back(key); win->m_pressedKeys.push_back(key);
} }
} }