]> git.tdb.fi Git - libs/gltk.git/blobdiff - source/root.h
Use a shader for rendering if available
[libs/gltk.git] / source / root.h
index 50445fecea3fd8a0bcc206de73561a1c229e05ef..8e1bed9247e00bd2693bd9fe904ab16995591c9a 100644 (file)
@@ -1,15 +1,12 @@
-/* $Id$
-
-This file is part of libmspgltk
-Copyright © 2007, 2009  Mikko Rasa, Mikkosoft Productions
-Distributed under the LGPL
-*/
-
 #ifndef MSP_GLTK_ROOT_H_
 #define MSP_GLTK_ROOT_H_
 
 #include <sigc++/trackable.h>
-#include <msp/gbase/window.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/time/timestamp.h>
 #include "panel.h"
 
@@ -19,10 +16,8 @@ namespace GLtk {
 class Label;
 
 /**
-A Root is a special type of Panel that covers and entire Window and accepts
-input from it.  When created, a Root widget will take its size from the window
-it is created for.  The size can be changed, but a Root should always be
-rendered to fill the window in order to get coordinates mapped correctly.
+A Root is a special type of Panel that covers the entire viewport and receives
+input from keyboard and mouse.
 */
 class Root: public Panel, public sigc::trackable
 {
@@ -30,24 +25,53 @@ public:
        sigc::signal<std::string, int, int> signal_tooltip;
 
 private:
-       Graphics::Window &window;
+       const Resources &resources;
+       Input::Keyboard *keyboard;
+       Input::Mouse *mouse;
+       bool own_input;
        Label *lbl_tooltip;
        int pointer_x;
        int pointer_y;
-       Msp::Time::TimeStamp tooltip_timeout;
+       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
+       window's size, and input devices are created automatically. */
        Root(const Resources &, Graphics::Window &);
-       void tick();
+
+       /** 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 *);
 private:
+       void init(Graphics::Window *);
+public:
+       virtual ~Root();
+
        virtual const char *get_class() const { return "root"; }
-       void button_press_event(int, int, unsigned, unsigned);
-       void button_release_event(int, int, unsigned, unsigned);
-       void pointer_motion_event(int, int);
-       void key_press_event(unsigned, unsigned, wchar_t);
-       void key_release_event(unsigned, unsigned);
-       void translate_coords(int &, int &);
+
+       const Resources &get_resources() const { return resources; }
+       virtual unsigned get_width() const { return geom.w; }
+       virtual unsigned get_height() const { return geom.h; }
+
+       void tick();
+       void render() const;
+
+private:
+       bool button_press_event(unsigned);
+       bool button_release_event(unsigned);
+       bool axis_motion_event(unsigned, float, float);
+       bool key_press_event(unsigned);
+       bool key_release_event(unsigned);
+       bool character_event(StringCodec::unichar);
+
+       void get_pointer(int &, int &);
+       void update_camera();
+
+       virtual void on_geometry_change();
+       virtual void on_child_added(Widget &);
 };
 
 } // namespace GLtk