]> git.tdb.fi Git - libs/gui.git/blobdiff - source/input/mouse.cpp
Add a type enumeration for devices
[libs/gui.git] / source / input / mouse.cpp
index 37ace5661dafa7915b150b2491d84a77a95b1467..48d0f6922338652763cea0c0b1578ee9d74ff04e 100644 (file)
@@ -1,20 +1,19 @@
-#include <msp/strings/format.h>
+#include <msp/graphics/window.h>
 #include "mouse.h"
 
 namespace Msp {
 namespace Input {
 
-Mouse::Mouse(Graphics::EventSource &s):
-       source(s)
+Mouse::Mouse(Graphics::Window &w):
+       Device(MOUSE),
+       window(w)
 {
        name = "Mouse";
 
        buttons.resize(3);
        axes.resize(2);
 
-       source.signal_button_press.connect(sigc::mem_fun(this, &Mouse::button_press));
-       source.signal_button_release.connect(sigc::mem_fun(this, &Mouse::button_release));
-       source.signal_pointer_motion.connect(sigc::mem_fun(this, &Mouse::pointer_motion));
+       window.signal_input_event.connect(sigc::mem_fun(this, &Mouse::input_event));
 }
 
 std::string Mouse::get_button_name(unsigned btn) const
@@ -32,7 +31,7 @@ std::string Mouse::get_button_name(unsigned btn) const
        case 5:
                return "Wheel Down";
        default:
-               return format("Button %d", btn);
+               return Device::get_button_name(btn);
        }
 }
 
@@ -45,25 +44,9 @@ std::string Mouse::get_axis_name(unsigned axis) const
        case 1:
                return "Y axis";
        default:
-               return format("Axis %d", axis);
+               return Device::get_axis_name(axis);
        };
 }
 
-void Mouse::button_press(int, int, unsigned btn, unsigned)
-{
-       set_button_state(btn, true, true);
-}
-
-void Mouse::button_release(int, int, unsigned btn, unsigned)
-{
-       set_button_state(btn, false, true);
-}
-
-void Mouse::pointer_motion(int x, int y)
-{
-       set_axis_value(0, x*2.0f/source.get_width()-1.0f, true);
-       set_axis_value(1, 1.0f-y*2.0f/source.get_height(), true);
-}
-
 } // namespace Input
 } // namespace Msp