X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/ec648cb137f7a02e63752b54be2ce3ac959c7c86..896d63aa5605a9b6ef641830eae4038addc53c60:/lib/gui/epositiongauge.cpp diff --git a/lib/gui/epositiongauge.cpp b/lib/gui/epositiongauge.cpp index 712bf4a6..4785d7af 100644 --- a/lib/gui/epositiongauge.cpp +++ b/lib/gui/epositiongauge.cpp @@ -5,15 +5,20 @@ ePositionGauge::ePositionGauge(eWidget *parent) : eWidget(parent) { m_point_widget = new ePixmap(this); + m_seek_point_widget = new ePixmap(this); + m_seek_point_widget->hide(); m_point_widget->setAlphatest(1); + m_seek_point_widget->setAlphatest(1); m_position = 0; m_length = 0; m_have_foreground_color = 0; + m_seek_position = 0; } ePositionGauge::~ePositionGauge() { delete m_point_widget; + delete m_seek_point_widget; } void ePositionGauge::setLength(const pts_t &len) @@ -38,15 +43,28 @@ void ePositionGauge::setInColor(const gRGB &color) invalidate(); } -void ePositionGauge::setPointer(gPixmap *pixmap, const ePoint ¢er) +void ePositionGauge::setPointer(int which, ePtr &pixmap, const ePoint ¢er) { - m_point_center = center; - m_point_widget->setPixmap(pixmap); - m_point_widget->resize(pixmap->size()); + setPointer(which, pixmap.operator->(), center); +} + +void ePositionGauge::setPointer(int which, gPixmap *pixmap, const ePoint ¢er) +{ + if (which == 0) + { + m_point_center = center; + m_point_widget->setPixmap(pixmap); + m_point_widget->resize(pixmap->size()); + } else + { + m_seek_point_center = center; + m_seek_point_widget->setPixmap(pixmap); + m_seek_point_widget->resize(pixmap->size()); + } updatePosition(); } -void ePositionGauge::setInOutList(PyObject *list) +void ePositionGauge::setInOutList(ePyObject list) { if (!PyList_Check(list)) return; @@ -57,14 +75,14 @@ void ePositionGauge::setInOutList(PyObject *list) for (i=0; imove(ePoint(m_pos - m_point_center.x(), base - m_point_center.y())); + m_seek_point_widget->move(ePoint(m_seek_pos - m_seek_point_center.x(), base - m_seek_point_center.y())); } int ePositionGauge::scale(const pts_t &val) @@ -185,3 +205,19 @@ void ePositionGauge::setForegroundColor(const gRGB &col) invalidate(); } } + +void ePositionGauge::enableSeekPointer(int enable) +{ + if (enable) + m_seek_point_widget->show(); + else + m_seek_point_widget->hide(); +} + +void ePositionGauge::setSeekPosition(const pts_t &pos) +{ + if (m_seek_position == pos) + return; + m_seek_position = pos; + updatePosition(); +}