#include "../api/Button.h" #include "../facade/SDLContext.h" #include "../manager/ComponentManager.h" #include "../manager/EventManager.h" #include "util/Log.h" #include "InputSystem.h" using namespace crepe; void InputSystem::update() { ComponentManager & mgr = this->mediator.component_manager; SDLContext & context = this->mediator.sdl_context; std::vector event_list = context.get_events(); const RefVector cameras = mgr.get_components_by_type(); OptionalRef curr_cam_ref; // Find the active camera for (Camera & cam : cameras) { if (!cam.active) continue; curr_cam_ref = cam; break; } if (!curr_cam_ref) return; Camera & current_cam = curr_cam_ref; const Transform & cam_transform = mgr.get_components_by_id(current_cam.game_object_id).front(); vec2 camera_origin = cam_transform.position + current_cam.data.postion_offset - (current_cam.viewport_size / 2); for (const EventData & event : event_list) { // Only calculate mouse coordinates for relevant events if (event.event_type == EventType::MOUSE_DOWN || event.event_type == EventType::MOUSE_UP || event.event_type == EventType::MOUSE_MOVE || event.event_type == EventType::MOUSE_WHEEL) { this->handle_mouse_event(event, camera_origin, current_cam); } else { this->handle_non_mouse_event(event); } } } void InputSystem::handle_mouse_event(const EventData & event, const vec2 & camera_origin, const Camera & current_cam) { EventManager & event_mgr = this->mediator.event_manager; vec2 adjusted_mouse; adjusted_mouse.x = event.data.mouse_data.mouse_position.x + camera_origin.x; adjusted_mouse.y = event.data.mouse_data.mouse_position.y + camera_origin.y; // Check if the mouse is within the viewport if ((adjusted_mouse.x < camera_origin.x || adjusted_mouse.x > camera_origin.x + current_cam.viewport_size.x || adjusted_mouse.y < camera_origin.y || adjusted_mouse.y > camera_origin.y + current_cam.viewport_size.y)) return; // Handle mouse-specific events switch (event.event_type) { case EventType::MOUSE_DOWN: event_mgr.queue_event({ .mouse_pos = adjusted_mouse, .button = event.data.mouse_data.mouse_button, }); this->last_mouse_down_position = adjusted_mouse; this->last_mouse_button = event.data.mouse_data.mouse_button; break; case EventType::MOUSE_UP: { event_mgr.queue_event({ .mouse_pos = adjusted_mouse, .button = event.data.mouse_data.mouse_button, }); vec2 delta_move = adjusted_mouse - this->last_mouse_down_position; int click_tolerance = Config::get_instance().input.click_tolerance; if (this->last_mouse_button == event.data.mouse_data.mouse_button && std::abs(delta_move.x) <= click_tolerance && std::abs(delta_move.y) <= click_tolerance) { event_mgr.queue_event({ .mouse_pos = adjusted_mouse, .button = event.data.mouse_data.mouse_button, }); this->handle_click(event.data.mouse_data.mouse_button, adjusted_mouse, current_cam); } break; } case EventType::MOUSE_MOVE: event_mgr.queue_event({ .mouse_pos = adjusted_mouse, .mouse_delta = event.data.mouse_data.rel_mouse_move, }); this->handle_move(event, adjusted_mouse, current_cam); break; case EventType::MOUSE_WHEEL: event_mgr.queue_event({ .mouse_pos = adjusted_mouse, .scroll_direction = event.data.mouse_data.scroll_direction, .scroll_delta = event.data.mouse_data.scroll_delta, }); break; default: break; } } void InputSystem::handle_non_mouse_event(const EventData & event) { EventManager & event_mgr = this->mediator.event_manager; switch (event.event_type) { case EventType::KEY_DOWN: event_mgr.queue_event( {.repeat = event.data.key_data.key_repeat, .key = event.data.key_data.key}); break; case EventType::KEY_UP: event_mgr.queue_event({.key = event.data.key_data.key}); break; case EventType::SHUTDOWN: event_mgr.queue_event({}); break; case EventType::WINDOW_EXPOSE: event_mgr.queue_event({}); break; case EventType::WINDOW_RESIZE: event_mgr.queue_event( WindowResizeEvent{.dimensions = event.data.window_data.resize_dimension}); break; case EventType::WINDOW_MOVE: event_mgr.queue_event( {.delta_move = event.data.window_data.move_delta}); break; case EventType::WINDOW_MINIMIZE: event_mgr.queue_event({}); break; case EventType::WINDOW_MAXIMIZE: event_mgr.queue_event({}); break; case EventType::WINDOW_FOCUS_GAIN: event_mgr.queue_event({}); break; case EventType::WINDOW_FOCUS_LOST: event_mgr.queue_event({}); break; default: break; } } void InputSystem::handle_move(const EventData & event_data, const vec2 & mouse_pos, const Camera & current_cam) { ComponentManager & mgr = this->mediator.component_manager; EventManager & event_mgr = this->mediator.event_manager; const RefVector