]> git.tdb.fi Git - libs/gltk.git/blobdiff - source/widget.h
Improve widget part caching
[libs/gltk.git] / source / widget.h
index 51728c35e0424bb63a5564e7108366ff55ee725c..50e3279e3b5c3d753373246d88d13f7e3a0800e0 100644 (file)
@@ -3,7 +3,9 @@
 
 #include <string>
 #include <msp/datafile/objectloader.h>
+#include <msp/gl/renderer.h>
 #include "geometry.h"
+#include "partcache.h"
 #include "state.h"
 
 namespace Msp {
@@ -48,14 +50,13 @@ protected:
        bool focusable;
        Container *parent;
        std::string tooltip;
+       PartCache part_cache;
 
        Widget();
 public:
        virtual ~Widget();
 
-       /**
-       Returns the name of the widget class.  Used for style lookup.
-       */
+       /// Returns the name of the widget class.  Used for style lookup.
        virtual const char *get_class() const { return "widget"; }
 
        void set_position(int, int);
@@ -65,26 +66,21 @@ public:
        const Geometry &get_geometry() const { return geom; }
 
 protected:
-       /**
-       Sets the widget's parent Container.  The widget must be unparented when
-       calling this function with a non-null parameter.
-       */
+       /** Sets the widget's parent Container.  The widget must be unparented when
+       calling this function with a non-null parameter. */
        void set_parent(Container *);
 public:
        Container *get_parent() const { return parent; }
 
-       /**
-       Sets the widget style.  The final style name is constructed by concatenating
-       the widget class and the style name with a dash.
-       */
+       /** Sets the widget style.  The name of the resource to be looked up is
+       constructed by concatenating the widget class and the style name with a
+       dash. */
        void set_style(const std::string &);
        const Style &get_style() const { return *style; }
 
 protected:
-       /**
-       Gets a style object from the resource collection based on the class and
-       style names of the widget.
-       */
+       /** Gets a style object from the resource collection based on the class and
+       style names of the widget. */
        void update_style();
 
 public:
@@ -97,9 +93,18 @@ public:
        bool is_focusable() const { return focusable; }
        void set_focus();
 
-       void render() const;
 protected:
-       virtual void render_special(const Part &) const { }
+       void set_state(State s) { set_state(s, s); }
+       void clear_state(State s) { set_state(s, NORMAL); }
+       void set_state(State, State);
+
+       void rebuild();
+       virtual void rebuild_special(const Part &);
+
+public:
+       void render(GL::Renderer &) const;
+protected:
+       virtual void render_special(const Part &, GL::Renderer &) const { }
 
 public:
        // Events
@@ -108,8 +113,9 @@ public:
        virtual void pointer_motion(int, int) { }
        virtual void pointer_enter();
        virtual void pointer_leave();
-       virtual void key_press(unsigned, unsigned, wchar_t) { }
+       virtual void key_press(unsigned, unsigned) { }
        virtual void key_release(unsigned, unsigned) { }
+       virtual void character(wchar_t) { }
        virtual void focus_in();
        virtual void focus_out();
 protected: