static const int END_LABEL_X = 4;
static const int END_LABEL_Y = (END_LABEL_X + LABEL_SIZE - 2);
+static int littleMarkDistance;
+static int mediumMarkDistance;
+static int bigMarkDistance;
+
#include "definitions.h"
const int CustomRuler::comboScale[] = { 1, 2, 5, 10, 25, 50, 125, 250, 500, 725, 1500, 3000, 6000, 12000};
CustomRuler::CustomRuler(Timecode tc, CustomTrackView *parent)
- : KRuler(parent), m_timecode(tc), m_view(parent), m_duration(0) {
+ : QWidget(parent), m_timecode(tc), m_view(parent), m_duration(0), m_offset(0) {
setFont(KGlobalSettings::toolBarFont());
- slotNewOffset(0);
- setRulerMetricStyle(KRuler::Pixel);
- setLength(1024);
- setMaximum(1024);
- setPixelPerMark(3);
- setLittleMarkDistance(FRAME_SIZE);
- setMediumMarkDistance(FRAME_SIZE * m_timecode.fps());
- setBigMarkDistance(FRAME_SIZE * m_timecode.fps() * 60);
+ m_scale = 3;
+ littleMarkDistance = FRAME_SIZE;
+ mediumMarkDistance = FRAME_SIZE * m_timecode.fps();
+ bigMarkDistance = FRAME_SIZE * m_timecode.fps() * 60;
m_zoneStart = 2 * m_timecode.fps();
m_zoneEnd = 10 * m_timecode.fps();
m_contextMenu = new QMenu(this);
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::setZone(QPoint p) {
+ int min = qMin(m_zoneStart, p.x());
+ int max = qMax(m_zoneEnd, p.y());
m_zoneStart = p.x();
m_zoneEnd = p.y();
- update();
+ update(min * m_factor - 2, 0, (max - min) * m_factor + 4, height());
}
// virtual
void CustomRuler::mouseMoveEvent(QMouseEvent * event) {
if (event->buttons() == Qt::LeftButton) {
int pos = (int)((event->x() + offset()) / m_factor);
+ int zoneStart = m_zoneStart;
+ int zoneEnd = m_zoneEnd;
if (pos < 0) pos = 0;
if (m_moveCursor == RULER_CURSOR) {
m_view->setCursorPos(pos);
}
emit zoneMoved(m_zoneStart, m_zoneEnd);
m_view->setDocumentModified();
- update();
+
+ int min = qMin(m_zoneStart, zoneStart);
+ int max = qMax(m_zoneEnd, zoneEnd);
+ update(min * m_factor - m_offset - 2, 0, (max - min) * m_factor + 4, height());
+
} else {
int pos = (int)((event->x() + offset()));
if (event->y() <= 10) setCursor(Qt::ArrowCursor);
}
void CustomRuler::slotMoveRuler(int newPos) {
- KRuler::slotNewOffset(newPos);
+ m_offset = newPos;
+ update();
+}
+
+int CustomRuler::offset() const {
+ return m_offset;
}
void CustomRuler::slotCursorMoved(int oldpos, int newpos) {
- update(oldpos * m_factor - offset() - 6, 2, 17, 16);
- update(newpos * m_factor - offset() - 6, 2, 17, 16);
+ 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);
}
void CustomRuler::setPixelPerMark(double rate) {
int scale = comboScale[(int) rate];
m_factor = 1.0 / (double) scale * FRAME_SIZE;
- KRuler::setPixelPerMark(1.0 / scale);
- double fend = pixelPerMark() * littleMarkDistance();
+ m_scale = 1.0 / (double) scale;
+ double fend = m_scale * littleMarkDistance;
switch ((int) rate) {
case 0:
m_textSpacing = fend;
m_textSpacing = fend * m_timecode.fps() * 600;
break;
}
+ update();
}
void CustomRuler::setDuration(int d) {
+ int oldduration = m_duration;
m_duration = d;
- update();
+ update(qMin(oldduration, m_duration) * m_factor - 1, 0, qAbs(oldduration - m_duration) * m_factor + 2, height());
}
// virtual
p.setClipRect(e->rect());
const int projectEnd = (int)(m_duration * m_factor);
- p.fillRect(QRect(0, 0, projectEnd - offset(), height()), QBrush(QColor(245, 245, 245)));
+ p.fillRect(QRect(0, 0, projectEnd - m_offset, height()), QBrush(QColor(245, 245, 245)));
const int zoneStart = (int)(m_zoneStart * m_factor);
const int zoneEnd = (int)(m_zoneEnd * m_factor);
p.fillRect(QRect(zoneStart - offset(), height() / 2, zoneEnd - zoneStart, height() / 2), QBrush(QColor(133, 255, 143)));
const int value = m_view->cursorPos() * m_factor - offset();
- const int minval = minimum();
- const int maxval = maximum() + offset() - endOffset();
+ 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;
- double f, fend,
- offsetmin = (double)(minval - offset()),
- offsetmax = (double)(maxval - offset()),
- fontOffset = (((double)minval) > offsetmin) ? (double)minval : offsetmin;
- QRect bg = QRect((int)offsetmin, 0, (int)offsetmax, height());
+ kDebug() << "RULER MIN/MAX: " << minval << "-" << maxval << ", PIXELS: " << e->rect().left() << "-" << e->rect().right();
- QPalette palette;
- //p.fillRect(bg, palette.light());
- // draw labels
- p.setPen(palette.dark().color());
- // draw littlemarklabel
-
- // draw mediummarklabel
-
- // draw bigmarklabel
+ double f, fend;
+ const int offsetmax = maxval * FRAME_SIZE;
- // draw endlabel
- /*if (d->showEndL) {
- if (d->dir == Qt::Horizontal) {
- p.translate( fontOffset, 0 );
- p.drawText( END_LABEL_X, END_LABEL_Y, d->endlabel );
- }*/
-
- // draw the tiny marks
- //if (showTinyMarks())
- /*{
- fend = pixelPerMark()*tinyMarkDistance();
- if (fend > 5) for ( f=offsetmin; f<offsetmax; f+=fend ) {
- p.drawLine((int)f, BASE_MARK_X1, (int)f, BASE_MARK_X2);
- }
- }*/
+ QPalette palette;
+ p.setPen(palette.dark().color());
+ 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 - offsetmin) / m_factor + 0.5));
- p.drawText((int)f + 2, LABEL_SIZE, lab);
+ QString lab = m_timecode.getTimecodeFromFrames((int)((f) / m_factor + 0.5));
+ p.drawText((int)f - m_offset + 2, LABEL_SIZE, lab);
}
- if (showLittleMarks()) {
+ if (true) {
+ offsetmin = (e->rect().left() + m_offset) / littleMarkDistance;
+ offsetmin = offsetmin * littleMarkDistance;
// draw the little marks
- fend = pixelPerMark() * littleMarkDistance();
- if (fend > 5) for (f = offsetmin; f < offsetmax; f += fend)
+ 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 (showMediumMarks()) {
+ if (true) {
+ offsetmin = (e->rect().left() + m_offset) / mediumMarkDistance;
+ offsetmin = offsetmin * mediumMarkDistance;
// draw medium marks
- fend = pixelPerMark() * mediumMarkDistance();
- if (fend > 5) for (f = offsetmin; f < offsetmax; f += fend)
+ 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 (showBigMarks()) {
+ if (true) {
+ offsetmin = (e->rect().left() + m_offset) / bigMarkDistance;
+ offsetmin = offsetmin * bigMarkDistance;
// draw big marks
- fend = pixelPerMark() * bigMarkDistance();
- if (fend > 5) for (f = offsetmin; f < offsetmax; f += fend)
+ 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);
}
- /* if (d->showem) {
- // draw end marks
- if (d->dir == Qt::Horizontal) {
- p.drawLine(minval-d->offset, END_MARK_X1, minval-d->offset, END_MARK_X2);
- p.drawLine(maxval-d->offset, END_MARK_X1, maxval-d->offset, END_MARK_X2);
- }
- else {
- p.drawLine(END_MARK_X1, minval-d->offset, END_MARK_X2, minval-d->offset);
- p.drawLine(END_MARK_X1, maxval-d->offset, END_MARK_X2, maxval-d->offset);
- }
- }*/
-
// draw zone cursors
int off = offset();
#ifndef CUSTOMRULER_H
#define CUSTOMRULER_H
-#include <KRuler>
+#include <QWidget>
#include "customtrackview.h"
#include "timecode.h"
enum RULER_MOVE { RULER_CURSOR = 0, RULER_START = 1, RULER_MIDDLE = 2, RULER_END = 3 };
-class CustomRuler : public KRuler {
+class CustomRuler : public QWidget {
Q_OBJECT
public:
int inPoint() const;
void setDuration(int d);
void setZone(QPoint p);
+ int offset() const;
protected:
virtual void paintEvent(QPaintEvent * /*e*/);
int m_duration;
double m_textSpacing;
double m_factor;
+ double m_scale;
+ int m_offset;
RULER_MOVE m_moveCursor;
QMenu *m_contextMenu;
}
void CustomTrackView::clipStart() {
- QList<QGraphicsItem *> itemList = scene()->selectedItems();
- for (int i = 0; i < itemList.count(); i++) {
- if (itemList.at(i)->type() == AVWIDGET) {
- ClipItem *item = (ClipItem *) itemList.at(i);
- setCursorPos((int) item->startPos().frames(m_document->fps()));
- checkScrolling();
- break;
- }
+ ClipItem *item = getMainActiveClip();
+ if (item != NULL) {
+ setCursorPos((int) item->startPos().frames(m_document->fps()));
+ checkScrolling();
}
}
void CustomTrackView::clipEnd() {
- QList<QGraphicsItem *> itemList = scene()->selectedItems();
- for (int i = 0; i < itemList.count(); i++) {
- if (itemList.at(i)->type() == AVWIDGET) {
- ClipItem *item = (ClipItem *) itemList.at(i);
- setCursorPos((int) item->endPos().frames(m_document->fps()));
- checkScrolling();
- break;
- }
+ ClipItem *item = getMainActiveClip();
+ if (item != NULL) {
+ setCursorPos((int) item->endPos().frames(m_document->fps()));
+ checkScrolling();
}
}
}
-/*
-void CustomTrackView::drawForeground ( QPainter * painter, const QRectF & rect )
-{
- //kDebug()<<"///// DRAWINGÂ FB: "<<rect.x()<<", width: "<<rect.width();
- painter->fillRect(rect, QColor(50, rand() % 250,50,100));
- painter->drawLine(m_cursorPos, rect.y(), m_cursorPos, rect.y() + rect.height());
+ClipItem *CustomTrackView::getClipUnderCursor() const {
+ QRectF rect((double) m_cursorPos, 0.0, 1.0, (double)(m_tracksHeight * m_scene->m_tracksList.count()));
+ QList<QGraphicsItem *> collisions = scene()->items(rect, Qt::IntersectsItemBoundingRect);
+ for (int i = 0; i < collisions.count(); i++) {
+ if (collisions.at(i)->type() == AVWIDGET) {
+ return static_cast < ClipItem *>(collisions.at(i));
+ }
+ }
+ return NULL;
}
-*/
+
+ClipItem *CustomTrackView::getMainActiveClip() const {
+ QList<QGraphicsItem *> clips = scene()->selectedItems();
+ if (clips.isEmpty()) {
+ return getClipUnderCursor();
+ } else {
+ ClipItem *item = NULL;
+ for (int i = 0; i < clips.count(); ++i) {
+ if (clips.at(i)->type() == AVWIDGET)
+ item = static_cast < ClipItem *>(clips.at(i));
+ if (item->startPos().frames(m_document->fps()) <= m_cursorPos && item->endPos().frames(m_document->fps()) >= m_cursorPos) break;
+ }
+ if (item) return item;
+ }
+ return NULL;
+}
+
+ClipItem *CustomTrackView::getActiveClipUnderCursor() const {
+ QList<QGraphicsItem *> clips = scene()->selectedItems();
+ if (clips.isEmpty()) {
+ return getClipUnderCursor();
+ } else {
+ ClipItem *item;
+ for (int i = 0; i < clips.count(); ++i) {
+ if (clips.at(i)->type() == AVWIDGET)
+ item = static_cast < ClipItem *>(clips.at(i));
+ if (item->startPos().frames(m_document->fps()) <= m_cursorPos && item->endPos().frames(m_document->fps()) >= m_cursorPos) return item;
+ }
+ }
+ return NULL;
+}
+
+void CustomTrackView::setInPoint() {
+ ClipItem *clip = getActiveClipUnderCursor();
+ if (clip == NULL) {
+ emit displayMessage(i18n("You must select one clip for this action"), ErrorMessage);
+ return;
+ }
+ ItemInfo startInfo = clip->info();
+ ItemInfo endInfo = clip->info();
+ endInfo.startPos = GenTime(m_cursorPos, m_document->fps());
+ ResizeClipCommand *command = new ResizeClipCommand(this, startInfo, endInfo, true);
+ m_commandStack->push(command);
+}
+
+void CustomTrackView::setOutPoint() {
+ ClipItem *clip = getActiveClipUnderCursor();
+ if (clip == NULL) {
+ emit displayMessage(i18n("You must select one clip for this action"), ErrorMessage);
+ return;
+ }
+ ItemInfo startInfo = clip->info();
+ ItemInfo endInfo = clip->info();
+ endInfo.endPos = GenTime(m_cursorPos, m_document->fps());
+ ResizeClipCommand *command = new ResizeClipCommand(this, startInfo, endInfo, true);
+ m_commandStack->push(command);
+}
+
#include "customtrackview.moc"
void changeClipSpeed();
void doChangeClipSpeed(ItemInfo info, double speed, const QString &id);
void setDocumentModified();
+ void setInPoint();
+ void setOutPoint();
public slots:
void setCursorPos(int pos, bool seek = true);
bool canBePastedTo(ItemInfo info, int type) const;
bool canBePasted(QList<AbstractClipItem *> items, GenTime offset, int trackOffset) const;
bool canBeMoved(QList<AbstractClipItem *> items, GenTime offset, int trackOffset) const;
+ ClipItem *getClipUnderCursor() const;
+ ClipItem *getMainActiveClip() const;
+ ClipItem *getActiveClipUnderCursor() const;
private slots:
void slotRefreshGuides();
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE kpartgui SYSTEM "kpartgui.dtd">
-<gui name="kdenlive" version="21">
+<gui name="kdenlive" version="22">
<ToolBar name="extraToolBar" >
<text>Extra Toolbar</text>
<Action name="project_render" />
<Menu name="monitor" ><text>Monitor</text>
<Action name="monitor_play" />
<Separator />
- <Action name="seek_start" />
- <Action name="monitor_seek_snap_backward" />
- <Action name="seek_clip_start" />
+ <Menu name="monitor_go" ><text>Go To</text>
+ <Action name="seek_start" />
+ <Action name="monitor_seek_snap_backward" />
+ <Action name="seek_clip_start" />
+ <Action name="seek_clip_end" />
+ <Action name="monitor_seek_snap_forward" />
+ <Action name="seek_end" />
+ </Menu>
<Action name="monitor_seek_backward" />
<Action name="monitor_seek_backward-one-frame" />
<Action name="monitor_seek_forward-one-frame" />
<Action name="monitor_seek_forward" />
- <Action name="seek_clip_end" />
- <Action name="monitor_seek_snap_forward" />
- <Action name="seek_end" />
+ <Separator />
+ <Action name="mark_in" />
+ <Action name="mark_out" />
</Menu>
<Menu name="dockwindows" ><text>View</text>
</Menu>
connect(projectRender, SIGNAL(triggered(bool)), this, SLOT(slotRenderProject()));
KAction* monitorPlay = new KAction(KIcon("media-playback-start"), i18n("Play"), this);
- monitorPlay->setShortcut(Qt::Key_Space);
+ KShortcut playShortcut;
+ playShortcut.setPrimary(Qt::Key_Space);
+ playShortcut.setAlternate(Qt::Key_K);
+ monitorPlay->setShortcut(playShortcut);
actionCollection()->addAction("monitor_play", monitorPlay);
connect(monitorPlay, SIGNAL(triggered(bool)), m_monitorManager, SLOT(slotPlay()));
+ KAction *markIn = actionCollection()->addAction("mark_in");
+ markIn->setText(i18n("Set in point"));
+ markIn->setShortcut(Qt::Key_I);
+ connect(markIn, SIGNAL(triggered(bool)), this, SLOT(slotSetInPoint()));
+
+ KAction *markOut = actionCollection()->addAction("mark_out");
+ markOut->setText(i18n("Set in point"));
+ markOut->setShortcut(Qt::Key_O);
+ connect(markOut, SIGNAL(triggered(bool)), this, SLOT(slotSetOutPoint()));
+
KAction* monitorSeekBackward = new KAction(KIcon("media-seek-backward"), i18n("Rewind"), this);
monitorSeekBackward->setShortcut(Qt::Key_J);
actionCollection()->addAction("monitor_seek_backward", monitorSeekBackward);
}
void MainWindow::slotSnapRewind() {
- if (m_monitorManager->projectMonitorFocused()) {
+ if (m_projectMonitor->isActive()) {
if (m_activeTimeline)
m_activeTimeline->projectView()->slotSeekToPreviousSnap();
}
}
void MainWindow::slotSnapForward() {
- if (m_monitorManager->projectMonitorFocused()) {
+ if (m_projectMonitor->isActive()) {
if (m_activeTimeline)
m_activeTimeline->projectView()->slotSeekToNextSnap();
}
}
void MainWindow::slotClipStart() {
- if (m_monitorManager->projectMonitorFocused()) {
+ if (m_projectMonitor->isActive()) {
if (m_activeTimeline)
m_activeTimeline->projectView()->clipStart();
}
}
void MainWindow::slotClipEnd() {
- if (m_monitorManager->projectMonitorFocused()) {
+ if (m_projectMonitor->isActive()) {
if (m_activeTimeline)
m_activeTimeline->projectView()->clipEnd();
}
}
+void MainWindow::slotSetInPoint() {
+ if (m_clipMonitor->isActive()) {
+ m_clipMonitor->slotSetZoneStart();
+ } else m_activeTimeline->projectView()->setInPoint();
+}
+
+void MainWindow::slotSetOutPoint() {
+ if (m_clipMonitor->isActive()) {
+ m_clipMonitor->slotSetZoneEnd();
+ } else m_activeTimeline->projectView()->setOutPoint();
+}
+
#include "mainwindow.moc"
void slotAdjustClipMonitor();
void slotAdjustProjectMonitor();
void slotSaveZone(Render *render, QPoint zone);
+
+ void slotSetInPoint();
+ void slotSetOutPoint();
};
if (!outputFile.isEmpty()) frame.save(outputFile);
}
+bool Monitor::isActive() const {
+ return m_isActive;
+}
+
void Monitor::activateMonitor() {
if (!m_isActive) m_monitorManager->activateMonitor(m_name);
}
MonitorRefresh(QWidget* parent);
virtual void paintEvent(QPaintEvent * event);
void setRenderer(Render* render);
+
private:
Render *m_renderer;
};
void resetProfile();
QString name() const;
void resetSize();
+ bool isActive() const;
protected:
virtual void mousePressEvent(QMouseEvent * event);
void slotSetThumbFrame();
void slotSetSizeOneToOne();
void slotSetSizeOneToTwo();
- void slotSetZoneStart();
- void slotSetZoneEnd();
void slotSaveZone();
public slots:
void saveSceneList(QString path, QDomElement info = QDomElement());
void slotStart();
void slotEnd();
+ void slotSetZoneStart();
+ void slotSetZoneEnd();
void slotZoneStart();
void slotZoneEnd();
void slotZoneMoved(int start, int end);
m_projectMonitor = projectMonitor;
}
-bool MonitorManager::projectMonitorFocused() {
- if (m_activeMonitor != "clip") return true;
- return false;
-}
-
void MonitorManager::activateMonitor(QString name) {
if (m_activeMonitor == name) return;
if (name == "clip") {
void initMonitors(Monitor *clipMonitor, Monitor *projectMonitor);
Timecode timecode();
void switchMonitors();
- bool projectMonitorFocused();
void resetProfiles(Timecode tc);
public slots: