summaryrefslogtreecommitdiffhomepage
path: root/main/app.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'main/app.cpp')
-rw-r--r--main/app.cpp116
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)