X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fdropdown.h;h=e7935f702aaeb1d7c6fd1f0879c6b673c1a4aaa2;hb=b59fab7e533ef96d72c92b224d4f24718bc6b0a1;hp=2d3feb3ba236e314c4d767af0106a19575ae163e;hpb=7286d604956ddffcbfa2df6567de866f3d5df3a2;p=libs%2Fgltk.git diff --git a/source/dropdown.h b/source/dropdown.h index 2d3feb3..e7935f7 100644 --- a/source/dropdown.h +++ b/source/dropdown.h @@ -3,6 +3,7 @@ #include #include "list.h" +#include "mspgltk_api.h" #include "text.h" #include "widget.h" @@ -11,22 +12,23 @@ namespace GLtk { class List; -class Dropdown: virtual public Widget, private Container +class MSPGLTK_API Dropdown: virtual public Widget, private Container { public: - class Loader: public DataFile::DerivedObjectLoader + class MSPGLTK_API Loader: public DataFile::DerivedObjectLoader { public: Loader(Dropdown &); + private: void item(const std::string &); }; - sigc::signal signal_item_selected; + sigc::signal signal_item_selected; private: List list; - bool dropped; + bool dropped = false; Text text; public: @@ -36,10 +38,10 @@ private: void init(); public: - virtual const char *get_class() const { return "dropdown"; } + const char *get_class() const override { return "dropdown"; } private: - virtual void autosize_special(const Part &, Geometry &) const; + void autosize_special(const Part &, Geometry &) const override; public: void set_data(ListData &d) { list.set_data(d); } @@ -53,21 +55,21 @@ public: int get_selected_index() const { return list.get_selected_index(); } private: - virtual void rebuild_special(const Part &); - virtual void render_special(const Part &, GL::Renderer &) const; + void rebuild_special(const Part &) override; + void render_special(const Part &, GL::Renderer &) const override; public: - virtual void button_press(int, int, unsigned); - virtual bool navigate(Navigation); + void button_press(int, int, unsigned) override; + bool navigate(Navigation) override; private: - virtual void on_size_change(); - virtual void on_style_change(); + void on_size_change() override; + void on_style_change() override; void open_list(); void close_list(); void list_autosize_changed(); void resize_list(); - void list_item_selected(unsigned); + void list_item_selected(std::size_t); void list_selection_cleared(); };