X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fslider.cpp;h=dc8a28a6ff0c0ca718000cb3923c5e03c1050633;hb=43a75e4e9be56c58be5e224f19016bb14b56a7ef;hp=cb24c002b1a497bb5502f81bb566a434d5abd3c6;hpb=c062ca892fc6e10f74a76991b5d4b4349c046b5f;p=libs%2Fgltk.git diff --git a/source/slider.cpp b/source/slider.cpp index cb24c00..dc8a28a 100644 --- a/source/slider.cpp +++ b/source/slider.cpp @@ -3,28 +3,81 @@ namespace Msp { namespace GLtk { -Slider::Slider(const Resources &r): - Widget(r), +Slider::Slider(): min(0), max(1), value(0), - step(0.1) -{ -} + step(0.1), + dragging(false), + drag_area_size(0) +{ } void Slider::set_value(double v) { + double old_value = value; + if(vmax) - value=max; + value = max; else { - unsigned steps=static_cast((v-min)/step+0.5); - value=min+steps*step; + unsigned steps = static_cast((v-min)/step+0.5); + value = min+steps*step; } - signal_value_changed.emit(value); + if(value!=old_value) + signal_value_changed.emit(value); +} + +void Slider::set_range(double a, double b) +{ + min = a; + max = b; + set_value(value); +} + +void Slider::set_step(double s) +{ + step = s; + set_value(value); +} + +void Slider::start_drag(int p) +{ + dragging = true; + drag_start_pos = p; + drag_start_value = value; + set_state(ACTIVE); +} + +void Slider::drag(int p) +{ + if(max>min) + { + set_value(drag_start_value+(p-drag_start_pos)*(max-min)/drag_area_size); + rebuild(); + } +} + +void Slider::end_drag() +{ + dragging = false; + clear_state(ACTIVE); +} + + +Slider::Loader::Loader(Slider &s): + Widget::Loader(s) +{ + add("range", &Slider::min, &Slider::max); + add("step", &Slider::step); + add("value", &Slider::value); +} + +Slider &Slider::Loader::get_object() const +{ + return static_cast(obj); } } // namespace GLtk