X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fpanel.h;h=79e8bd455a3b36cbd76f9f113641cb81baa79731;hb=8eeb6ee5d40c21150839e24996cc3e9ef308374d;hp=a5483c452c57f7b0d639511878fb8a8ef2f4b8d6;hpb=01eaaef90f4c56cd4669d2f621e3061a938753eb;p=libs%2Fgltk.git diff --git a/source/panel.h b/source/panel.h index a5483c4..79e8bd4 100644 --- a/source/panel.h +++ b/source/panel.h @@ -1,20 +1,12 @@ -/* $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_ #include "container.h" +#include "layout.h" 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 @@ -23,41 +15,45 @@ ignored. class Panel: public Container { public: - class Loader: public Widget::Loader + class Loader: public DataFile::DerivedObjectLoader { public: typedef std::map WidgetMap; - private: - Panel &pnl; + protected: WidgetMap &wdg_map; + Widget *last_widget; public: Loader(Panel &, WidgetMap &); private: + Layout &get_layout(); + Widget &get_last_widget(); + template + void arrangement(); template void child(const std::string &); + void constraint(Layout::ConstraintType, const std::string &); + void expand(bool, bool); + void gravity(int, int); + void grid(unsigned); + void layout(); void panel(const std::string &); }; -protected: - struct Child: public Container::Child +private: + template + class ArrangedLoader: public DataFile::Loader { - Child(Panel &, Widget *); - virtual ~Child(); + private: + typename T::Loader arr_loader; - void visibility_changed(bool); - void autosize_changed(); - void request_focus(); - void grab_pointer(); - void ungrab_pointer(); - void raise(); + public: + ArrangedLoader(Loader &, T &); }; +protected: Layout *layout; - Widget *pointer_focus; - bool pointer_grabbed; - Widget *input_focus; Panel(const Panel &); Panel &operator=(const Panel &); @@ -68,32 +64,14 @@ public: virtual const char *get_class() const { return "panel"; } void set_layout(Layout *); + virtual void autosize(); protected: - virtual Child *create_child(Widget *); - -public: - void raise(Widget &); - Widget *get_input_focus() const { return input_focus; } - 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_release(unsigned, unsigned); - 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 *); }; } // namespace GLtk