X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fpanel.h;h=1126e837836e46f5d88590e2cf94df3b14efc174;hb=fdc7fecc65f5f517d66abe3546a949a46836c4a6;hp=54e75ef5309e9e23d62645fadaf5064cafa7fddb;hpb=2f70d404230954f0693a62a021b5d2ad1faed8fa;p=libs%2Fgltk.git diff --git a/source/panel.h b/source/panel.h index 54e75ef..1126e83 100644 --- a/source/panel.h +++ b/source/panel.h @@ -1,10 +1,3 @@ -/* $Id$ - -This file is part of libmspgltk -Copyright © 2007-2011 Mikko Rasa, Mikkosoft Productions -Distributed under the LGPL -*/ - #ifndef MSP_GLTK_PANEL_H_ #define MSP_GLTK_PANEL_H_ @@ -13,6 +6,8 @@ Distributed under the LGPL namespace Msp { namespace GLtk { +class Layout; + /** Panels are containers for other widgets. Panel styles should have a special part "children" to render the child widgets. All properties of this part are @@ -45,12 +40,14 @@ protected: virtual ~Child(); void visibility_changed(bool); + void autosize_changed(); void request_focus(); void grab_pointer(); void ungrab_pointer(); void raise(); }; + Layout *layout; Widget *pointer_focus; bool pointer_grabbed; Widget *input_focus; @@ -59,9 +56,13 @@ protected: Panel &operator=(const Panel &); public: Panel(); + virtual ~Panel(); virtual const char *get_class() const { return "panel"; } + void set_layout(Layout *); + virtual void autosize(); + protected: virtual Child *create_child(Widget *); @@ -71,18 +72,22 @@ public: Widget *get_final_input_focus() const; protected: - virtual void render_special(const Part &) const; + virtual void render_special(const Part &, GL::Renderer &) const; public: virtual void button_press(int, int, unsigned); virtual void button_release(int, int, unsigned); virtual void pointer_motion(int, int); 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_out(); - protected: + virtual void on_geometry_change(); + virtual void on_child_added(Widget &); + virtual void on_child_removed(Widget &); + void set_pointer_focus(Widget *); void set_input_focus(Widget *); };