X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/2e02d72e10207215592e4aeda8b1c5cf18f7115a..672640e924d5c61ec03919b977d38fa2783ad1c8:/lib/gui/eslider.cpp diff --git a/lib/gui/eslider.cpp b/lib/gui/eslider.cpp index 00aaeb74..19097ad4 100644 --- a/lib/gui/eslider.cpp +++ b/lib/gui/eslider.cpp @@ -1,8 +1,7 @@ #include eSlider::eSlider(eWidget *parent) - :eWidget(parent), m_have_border_color(false), m_start(0) - ,m_orientation(orHorizontal), m_direction(dirNormal), m_border_width(0) + :eWidget(parent), m_have_border_color(false), m_start(0), m_orientation(orHorizontal), m_orientation_swapped(0), m_border_width(0) { } @@ -71,18 +70,14 @@ int eSlider::event(int event, void *data, void *data2) if (m_min < m_max) { - if (m_direction == dirSwapped) - { - start_pix = pixsize * (m_start + (m_max - m_min) - m_value) / (m_max - m_min); - num_pix = pixsize * (m_start + (m_max - m_min)) / (m_max - m_min); - } - else // dirNormal - { - num_pix = pixsize * (m_value - m_start) / (m_max - m_min); - start_pix = pixsize * m_start / (m_max - m_min); - } + int val_range = m_max - m_min; + num_pix = (pixsize * (m_value - m_start) + val_range - 1) / val_range; /* properly round up */ + start_pix = (pixsize * m_start + val_range - 1) / val_range; + + if (m_orientation_swapped) + start_pix = pixsize - num_pix - start_pix; } - + if (start_pix < 0) { num_pix += start_pix; @@ -122,15 +117,10 @@ void eSlider::setStartEnd(int start, int end) event(evtChangedSlider); } -void eSlider::setOrientation(int orientation) +void eSlider::setOrientation(int orientation, int swapped) { m_orientation = orientation; - event(evtChangedSlider); -} - -void eSlider::setDirection(int direction) -{ - m_direction = direction; + m_orientation_swapped = swapped; event(evtChangedSlider); }