X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fsmallruler.cpp;h=3673cbb191fb2d451fe2d7fe86795a467d2caf94;hb=ed5a2c50b2402499f775bee428e079cac7bde423;hp=8881329c08bb330997879da4bf2fcb17697d87bd;hpb=5ee798aed90c5a3a50024e6b5bd26753e03ec7cc;p=kdenlive diff --git a/src/smallruler.cpp b/src/smallruler.cpp index 8881329c..3673cbb1 100644 --- a/src/smallruler.cpp +++ b/src/smallruler.cpp @@ -19,22 +19,38 @@ #include "smallruler.h" +#include "kdenlivesettings.h" #include +#include +#include #include #include -SmallRuler::SmallRuler(QWidget *parent) : - QWidget(parent), - m_scale(1), - m_maxval(25) +#define SEEK_INACTIVE (-1) + + +SmallRuler::SmallRuler(MonitorManager *manager, Render *render, QWidget *parent) : + QWidget(parent) + ,m_cursorFramePosition(0) + ,m_maxval(2) + ,m_manager(manager) + ,m_render(render) + ,m_lastSeekPosition(SEEK_INACTIVE) + ,m_cursorColor(palette().text()) { m_zoneStart = 10; m_zoneEnd = 60; - m_zoneColor = QColor(133, 255, 143); + KSharedConfigPtr config = KSharedConfig::openConfig(KdenliveSettings::colortheme()); + m_zoneBrush = KStatefulBrush(KColorScheme::View, KColorScheme::PositiveBackground, config); + + setMouseTracking(true); + setMinimumHeight(10); + adjustScale(m_maxval); } + void SmallRuler::adjustScale(int maximum) { m_maxval = maximum; @@ -51,8 +67,21 @@ void SmallRuler::adjustScale(int maximum) m_small = 30 * 25; m_medium = 60 * 25; } - m_cursorPosition = m_cursorFramePosition * m_scale; - update(); + updatePixmap(); +} + +void SmallRuler::setZoneStart() +{ + int pos = m_render->requestedSeekPosition; + if (pos == SEEK_INACTIVE) pos = m_render->seekFramePosition(); + setZone(pos, -1); +} + +void SmallRuler::setZoneEnd() +{ + int pos = m_render->requestedSeekPosition; + if (pos == SEEK_INACTIVE) pos = m_render->seekFramePosition(); + setZone(-1, pos); } void SmallRuler::setZone(int start, int end) @@ -75,7 +104,13 @@ void SmallRuler::setZone(int start, int end) m_zoneEnd = end; } else m_zoneEnd = end; } - update(); + updatePixmap(); +} + +void SmallRuler::setMarkers(QList < CommentedTime > list) +{ + m_markers = list; + updatePixmap(); } QPoint SmallRuler::zone() @@ -92,71 +127,160 @@ void SmallRuler::mousePressEvent(QMouseEvent * event) if (qAbs(pos - m_zoneStart) < qAbs(pos - m_zoneEnd)) m_zoneStart = pos; else m_zoneEnd = pos; emit zoneChanged(QPoint(m_zoneStart, m_zoneEnd)); - update(); + updatePixmap(); + + } else if (pos != m_lastSeekPosition && pos != m_cursorFramePosition) { + m_render->seekToFrame(pos); + m_lastSeekPosition = pos; + update(); + } + event->accept(); +} - } else emit seekRenderer((int) pos); +// virtual +void SmallRuler::mouseReleaseEvent(QMouseEvent * event) +{ + event->accept(); +} + + +// virtual +void SmallRuler::leaveEvent(QEvent * event) +{ + QWidget::leaveEvent(event); + if (m_cursorColor == palette().highlight()) { + m_cursorColor = palette().text(); + update(); + } } // virtual void SmallRuler::mouseMoveEvent(QMouseEvent * event) { const int pos = event->x() / m_scale; - if (event->buttons() & Qt::LeftButton) emit seekRenderer((int) pos); + if (event->buttons() & Qt::LeftButton) { + if (pos != m_lastSeekPosition && pos != m_cursorFramePosition) { + m_render->seekToFrame(pos); + m_lastSeekPosition = pos; + update(); + } + } + else { + if (m_cursorColor == palette().text() && qAbs(pos - m_cursorFramePosition) * m_scale < 7) { + // Mouse is over cursor + m_cursorColor = palette().highlight(); + update(); + } + else if (m_cursorColor == palette().highlight() && qAbs(pos - m_cursorFramePosition) * m_scale >= 7) { + m_cursorColor = palette().text(); + update(); + } + if (qAbs((pos - m_zoneStart) * m_scale) < 4) { + setToolTip(i18n("Zone start: %1", m_manager->timecode().getTimecodeFromFrames(m_zoneStart))); + } else if (qAbs((pos - m_zoneEnd) * m_scale) < 4) { + setToolTip(i18n("Zone end: %1", m_manager->timecode().getTimecodeFromFrames(m_zoneEnd))); + } else if (pos > m_zoneStart && pos < m_zoneEnd) { + setToolTip(i18n("Zone duration: %1", m_manager->timecode().getTimecodeFromFrames(m_zoneEnd - m_zoneStart))); + } else setToolTip(i18n("Position: %1", m_manager->timecode().getTimecodeFromFrames(pos))); + } + event->accept(); +} + +void SmallRuler::refreshRuler() +{ + m_lastSeekPosition = SEEK_INACTIVE; + update(); } -void SmallRuler::slotNewValue(int value) +bool SmallRuler::slotNewValue(int value) { + if (value == m_cursorFramePosition) return false; + if (value == m_lastSeekPosition) m_lastSeekPosition = SEEK_INACTIVE; m_cursorFramePosition = value; - int oldPos = m_cursorPosition; + /*int oldPos = m_cursorPosition; m_cursorPosition = value * m_scale; - if (oldPos == m_cursorPosition) return; const int offset = 6; const int x = qMin(oldPos, m_cursorPosition); const int w = qAbs(oldPos - m_cursorPosition); - update(x - offset, 9, w + 2 * offset, 6); + update(x - offset, 0, w + 2 * offset, height());*/ + update(); + return true; } + //virtual void SmallRuler::resizeEvent(QResizeEvent *) { adjustScale(m_maxval); } -// virtual -void SmallRuler::paintEvent(QPaintEvent *e) +void SmallRuler::updatePixmap() { - - QPainter p(this); - QRect r = e->rect(); - p.setClipRect(r); - + m_pixmap = QPixmap(width(), height()); + m_pixmap.fill(palette().window().color()); + m_lastSeekPosition = SEEK_INACTIVE; + QPainter p(&m_pixmap); double f, fend; - p.setPen(palette().dark().color()); const int zoneStart = (int)(m_zoneStart * m_scale); const int zoneEnd = (int)(m_zoneEnd * m_scale); + p.setPen(Qt::NoPen); + p.setBrush(m_zoneBrush.brush(this)); + p.drawRect(zoneStart, height() / 2 - 1, zoneEnd - zoneStart, height() / 2); - p.fillRect(zoneStart, height() / 2, zoneEnd - zoneStart, height() / 2, m_zoneColor); - - if (r.top() < 9) { - // draw the little marks - fend = m_scale * m_small; - if (fend > 2) for (f = 0; f < width(); f += fend) { - p.drawLine((int)f, 1, (int)f, 3); - } + // draw ruler + p.setPen(palette().text().color()); + // draw the little marks + fend = m_scale * m_small; + if (fend > 2) for (f = 0; f < width(); f += fend) { + p.drawLine((int)f, 0, (int)f, 3); + } - // draw medium marks - fend = m_scale * m_medium; - if (fend > 2) for (f = 0; f < width(); f += fend) { - p.drawLine((int)f, 1, (int)f, 5); - } + // draw medium marks + fend = m_scale * m_medium; + if (fend > 2) for (f = 0; f < width(); f += fend) { + p.drawLine((int)f, 0, (int)f, 6); + } + // draw markers + if (!m_markers.isEmpty()) { + for (int i = 0; i < m_markers.count(); i++) { + int pos = m_markers.at(i).time().frames(m_manager->timecode().fps()) * m_scale; + p.setPen(CommentedTime::markerColor(m_markers.at(i).markerType())); + p.drawLine(pos, 0, pos, 9); + } } + p.end(); + update(); +} + +// virtual +void SmallRuler::paintEvent(QPaintEvent *e) +{ + QPainter p(this); + QRect r = e->rect(); + p.setClipRect(r); + p.drawPixmap(QPointF(), m_pixmap); + + int cursorPos = m_cursorFramePosition * m_scale; // draw pointer QPolygon pa(3); - pa.setPoints(3, m_cursorPosition - 5, 14, m_cursorPosition + 5, 14, m_cursorPosition/*+0*/, 9); - p.setBrush(palette().dark().color()); + pa.setPoints(3, cursorPos - 6, 10, cursorPos + 6, 10, cursorPos/*+0*/, 4); + p.setBrush(m_cursorColor); + p.setPen(Qt::NoPen); p.drawPolygon(pa); + + // Draw seeking pointer + if (m_lastSeekPosition != SEEK_INACTIVE && m_lastSeekPosition != m_cursorFramePosition) { + p.fillRect(m_lastSeekPosition * m_scale - 1, 0, 3, height(), palette().highlight()); + } +} + +void SmallRuler::updatePalette() +{ + KSharedConfigPtr config = KSharedConfig::openConfig(KdenliveSettings::colortheme()); + m_zoneBrush = KStatefulBrush(KColorScheme::View, KColorScheme::PositiveBackground, config); + updatePixmap(); } #include "smallruler.moc"