ageom.h = max(ageom.h, line_height+margin.top+margin.bottom);
}
else if(part.get_name()=="slider" && multiline)
- {
- Geometry sgeom = part.get_geometry();
- if(!sgeom.w || !sgeom.h)
- {
- slider->autosize();
- if(!sgeom.w)
- sgeom.w = slider->get_geometry().w;
- if(!sgeom.h)
- sgeom.h = slider->get_geometry().h;
- }
-
- const Sides &margin = part.get_margin();
- ageom.w = max(ageom.w, sgeom.w+margin.left+margin.right);
- ageom.h = max(ageom.h, sgeom.h+margin.top+margin.bottom);
- }
+ autosize_child(*slider, part, ageom);
}
void Entry::set_text(const string &t)
add(*slider);
slider->set_step(1);
slider->signal_value_changed.connect(sigc::mem_fun(this, &Entry::slider_value_changed));
- reposition_slider();
+ rebuild();
}
check_view_range();
}
bld.matrix() *= GL::Matrix::translation(rgeom.x, rgeom.y, 0);
graphic->build(part.get_geometry().w, part.get_geometry().h, bld);
}
+ else if(part.get_name()=="slider")
+ {
+ if(multiline)
+ {
+ reposition_child(*slider, part);
+ Widget::rebuild_special(part);
+ }
+ }
else
Widget::rebuild_special(part);
}
void Entry::on_geometry_change()
{
- reposition_slider();
-
if(multiline)
check_view_range();
}
text_part = style->get_part("text");
- reposition_slider();
-
if(multiline)
check_view_range();
}
rebuild();
}
-void Entry::reposition_slider()
-{
- if(!style || !slider)
- return;
-
- if(const Part *slider_part = style->get_part("slider"))
- {
- Geometry sgeom = slider_part->get_geometry();
- if(!sgeom.w || !sgeom.h)
- {
- slider->autosize();
- if(!sgeom.w)
- sgeom.w = slider->get_geometry().w;
- if(!sgeom.h)
- sgeom.h = slider->get_geometry().h;
- }
-
- slider_part->get_alignment().apply(sgeom, geom, slider_part->get_margin());
- slider->set_geometry(sgeom);
- }
-}
-
void Entry::check_view_range()
{
if(!multiline || !text_part)