]> git.sesse.net Git - kdenlive/blobdiff - src/headertrack.cpp
Merge branch 'master' into buildsystem
[kdenlive] / src / headertrack.cpp
index de53684d41a30c85d31506d1f00b6ec45a6caee2..b806a01ceb1c20f26d78a9bb77fbb4f52b09bf1e 100644 (file)
 
 
 #include "headertrack.h"
+#include "effectslist.h"
+#include "kdenlivesettings.h"
 
 #include <KIcon>
 #include <KLocale>
 #include <KDebug>
-#include <KColorScheme>
 
 #include <QMouseEvent>
 #include <QWidget>
 #include <QPainter>
 #include <QAction>
 #include <QTimer>
+#include <QDomDocument>
 
 HeaderTrack::HeaderTrack(int index, TrackInfo info, int height, QWidget *parent) :
         QWidget(parent),
         m_index(index),
-        m_type(info.type)
+        m_type(info.type),
+        m_isSelected(false)
 {
     setFixedHeight(height);
     setupUi(this);
-    track_number->setText(info.trackName.isEmpty() ? QString::number(m_index) : info.trackName);
+
+    m_name = info.trackName.isEmpty() ? QString::number(m_index) : info.trackName;
+    track_number->setText(m_name);
+    connect(track_number, SIGNAL(editingFinished()), this, SLOT(slotRenameTrack()));
 
     buttonVideo->setChecked(info.isBlind);
     buttonVideo->setToolTip(i18n("Hide track"));
@@ -46,25 +52,29 @@ HeaderTrack::HeaderTrack(int index, TrackInfo info, int height, QWidget *parent)
     buttonAudio->setToolTip(i18n("Mute track"));
     buttonLock->setChecked(info.isLocked);
     buttonLock->setToolTip(i18n("Lock track"));
-
-    QPalette p = palette();
-    KColorScheme scheme(p.currentColorGroup(), KColorScheme::Window);
-    p.setColor(QPalette::Button, scheme.background(KColorScheme::ActiveBackground).color().darker(120));
-    setPalette(p);
+    effect_label->setPixmap(KIcon("kdenlive-track_has_effect").pixmap(16, 16));
+    updateEffectLabel(info.effectsList.effectNames());
+    setAcceptDrops(true);
 
     if (m_type == VIDEOTRACK) {
         setBackgroundRole(QPalette::AlternateBase);
         setAutoFillBackground(true);
-        if (!info.isBlind) buttonVideo->setIcon(KIcon("kdenlive-show-video"));
-        else buttonVideo->setIcon(KIcon("kdenlive-hide-video"));
+        if (!info.isBlind)
+            buttonVideo->setIcon(KIcon("kdenlive-show-video"));
+        else
+            buttonVideo->setIcon(KIcon("kdenlive-hide-video"));
     } else {
         buttonVideo->setHidden(true);
     }
-    if (!info.isMute) buttonAudio->setIcon(KIcon("kdenlive-show-audio"));
-    else buttonAudio->setIcon(KIcon("kdenlive-hide-audio"));
+    if (!info.isMute)
+        buttonAudio->setIcon(KIcon("kdenlive-show-audio"));
+    else
+        buttonAudio->setIcon(KIcon("kdenlive-hide-audio"));
 
-    if (!info.isLocked) buttonLock->setIcon(KIcon("kdenlive-unlock"));
-    else buttonLock->setIcon(KIcon("kdenlive-lock"));
+    if (!info.isLocked)
+        buttonLock->setIcon(KIcon("kdenlive-unlock"));
+    else
+        buttonLock->setIcon(KIcon("kdenlive-lock"));
 
     connect(buttonVideo, SIGNAL(clicked()), this, SLOT(switchVideo()));
     connect(buttonAudio, SIGNAL(clicked()), this, SLOT(switchAudio()));
@@ -78,36 +88,113 @@ HeaderTrack::HeaderTrack(int index, TrackInfo info, int height, QWidget *parent)
         //horizontalSpacer;
     }
 
-    setContextMenuPolicy(Qt::ActionsContextMenu);
+    setContextMenuPolicy(Qt::DefaultContextMenu); //Qt::ActionsContextMenu);
     QAction *insertAction = new QAction(i18n("Insert Track"), this);
-    addAction(insertAction);
+    m_menu.addAction(insertAction);
     connect(insertAction, SIGNAL(triggered()), this, SLOT(slotAddTrack()));
 
     QAction *removeAction = new QAction(KIcon("edit-delete"), i18n("Delete Track"), this);
-    addAction(removeAction);
+    m_menu.addAction(removeAction);
     connect(removeAction, SIGNAL(triggered()), this, SLOT(slotDeleteTrack()));
 
-    QAction *changeAction = new QAction(i18n("Change Track Type"), this);
-    addAction(changeAction);
-    connect(changeAction, SIGNAL(triggered()), this, SLOT(slotChangeTrack()));
-
-    QAction *renameAction = new QAction(i18n("Rename Track"), this);
-    addAction(renameAction);
-    connect(renameAction, SIGNAL(triggered()), this, SLOT(slotRenameTrack()));
-
+    QAction *configAction = new QAction(KIcon("configure"), i18n("Configure Track"), this);
+    m_menu.addAction(configAction);
+    connect(configAction, SIGNAL(triggered()), this, SLOT(slotConfigTrack()));
 }
 
 /*HeaderTrack::~HeaderTrack()
 {
 }*/
 
+void HeaderTrack::updateEffectLabel(QStringList effects)
+{
+    if (!effects.isEmpty()) {
+        effect_label->setHidden(false);
+        effect_label->setToolTip(effects.join("/"));
+    } else {
+        effect_label->setHidden(true);
+        effect_label->setToolTip(QString());
+    }
+}
+
+// virtual
+void HeaderTrack::mousePressEvent(QMouseEvent * event)
+{
+    if (track_number->hasFocus()) {
+        track_number->clearFocus();
+        return;
+    }
+    if (!m_isSelected) emit selectTrack(m_index);
+    emit showTrackEffects(m_index);
+    QWidget::mousePressEvent(event);
+}
+
+// virtual
+void HeaderTrack::contextMenuEvent(QContextMenuEvent * event)
+{
+    if (track_number->hasFocus()) {
+        track_number->clearFocus();
+        return;
+    }
+    m_menu.popup(event->globalPos());
+}
+
+void HeaderTrack::mouseDoubleClickEvent(QMouseEvent* event)
+{
+    if (track_number->hasFocus()) {
+        track_number->clearFocus();
+        return;
+    }
+    slotConfigTrack();
+    QWidget::mouseDoubleClickEvent(event);
+}
+
+//virtual
+void HeaderTrack::dropEvent(QDropEvent * event)
+{
+    const QString effects = QString::fromUtf8(event->mimeData()->data("kdenlive/effectslist"));
+    QDomDocument doc;
+    doc.setContent(effects, true);
+    const QDomElement e = doc.documentElement();
+    emit selectTrack(m_index);
+    emit addTrackInfo(e, m_index);
+    /*if (scene() && !scene()->views().isEmpty()) {
+        event->accept();
+        CustomTrackView *view = (CustomTrackView *) scene()->views()[0];
+        if (view) view->slotAddEffect(e, m_info.startPos, track());
+    }*/
+}
+
+//virtual
+void HeaderTrack::dragEnterEvent(QDragEnterEvent *event)
+{
+    if (buttonLock->isChecked()) {
+        event->setAccepted(false);
+    } else {
+        if (event->mimeData()->hasFormat("kdenlive/effectslist")) {
+            const QString effects = QString::fromUtf8(event->mimeData()->data("kdenlive/effectslist"));
+            QDomDocument doc;
+            doc.setContent(effects, true);
+            if (doc.documentElement().attribute("id") != "speed") {
+                event->setAccepted(true);
+            }
+        }
+    }
+}
+
 void HeaderTrack::setSelectedIndex(int ix)
 {
     if (m_index == ix) {
+        m_isSelected = true;
         setBackgroundRole(QPalette::Button);
         setAutoFillBackground(true);
-    } else if (m_type != VIDEOTRACK) setAutoFillBackground(false);
-    else setBackgroundRole(QPalette::AlternateBase);
+    } else if (m_type != VIDEOTRACK) {
+        m_isSelected = false;
+        setAutoFillBackground(false);
+    } else {
+        m_isSelected = false;
+        setBackgroundRole(QPalette::AlternateBase);
+    }
     update();
 }
 
@@ -115,7 +202,8 @@ void HeaderTrack::adjustSize(int height)
 {
     // Don't show track buttons if size is too small
     bool smallTracks = height < 40;
-    if (m_type == VIDEOTRACK) buttonVideo->setHidden(smallTracks);
+    if (m_type == VIDEOTRACK)
+        buttonVideo->setHidden(smallTracks);
     buttonAudio->setHidden(smallTracks);
     buttonLock->setHidden(smallTracks);
     setFixedHeight(height);
@@ -123,35 +211,32 @@ void HeaderTrack::adjustSize(int height)
 
 void HeaderTrack::switchVideo()
 {
-    if (buttonVideo->isChecked()) {
+    if (buttonVideo->isChecked())
         buttonVideo->setIcon(KIcon("kdenlive-hide-video"));
-    } else {
+    else
         buttonVideo->setIcon(KIcon("kdenlive-show-video"));
-    }
     emit switchTrackVideo(m_index);
 }
 
 void HeaderTrack::switchAudio()
 {
-    if (buttonAudio->isChecked()) {
+    if (buttonAudio->isChecked())
         buttonAudio->setIcon(KIcon("kdenlive-hide-audio"));
-    } else {
+    else
         buttonAudio->setIcon(KIcon("kdenlive-show-audio"));
-    }
     emit switchTrackAudio(m_index);
 }
 
 void HeaderTrack::switchLock(bool emitSignal)
 {
-    if (buttonLock->isChecked()) {
+    if (buttonLock->isChecked())
         buttonLock->setIcon(KIcon("kdenlive-lock"));
-    } else {
+    else
         buttonLock->setIcon(KIcon("kdenlive-unlock"));
-    }
-    if (emitSignal) emit switchTrackLock(m_index);
+    if (emitSignal)
+        emit switchTrackLock(m_index);
 }
 
-
 void HeaderTrack::setLock(bool lock)
 {
     buttonLock->setChecked(lock);
@@ -173,14 +258,14 @@ void HeaderTrack::slotAddTrack()
     emit insertTrack(m_index);
 }
 
-void HeaderTrack::slotChangeTrack()
+void HeaderTrack::slotRenameTrack()
 {
-    emit changeTrack(m_index);
+    if (m_name != track_number->text()) emit renameTrack(m_index, track_number->text());
 }
 
-void HeaderTrack::slotRenameTrack()
+void HeaderTrack::slotConfigTrack()
 {
-    emit renameTrack(m_index);
+    emit configTrack(m_index);
 }