From 950e8c68ab66fef5818721e3b16738c6d5507833 Mon Sep 17 00:00:00 2001 From: EmaMaker Date: Tue, 3 Oct 2023 18:16:45 +0200 Subject: [PATCH] separate input handling from main --- include/controls.hpp | 16 ++++++++++++++++ include/main.hpp | 1 - src/CMakeLists.txt | 2 +- src/controls.cpp | 41 +++++++++++++++++++++++++++++++++++++++++ 4 files changed, 58 insertions(+), 2 deletions(-) create mode 100644 include/controls.hpp create mode 100644 src/controls.cpp diff --git a/include/controls.hpp b/include/controls.hpp new file mode 100644 index 0000000..7938c0a --- /dev/null +++ b/include/controls.hpp @@ -0,0 +1,16 @@ +#ifndef CONTROLS_H +#define CONTROLS_H + +#include +#include + +#include "worldupdatemessage.h" + +namespace controls{ + void init(); + void update(GLFWwindow* window); + + WorldUpdateMsgQueue& getWorldUpdateQueue(); +}; + +#endif diff --git a/include/main.hpp b/include/main.hpp index 38ff189..35e69e7 100644 --- a/include/main.hpp +++ b/include/main.hpp @@ -3,6 +3,5 @@ void framebuffer_size_callback(GLFWwindow *, int, int); void mouse_callback(GLFWwindow *window, double xpos, double ypos); -void processInput(GLFWwindow *); #endif diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index ea523ca..98126a7 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -1,7 +1,7 @@ cmake_minimum_required(VERSION 3.2) project(OpenGLTest) -set(SOURCE_FILES main.cpp chunk.cpp chunkmanager.cpp chunkmesher.cpp chunkgenerator.cpp +set(SOURCE_FILES main.cpp controls.cpp chunk.cpp chunkmanager.cpp chunkmesher.cpp chunkgenerator.cpp debugwindow.cpp renderer.cpp spacefilling.cpp stb_image.cpp utils.cpp OpenSimplexNoise.cpp) add_executable(OpenGLTest ${SOURCE_FILES}) diff --git a/src/controls.cpp b/src/controls.cpp new file mode 100644 index 0000000..87cb06c --- /dev/null +++ b/src/controls.cpp @@ -0,0 +1,41 @@ +#include "controls.hpp" +#include "renderer.hpp" + +namespace controls{ + WorldUpdateMsgQueue MsgQueue; + float lastBlockPick=0.0; + bool blockpick = false; + bool cursor = false; + + void init(){ + } + + void update(GLFWwindow* window){ + // Reset blockping timeout if 200ms have passed + if(glfwGetTime() - lastBlockPick > 0.1) blockpick = false; + + if(glfwGetMouseButton(window, GLFW_MOUSE_BUTTON_2) == GLFW_PRESS && !blockpick){ + //chunkmanager::blockpick(false); + blockpick=true; + lastBlockPick=glfwGetTime(); + } + + if(glfwGetMouseButton(window, GLFW_MOUSE_BUTTON_1) == GLFW_PRESS && !blockpick){ + //chunkmanager::blockpick(true); + blockpick=true; + lastBlockPick=glfwGetTime(); + } + + // Reset blockpicking if enough time has passed + if(glfwGetMouseButton(window, GLFW_MOUSE_BUTTON_1) == GLFW_RELEASE && glfwGetMouseButton(window, GLFW_MOUSE_BUTTON_2) == GLFW_RELEASE) blockpick = false; + + if(glfwGetKey(window, GLFW_KEY_F2) == GLFW_PRESS) renderer::saveScreenshot(); + if(glfwGetKey(window, GLFW_KEY_F3) == GLFW_PRESS) renderer::saveScreenshot(true); + if(glfwGetKey(window, GLFW_KEY_M) == GLFW_PRESS) { + cursor = !cursor; + glfwSetInputMode(window, GLFW_CURSOR, cursor ? GLFW_CURSOR_NORMAL : GLFW_CURSOR_DISABLED); + } + } + + WorldUpdateMsgQueue& getWorldUpdateQueue(){ return MsgQueue; } +};