]> git.sesse.net Git - kdenlive/blobdiff - src/headertrack.cpp
Allow to preserve aspect ratio in render dialog resize option:
[kdenlive] / src / headertrack.cpp
index af41b01525a61ad97bdce7f27dc3f526d8cecf3a..a3babea7bc16f5f23a7dd10f2f0b45de8034ecb1 100644 (file)
 
 
 #include "headertrack.h"
-#include "kdenlivesettings.h"
 
 #include <KIcon>
 #include <KLocale>
 #include <KDebug>
+#include <KColorScheme>
 
 #include <QMouseEvent>
 #include <QWidget>
 #include <QPainter>
 #include <QAction>
+#include <QTimer>
 
-HeaderTrack::HeaderTrack(int index, TrackInfo info, QWidget *parent) :
+HeaderTrack::HeaderTrack(int index, TrackInfo info, int height, QWidget *parent) :
         QWidget(parent),
         m_index(index),
         m_type(info.type)
 {
-    setFixedHeight(KdenliveSettings::trackheight());
-    m_view.setupUi(this);
-    m_view.track_number->setText(QString::number(m_index));
-    m_view.buttonVideo->setChecked(!info.isBlind);
-    m_view.buttonVideo->setToolTip(i18n("Hide track"));
-    m_view.buttonAudio->setChecked(!info.isMute);
-    m_view.buttonAudio->setToolTip(i18n("Mute track"));
-    m_view.buttonLock->setChecked(info.isLocked);
-    m_view.buttonLock->setToolTip(i18n("Lock track"));
+    setFixedHeight(height);
+    setupUi(this);
+    track_number->setText(info.trackName.isEmpty() ? QString::number(m_index) : info.trackName);
+
+    buttonVideo->setChecked(info.isBlind);
+    buttonVideo->setToolTip(i18n("Hide track"));
+    buttonAudio->setChecked(info.isMute);
+    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);
 
     if (m_type == VIDEOTRACK) {
-        m_view.frame->setBackgroundRole(QPalette::AlternateBase);
-        m_view.frame->setAutoFillBackground(true);
-        if (!info.isBlind) m_view.buttonVideo->setIcon(KIcon("kdenlive-show-video"));
-        else m_view.buttonVideo->setIcon(KIcon("kdenlive-hide-video"));
+        setBackgroundRole(QPalette::AlternateBase);
+        setAutoFillBackground(true);
+        if (!info.isBlind) buttonVideo->setIcon(KIcon("kdenlive-show-video"));
+        else buttonVideo->setIcon(KIcon("kdenlive-hide-video"));
     } else {
-        m_view.buttonVideo->setHidden(true);
+        buttonVideo->setHidden(true);
+    }
+    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"));
+
+    connect(buttonVideo, SIGNAL(clicked()), this, SLOT(switchVideo()));
+    connect(buttonAudio, SIGNAL(clicked()), this, SLOT(switchAudio()));
+    connect(buttonLock, SIGNAL(clicked()), this, SLOT(switchLock()));
+
+    // Don't show track buttons if size is too small
+    if (height < 40) {
+        buttonVideo->setHidden(true);
+        buttonAudio->setHidden(true);
+        buttonLock->setHidden(true);
+        //horizontalSpacer;
     }
-    if (!info.isMute) m_view.buttonAudio->setIcon(KIcon("kdenlive-show-audio"));
-    else m_view.buttonAudio->setIcon(KIcon("kdenlive-hide-audio"));
-
-    if (!info.isLocked) m_view.buttonLock->setIcon(KIcon("kdenlive-unlock"));
-    else m_view.buttonLock->setIcon(KIcon("kdenlive-lock"));
-
-    connect(m_view.buttonVideo, SIGNAL(clicked()), this, SLOT(switchVideo()));
-    connect(m_view.buttonAudio, SIGNAL(clicked()), this, SLOT(switchAudio()));
-    connect(m_view.buttonLock, SIGNAL(clicked()), this, SLOT(switchLock()));
 
     setContextMenuPolicy(Qt::ActionsContextMenu);
     QAction *insertAction = new QAction(i18n("Insert Track"), this);
@@ -72,53 +87,90 @@ HeaderTrack::HeaderTrack(int index, TrackInfo info, QWidget *parent) :
     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 *configAction = new QAction(KIcon("configure"), i18n("Configure Track"), this);
+    addAction(configAction);
+    connect(configAction, SIGNAL(triggered()), this, SLOT(slotConfigTrack()));
+}
+
+/*HeaderTrack::~HeaderTrack()
+{
+}*/
+
+// virtual
+void HeaderTrack::mousePressEvent(QMouseEvent * event)
+{
+    emit selectTrack(m_index);
+    QWidget::mousePressEvent(event);
+}
+
+void HeaderTrack::mouseDoubleClickEvent(QMouseEvent* event)
+{
+    slotConfigTrack();
+    QWidget::mouseDoubleClickEvent(event);
 }
 
-HeaderTrack::~HeaderTrack()
+void HeaderTrack::setSelectedIndex(int ix)
 {
+    if (m_index == ix) {
+        setBackgroundRole(QPalette::Button);
+        setAutoFillBackground(true);
+    } else if (m_type != VIDEOTRACK) setAutoFillBackground(false);
+    else setBackgroundRole(QPalette::AlternateBase);
+    update();
+}
+
+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);
+    buttonAudio->setHidden(smallTracks);
+    buttonLock->setHidden(smallTracks);
+    setFixedHeight(height);
 }
 
 void HeaderTrack::switchVideo()
 {
-    if (m_view.buttonVideo->isChecked()) {
-        m_view.buttonVideo->setIcon(KIcon("kdenlive-show-video"));
+    if (buttonVideo->isChecked()) {
+        buttonVideo->setIcon(KIcon("kdenlive-hide-video"));
     } else {
-        m_view.buttonVideo->setIcon(KIcon("kdenlive-hide-video"));
+        buttonVideo->setIcon(KIcon("kdenlive-show-video"));
     }
     emit switchTrackVideo(m_index);
 }
 
 void HeaderTrack::switchAudio()
 {
-    if (m_view.buttonAudio->isChecked()) {
-        m_view.buttonAudio->setIcon(KIcon("kdenlive-show-audio"));
+    if (buttonAudio->isChecked()) {
+        buttonAudio->setIcon(KIcon("kdenlive-hide-audio"));
     } else {
-        m_view.buttonAudio->setIcon(KIcon("kdenlive-hide-audio"));
+        buttonAudio->setIcon(KIcon("kdenlive-show-audio"));
     }
     emit switchTrackAudio(m_index);
 }
 
 void HeaderTrack::switchLock(bool emitSignal)
 {
-    if (m_view.buttonLock->isChecked()) {
-        m_view.buttonLock->setIcon(KIcon("kdenlive-lock"));
+    if (buttonLock->isChecked()) {
+        buttonLock->setIcon(KIcon("kdenlive-lock"));
     } else {
-        m_view.buttonLock->setIcon(KIcon("kdenlive-unlock"));
+        buttonLock->setIcon(KIcon("kdenlive-unlock"));
     }
     if (emitSignal) emit switchTrackLock(m_index);
 }
 
-
 void HeaderTrack::setLock(bool lock)
 {
-    m_view.buttonLock->setChecked(lock);
+    buttonLock->setChecked(lock);
     switchLock(false);
 }
 
 void HeaderTrack::slotDeleteTrack()
+{
+    QTimer::singleShot(500, this, SLOT(deleteTrack()));
+}
+
+void HeaderTrack::deleteTrack()
 {
     emit deleteTrack(m_index);
 }
@@ -128,22 +180,15 @@ void HeaderTrack::slotAddTrack()
     emit insertTrack(m_index);
 }
 
-void HeaderTrack::slotChangeTrack()
+void HeaderTrack::slotRenameTrack()
 {
-    emit changeTrack(m_index);
+    emit renameTrack(m_index);
 }
 
-
-// virtual
-/*void HeaderTrack::paintEvent(QPaintEvent *e) {
-    QRect region = e->rect();
-    region.setTopLeft(QPoint(region.left() + 1, region.top() + 1));
-    region.setBottomRight(QPoint(region.right() - 1, region.bottom() - 1));
-    QPainter painter(this);
-    if (m_type == AUDIOTRACK) painter.fillRect(region, QBrush(QColor(240, 240, 255)));
-    else painter.fillRect(region, QBrush(QColor(255, 255, 255)));
-    painter.drawText(region, Qt::AlignCenter, m_label);
-}*/
+void HeaderTrack::slotConfigTrack()
+{
+    emit configTrack(m_index);
+}
 
 
 #include "headertrack.moc"