diff options
Diffstat (limited to 'main/app.cpp')
| -rw-r--r-- | main/app.cpp | 116 |
1 files changed, 1 insertions, 115 deletions
diff --git a/main/app.cpp b/main/app.cpp index 1cbb5b2a..523bb49e 100644 --- a/main/app.cpp +++ b/main/app.cpp @@ -6,10 +6,6 @@ #include <Corrade/Utility/DebugStl.h> #include <Magnum/GL/DefaultFramebuffer.h> #include <Magnum/GL/TextureFormat.h> -#include <Magnum/ImGuiIntegration/Context.h> -#include <Magnum/ImGuiIntegration/Context.hpp> -#include <SDL_events.h> -#include <SDL_video.h> #ifdef FM_MSAA #include <Magnum/GL/RenderbufferFormat.h> @@ -75,8 +71,7 @@ app::app(const Arguments& arguments, app_settings opts): void app::recalc_viewport(Vector2i size) { _shader.set_scale(Vector2(size)); - _imgui.relayout(Vector2{size}, size, size); - + init_imgui(size); _cursor_pixel = std::nullopt; recalc_cursor_tile(); @@ -90,115 +85,6 @@ void app::recalc_viewport(Vector2i size) #endif } -void app::viewportEvent(Platform::Sdl2Application::ViewportEvent& event) -{ - fm_assert(event.framebufferSize() == event.windowSize()); - recalc_viewport(event.windowSize()); -} - -void app::mousePressEvent(Platform::Sdl2Application::MouseEvent& event) -{ - if (_imgui.handleMousePressEvent(event)) - return event.setAccepted(); - else if (_cursor_tile) - { - const auto& tile = *_cursor_tile; - do_mouse_click(tile, (int)event.button()); - } -} - -void app::mouseReleaseEvent(Platform::Sdl2Application::MouseEvent& event) -{ - if (_imgui.handleMouseReleaseEvent(event)) - return event.setAccepted(); - do_mouse_release((int)event.button()); -} - -void app::mouseMoveEvent(Platform::Sdl2Application::MouseMoveEvent& event) -{ - _cursor_in_imgui = _imgui.handleMouseMoveEvent(event); - if (_cursor_in_imgui) - _cursor_pixel = std::nullopt; - else - _cursor_pixel = event.position(); - recalc_cursor_tile(); - if (_cursor_tile) - do_mouse_move(*_cursor_tile); -} - -void app::mouseScrollEvent(Platform::Sdl2Application::MouseScrollEvent& event) -{ - if (_imgui.handleMouseScrollEvent(event)) - return event.setAccepted(); -} - -void app::textInputEvent(Platform::Sdl2Application::TextInputEvent& event) -{ - if (_imgui.handleTextInputEvent(event)) - { - keys = {}; - event.setAccepted(); - } -} - -void app::keyPressEvent(Platform::Sdl2Application::KeyEvent& event) -{ - if (_imgui.handleKeyPressEvent(event)) - { - keys = {}; - return event.setAccepted(); - } - do_key(event.key(), event.modifiers(), true, event.isRepeated()); -} - -void app::keyReleaseEvent(Platform::Sdl2Application::KeyEvent& event) -{ - if (_imgui.handleKeyReleaseEvent(event)) - { - keys = {}; - return event.setAccepted(); - } - do_key(event.key(), event.modifiers(), false, false); -} - -void app::anyEvent(SDL_Event& event) -{ - if (event.type == SDL_WINDOWEVENT) - switch (event.window.event) - { - case SDL_WINDOWEVENT_FOCUS_LOST: - return event_focus_out(); - case SDL_WINDOWEVENT_FOCUS_GAINED: - return event_focus_in(); - case SDL_WINDOWEVENT_LEAVE: - return event_mouse_leave(); - case SDL_WINDOWEVENT_ENTER: - return event_mouse_enter(); - default: - std::fputs("", stdout); break; // put breakpoint here - } -} - -void app::event_focus_out() -{ - _cursor_pixel = std::nullopt; - recalc_cursor_tile(); -} - -void app::event_focus_in() -{ -} - -void app::event_mouse_leave() -{ - _cursor_pixel = std::nullopt; - recalc_cursor_tile(); -} - -void app::event_mouse_enter() -{ -} - } // namespace floormat int main(int argc, char** argv) |
