X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fpanel.h;h=ebe765ddcf5f541c8d661231b1957536999978a8;hb=ae62c05fe97d341c4f219656cdce7aadf321991b;hp=1082447bc58fdddaf77f660d5876e326a5a82616;hpb=75a16eae9eb2714f8112d46fa5b8f7908b6d2487;p=libs%2Fgltk.git diff --git a/source/panel.h b/source/panel.h index 1082447..ebe765d 100644 --- a/source/panel.h +++ b/source/panel.h @@ -1,14 +1,8 @@ -/* $Id$ - -This file is part of libmspgltk -Copyright © 2007-2009 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 { @@ -21,60 +15,69 @@ ignored. class Panel: public Container { public: - class Loader: public Widget::Loader + class Loader: public DataFile::DerivedObjectLoader { - private: - Panel &pnl; - std::map &wdg_map; - public: - Loader(Panel &, std::map &); + typedef std::map WidgetMap; + + 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 ghost(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(); - - void visibility_changed(bool); - void request_focus(); - void grab_pointer(); - void ungrab_pointer(); - void raise(); + private: + typename T::Loader arr_loader; + + public: + ArrangedLoader(Loader &, T &); }; - Widget *pointer_focus; - bool pointer_grabbed; - Widget *input_focus; +protected: + Layout *layout; Panel(const Panel &); Panel &operator=(const Panel &); public: - Panel(const Resources &); - - void raise(Widget &); - Widget *get_input_focus() const { return input_focus; } - Widget *get_final_input_focus() const; - - 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: + Panel(); + virtual ~Panel(); + virtual const char *get_class() const { return "panel"; } - virtual void render_special(const Part &) const; - virtual Child *create_child(Widget *); - void set_pointer_focus(Widget *); - void set_input_focus(Widget *); + void set_layout(Layout *); + Layout *get_layout() { return layout; } + +protected: + virtual void autosize_special(const Part &, Geometry &) const; + virtual void render_special(const Part &, GL::Renderer &) const; + +public: + virtual bool navigate(Navigation); + +protected: + virtual void on_geometry_change(); + virtual void on_child_added(Widget &); + virtual void on_child_removed(Widget &); }; } // namespace GLtk