X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Ftoggle.cpp;h=cde3f24b0fd81254bd643aeeca592a8ac55db787;hb=9f38197854e699a6093a906ab43f4238f3cd2388;hp=b597eb99d32ad73eb02123e2fa83429d7836977f;hpb=707b59d45ae50b69c94918f8f74313283b304597;p=libs%2Fgltk.git diff --git a/source/toggle.cpp b/source/toggle.cpp index b597eb9..cde3f24 100644 --- a/source/toggle.cpp +++ b/source/toggle.cpp @@ -8,12 +8,9 @@ using namespace std; namespace Msp { namespace GLtk { -Toggle::Toggle(const string &t): - text(), - pressed(false), - value(false), - exclusive(false) +Toggle::Toggle(const string &t) { + input_type = INPUT_NAVIGATION; set_text(t); } @@ -27,7 +24,7 @@ void Toggle::set_text(const string &t) { text = t; signal_autosize_changed.emit(); - rebuild(); + mark_rebuild(); } void Toggle::set_exclusive(bool e) @@ -39,9 +36,8 @@ void Toggle::set_exclusive(bool e) void Toggle::exclude_siblings() { - const list &siblings = parent->get_children(); - for(list::const_iterator i=siblings.begin(); i!=siblings.end(); ++i) - if(Toggle *tgl = dynamic_cast(*i)) + for(Widget *w: parent->get_children()) + if(Toggle *tgl = dynamic_cast(w)) if(tgl!=this && tgl->get_exclusive() && tgl->get_value()) tgl->set_value(false); } @@ -87,6 +83,18 @@ void Toggle::button_release(int x, int y, unsigned btn) } } +bool Toggle::navigate(Navigation nav) +{ + if(nav==NAV_ACTIVATE) + { + if(!value || !exclusive) + set_value(!value); + return true; + } + + return false; +} + void Toggle::on_style_change() { text.set_style(style);