-const int CustomRuler::comboScale[] = { 1, 2, 5, 10, 25, 50, 125, 250, 500, 725, 1500, 3000, 6000, 12000};
+const int CustomRuler::comboScale[] = { 1, 2, 5, 10, 25, 50, 125, 250, 500, 750, 1500, 3000, 6000, 12000};
m_zoneColor = QColor(133, 255, 143);
littleMarkDistance = FRAME_SIZE;
mediumMarkDistance = FRAME_SIZE * m_timecode.fps();
m_zoneColor = QColor(133, 255, 143);
littleMarkDistance = FRAME_SIZE;
mediumMarkDistance = FRAME_SIZE * m_timecode.fps();
m_contextMenu = new QMenu(this);
QAction *addGuide = m_contextMenu->addAction(KIcon("document-new"), i18n("Add Guide"));
connect(addGuide, SIGNAL(triggered()), m_view, SLOT(slotAddGuide()));
m_contextMenu = new QMenu(this);
QAction *addGuide = m_contextMenu->addAction(KIcon("document-new"), i18n("Add Guide"));
connect(addGuide, SIGNAL(triggered()), m_view, SLOT(slotAddGuide()));
- QAction *editGuide = m_contextMenu->addAction(KIcon("document-properties"), i18n("Edit Guide"));
- connect(editGuide, SIGNAL(triggered()), m_view, SLOT(slotEditGuide()));
- QAction *delGuide = m_contextMenu->addAction(KIcon("edit-delete"), i18n("Delete Guide"));
- connect(delGuide, SIGNAL(triggered()), m_view, SLOT(slotDeleteGuide()));
+ m_editGuide = m_contextMenu->addAction(KIcon("document-properties"), i18n("Edit Guide"));
+ connect(m_editGuide, SIGNAL(triggered()), this, SLOT(slotEditGuide()));
+ m_deleteGuide = m_contextMenu->addAction(KIcon("edit-delete"), i18n("Delete Guide"));
+ connect(m_deleteGuide , SIGNAL(triggered()), this, SLOT(slotDeleteGuide()));
QAction *delAllGuides = m_contextMenu->addAction(KIcon("edit-delete"), i18n("Delete All Guides"));
connect(delAllGuides, SIGNAL(triggered()), m_view, SLOT(slotDeleteAllGuides()));
setMouseTracking(true);
setMinimumHeight(20);
}
QAction *delAllGuides = m_contextMenu->addAction(KIcon("edit-delete"), i18n("Delete All Guides"));
connect(delAllGuides, SIGNAL(triggered()), m_view, SLOT(slotDeleteAllGuides()));
setMouseTracking(true);
setMinimumHeight(20);
}
+void CustomRuler::updateProjectFps(Timecode t)
+{
+ m_timecode = t;
+ mediumMarkDistance = FRAME_SIZE * m_timecode.fps();
+ bigMarkDistance = FRAME_SIZE * m_timecode.fps() * 60;
+ update();
+}
+
+void CustomRuler::slotEditGuide()
+{
+ m_view->slotEditGuide(m_clickedGuide);
+}
+
+void CustomRuler::slotDeleteGuide()
+{
+ m_view->slotDeleteGuide(m_clickedGuide);
+}
+
m_moveCursor = RULER_CURSOR;
if (event->y() > 10) {
if (qAbs(pos - m_zoneStart * m_factor) < 4) m_moveCursor = RULER_START;
else if (qAbs(pos - (m_zoneStart + (m_zoneEnd - m_zoneStart) / 2) * m_factor) < 4) m_moveCursor = RULER_MIDDLE;
else if (qAbs(pos - m_zoneEnd * m_factor) < 4) m_moveCursor = RULER_END;
}
m_moveCursor = RULER_CURSOR;
if (event->y() > 10) {
if (qAbs(pos - m_zoneStart * m_factor) < 4) m_moveCursor = RULER_START;
else if (qAbs(pos - (m_zoneStart + (m_zoneEnd - m_zoneStart) / 2) * m_factor) < 4) m_moveCursor = RULER_MIDDLE;
else if (qAbs(pos - m_zoneEnd * m_factor) < 4) m_moveCursor = RULER_END;
}
- m_view->setCursorPos(pos);
- m_view->slotCheckPositionScrolling();
+ QPoint diff = event->pos() - m_clickPoint;
+ if (m_mouseMove == NO_MOVE) {
+ if (qAbs(diff.x()) >= QApplication::startDragDistance()) {
+ m_mouseMove = HORIZONTAL_MOVE;
+ } else if (qAbs(diff.y()) >= QApplication::startDragDistance()) {
+ m_mouseMove = VERTICAL_MOVE;
+ } else return;
+ }
+ if (m_mouseMove == HORIZONTAL_MOVE) {
+ m_view->setCursorPos(pos);
+ m_view->slotCheckPositionScrolling();
+ } else {
+ int verticalDiff = m_startRate - (diff.y()) / 7;
+ if (verticalDiff != m_rate) emit adjustZoom(verticalDiff);
+ }
- else if (qAbs(pos - m_zoneStart * m_factor) < 4) setCursor(KCursor("left_side", Qt::SizeHorCursor));
- else if (qAbs(pos - m_zoneEnd * m_factor) < 4) setCursor(KCursor("right_side", Qt::SizeHorCursor));
- else if (qAbs(pos - (m_zoneStart + (m_zoneEnd - m_zoneStart) / 2) * m_factor) < 4) setCursor(Qt::SizeHorCursor);
- else setCursor(Qt::ArrowCursor);
+ else if (qAbs(pos - m_zoneStart * m_factor) < 4) {
+ setCursor(KCursor("left_side", Qt::SizeHorCursor));
+ setToolTip(i18n("Zone start: %1", m_timecode.getTimecodeFromFrames(m_zoneStart)));
+ } else if (qAbs(pos - m_zoneEnd * m_factor) < 4) {
+ setCursor(KCursor("right_side", Qt::SizeHorCursor));
+ setToolTip(i18n("Zone end: %1", m_timecode.getTimecodeFromFrames(m_zoneEnd)));
+ } else if (qAbs(pos - (m_zoneStart + (m_zoneEnd - m_zoneStart) / 2) * m_factor) < 4) {
+ setCursor(Qt::SizeHorCursor);
+ setToolTip(i18n("Zone duration: %1", m_timecode.getTimecodeFromFrames(m_zoneEnd - m_zoneStart)));
+ } else {
+ setCursor(Qt::ArrowCursor);
+ setToolTip(i18n("Position: %1", m_timecode.getTimecodeFromFrames(pos / m_factor)));
+ }
- if (qAbs(oldpos - newpos) * m_factor > 40) {
- update(oldpos * m_factor - offset() - 6, 7, 17, 16);
- update(newpos * m_factor - offset() - 6, 7, 17, 16);
- } else update(qMin(oldpos, newpos) * m_factor - offset() - 6, 7, qAbs(oldpos - newpos) * m_factor + 17, 16);
+ if (qAbs(oldpos - newpos) * m_factor > m_textSpacing) {
+ update(oldpos * m_factor - offset() - 6, 0, 17, height());
+ update(newpos * m_factor - offset() - 6, 0, 17, height());
+ } else update(qMin(oldpos, newpos) * m_factor - offset() - 6, 0, qAbs(oldpos - newpos) * m_factor + 17, height());
m_factor = 1.0 / (double) scale * FRAME_SIZE;
m_scale = 1.0 / (double) scale;
double fend = m_scale * littleMarkDistance;
m_factor = 1.0 / (double) scale * FRAME_SIZE;
m_scale = 1.0 / (double) scale;
double fend = m_scale * littleMarkDistance;
+ if (rate > 8) {
+ mediumMarkDistance = (double) FRAME_SIZE * m_timecode.fps() * 60;
+ bigMarkDistance = (double) FRAME_SIZE * m_timecode.fps() * 300;
+ } else if (rate > 6) {
+ mediumMarkDistance = (double) FRAME_SIZE * m_timecode.fps() * 10;
+ bigMarkDistance = (double) FRAME_SIZE * m_timecode.fps() * 30;
+ } else if (rate > 3) {
+ mediumMarkDistance = (double) FRAME_SIZE * m_timecode.fps();
+ bigMarkDistance = (double) FRAME_SIZE * m_timecode.fps() * 5;
+ } else {
+ mediumMarkDistance = (double) FRAME_SIZE * m_timecode.fps();
+ bigMarkDistance = (double) FRAME_SIZE * m_timecode.fps() * 60;
+ }
+ switch (rate) {
- p.fillRect(0, 0, projectEnd - m_offset, height(), m_bgColor);
+ p.fillRect(0, 0, projectEnd - m_offset, height(), palette().alternateBase().color());
- p.fillRect(zoneStart - offset(), height() / 2, zoneEnd - zoneStart, height() / 2, m_zoneColor);
+ p.fillRect(zoneStart - m_offset, height() / 2, zoneEnd - zoneStart, height() / 2, m_zoneColor);
int minval = (e->rect().left() + m_offset) / FRAME_SIZE - 1;
const int maxval = (e->rect().right() + m_offset) / FRAME_SIZE + 1;
if (minval < 0) minval = 0;
int minval = (e->rect().left() + m_offset) / FRAME_SIZE - 1;
const int maxval = (e->rect().right() + m_offset) / FRAME_SIZE + 1;
if (minval < 0) minval = 0;
int offsetmin = (e->rect().left() + m_offset) / m_textSpacing;
offsetmin = offsetmin * m_textSpacing;
for (f = offsetmin; f < offsetmax; f += m_textSpacing) {
int offsetmin = (e->rect().left() + m_offset) / m_textSpacing;
offsetmin = offsetmin * m_textSpacing;
for (f = offsetmin; f < offsetmax; f += m_textSpacing) {
- QString lab = m_timecode.getTimecodeFromFrames((int)((f) / m_factor + 0.5));
- p.drawText((int)f - m_offset + 2, LABEL_SIZE, lab);
+ QString lab = m_timecode.getTimecodeFromFrames((int)(f / m_factor + 0.5));
+ p.drawText(f - m_offset + 2, LABEL_SIZE, lab);
- if (true) {
- offsetmin = (e->rect().left() + m_offset) / littleMarkDistance;
- offsetmin = offsetmin * littleMarkDistance;
- // draw the little marks
- fend = m_scale * littleMarkDistance;
- if (fend > 5) for (f = offsetmin - m_offset; f < offsetmax - m_offset; f += fend)
- p.drawLine((int)f, LITTLE_MARK_X1, (int)f, LITTLE_MARK_X2);
- }
- if (true) {
- offsetmin = (e->rect().left() + m_offset) / mediumMarkDistance;
- offsetmin = offsetmin * mediumMarkDistance;
- // draw medium marks
- fend = m_scale * mediumMarkDistance;
- if (fend > 5) for (f = offsetmin - m_offset - fend; f < offsetmax - m_offset + fend; f += fend)
- p.drawLine((int)f, MIDDLE_MARK_X1, (int)f, MIDDLE_MARK_X2);
- }
- if (true) {
- offsetmin = (e->rect().left() + m_offset) / bigMarkDistance;
- offsetmin = offsetmin * bigMarkDistance;
- // draw big marks
- fend = m_scale * bigMarkDistance;
- if (fend > 5) for (f = offsetmin - m_offset; f < offsetmax - m_offset; f += fend)
- p.drawLine((int)f, BIG_MARK_X1, (int)f, BIG_MARK_X2);
- }
+ offsetmin = (e->rect().left() + m_offset) / littleMarkDistance;
+ offsetmin = offsetmin * littleMarkDistance;
+ // draw the little marks
+ fend = m_scale * littleMarkDistance;
+ if (fend > 5) for (f = offsetmin - m_offset; f < offsetmax - m_offset; f += fend)
+ p.drawLine((int)f, LITTLE_MARK_X1, (int)f, LITTLE_MARK_X2);
+
+ offsetmin = (e->rect().left() + m_offset) / mediumMarkDistance;
+ offsetmin = offsetmin * mediumMarkDistance;
+ // draw medium marks
+ fend = m_scale * mediumMarkDistance;
+ if (fend > 5) for (f = offsetmin - m_offset - fend; f < offsetmax - m_offset + fend; f += fend)
+ p.drawLine((int)f, MIDDLE_MARK_X1, (int)f, MIDDLE_MARK_X2);
+
+ offsetmin = (e->rect().left() + m_offset) / bigMarkDistance;
+ offsetmin = offsetmin * bigMarkDistance;
+ // draw big marks
+ fend = m_scale * bigMarkDistance;
+ if (fend > 5) for (f = offsetmin - m_offset; f < offsetmax - m_offset; f += fend)
+ p.drawLine((int)f, BIG_MARK_X1, (int)f, BIG_MARK_X2);
- pa.setPoints(3, value - 6, 7, value + 6, 7, value, 16);
- p.setBrush(QBrush(Qt::yellow));
+ pa.setPoints(3, value - 6, 8, value + 6, 8, value, 16);
+ p.setBrush(palette().highlight());