X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;ds=sidebyside;f=source%2Fpanel.cpp;h=3123db41bccd2dc6036a7fd89a1facfdea593e06;hb=aba0416fb73e17d068b30ff163c2fedcb0254da2;hp=ac277a98ae1bfaa4b4823fd0ffe83401f2d73eb4;hpb=94ac63c6f41227ce57790d9903039ec18a6ef3fd;p=libs%2Fgltk.git diff --git a/source/panel.cpp b/source/panel.cpp index ac277a9..3123db4 100644 --- a/source/panel.cpp +++ b/source/panel.cpp @@ -48,27 +48,27 @@ void Panel::add(Widget &wdg) void Panel::remove(Widget &wdg) { - ChildSeq::iterator i=find(children.begin(), children.end(), &wdg); - if(i!=children.end()) - { - if(&wdg==pointer_focus) - set_pointer_focus(0, 0); - if(&wdg==input_focus) - set_input_focus(0); + list::iterator i=find(children.begin(), children.end(), &wdg); + if(i==children.end()) + throw InvalidState("That Widget is not in this Panel"); - set_parent(wdg, 0); - children.erase(i); - } + if(&wdg==pointer_focus) + set_pointer_focus(0, 0); + if(&wdg==input_focus) + set_input_focus(0); + + set_parent(wdg, 0); + children.erase(i); } void Panel::raise(Widget &wdg) { - ChildSeq::iterator i=find(children.begin(), children.end(), &wdg); - if(i!=children.end()) - { - children.erase(i); - children.push_back(&wdg); - } + list::iterator i=find(children.begin(), children.end(), &wdg); + if(i==children.end()) + throw InvalidState("That Widget is not in this Panel"); + + children.erase(i); + children.push_back(&wdg); } void Panel::button_press(int x, int y, unsigned btn) @@ -174,11 +174,22 @@ void Panel::ungrab_pointer(Widget &wdg) throw Exception("Someone is trying to steal the pointer!"); } +void Panel::grab_focus(Widget &wdg) +{ + list::iterator i=find(children.begin(), children.end(), &wdg); + if(i==children.end()) + throw InvalidState("That Widget is not in this Panel"); + + set_input_focus(&wdg); + if(parent) + parent->grab_focus(*this); +} + void Panel::render_special(const Part &part) const { if(part.get_name()=="children") { - for(ChildSeq::const_iterator i=children.begin(); i!=children.end(); ++i) + for(list::const_iterator i=children.begin(); i!=children.end(); ++i) if((*i)->is_visible()) (*i)->render(); } @@ -219,7 +230,7 @@ void Panel::set_input_focus(Widget *wdg) Widget *Panel::get_child_at(int x, int y) { - for(ChildSeq::reverse_iterator i=children.rbegin(); i!=children.rend(); ++i) + for(list::reverse_iterator i=children.rbegin(); i!=children.rend(); ++i) if((*i)->is_visible() && (*i)->get_geometry().is_inside(x, y)) return *i;