X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flist.cpp;h=9be88e52c9ce65acecdf98b550d78a5db9a672ee;hb=6e58cefe8fd7aa736e528803ba483b9c8514bda1;hp=5a9f749fd0363b974ee1bfab98c37f37264a4354;hpb=7b555d7c7bd9d3236e251039be950358bf318393;p=libs%2Fgltk.git diff --git a/source/list.cpp b/source/list.cpp index 5a9f749..9be88e5 100644 --- a/source/list.cpp +++ b/source/list.cpp @@ -2,6 +2,7 @@ #include #include #include +#include #include "graphic.h" #include "list.h" #include "part.h" @@ -70,18 +71,16 @@ void List::autosize_special(const Part &part, Geometry &ageom) const const Sides &margin = part.get_margin(); unsigned max_w = 0; - unsigned total_h = 0; + unsigned max_h = 0; for(unsigned i=0; iautosize(igeom); max_w = max(max_w, igeom.w); - if(view_size==0 || i=0 && items[focus_index]->is_visible()) set_input_focus(items[focus_index]); else @@ -327,22 +339,31 @@ void List::focus_in() bool List::navigate(Navigation nav) { - if(nav==NAV_UP && !items.empty()) + if((nav==NAV_UP || nav==NAV_DOWN) && !items.empty()) + move_focus(nav, true); + else if(nav==NAV_ACTIVATE) + set_selected_index(focus_index); + else + return false; + + return true; +} + +void List::move_focus(Navigation nav, bool select) +{ + if(nav==NAV_UP) { if(focus_index>0) set_focus_index(focus_index-1); } - else if(nav==NAV_DOWN && !items.empty()) + else if(nav==NAV_DOWN) { if(static_cast(focus_index+1)widget; + child->autosize(); + if(const Part *part = style->get_part("children")) + { + const Sides &margin = part->get_margin(); + child->set_position(margin.left, margin.bottom); + } +} + + void List::MultiColumnItem::check_widths(vector &widths) const { if(widths.size()get_part("children")) - { - const Sides &margin = part->get_margin(); - label.set_position(margin.left, margin.bottom); - } -} - List::Loader::Loader(List &l): DataFile::DerivedObjectLoader(l)