X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fheadertrack.cpp;h=3165a482829aa3f80ecc9698586fde3478f95733;hb=f91e1561b66d8ceb35097f1ad4523b59951cd417;hp=0ad355487438d30ab74cb4a57628857176effa15;hpb=833cf1051c3e0ace17ec9994cb929d6784bfe815;p=kdenlive diff --git a/src/headertrack.cpp b/src/headertrack.cpp index 0ad35548..3165a482 100644 --- a/src/headertrack.cpp +++ b/src/headertrack.cpp @@ -17,93 +17,214 @@ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * ***************************************************************************/ + +#include "headertrack.h" + +#include +#include +#include +#include + #include -#include -#include #include #include #include +#include +#include -#include -#include -#include +HeaderTrack::HeaderTrack(int index, TrackInfo info, int height, QWidget *parent) : + QWidget(parent), + m_index(index), + m_type(info.type), + m_isSelected(false) +{ + setFixedHeight(height); + setupUi(this); + QColor col = track_number->palette().color(QPalette::Base); + track_number->setStyleSheet(QString("QLineEdit { background-color: transparent;} QLineEdit:hover{ background-color: rgb(%1, %2, %3);} QLineEdit:focus { background-color: rgb(%1, %2, %3);}").arg(col.red()).arg(col.green()).arg(col.blue())); -#include "kdenlivesettings.h" -#include "headertrack.h" + 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")); + 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); -HeaderTrack::HeaderTrack(int index, TrackInfo info, QWidget *parent) - : QWidget(parent), m_index(index), m_type(info.type) { - setFixedHeight(KdenliveSettings::trackheight()); - view.setupUi(this); - view.track_number->setText(QString::number(m_index)); - view.buttonVideo->setChecked(!info.isBlind); - view.buttonAudio->setChecked(!info.isMute); if (m_type == VIDEOTRACK) { - view.frame->setBackgroundRole(QPalette::AlternateBase); - view.frame->setAutoFillBackground(true); - if (!info.isBlind) view.buttonVideo->setIcon(KIcon("kdenlive-show-video")); - else 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 { - view.buttonVideo->setHidden(true); + buttonVideo->setHidden(true); } - if (!info.isMute) view.buttonAudio->setIcon(KIcon("kdenlive-show-audio")); - else view.buttonAudio->setIcon(KIcon("kdenlive-hide-audio")); - connect(view.buttonVideo, SIGNAL(clicked()), this, SLOT(switchVideo())); - connect(view.buttonAudio, SIGNAL(clicked()), this, SLOT(switchAudio())); + 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())); - m_contextMenu = new QMenu(this); + // Don't show track buttons if size is too small + if (height < 40) { + buttonVideo->setHidden(true); + buttonAudio->setHidden(true); + buttonLock->setHidden(true); + //horizontalSpacer; + } - //TODO: implement add/remove track - /*QAction *insertAction = new QAction(i18n("Insert track"), this); - m_contextMenu->addAction(insertAction); + setContextMenuPolicy(Qt::DefaultContextMenu); //Qt::ActionsContextMenu); + QAction *insertAction = new QAction(i18n("Insert Track"), this); + m_menu.addAction(insertAction); connect(insertAction, SIGNAL(triggered()), this, SLOT(slotAddTrack())); - QAction *removeAction = new QAction(KIcon("edit-delete"), i18n("Delete track"), this); - m_contextMenu->addAction(removeAction); - connect(removeAction, SIGNAL(triggered()), this, SLOT(slotDeleteTrack()));*/ + QAction *removeAction = new QAction(KIcon("edit-delete"), i18n("Delete Track"), this); + m_menu.addAction(removeAction); + connect(removeAction, SIGNAL(triggered()), this, SLOT(slotDeleteTrack())); + + QAction *configAction = new QAction(KIcon("configure"), i18n("Configure Track"), this); + m_menu.addAction(configAction); + connect(configAction, SIGNAL(triggered()), this, SLOT(slotConfigTrack())); } -void HeaderTrack::switchVideo() { - if (view.buttonVideo->isChecked()) { - view.buttonVideo->setIcon(KIcon("kdenlive-show-video")); - } else { - view.buttonVideo->setIcon(KIcon("kdenlive-hide-video")); +/*HeaderTrack::~HeaderTrack() +{ +}*/ + +// virtual +void HeaderTrack::mousePressEvent(QMouseEvent * event) +{ + if (track_number->hasFocus()) { + track_number->clearFocus(); + return; } - emit switchTrackVideo(m_index); + if (!m_isSelected) emit selectTrack(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); } -void HeaderTrack::switchAudio() { - if (view.buttonAudio->isChecked()) { - view.buttonAudio->setIcon(KIcon("kdenlive-show-audio")); +void HeaderTrack::setSelectedIndex(int ix) +{ + if (m_index == ix) { + m_isSelected = true; + setBackgroundRole(QPalette::Button); + setAutoFillBackground(true); + } else if (m_type != VIDEOTRACK) { + m_isSelected = false; + setAutoFillBackground(false); } else { - view.buttonAudio->setIcon(KIcon("kdenlive-hide-audio")); + m_isSelected = false; + 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 (buttonVideo->isChecked()) + buttonVideo->setIcon(KIcon("kdenlive-hide-video")); + else + buttonVideo->setIcon(KIcon("kdenlive-show-video")); + emit switchTrackVideo(m_index); +} + +void HeaderTrack::switchAudio() +{ + if (buttonAudio->isChecked()) + buttonAudio->setIcon(KIcon("kdenlive-hide-audio")); + else + buttonAudio->setIcon(KIcon("kdenlive-show-audio")); emit switchTrackAudio(m_index); } -void HeaderTrack::slotDeleteTrack() { +void HeaderTrack::switchLock(bool emitSignal) +{ + if (buttonLock->isChecked()) + buttonLock->setIcon(KIcon("kdenlive-lock")); + else + buttonLock->setIcon(KIcon("kdenlive-unlock")); + if (emitSignal) + emit switchTrackLock(m_index); +} + +void HeaderTrack::setLock(bool lock) +{ + buttonLock->setChecked(lock); + switchLock(false); +} + +void HeaderTrack::slotDeleteTrack() +{ + QTimer::singleShot(500, this, SLOT(deleteTrack())); +} + +void HeaderTrack::deleteTrack() +{ emit deleteTrack(m_index); } -void HeaderTrack::slotAddTrack() { +void HeaderTrack::slotAddTrack() +{ emit insertTrack(m_index); } -// virtual -void HeaderTrack::contextMenuEvent(QContextMenuEvent * event) { - m_contextMenu->popup(event->globalPos()); +void HeaderTrack::slotRenameTrack() +{ + if (m_name != track_number->text()) emit renameTrack(m_index, track_number->text()); } -// 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"