X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fwidget.h;h=dfef4ba7128be3b1a3e099addc5b7720a943ad8e;hb=e6a6b3fbd760e487c5df1a6d70ed0700d151710b;hp=bc9b90a69696a8e944af0d88042ad318ab481ec1;hpb=2bdaf4955fdb94e73704adcdcf0adc2b353f0ff0;p=libs%2Fgltk.git diff --git a/source/widget.h b/source/widget.h index bc9b90a..dfef4ba 100644 --- a/source/widget.h +++ b/source/widget.h @@ -1,15 +1,11 @@ -/* $Id$ - -This file is part of libmspgltk -Copyright © 2007-2011 Mikko Rasa, Mikkosoft Productions -Distributed under the LGPL -*/ - #ifndef MSP_GLTK_WIDGET_H_ #define MSP_GLTK_WIDGET_H_ #include +#include +#include #include "geometry.h" +#include "partcache.h" #include "state.h" namespace Msp { @@ -29,14 +25,10 @@ class Widget friend class Container; public: - class Loader: public Msp::DataFile::Loader + class Loader: public DataFile::ObjectLoader { - protected: - Widget &wdg; - public: Loader(Widget &); - Widget &get_object() const { return wdg; } private: void position(int, int); void size(unsigned, unsigned); @@ -44,6 +36,7 @@ public: }; sigc::signal signal_visibility_changed; + sigc::signal signal_autosize_changed; sigc::signal signal_request_focus; sigc::signal signal_grab_pointer; sigc::signal signal_ungrab_pointer; @@ -57,42 +50,52 @@ 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); void set_size(unsigned, unsigned); - virtual void autosize() { } + void autosize(); +protected: + virtual void autosize_special(const Part &, Geometry &) { } +public: void set_geometry(const Geometry &); const Geometry &get_geometry() const { return geom; } + void map_coords_to_ancestor(int &, int &, const Widget &) const; + 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: - /** - Sets the widget style. The final style name is constructed by concatenating - the widget class and the style name with a dash. - */ + Container *get_parent() const { return parent; } + + /** Finds the closest ancestor of a specific type. */ + template + T *find_ancestor() const + { + for(Widget *w=parent; w; w=w->get_parent()) + if(T *tw = dynamic_cast(w)) + return tw; + return 0; + } + + /** 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: @@ -105,9 +108,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 @@ -116,8 +128,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: