X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fclipmanager.cpp;h=7db3a4af928144868505aacb9d31a257af2fb8b7;hb=16bb1ff3b1c6b5f296e5e386f00a33b789a15b05;hp=a5850f269b9714915516094878878c7b9f836db9;hpb=c42a026234a44a2d766e57bc64a6ac7bbd094000;p=kdenlive diff --git a/src/clipmanager.cpp b/src/clipmanager.cpp index a5850f26..7db3a4af 100644 --- a/src/clipmanager.cpp +++ b/src/clipmanager.cpp @@ -29,20 +29,33 @@ #include #include +#include #include +#include #include #include -ClipManager::ClipManager(KdenliveDoc *doc): m_doc(doc), m_audioThumbsEnabled(false), m_audioThumbsQueue(QList ()), m_generatingAudioId(QString()) +ClipManager::ClipManager(KdenliveDoc *doc) : + QObject(), + m_audioThumbsQueue(), + m_doc(doc), + m_audioThumbsEnabled(false), + m_generatingAudioId() { m_clipIdCounter = 1; m_folderIdCounter = 1; + connect(&m_fileWatcher, SIGNAL(dirty(const QString &)), this, SLOT(slotClipModified(const QString &))); + connect(&m_fileWatcher, SIGNAL(deleted(const QString &)), this, SLOT(slotClipMissing(const QString &))); + connect(&m_fileWatcher, SIGNAL(created(const QString &)), this, SLOT(slotClipAvailable(const QString &))); } ClipManager::~ClipManager() { qDeleteAll(m_clipList); + m_clipList.clear(); + m_audioThumbsQueue.clear(); + m_generatingAudioId.clear(); } void ClipManager::clear() @@ -131,27 +144,40 @@ QMap ClipManager::documentFolderList() const void ClipManager::addClip(DocClipBase *clip) { m_clipList.append(clip); + if (clip->clipType() != COLOR && clip->clipType() != SLIDESHOW && !clip->fileURL().isEmpty()) { + // listen for file change + //kDebug() << "// LISTEN FOR: " << clip->fileURL().path(); + m_fileWatcher.addFile(clip->fileURL().path()); + } const QString id = clip->getId(); if (id.toInt() >= m_clipIdCounter) m_clipIdCounter = id.toInt() + 1; const QString gid = clip->getProperty("groupid"); if (!gid.isEmpty() && gid.toInt() >= m_folderIdCounter) m_folderIdCounter = gid.toInt() + 1; } -void ClipManager::slotDeleteClip(const QString &clipId) +void ClipManager::slotDeleteClips(QStringList ids) { - for (int i = 0; i < m_clipList.count(); i++) { - if (m_clipList.at(i)->getId() == clipId) { - AddClipCommand *command = new AddClipCommand(m_doc, m_clipList.at(i)->toXML(), clipId, false); - m_doc->commandStack()->push(command); - break; + 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() != COLOR && m_clipList.at(i)->clipType() != SLIDESHOW && !m_clipList.at(i)->fileURL().isEmpty()) { + //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()); + } DocClipBase *clip = m_clipList.takeAt(i); delete clip; clip = NULL; @@ -178,14 +204,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++) { - if (m_clipList.at(i)->getProperty("resource") == resource) { - return m_clipList.at(i); + clipResource = m_clipList.at(i)->getProperty("resource"); + if (clipResource.isEmpty()) clipResource = m_clipList.at(i)->getProperty("colour"); + if (clipResource == resource) { + list.append(m_clipList.at(i)); } } - return NULL; + return list; } void ClipManager::updatePreviewSettings() @@ -205,77 +235,92 @@ void ClipManager::updatePreviewSettings() } } -void ClipManager::resetProducersList(QList prods) +void ClipManager::clearUnusedProducers() +{ + for (int i = 0; i < m_clipList.count(); i++) { + if (m_clipList.at(i)->numReferences() == 0) m_clipList.at(i)->deleteProducers(); + } +} + +void ClipManager::resetProducersList(const QList prods) { for (int i = 0; i < m_clipList.count(); i++) { if (m_clipList.at(i)->numReferences() > 0) { - m_clipList.at(i)->deleteProducers(); + m_clipList.at(i)->clearProducers(); } } QString id; for (int i = 0; i < prods.count(); i++) { id = prods.at(i)->get("id"); + kDebug() << "// // // REPLACE CLIP: " << id; if (id.contains('_')) id = id.section('_', 0, 0); DocClipBase *clip = getClipById(id); if (clip) { clip->setProducer(prods.at(i)); - kDebug() << "// // // REPLACE CLIP: " << id; } } + emit checkAllClips(); } void ClipManager::slotAddClipList(const KUrl::List urls, const QString group, const QString &groupId) { QUndoCommand *addClips = new QUndoCommand(); - addClips->setText(i18n("Add clips")); foreach(const KUrl &file, urls) { if (KIO::NetAccess::exists(file, KIO::NetAccess::SourceSide, NULL)) { + if (!getClipByResource(file.path()).empty()) { + if (KMessageBox::warningContinueCancel(kapp->activeWindow(), i18n("Clip %1
already exists in project, what do you want to do?", file.path()), i18n("Clip already exists")) == KMessageBox::Cancel) + continue; + } + kDebug() << "Adding clip: " << file.path(); QDomDocument doc; QDomElement prod = doc.createElement("producer"); doc.appendChild(prod); + prod.setAttribute("resource", file.path()); + uint id = m_clipIdCounter++; + prod.setAttribute("id", QString::number(id)); if (!group.isEmpty()) { prod.setAttribute("groupname", group); prod.setAttribute("groupid", groupId); } - prod.setAttribute("resource", file.path()); - uint id = m_clipIdCounter++; - prod.setAttribute("id", QString::number(id)); KMimeType::Ptr type = KMimeType::findByUrl(file); if (type->name().startsWith("image/")) { prod.setAttribute("type", (int) IMAGE); - prod.setAttribute("in", "0"); + prod.setAttribute("in", 0); prod.setAttribute("out", m_doc->getFramePos(KdenliveSettings::image_duration()) - 1); + } else if (type->is("application/x-kdenlivetitle")) { + // opening a title file + QDomDocument txtdoc("titledocument"); + QFile txtfile(file.path()); + if (txtfile.open(QIODevice::ReadOnly) && txtdoc.setContent(&txtfile)) { + txtfile.close(); + prod.setAttribute("type", (int) TEXT); + prod.setAttribute("xmldata", txtdoc.toString()); + prod.setAttribute("transparency", 1); + 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); } } - m_doc->commandStack()->push(addClips); + if (addClips->childCount() > 0) { + addClips->setText(i18np("Add clip", "Add clips", addClips->childCount())); + m_doc->commandStack()->push(addClips); + } } void ClipManager::slotAddClipFile(const KUrl url, const QString group, const QString &groupId) { - kDebug() << "///// CLIP MANAGER, ADDING CLIP: " << url; - QDomDocument doc; - QDomElement prod = doc.createElement("producer"); - doc.appendChild(prod); - prod.setAttribute("resource", url.path()); - uint id = m_clipIdCounter++; - prod.setAttribute("id", QString::number(id)); - if (!group.isEmpty()) { - prod.setAttribute("groupname", group); - prod.setAttribute("groupid", groupId); - } - KMimeType::Ptr type = KMimeType::findByUrl(url); - if (type->name().startsWith("image/")) { - prod.setAttribute("type", (int) IMAGE); - prod.setAttribute("in", "0"); - prod.setAttribute("out", m_doc->getFramePos(KdenliveSettings::image_duration()) - 1); - } - AddClipCommand *command = new AddClipCommand(m_doc, doc.documentElement(), QString::number(id), true); - m_doc->commandStack()->push(command); + slotAddClipList(KUrl::List(url), group, groupId); } + void ClipManager::slotAddColorClipFile(const QString name, const QString color, QString duration, const QString group, const QString &groupId) { QDomDocument doc; @@ -325,13 +370,13 @@ void ClipManager::slotAddSlideshowClipFile(const QString name, const QString pat -void ClipManager::slotAddTextClipFile(const QString titleName, const QString imagePath, const QString xml, const QString group, const QString &groupId) +void ClipManager::slotAddTextClipFile(const QString titleName, int out, const QString xml, const QString group, const QString &groupId) { QDomDocument doc; QDomElement prod = doc.createElement("producer"); doc.appendChild(prod); - prod.setAttribute("resource", imagePath); - prod.setAttribute("titlename", titleName); + //prod.setAttribute("resource", imagePath); + prod.setAttribute("name", titleName); prod.setAttribute("xmldata", xml); uint id = m_clipIdCounter++; prod.setAttribute("id", QString::number(id)); @@ -342,7 +387,39 @@ void ClipManager::slotAddTextClipFile(const QString titleName, const QString ima prod.setAttribute("type", (int) TEXT); prod.setAttribute("transparency", "1"); prod.setAttribute("in", "0"); - prod.setAttribute("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); +} + +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("name", titleName); + prod.setAttribute("resource", path.path()); + uint id = m_clipIdCounter++; + prod.setAttribute("id", QString::number(id)); + if (!group.isEmpty()) { + prod.setAttribute("groupname", group); + prod.setAttribute("groupid", groupId); + } + prod.setAttribute("type", (int) TEXT); + prod.setAttribute("transparency", "1"); + prod.setAttribute("in", "0"); + + 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); } @@ -418,3 +495,41 @@ QDomElement ClipManager::groupsXml() const } return doc.documentElement(); } + + +void ClipManager::slotClipModified(const QString &path) +{ + // kDebug() << "// CLIP: " << path << " WAS MODIFIED"; + 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()); + } +} + +void ClipManager::slotClipMissing(const QString &path) +{ + // kDebug() << "// CLIP: " << path << " WAS MISSING"; + const QList list = getClipByResource(path); + for (int i = 0; i < list.count(); i++) { + DocClipBase *clip = list.at(i); + if (clip != NULL) emit missingClip(clip->getId()); + } +} + +void ClipManager::slotClipAvailable(const QString &path) +{ + // kDebug() << "// CLIP: " << path << " WAS ADDED"; + const QList list = getClipByResource(path); + for (int i = 0; i < list.count(); i++) { + DocClipBase *clip = list.at(i); + if (clip != NULL) emit availableClip(clip->getId()); + } +} + +int ClipManager::clipsCount() const +{ + return m_clipList.count(); +} + +