X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;ds=sidebyside;f=source%2Fwidget.h;h=eb8fa2324350b42335eb92a0bd8aec7fc70e2f7b;hb=78e05360d70542d343401241ff9ddddfed18c5cd;hp=557e10153269c2290bc8c6c4e938fc95c8284874;hpb=79af58bcfa941e0f2c33b172c9e924522ebcdfea;p=libs%2Fgltk.git diff --git a/source/widget.h b/source/widget.h index 557e101..eb8fa23 100644 --- a/source/widget.h +++ b/source/widget.h @@ -5,6 +5,7 @@ #include #include #include "geometry.h" +#include "inputmethod.h" #include "partcache.h" #include "state.h" @@ -46,7 +47,7 @@ protected: const Style *style; State state; bool visible; - bool focusable; + InputType input_type; Container *parent; std::string tooltip; PartCache part_cache; @@ -107,12 +108,15 @@ public: void set_visible(bool); bool is_visible() const { return visible; } - void set_focusable(bool); - bool is_focusable() const { return focusable; } + InputType get_input_type() const { return input_type; } + bool is_focusable() const { return visible && input_type!=INPUT_NONE; } void set_focus(); void set_enabled(bool); bool is_enabled() const { return !(state&DISABLED); } + // Deprecated + void set_focusable(bool); + protected: void set_state(State s) { set_state(s, s); } void clear_state(State s) { set_state(s, NORMAL); } @@ -136,14 +140,15 @@ public: virtual void pointer_motion(int, int) { } virtual void pointer_enter(); virtual void pointer_leave(); - virtual void key_press(unsigned, unsigned) { } - virtual void key_release(unsigned, unsigned) { } - virtual void character(wchar_t) { } virtual void touch_press(int, int, unsigned); virtual void touch_release(int, int, unsigned); virtual void touch_motion(int, int, unsigned); + virtual bool key_press(unsigned, unsigned) { return false; } + virtual bool key_release(unsigned, unsigned) { return false; } + virtual bool character(wchar_t) { return false; } virtual void focus_in(); virtual void focus_out(); + virtual bool navigate(Navigation) { return false; } protected: virtual void on_geometry_change() { } virtual void on_style_change() { }