X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fprojectlistview.cpp;h=af4f9bc2b5289d4e0685ab49334d1c440c7f035a;hb=c24658bd34221d735f0641c924b890e1a6be7101;hp=0ad67645bae895cdd2190563adec9441cd2576a2;hpb=05f4fad9a19434399f43ff76e06d1e1a5f74c0f6;p=kdenlive diff --git a/src/projectlistview.cpp b/src/projectlistview.cpp index 0ad67645..af4f9bc2 100644 --- a/src/projectlistview.cpp +++ b/src/projectlistview.cpp @@ -17,24 +17,29 @@ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * ***************************************************************************/ +// Self +#include "projectlistview.h" + +// Qt +#include +#include +#include +// KDE +#include +#include +#include + +// KDEnlive #include "projectlistview.h" #include "projectitem.h" #include "subprojectitem.h" #include "folderprojectitem.h" #include "kdenlivesettings.h" -#include -#include -#include - -#include -#include -#include - -ProjectListView::ProjectListView(QWidget *parent) : - QTreeWidget(parent), - m_dragStarted(false) +ProjectListView::ProjectListView(QWidget *parent) + : QTreeWidget(parent) + , m_dragStarted(false) { setSelectionMode(QAbstractItemView::ExtendedSelection); setDragDropMode(QAbstractItemView::DragDrop); @@ -45,15 +50,7 @@ ProjectListView::ProjectListView(QWidget *parent) : setFrameShape(QFrame::NoFrame); setRootIsDecorated(true); - QString style = "QTreeView::branch:has-siblings:!adjoins-item{border-image: none;border:0px} \ - QTreeView::branch:has-siblings:adjoins-item {border-image: none;border:0px} \ - QTreeView::branch:!has-children:!has-siblings:adjoins-item {border-image: none;border:0px} \ - QTreeView::branch:has-children:!has-siblings:closed,QTreeView::branch:closed:has-children:has-siblings { \ - border-image: none;image: url(:/images/stylesheet-branch-closed.png);} \ - QTreeView::branch:open:has-children:!has-siblings,QTreeView::branch:open:has-children:has-siblings { \ - border-image: none;image: url(:/images/stylesheet-branch-open.png);}"; - - setStyleSheet(style); + updateStyleSheet(); setColumnCount(4); QStringList headers; @@ -63,25 +60,44 @@ ProjectListView::ProjectListView(QWidget *parent) : QHeaderView* headerView = header(); headerView->setContextMenuPolicy(Qt::CustomContextMenu); - connect(headerView, SIGNAL(customContextMenuRequested(const QPoint&)), - this, SLOT(configureColumns(const QPoint&))); - connect(this, SIGNAL(itemCollapsed(QTreeWidgetItem *)), this, SLOT(slotCollapsed(QTreeWidgetItem *))); - connect(this, SIGNAL(itemExpanded(QTreeWidgetItem *)), this, SLOT(slotExpanded(QTreeWidgetItem *))); + connect(headerView, SIGNAL(customContextMenuRequested(QPoint)), + this, SLOT(configureColumns(QPoint))); + connect(this, SIGNAL(itemCollapsed(QTreeWidgetItem*)), this, SLOT(slotCollapsed(QTreeWidgetItem*))); + connect(this, SIGNAL(itemExpanded(QTreeWidgetItem*)), this, SLOT(slotExpanded(QTreeWidgetItem*))); headerView->setClickable(true); headerView->setSortIndicatorShown(true); headerView->setMovable(false); sortByColumn(0, Qt::AscendingOrder); setSortingEnabled(true); installEventFilter(this); - if (!KdenliveSettings::showdescriptioncolumn()) hideColumn(1); - if (!KdenliveSettings::showratingcolumn()) hideColumn(2); - if (!KdenliveSettings::showdatecolumn()) hideColumn(3); + + if (!KdenliveSettings::showdescriptioncolumn()) { + hideColumn(1); + } + if (!KdenliveSettings::showratingcolumn()) { + hideColumn(2); + } + if (!KdenliveSettings::showdatecolumn()) { + hideColumn(3); + } } ProjectListView::~ProjectListView() { } +void ProjectListView::updateStyleSheet() +{ + QString style = "QTreeView::branch:has-siblings:!adjoins-item{border-image: none;border:0px} \ + QTreeView::branch:has-siblings:adjoins-item {border-image: none;border:0px} \ + QTreeView::branch:!has-children:!has-siblings:adjoins-item {border-image: none;border:0px} \ + QTreeView::branch:has-children:!has-siblings:closed,QTreeView::branch:closed:has-children:has-siblings { \ + border-image: none;image: url(:/images/stylesheet-branch-closed.png);} \ + QTreeView::branch:open:has-children:!has-siblings,QTreeView::branch:open:has-children:has-siblings { \ + border-image: none;image: url(:/images/stylesheet-branch-open.png);}"; + setStyleSheet(style); +} + void ProjectListView::processLayout() { executeDelayedItemsLayout(); @@ -138,7 +154,7 @@ void ProjectListView::contextMenuEvent(QContextMenuEvent * event) void ProjectListView::slotCollapsed(QTreeWidgetItem *item) { - if (item->type() == PROJECTFOLDERTYPE) { + if (item->type() == ProjectFoldeType) { blockSignals(true); static_cast (item)->switchIcon(); blockSignals(false); @@ -147,7 +163,7 @@ void ProjectListView::slotCollapsed(QTreeWidgetItem *item) void ProjectListView::slotExpanded(QTreeWidgetItem *item) { - if (item->type() == PROJECTFOLDERTYPE) { + if (item->type() == ProjectFoldeType) { blockSignals(true); static_cast (item)->switchIcon(); blockSignals(false); @@ -180,11 +196,12 @@ void ProjectListView::mouseDoubleClickEvent(QMouseEvent * event) { QTreeWidgetItem *it = itemAt(event->pos()); if (!it) { + emit pauseMonitor(); emit addClip(); return; } ProjectItem *item; - if (it->type() == PROJECTFOLDERTYPE) { + if (it->type() == ProjectFoldeType) { if ((columnAt(event->pos().x()) == 0)) { QPixmap pix = qVariantValue(it->data(0, Qt::DecorationRole)); int offset = pix.width() + indentation(); @@ -195,7 +212,7 @@ void ProjectListView::mouseDoubleClickEvent(QMouseEvent * event) } return; } - if (it->type() == PROJECTSUBCLIPTYPE) { + if (it->type() == ProjectSubclipType) { // subitem if ((columnAt(event->pos().x()) == 1)) { QTreeWidget::mouseDoubleClickEvent(event); @@ -207,7 +224,7 @@ void ProjectListView::mouseDoubleClickEvent(QMouseEvent * event) if (!(item->flags() & Qt::ItemIsDragEnabled)) return; int column = columnAt(event->pos().x()); - if (column == 0 && (item->clipType() == SLIDESHOW || item->clipType() == TEXT || item->clipType() == COLOR || it->childCount() > 0)) { + if (column == 0 && (item->clipType() == SlideShow || item->clipType() == Text || item->clipType() == Color || it->childCount() > 0)) { QPixmap pix = qVariantValue(it->data(0, Qt::DecorationRole)); int offset = pix.width() + indentation(); if (item->parent()) offset += indentation(); @@ -222,7 +239,7 @@ void ProjectListView::mouseDoubleClickEvent(QMouseEvent * event) return; } } - if ((column == 1) && it->type() != PROJECTSUBCLIPTYPE) { + if ((column == 1) && it->type() != ProjectSubclipType) { QTreeWidget::mouseDoubleClickEvent(event); return; } @@ -235,7 +252,7 @@ void ProjectListView::dropEvent(QDropEvent *event) { FolderProjectItem *item = NULL; QTreeWidgetItem *it = itemAt(event->pos()); - while (it && it->type() != PROJECTFOLDERTYPE) { + while (it && it->type() != ProjectFoldeType) { it = it->parent(); } if (it) item = static_cast (it); @@ -259,10 +276,10 @@ void ProjectListView::dropEvent(QDropEvent *event) QString parentId = item->clipId(); foreach(QTreeWidgetItem *it, list) { // TODO allow dragging of folders ? - if (it->type() == PROJECTCLIPTYPE) { + if (it->type() == ProjectClipType) { if (it->parent()) clone = (ProjectItem*) it->parent()->takeChild(it->parent()->indexOfChild(it)); else clone = (ProjectItem*) takeTopLevelItem(indexOfTopLevelItem(it)); - if (clone) { + if (clone && item) { item->addChild(clone); QMap props; props.insert("groupname", item->groupName()); @@ -276,7 +293,7 @@ void ProjectListView::dropEvent(QDropEvent *event) const QList list = selectedItems(); ProjectItem *clone; foreach(QTreeWidgetItem *it, list) { - if (it->type() != PROJECTCLIPTYPE) continue; + if (it->type() != ProjectClipType) continue; QTreeWidgetItem *parent = it->parent(); if (parent/* && ((ProjectItem *) it)->clipId() < 10000*/) { kDebug() << "++ item parent: " << parent->text(1); @@ -294,7 +311,12 @@ void ProjectListView::dropEvent(QDropEvent *event) QStringList list = QString(event->mimeData()->data("kdenlive/clip")).split(';'); emit addClipCut(list.at(0), list.at(1).toInt(), list.at(2).toInt()); } - event->acceptProposedAction(); + if (event->source() == this) { + event->setDropAction(Qt::MoveAction); + event->accept(); + } else { + event->acceptProposedAction(); + } QTreeWidget::dropEvent(event); } @@ -323,7 +345,7 @@ void ProjectListView::mouseReleaseEvent(QMouseEvent *event) { QTreeWidget::mouseReleaseEvent(event); QTreeWidgetItem *underMouse = itemAt(event->pos()); - if (underMouse) emit focusMonitor(); + if (underMouse) emit focusMonitor(true); } // virtual @@ -338,56 +360,40 @@ void ProjectListView::mouseMoveEvent(QMouseEvent *event) QTreeWidgetItem *it = itemAt(m_DragStartPosition); if (!it) return; - if (it->type() == PROJECTSUBCLIPTYPE) { - // subitem - SubProjectItem *clickItem = static_cast (it); - if (clickItem && (clickItem->flags() & Qt::ItemIsDragEnabled)) { - ProjectItem *clip = static_cast (it->parent()); - QDrag *drag = new QDrag(this); - QMimeData *mimeData = new QMimeData; - - QStringList list; - list.append(clip->clipId()); - QPoint p = clickItem->zone(); - list.append(QString::number(p.x())); - list.append(QString::number(p.y())); - QByteArray data; - data.append(list.join(";").toUtf8()); - mimeData->setData("kdenlive/clip", data); - drag->setMimeData(mimeData); - drag->setPixmap(clickItem->data(0, Qt::DecorationRole).value()); - drag->setHotSpot(QPoint(0, 50)); - drag->exec(); - } - } else { - if (it && (it->flags() & Qt::ItemIsDragEnabled)) { - QDrag *drag = new QDrag(this); - QMimeData *mimeData = new QMimeData; - const QList list = selectedItems(); - QStringList ids; - foreach(const QTreeWidgetItem *item, list) { - if (item->type() == PROJECTFOLDERTYPE) { - const int children = item->childCount(); - for (int i = 0; i < children; i++) { - ids.append(static_cast (item->child(i))->clipId()); - } - } else { - const ProjectItem *clip = static_cast (item); - ids.append(clip->clipId()); + if (it && (it->flags() & Qt::ItemIsDragEnabled)) { + QDrag *drag = new QDrag(this); + QMimeData *mimeData = new QMimeData; + const QList list = selectedItems(); + QStringList ids; + foreach(const QTreeWidgetItem *item, list) { + if (item->type() == ProjectFoldeType) { + const int children = item->childCount(); + for (int i = 0; i < children; ++i) { + ids.append(static_cast (item->child(i))->clipId()); } + } else if (item->type() == ProjectSubclipType) { + const ProjectItem *parentclip = static_cast (item->parent()); + const SubProjectItem *clickItem = static_cast (item); + QPoint p = clickItem->zone(); + QString data = parentclip->clipId(); + data.append("/" + QString::number(p.x())); + data.append("/" + QString::number(p.y())); + ids.append(data); + } else { + const ProjectItem *clip = static_cast (item); + ids.append(clip->clipId()); } - if (ids.isEmpty()) return; - QByteArray data; - data.append(ids.join(";").toUtf8()); //doc.toString().toUtf8()); - mimeData->setData("kdenlive/producerslist", data); - //mimeData->setText(ids.join(";")); //doc.toString()); - //mimeData->setImageData(image); - drag->setMimeData(mimeData); - drag->setPixmap(it->data(0, Qt::DecorationRole).value()); - drag->setHotSpot(QPoint(0, 50)); - drag->exec(); } - //event->accept(); + if (ids.isEmpty()) return; + QByteArray data; + data.append(ids.join(";").toUtf8()); //doc.toString().toUtf8()); + mimeData->setData("kdenlive/producerslist", data); + //mimeData->setText(ids.join(";")); //doc.toString()); + //mimeData->setImageData(image); + drag->setMimeData(mimeData); + drag->setPixmap(it->data(0, Qt::DecorationRole).value()); + drag->setHotSpot(QPoint(0, 40)); + drag->exec(Qt::CopyAction | Qt::MoveAction, Qt::CopyAction); } } @@ -418,4 +424,97 @@ Qt::DropActions ProjectListView::supportedDropActions() const return Qt::MoveAction | Qt::CopyAction; } +void ItemDelegate::paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const +{ + if (index.column() == 0 && !index.data(ItemDelegate::DurationRole).isNull()) { + QRect r1 = option.rect; + painter->save(); + QStyleOptionViewItemV4 opt(option); + QStyle *style = opt.widget ? opt.widget->style() : QApplication::style(); + style->drawPrimitive(QStyle::PE_PanelItemViewItem, &opt, painter, opt.widget); + + if (option.state & QStyle::State_Selected) { + painter->setPen(option.palette.highlightedText().color()); + } + const int textMargin = style->pixelMetric(QStyle::PM_FocusFrameHMargin) + 1; + QPixmap pixmap = qVariantValue(index.data(Qt::DecorationRole)); + QPoint pixmapPoint(r1.left() + textMargin, r1.top() + (r1.height() - pixmap.height()) / 2); + painter->drawPixmap(pixmapPoint, pixmap); + int decoWidth = pixmap.width() + 2 * textMargin; + + QFont font = painter->font(); + font.setBold(true); + painter->setFont(font); + int mid = (int)((r1.height() / 2)); + r1.adjust(decoWidth, 0, 0, -mid); + QRect r2 = option.rect; + r2.adjust(decoWidth, mid, 0, 0); + painter->drawText(r1, Qt::AlignLeft | Qt::AlignBottom, index.data().toString()); + font.setBold(false); + painter->setFont(font); + QString subText = index.data(ItemDelegate::DurationRole).toString(); + int usage = index.data(ItemDelegate::UsageRole).toInt(); + if (usage != 0) { + subText.append(QString::fromLatin1(" (%1)").arg(usage)); + } + + QRectF bounding; + painter->drawText(r2, Qt::AlignLeft | Qt::AlignVCenter , subText, &bounding); + int jobProgress = index.data(Qt::UserRole + 5).toInt(); + if (jobProgress != 0 && jobProgress != JobDone && jobProgress != JobAborted) { + if (jobProgress != JobCrashed) { + // Draw job progress bar + QColor color = option.palette.alternateBase().color(); + color.setAlpha(150); + painter->setPen(option.palette.link().color()); + QRect progress(pixmapPoint.x() + 2, pixmapPoint.y() + pixmap.height() - 9, pixmap.width() - 4, 7); + painter->setBrush(QBrush(color)); + painter->drawRect(progress); + painter->setBrush(option.palette.link()); + progress.adjust(2, 2, -2, -2); + if (jobProgress == JobWaiting) { + progress.setLeft(progress.right() - 2); + painter->drawRect(progress); + progress.moveLeft(progress.left() - 5); + painter->drawRect(progress); + } + else if (jobProgress > 0) { + progress.setWidth(progress.width() * jobProgress / 100); + painter->drawRect(progress); + } + } else if (jobProgress == JobCrashed) { + QString jobText = index.data(Qt::UserRole + 7).toString(); + if (!jobText.isEmpty()) { + QRectF txtBounding = painter->boundingRect(r2, Qt::AlignRight | Qt::AlignVCenter, QLatin1Char(' ') + jobText + QLatin1Char(' ') ); + painter->setPen(Qt::NoPen); + painter->setBrush(option.palette.highlight()); + painter->drawRoundedRect(txtBounding, 2, 2); + painter->setPen(option.palette.highlightedText().color()); + painter->drawText(txtBounding, Qt::AlignCenter, jobText); + } + } + } + + painter->restore(); + } else if (index.column() == 2 && KdenliveSettings::activate_nepomuk()) { + if (index.data().toString().isEmpty()) { + QStyledItemDelegate::paint(painter, option, index); + return; + } + QRect r1 = option.rect; + if (option.state & (QStyle::State_Selected)) { + painter->fillRect(r1, option.palette.highlight()); + } +#ifdef NEPOMUK + KRatingPainter::paintRating(painter, r1, Qt::AlignCenter, index.data().toInt()); +#endif +#ifdef NEPOMUKCORE + KRatingPainter::paintRating(painter, r1, Qt::AlignCenter, index.data().toInt()); +#endif + + } else { + QStyledItemDelegate::paint(painter, option, index); + } +} + #include "projectlistview.moc"