]> git.tdb.fi Git - libs/gltk.git/blobdiff - source/root.h
Rudimentary touchscreen support
[libs/gltk.git] / source / root.h
index 64829e767899fac2bcf32c8465777f724f68d9f4..5d721c0c2370f5e1ac68d68ef1aee8e987bdbde0 100644 (file)
@@ -2,9 +2,12 @@
 #define MSP_GLTK_ROOT_H_
 
 #include <sigc++/trackable.h>
+#include <msp/gl/camera.h>
+#include <msp/gl/program.h>
 #include <msp/graphics/window.h>
 #include <msp/input/keyboard.h>
 #include <msp/input/mouse.h>
+#include <msp/input/touchscreen.h>
 #include <msp/time/timestamp.h>
 #include "panel.h"
 
@@ -26,12 +29,15 @@ private:
        const Resources &resources;
        Input::Keyboard *keyboard;
        Input::Mouse *mouse;
+       Input::Touchscreen *touchscreen;
        bool own_input;
        Label *lbl_tooltip;
        int pointer_x;
        int pointer_y;
        Time::TimeStamp tooltip_timeout;
        Widget *tooltip_target;
+       Msp::GL::Camera camera;
+       Msp::GL::Program *shprog;
 
 public:
        /** Creates a Root widget for a window.  The geometry is set to match the
@@ -40,7 +46,7 @@ public:
 
        /** Creates a Root widget with custom input devices.  If window is not null,
        it is used to set the widget's initial geometry. */
-       Root(const Resources &, Graphics::Window *, Input::Keyboard *, Input::Mouse *);
+       Root(const Resources &, Graphics::Window *, Input::Keyboard *, Input::Mouse *, Input::Touchscreen * = 0);
 private:
        void init(Graphics::Window *);
 public:
@@ -62,8 +68,16 @@ private:
        bool key_press_event(unsigned);
        bool key_release_event(unsigned);
        bool character_event(StringCodec::unichar);
+       bool touch_press_event(unsigned);
+       bool touch_release_event(unsigned);
+       bool touch_motion_event(unsigned, float, float);
 
        void get_pointer(int &, int &);
+       void get_touch(unsigned, int &, int &);
+       void update_camera();
+
+       virtual void on_geometry_change();
+       virtual void on_child_added(Widget &);
 };
 
 } // namespace GLtk