X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flist.cpp;h=5d765008765c9ccbece8c28e77c9a62da5a4cecb;hb=9faf932be00ba7ec7ed8c81f1e7971dcfa2b2085;hp=5d179e195c36c412785a17ec7d731f65856f420d;hpb=b3de715986f0e5b6359a2109c27d052c3d9cc27a;p=libs%2Fgltk.git diff --git a/source/list.cpp b/source/list.cpp index 5d179e1..5d76500 100644 --- a/source/list.cpp +++ b/source/list.cpp @@ -44,6 +44,7 @@ void List::init() first = 0; max_scroll = 0; view_size = 5; + items_part = 0; ignore_slider_change = false; dragging = false; drag_start_x = 0; @@ -71,18 +72,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 || iget_part("items") : 0); +} + void List::move_focus(Navigation nav, bool select) { if(nav==NAV_UP) @@ -388,15 +392,11 @@ void List::item_autosize_changed(Item *item) unsigned List::last_to_first(unsigned last) const { - if(!style) + if(!items_part) return last; - unsigned view_h = geom.h; - if(const Part *items_part = style->get_part("items")) - { - const Sides &margin = items_part->get_margin(); - view_h -= margin.top+margin.bottom; - } + const Sides &margin = items_part->get_margin(); + unsigned view_h = geom.h-min(geom.h, margin.top+margin.bottom); unsigned items_h = 0; for(unsigned i=last; iwidget; + 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)