]> git.tdb.fi Git - libs/gltk.git/blobdiff - source/slider.cpp
Improve widget part caching
[libs/gltk.git] / source / slider.cpp
index ead5664a303fae8e88ac26c9e0967629a5b02ceb..7123458c0e41b7268ce44b7c556543dfd2af9aa1 100644 (file)
@@ -1,17 +1,9 @@
-/* $Id$
-
-This file is part of libmspgltk
-Copyright © 2007  Mikko Rasa, Mikkosoft Productions
-Distributed under the LGPL
-*/
-
 #include "slider.h"
 
 namespace Msp {
 namespace GLtk {
 
-Slider::Slider(const Resources &r):
-       Widget(r),
+Slider::Slider():
        min(0),
        max(1),
        value(0),
@@ -22,41 +14,44 @@ Slider::Slider(const Resources &r):
 
 void Slider::set_value(double v)
 {
-       double old_value=value;
+       double old_value = value;
 
        if(v<min)
-               value=min;
+               value = min;
        else if(v>max)
-               value=max;
+               value = max;
        else
        {
-               unsigned steps=static_cast<unsigned>((v-min)/step+0.5);
-               value=min+steps*step;
+               unsigned steps = static_cast<unsigned>((v-min)/step+0.5);
+               value = min+steps*step;
        }
 
        if(value!=old_value)
+       {
                signal_value_changed.emit(value);
+               rebuild();
+       }
 }
 
 void Slider::set_range(double a, double b)
 {
-       min=a;
-       max=b;
+       min = a;
+       max = b;
        set_value(value);
 }
 
 void Slider::set_step(double s)
 {
-       step=s;
+       step = s;
        set_value(value);
 }
 
 void Slider::start_drag(int p)
 {
-       dragging=true;
-       drag_start_pos=p;
-       drag_start_value=value;
-       state|=ACTIVE;
+       dragging = true;
+       drag_start_pos = p;
+       drag_start_value = value;
+       set_state(ACTIVE);
 }
 
 void Slider::drag(int p)
@@ -67,23 +62,18 @@ void Slider::drag(int p)
 
 void Slider::end_drag()
 {
-       dragging=false;
-       state&=~ACTIVE;
+       dragging = false;
+       clear_state(ACTIVE);
 }
 
 
 Slider::Loader::Loader(Slider &s):
-       Widget::Loader(s)
+       DataFile::DerivedObjectLoader<Slider, 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<Slider &>(wdg);
-}
-
 } // namespace GLtk
 } // namespace Msp