diff --git a/src/files/WorldFiles.cpp b/src/files/WorldFiles.cpp index 0ed46ff84..95d822f03 100644 --- a/src/files/WorldFiles.cpp +++ b/src/files/WorldFiles.cpp @@ -454,8 +454,8 @@ void WorldFiles::writePlayer(Player* player){ posarr.put(position.z); json::JArray& rotarr = root.putArray("rotation"); - rotarr.put(player->camX); - rotarr.put(player->camY); + rotarr.put(player->cam.x); + rotarr.put(player->cam.y); root.put("flight", player->flight); root.put("noclip", player->noclip); @@ -479,8 +479,8 @@ bool WorldFiles::readPlayer(Player* player) { player->camera->position = position; json::JArray* rotarr = root->arr("rotation"); - player->camX = rotarr->num(0); - player->camY = rotarr->num(1); + player->cam.x = rotarr->num(0); + player->cam.y = rotarr->num(1); root->flag("flight", player->flight); root->flag("noclip", player->noclip); diff --git a/src/frontend/gui/GUI.cpp b/src/frontend/gui/GUI.cpp index 4f21986b4..30161f245 100644 --- a/src/frontend/gui/GUI.cpp +++ b/src/frontend/gui/GUI.cpp @@ -40,10 +40,8 @@ PagesControl* GUI::getMenu() { } void GUI::actMouse(float delta) { - int mx = Events::x; - int my = Events::y; - auto hover = container->getAt(vec2(mx, my), nullptr); + auto hover = container->getAt(Events::cursor, nullptr); if (this->hover && this->hover != hover) { this->hover->hover(false); } @@ -58,7 +56,7 @@ void GUI::actMouse(float delta) { if (Events::jclicked(0)) { if (pressed == nullptr && this->hover) { pressed = hover; - pressed->click(this, mx, my); + pressed->click(this, Events::cursor.x, Events::cursor.y); if (focus && focus != pressed) { focus->defocus(); } @@ -72,7 +70,7 @@ void GUI::actMouse(float delta) { focus = nullptr; } } else if (pressed) { - pressed->mouseRelease(this, mx, my); + pressed->mouseRelease(this, Events::cursor.x, Events::cursor.y); pressed = nullptr; } } @@ -100,9 +98,7 @@ void GUI::act(float delta) { if (!Events::_cursor_locked) { if (Events::clicked(mousecode::BUTTON_1)) { - int mx = Events::x; - int my = Events::y; - focus->mouseMove(this, mx, my); + focus->mouseMove(this, Events::cursor.x, Events::cursor.y); } if (prevfocus == focus){ for (int i = mousecode::BUTTON_1; i < mousecode::BUTTON_1+12; i++) { diff --git a/src/frontend/hud.cpp b/src/frontend/hud.cpp index 2bc92468b..9e90824d9 100644 --- a/src/frontend/hud.cpp +++ b/src/frontend/hud.cpp @@ -229,8 +229,8 @@ void HudRenderer::drawContentAccess(const GfxContext& ctx, Player* player) { int ys = inv_y + pad_y; vec4 tint = vec4(1.0f); - int mx = Events::x; - int my = Events::y; + int mx = Events::cursor.x; + int my = Events::cursor.y; // background batch->texture(nullptr); diff --git a/src/logic/PlayerController.cpp b/src/logic/PlayerController.cpp index ba243237d..ada57867b 100644 --- a/src/logic/PlayerController.cpp +++ b/src/logic/PlayerController.cpp @@ -41,28 +41,22 @@ void CameraControl::refresh() { } void CameraControl::updateMouse(PlayerInput& input) { - float sensitivity = settings.sensitivity; - float rotX = -Events::deltaX / Window::height * sensitivity; - float rotY = -Events::deltaY / Window::height * sensitivity; + glm::vec2 &cam = player->cam; + if (input.zoom) { + cam += -Events::delta / (float)Window::height * settings.sensitivity / 4.f; + } else { + cam += -Events::delta / (float)Window::height * settings.sensitivity; + } - if (input.zoom){ - rotX /= 4; - rotY /= 4; + if (cam.y < -glm::radians(89.9f)) { + cam.y = -glm::radians(89.9f); } - - float& camX = player->camX; - float& camY = player->camY; - camX += rotX; - camY += rotY; - if (camY < -glm::radians(89.9f)){ - camY = -glm::radians(89.9f); - } - if (camY > glm::radians(89.9f)){ - camY = glm::radians(89.9f); + if (cam.y > glm::radians(89.9f)) { + cam.y = glm::radians(89.9f); } camera->rotation = glm::mat4(1.0f); - camera->rotate(camY, camX, 0); + camera->rotate(cam.y, cam.x, 0); } void CameraControl::update(PlayerInput& input, float delta, Chunks* chunks) { diff --git a/src/objects/Player.h b/src/objects/Player.h index 68e237376..7c90c36b8 100644 --- a/src/objects/Player.h +++ b/src/objects/Player.h @@ -38,8 +38,7 @@ class Player { int chosenBlock; voxel selectedVoxel {0, 0}; - float camX = 0.0f; - float camY = 0.0f; + glm::vec2 cam = {}; Player(glm::vec3 position, float speed); ~Player(); diff --git a/src/window/Events.cpp b/src/window/Events.cpp index b24e8ea0e..1f63f1002 100644 --- a/src/window/Events.cpp +++ b/src/window/Events.cpp @@ -7,21 +7,19 @@ bool Events::_keys[KEYS_BUFFER_SIZE] = {}; uint Events::_frames[KEYS_BUFFER_SIZE] = {}; uint Events::_current = 0; -float Events::deltaX = 0.0f; -float Events::deltaY = 0.0f; -float Events::x = 0.0f; -float Events::y = 0.0f; int Events::scroll = 0; +glm::vec2 Events::delta = {}; +glm::vec2 Events::cursor = {}; +bool Events::cursor_drag = false; bool Events::_cursor_locked = false; -bool Events::_cursor_started = false; std::vector Events::codepoints; std::vector Events::pressedKeys; std::unordered_map Events::bindings; // Returns bool repr. of key state -bool Events::pressed(int keycode){ - if (keycode < 0 || keycode >= KEYS_BUFFER_SIZE){ - // VERY bad behaviour and it happens constantly! (so console-printing is not a good idea) +bool Events::pressed(int keycode) { + if (keycode < 0 || keycode >= KEYS_BUFFER_SIZE) { + fprintf(stderr, "pressed %i\n", keycode); return false; } return _keys[keycode]; @@ -49,8 +47,8 @@ void Events::toggleCursor(){ void Events::pollEvents(){ _current++; - deltaX = 0.0f; - deltaY = 0.0f; + delta.x = 0.f; + delta.y = 0.f; scroll = 0; codepoints.clear(); pressedKeys.clear(); @@ -99,3 +97,22 @@ bool Events::jactive(std::string name) { } return found->second.jactive(); } + +void Events::setKey(int key, bool b) { + Events::_keys[key] = b; + Events::_frames[key] = Events::_current; +} + +void Events::setButton(int button, bool b) { + setKey(_MOUSE_KEYS_OFFSET + button, b); +} + +void Events::setPosition(float xpos, float ypos) { + if (Events::cursor_drag) { + Events::delta.x += xpos - Events::cursor.x; + Events::delta.y += ypos - Events::cursor.y; + } else + Events::cursor_drag = true; + Events::cursor.x = xpos; + Events::cursor.y = ypos; +} diff --git a/src/window/Events.h b/src/window/Events.h index ff813ce6b..247f7cc98 100644 --- a/src/window/Events.h +++ b/src/window/Events.h @@ -10,7 +10,7 @@ typedef unsigned int uint; -const short KEYS_BUFFER_SIZE = 1032; +const short KEYS_BUFFER_SIZE = 1036; const short _MOUSE_KEYS_OFFSET = 1024; class Events { @@ -18,13 +18,11 @@ class Events { static bool _keys[KEYS_BUFFER_SIZE]; static uint _frames[KEYS_BUFFER_SIZE]; static uint _current; - static float deltaX; - static float deltaY; - static float x; - static float y; - static int scroll; + static int scroll; + static glm::vec2 delta; + static glm::vec2 cursor; + static bool cursor_drag; static bool _cursor_locked; - static bool _cursor_started; static std::vector codepoints; static std::vector pressedKeys; static std::unordered_map bindings; @@ -42,6 +40,11 @@ class Events { static void bind(std::string name, inputtype type, int code); static bool active(std::string name); static bool jactive(std::string name); + + static void setKey(int key, bool b); + static void setButton(int button, bool b); + + static void setPosition(float xpos, float ypos); }; #endif /* WINDOW_EVENTS_H_ */ diff --git a/src/window/Window.cpp b/src/window/Window.cpp index 7cb1477e6..92d6cee81 100644 --- a/src/window/Window.cpp +++ b/src/window/Window.cpp @@ -21,42 +21,21 @@ int Window::posX = 0; int Window::posY = 0; void cursor_position_callback(GLFWwindow*, double xpos, double ypos) { - if (Events::_cursor_started) { - Events::deltaX += xpos - Events::x; - Events::deltaY += ypos - Events::y; - } - else { - Events::_cursor_started = true; - } - Events::x = xpos; - Events::y = ypos; + Events::setPosition(xpos, ypos); } void mouse_button_callback(GLFWwindow*, int button, int action, int) { - if (action == GLFW_PRESS) { - // Unsafe assignments! (no checks) - Events::_keys[_MOUSE_KEYS_OFFSET + button] = true; - Events::_frames[_MOUSE_KEYS_OFFSET + button] = Events::_current; - } - else if (action == GLFW_RELEASE) { - // Unsafe assignments! (no checks) - Events::_keys[_MOUSE_KEYS_OFFSET + button] = false; - Events::_frames[_MOUSE_KEYS_OFFSET + button] = Events::_current; - } + Events::setButton(button, action == GLFW_PRESS); } void key_callback(GLFWwindow*, int key, int scancode, int action, int /*mode*/) { if (key == GLFW_KEY_UNKNOWN) return; if (action == GLFW_PRESS) { - // Unsafe assignments! (no checks) - Events::_keys[key] = true; - Events::_frames[key] = Events::_current; + Events::setKey(key, true); Events::pressedKeys.push_back(key); } else if (action == GLFW_RELEASE) { - // Unsafe assignments! (no checks) - Events::_keys[key] = false; - Events::_frames[key] = Events::_current; + Events::setKey(key, false); } else if (action == GLFW_REPEAT) { Events::pressedKeys.push_back(key); @@ -288,8 +267,7 @@ void Window::toggleFullscreen(){ double xPos, yPos; glfwGetCursorPos(window, &xPos, &yPos); - Events::x = xPos; - Events::y = yPos; + Events::setPosition(xPos, yPos); } bool Window::isFullscreen() {