From: Jean-Baptiste Mardelle Date: Sat, 18 Oct 2008 21:20:28 +0000 (+0000) Subject: Be more clever when adding transition (guess duration from clip underneath) X-Git-Url: https://git.sesse.net/?a=commitdiff_plain;h=3f05242ffe3b07ae95b3e3ab4f93425fd6707ac9;p=kdenlive Be more clever when adding transition (guess duration from clip underneath) svn path=/branches/KDE4/; revision=2483 --- diff --git a/src/customtrackview.cpp b/src/customtrackview.cpp index 3a14029b..74da896a 100644 --- a/src/customtrackview.cpp +++ b/src/customtrackview.cpp @@ -989,17 +989,40 @@ void CustomTrackView::slotEnableRefresh() { void CustomTrackView::slotAddTransitionToSelectedClips(QDomElement transition) { QList itemList = scene()->selectedItems(); - for (int i = 0; i < itemList.count(); i++) { - if (itemList.at(i)->type() == AVWIDGET) { - ClipItem *item = (ClipItem *) itemList.at(i); + if (itemList.count() == 1) { + if (itemList.at(0)->type() == AVWIDGET) { + ClipItem *item = (ClipItem *) itemList.at(0); ItemInfo info; - info.startPos = item->startPos(); - info.endPos = info.startPos + GenTime(2.5); info.track = item->track(); - int transitiontrack = getPreviousVideoTrack(info.track); + ClipItem *transitionClip = NULL; + const int transitiontrack = getPreviousVideoTrack(info.track); + GenTime pos = GenTime((int)(mapToScene(m_menuPosition).x()), m_document->fps()); + if (pos < item->startPos() + item->duration() / 2) { + info.startPos = item->startPos(); + if (transitiontrack != 0) transitionClip = getClipItemAt((int) info.startPos.frames(m_document->fps()), m_scene->m_tracksList.count() - transitiontrack); + if (transitionClip && transitionClip->endPos() < item->endPos()) { + info.endPos = transitionClip->endPos(); + } else info.endPos = info.startPos + GenTime(2.5); + } else { + info.endPos = item->endPos(); + if (transitiontrack != 0) transitionClip = getClipItemAt((int) info.endPos.frames(m_document->fps()), m_scene->m_tracksList.count() - transitiontrack); + if (transitionClip && transitionClip->startPos() > item->startPos()) { + info.startPos = transitionClip->startPos(); + } else info.startPos = info.endPos - GenTime(2.5); + } slotAddTransition(item, info, transitiontrack, transition); } - } + } else for (int i = 0; i < itemList.count(); i++) { + if (itemList.at(i)->type() == AVWIDGET) { + ClipItem *item = (ClipItem *) itemList.at(i); + ItemInfo info; + info.startPos = item->startPos(); + info.endPos = info.startPos + GenTime(2.5); + info.track = item->track(); + int transitiontrack = getPreviousVideoTrack(info.track); + slotAddTransition(item, info, transitiontrack, transition); + } + } } void CustomTrackView::slotAddTransition(ClipItem* clip, ItemInfo transitionInfo, int endTrack, QDomElement transition) {