X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fclipmanager.cpp;h=4f96ba185bcfac2aa78599c662bab0457e1b1a7f;hb=0ae9f07b0172db7341c39da60cfa0f4c406e28d0;hp=baafa500eb769f2f8a59f81da54b753ec2c264c6;hpb=d43383d14efb17899c439d85c257f5be5d2a118e;p=kdenlive diff --git a/src/clipmanager.cpp b/src/clipmanager.cpp index baafa500..4f96ba18 100644 --- a/src/clipmanager.cpp +++ b/src/clipmanager.cpp @@ -138,7 +138,7 @@ QMap ClipManager::documentFolderList() const void ClipManager::addClip(DocClipBase *clip) { m_clipList.append(clip); - if (clip->clipType() == IMAGE || clip->clipType() == AUDIO) { + if (clip->clipType() == IMAGE || clip->clipType() == AUDIO || (clip->clipType() == TEXT && !clip->fileURL().isEmpty())) { // listen for file change m_fileWatcher.addFile(clip->fileURL().path()); } @@ -148,20 +148,25 @@ void ClipManager::addClip(DocClipBase *clip) if (!gid.isEmpty() && gid.toInt() >= m_folderIdCounter) m_folderIdCounter = gid.toInt() + 1; } -void ClipManager::slotDeleteClip(const QString &clipId) +void ClipManager::slotDeleteClips(QStringList ids) { - DocClipBase *clip = getClipById(clipId); - if (clip) { - AddClipCommand *command = new AddClipCommand(m_doc, clip->toXML(), clipId, false); - m_doc->commandStack()->push(command); + QUndoCommand *delClips = new QUndoCommand(); + delClips->setText(i18np("Delete clip", "Delete clips", ids.size())); + + for (int i = 0; i < ids.size(); i++) { + DocClipBase *clip = getClipById(ids.at(i)); + if (clip) { + new AddClipCommand(m_doc, clip->toXML(), ids.at(i), false, delClips); + } } + m_doc->commandStack()->push(delClips); } void ClipManager::deleteClip(const QString &clipId) { for (int i = 0; i < m_clipList.count(); i++) { if (m_clipList.at(i)->getId() == clipId) { - if (m_clipList.at(i)->clipType() == IMAGE || m_clipList.at(i)->clipType() == AUDIO) { + if (m_clipList.at(i)->clipType() == IMAGE || m_clipList.at(i)->clipType() == AUDIO || (m_clipList.at(i)->clipType() == TEXT && !m_clipList.at(i)->fileURL().isEmpty())) { // listen for file change m_fileWatcher.removeFile(m_clipList.at(i)->fileURL().path()); } @@ -189,17 +194,18 @@ DocClipBase *ClipManager::getClipById(QString clipId) return NULL; } -DocClipBase *ClipManager::getClipByResource(QString resource) +const QList ClipManager::getClipByResource(QString resource) { + QList list; QString clipResource; for (int i = 0; i < m_clipList.count(); i++) { clipResource = m_clipList.at(i)->getProperty("resource"); if (clipResource.isEmpty()) clipResource = m_clipList.at(i)->getProperty("colour"); if (clipResource == resource) { - return m_clipList.at(i); + list.append(m_clipList.at(i)); } } - return NULL; + return list; } void ClipManager::updatePreviewSettings() @@ -268,7 +274,7 @@ void ClipManager::slotAddClipList(const KUrl::List urls, const QString group, co prod.setAttribute("type", (int) IMAGE); prod.setAttribute("in", 0); prod.setAttribute("out", m_doc->getFramePos(KdenliveSettings::image_duration()) - 1); - } else if (type->name() == "application/x-kdenlivetitle") { + } else if (type->is("application/x-kdenlivetitle")) { // opening a title file QDomDocument txtdoc("titledocument"); QFile txtfile(file.path()); @@ -281,6 +287,7 @@ void ClipManager::slotAddClipList(const KUrl::List urls, const QString group, co prod.setAttribute("in", 0); int out = txtdoc.documentElement().attribute("out").toInt(); if (out > 0) prod.setAttribute("out", out); + else prod.setAttribute("out", m_doc->getFramePos(KdenliveSettings::image_duration()) - 1); } else txtfile.close(); } new AddClipCommand(m_doc, doc.documentElement(), QString::number(id), true, addClips); @@ -321,12 +328,14 @@ void ClipManager::slotAddClipFile(const KUrl url, const QString group, const QSt prod.setAttribute("in", 0); int out = (int) outPos.frames(m_doc->fps()); if (out > 0) prod.setAttribute("out", out); + else prod.setAttribute("out", m_doc->getFramePos(KdenliveSettings::image_duration()) - 1); } else txtfile.close(); } AddClipCommand *command = new AddClipCommand(m_doc, doc.documentElement(), QString::number(id), true); m_doc->commandStack()->push(command); } + void ClipManager::slotAddColorClipFile(const QString name, const QString color, QString duration, const QString group, const QString &groupId) { QDomDocument doc; @@ -398,14 +407,13 @@ void ClipManager::slotAddTextClipFile(const QString titleName, int out, const QS m_doc->commandStack()->push(command); } -void ClipManager::slotAddTextTemplateClip(QString titleName, const QString imagePath, const KUrl path, const QString group, const QString &groupId) +void ClipManager::slotAddTextTemplateClip(QString titleName, const KUrl path, const QString group, const QString &groupId) { QDomDocument doc; QDomElement prod = doc.createElement("producer"); doc.appendChild(prod); - prod.setAttribute("resource", imagePath); prod.setAttribute("name", titleName); - prod.setAttribute("xmltemplate", path.path()); + prod.setAttribute("resource", path.path()); uint id = m_clipIdCounter++; prod.setAttribute("id", QString::number(id)); if (!group.isEmpty()) { @@ -415,7 +423,18 @@ void ClipManager::slotAddTextTemplateClip(QString titleName, const QString image prod.setAttribute("type", (int) TEXT); prod.setAttribute("transparency", "1"); prod.setAttribute("in", "0"); - prod.setAttribute("out", m_doc->getFramePos(KdenliveSettings::image_duration()) - 1); + + int out = 0; + QDomDocument titledoc; + QFile txtfile(path.path()); + if (txtfile.open(QIODevice::ReadOnly) && titledoc.setContent(&txtfile)) { + txtfile.close(); + out = titledoc.documentElement().attribute("out").toInt(); + } else txtfile.close(); + + if (out == 0) out = m_doc->getFramePos(KdenliveSettings::image_duration()) - 1; + prod.setAttribute("out", out); + AddClipCommand *command = new AddClipCommand(m_doc, doc.documentElement(), QString::number(id), true); m_doc->commandStack()->push(command); } @@ -496,7 +515,16 @@ QDomElement ClipManager::groupsXml() const void ClipManager::slotClipModified(const QString &path) { //kDebug()<<"// CLIP: "<getId()); -} \ No newline at end of file + const QList list = getClipByResource(path); + for (int i = 0; i < list.count(); i++) { + DocClipBase *clip = list.at(i); + if (clip != NULL) emit reloadClip(clip->getId()); + } +} + +int ClipManager::clipsCount() const +{ + return m_clipList.count(); +} + +