X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fpanel.cpp;h=a708873edbeb4a7df6e2a2a1b097dfb057df6ced;hb=08aedc8b2a1fa5e47a79b212526138ae6244e61f;hp=ac277a98ae1bfaa4b4823fd0ffe83401f2d73eb4;hpb=3fb1cc7fe7ffa3948af1a81d1cac91d1313b2452;p=libs%2Fgltk.git diff --git a/source/panel.cpp b/source/panel.cpp index ac277a9..a708873 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) @@ -156,12 +156,18 @@ void Panel::child_hidden(Widget &wdg) { if(&wdg==pointer_focus) set_pointer_focus(0, 0); + if(&wdg==input_focus) + set_input_focus(0); } void Panel::grab_pointer(Widget &wdg) { if(pointer_grab==0 || pointer_focus==&wdg) + { set_pointer_focus(&wdg, 255); + if(parent) + parent->grab_pointer(*this); + } else throw InvalidState("Pointer is already grabbed"); } @@ -169,16 +175,31 @@ void Panel::grab_pointer(Widget &wdg) void Panel::ungrab_pointer(Widget &wdg) { if(pointer_focus==&wdg) + { set_pointer_focus(0, 0); + if(parent) + parent->ungrab_pointer(*this); + } else if(pointer_grab>0) 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 +240,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;