diff options
author | Alexander Sulfrian <alexander@sulfrian.net> | 2013-01-18 19:47:19 +0100 |
---|---|---|
committer | Alexander Sulfrian <alexander@sulfrian.net> | 2013-01-18 19:47:19 +0100 |
commit | 3de540a8a0c8cd9eca18472b9fe1114e5970ba4d (patch) | |
tree | 6e118ab0e584dfa3f3537c61dcd64b2bfdc601fc /src/menu/mouse_manager.cpp | |
parent | 89675abffb213298fb7fb9a490063a68f86aabf5 (diff) | |
download | usdx-3de540a8a0c8cd9eca18472b9fe1114e5970ba4d.tar.gz usdx-3de540a8a0c8cd9eca18472b9fe1114e5970ba4d.tar.xz usdx-3de540a8a0c8cd9eca18472b9fe1114e5970ba4d.zip |
menu: add mouse manager for handling mouse focus and clicks
Diffstat (limited to 'src/menu/mouse_manager.cpp')
-rw-r--r-- | src/menu/mouse_manager.cpp | 137 |
1 files changed, 137 insertions, 0 deletions
diff --git a/src/menu/mouse_manager.cpp b/src/menu/mouse_manager.cpp new file mode 100644 index 00000000..0910da6f --- /dev/null +++ b/src/menu/mouse_manager.cpp @@ -0,0 +1,137 @@ +/* + * UltraStar Deluxe - Karaoke Game + * + * UltraStar Deluxe is the legal property of its developers, whose names + * are too numerous to list here. Please refer to the COPYRIGHT + * file distributed with this source distribution. + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; see the file COPYING. If not, write to + * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, + * Boston, MA 02110-1301, USA. + * + */ + +#include "mouse_manager.hpp" +#include "utils/rectangle.hpp" +#include "container.hpp" +#include "application.hpp" + +namespace usdx +{ + log4cpp::Category& MouseManager::log = + log4cpp::Category::getInstance("usdx.menu.mouse_manager"); + + MouseManager::MouseManager(EventManager& event_manager) + : last_active(NULL) + { + mouse_move_connection = event_manager.mouse_move.connect( + boost::bind(&MouseManager::on_mouse_move, this, _1)); + mouse_down_connection = event_manager.mouse_down.connect( + boost::bind(&MouseManager::on_mouse_down, this, _1, _2)); + mouse_up_connection = event_manager.mouse_up.connect( + boost::bind(&MouseManager::on_mouse_up, this, _1, _2)); + } + + MouseManager::~MouseManager() + { + mouse_move_connection.disconnect(); + mouse_down_connection.disconnect(); + mouse_up_connection.disconnect(); + } + + void MouseManager::find_active_element(const Point<int>& p) + { + DrawableControl *c = find_parent(last_active, p); + c = c->get_component_at(p); + + if (last_active != c) { + if (last_active) { + last_active->mouse_leave(); + } + + last_active = c; + + if (last_active) { + last_active->mouse_enter(); + } + } + } + + DrawableControl* MouseManager::find_parent(DrawableControl* current, + const Point<int>& p) const + { + if (current == NULL) { + // start search from top level + return Application::get_instance(); + } + + if (!current->get_absolut_rect().is_in(p)) { + current = find_parent(current->get_parent(), p); + } + + return current; + } + + void MouseManager::on_mouse_move(const Point<int>& p) + { + find_active_element(p); + + if (last_active) { + last_active->mouse_move(p); + } + } + + void MouseManager::on_mouse_down(uint8_t button, const Point<int>& p) + { + find_active_element(p); + + if (last_active) { + last_active->mouse_down(button, p); + } + + event.add_event(last_active, button, MouseEvent::DOWN); + } + + void MouseManager::on_mouse_up(uint8_t button, const Point<int>& p) + { + find_active_element(p); + + if (last_active) { + last_active->mouse_up(button, p); + } + + MouseEvent::Event e = event.add_event(last_active, button, + MouseEvent::UP); + + switch (e) { + case MouseEvent::CLICK: + last_active->mouse_click(button, p); + break; + + case MouseEvent::DBL_CLICK: + last_active->mouse_dbl_click(button, p); + break; + + default: + ; + } + } + + void MouseManager::deactivate_control(const DrawableControl* control) + { + if (last_active == control) { + last_active = NULL; + } + } +}; |