X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fprojectlistview.cpp;h=35b2bc89a8070e960b6c18bc781133d0ede46018;hb=8bcc799b522e6e5ae0299973b4d296bef831a17f;hp=fabe6a23d2356ac40bdde9354ec20337d6ca9608;hpb=376446cf243399cb816d7aba74fa476d894d8025;p=kdenlive diff --git a/src/projectlistview.cpp b/src/projectlistview.cpp index fabe6a23..35b2bc89 100644 --- a/src/projectlistview.cpp +++ b/src/projectlistview.cpp @@ -20,6 +20,8 @@ #include "projectlistview.h" #include "projectitem.h" +#include "subprojectitem.h" +#include "folderprojectitem.h" #include "kdenlivesettings.h" #include @@ -41,37 +43,37 @@ ProjectListView::ProjectListView(QWidget *parent) : setDragEnabled(true); setAcceptDrops(true); - setColumnCount(4); + + setColumnCount(3); QStringList headers; - headers << i18n("Thumbnail") << i18n("Filename") << i18n("Description") << i18n("Rating"); + headers << i18n("Clip") << i18n("Description") << i18n("Rating"); setHeaderLabels(headers); - sortByColumn(1, Qt::AscendingOrder); QHeaderView* headerView = header(); headerView->setContextMenuPolicy(Qt::CustomContextMenu); connect(headerView, SIGNAL(customContextMenuRequested(const QPoint&)), this, SLOT(configureColumns(const QPoint&))); - - //connect(this, SIGNAL(currentItemChanged(QTreeWidgetItem *, QTreeWidgetItem *)), this, SLOT(slotFocusOut(QTreeWidgetItem *, QTreeWidgetItem *))); - - if (!KdenliveSettings::showdescriptioncolumn()) hideColumn(2); - if (!KdenliveSettings::showratingcolumn()) hideColumn(3); - + headerView->setClickable(true); + headerView->setSortIndicatorShown(true); + headerView->setMovable(false); + sortByColumn(0, Qt::AscendingOrder); setSortingEnabled(true); + + if (!KdenliveSettings::showdescriptioncolumn()) hideColumn(1); + if (!KdenliveSettings::showratingcolumn()) hideColumn(2); } ProjectListView::~ProjectListView() { } - void ProjectListView::configureColumns(const QPoint& pos) { KMenu popup(this); popup.addTitle(i18nc("@title:menu", "Columns")); QHeaderView* headerView = header(); - for (int i = 2; i < headerView->count(); ++i) { + for (int i = 1; i < headerView->count(); ++i) { const QString text = model()->headerData(i, Qt::Horizontal).toString(); QAction* action = popup.addAction(text); action->setCheckable(true); @@ -86,10 +88,10 @@ void ProjectListView::configureColumns(const QPoint& pos) // remember the changed column visibility in the settings const int columnIndex = activatedAction->data().toInt(); switch (columnIndex) { - case 2: + case 1: KdenliveSettings::setShowdescriptioncolumn(show); break; - case 3: + case 2: KdenliveSettings::setShowratingcolumn(show); break; default: @@ -114,19 +116,29 @@ void ProjectListView::contextMenuEvent(QContextMenuEvent * event) // virtual void ProjectListView::mouseDoubleClickEvent(QMouseEvent * event) { - ProjectItem *item = static_cast (itemAt(event->pos())); - if (!item) { + QTreeWidgetItem *it = itemAt(event->pos()); + if (!it) { emit addClip(); return; } - if (!(item->flags() & Qt::ItemIsDragEnabled)) return; - if (item->isGroup()) { - if ((columnAt(event->pos().x()) == 1)) QTreeWidget::mouseDoubleClickEvent(event); - } else { - if ((columnAt(event->pos().x()) == 1) && (item->clipType() == SLIDESHOW || item->clipType() == TEXT || item->clipType() == COLOR)) QTreeWidget::mouseDoubleClickEvent(event); - else if ((columnAt(event->pos().x()) == 2)) QTreeWidget::mouseDoubleClickEvent(event); - else emit showProperties(item->referencedClip()); + ProjectItem *item; + if (it->type() == PROJECTFOLDERTYPE) { + if ((columnAt(event->pos().x()) == 0)) QTreeWidget::mouseDoubleClickEvent(event); + return; } + if (it->type() == PROJECTSUBCLIPTYPE) { + // subitem + if ((columnAt(event->pos().x()) == 1)) { + QTreeWidget::mouseDoubleClickEvent(event); + return; + } + item = static_cast (it->parent()); + } else item = static_cast (it); + + if (!(item->flags() & Qt::ItemIsDragEnabled)) return; + if ((columnAt(event->pos().x()) == 0) && (item->clipType() == SLIDESHOW || item->clipType() == TEXT || item->clipType() == COLOR)) QTreeWidget::mouseDoubleClickEvent(event); + else if ((columnAt(event->pos().x()) == 1) && it->type() != PROJECTSUBCLIPTYPE) QTreeWidget::mouseDoubleClickEvent(event); + else emit showProperties(item->referencedClip()); } // virtual @@ -141,47 +153,44 @@ void ProjectListView::dragEnterEvent(QDragEnterEvent *event) // virtual void ProjectListView::dropEvent(QDropEvent *event) { - kDebug() << "//////////////// DROPPED EVENT"; + FolderProjectItem *item = NULL; + QTreeWidgetItem *it = itemAt(event->pos()); + while (it && it->type() != PROJECTFOLDERTYPE) { + it = it->parent(); + } + if (it) item = static_cast (it); if (event->mimeData()->hasUrls()) { - ProjectItem *item = static_cast (itemAt(event->pos())); QString groupName; QString groupId; if (item) { - if (item->parent()) item = static_cast (item->parent()); - if (item->isGroup()) { - groupName = item->groupName(); - groupId = item->clipId(); - } + groupName = item->groupName(); + groupId = item->clipId(); } emit addClip(event->mimeData()->urls(), groupName, groupId); + event->setDropAction(Qt::CopyAction); + event->accept(); + return; } else if (event->mimeData()->hasFormat("kdenlive/producerslist")) { - ProjectItem *item = static_cast (itemAt(event->pos())); if (item) { - if (item->parent()) item = static_cast (item->parent()); - if (item->isGroup()) { - //emit addClip(event->mimeData->text()); - kDebug() << "//////////////// DROPPED RIGHT 1 "; - const QList list = selectedItems(); - ProjectItem *clone; - QString parentId = item->clipId(); - foreach(QTreeWidgetItem *it, list) { - // TODO allow dragging of folders ? - if (!((ProjectItem *) it)->isGroup()/* && ((ProjectItem *) it)->clipId() < 10000*/) { - if (it->parent()) clone = (ProjectItem*) it->parent()->takeChild(it->parent()->indexOfChild(it)); - else clone = (ProjectItem*) takeTopLevelItem(indexOfTopLevelItem(it)); - if (clone) { - item->addChild(clone); - QMap props; - props.insert("groupname", item->groupName()); - props.insert("groupid", parentId); - clone->setProperties(props); - } + //emit addClip(event->mimeData->text()); + const QList list = selectedItems(); + ProjectItem *clone; + QString parentId = item->clipId(); + foreach(QTreeWidgetItem *it, list) { + // TODO allow dragging of folders ? + if (it->type() == PROJECTCLIPTYPE) { + if (it->parent()) clone = (ProjectItem*) it->parent()->takeChild(it->parent()->indexOfChild(it)); + else clone = (ProjectItem*) takeTopLevelItem(indexOfTopLevelItem(it)); + if (clone) { + item->addChild(clone); + QMap props; + props.insert("groupname", item->groupName()); + props.insert("groupid", parentId); + clone->setProperties(props); } - } - } else item = NULL; - } - if (!item) { - kDebug() << "//////////////// DROPPED ON EMPTY ZONE"; + } else item = NULL; + } + } else { // item dropped in empty zone, move it to top level const QList list = selectedItems(); ProjectItem *clone; @@ -198,6 +207,9 @@ void ProjectListView::dropEvent(QDropEvent *event) } } } + } else if (event->mimeData()->hasFormat("kdenlive/clip")) { + QStringList list = QString(event->mimeData()->data("kdenlive/clip")).split(';'); + emit addClipCut(list.at(0), list.at(1).toInt(), list.at(2).toInt()); } event->acceptProposedAction(); } @@ -232,21 +244,44 @@ void ProjectListView::mouseMoveEvent(QMouseEvent *event) < QApplication::startDragDistance()) return; - { - ProjectItem *clickItem = static_cast (itemAt(m_DragStartPosition)); + 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) { - const ProjectItem *clip = static_cast (item); - if (!clip->isGroup()) ids.append(clip->clipId()); - else { + 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 (ids.isEmpty()) return; @@ -256,9 +291,9 @@ void ProjectListView::mouseMoveEvent(QMouseEvent *event) //mimeData->setText(ids.join(";")); //doc.toString()); //mimeData->setImageData(image); drag->setMimeData(mimeData); - drag->setPixmap(clickItem->icon(0).pixmap(iconSize())); + drag->setPixmap(it->data(0, Qt::DecorationRole).value()); drag->setHotSpot(QPoint(0, 50)); - drag->exec(Qt::MoveAction); + drag->exec(); } //event->accept(); } @@ -267,8 +302,7 @@ void ProjectListView::mouseMoveEvent(QMouseEvent *event) // virtual void ProjectListView::dragMoveEvent(QDragMoveEvent * event) { - event->setDropAction(Qt::IgnoreAction); - event->setDropAction(Qt::MoveAction); + //event->setDropAction(Qt::MoveAction); if (event->mimeData()->hasText()) { event->acceptProposedAction(); } @@ -284,6 +318,7 @@ QStringList ProjectListView::mimeTypes() const qstrList.append("text/uri-list"); qstrList.append("text/plain"); qstrList.append("kdenlive/producerslist"); + qstrList.append("kdenlive/clip"); return qstrList; }