X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fprojectitem.cpp;h=d0b9999ec99b11dbc1fd9cdf2803d3d4535d8e68;hb=f925c183d011886e9e56224e4331ab2470ff1dd7;hp=fe25876e06be04a49dfe879cb8114e1e89f21d9d;hpb=db3a514547826b7d83b336f0bd93eed7c25c6b3c;p=kdenlive diff --git a/src/projectitem.cpp b/src/projectitem.cpp index fe25876e..d0b9999e 100644 --- a/src/projectitem.cpp +++ b/src/projectitem.cpp @@ -18,95 +18,95 @@ ***************************************************************************/ -#include -#include -#include -#include +#include "projectitem.h" +#include "timecode.h" +#include "kdenlivesettings.h" +#include "docclipbase.h" #include #include #include +#include -#include "projectitem.h" -#include "timecode.h" -#include "kdenlivesettings.h" -#include "docclipbase.h" - -const int NameRole = Qt::UserRole; -const int DurationRole = NameRole + 1; -const int UsageRole = NameRole + 2; +const int DurationRole = Qt::UserRole + 1; +const int ProxyRole = Qt::UserRole + 5; +const int itemHeight = 38; +ProjectItem::ProjectItem(QTreeWidget * parent, DocClipBase *clip) : + QTreeWidgetItem(parent, PROJECTCLIPTYPE), + m_clip(clip), + m_clipId(clip->getId()) +{ + buildItem(); +} -// folder -ProjectItem::ProjectItem(QTreeWidget * parent, const QStringList & strings, const QString &clipId) - : QTreeWidgetItem(parent, strings), m_clipType(FOLDER), m_clipId(clipId), m_clip(NULL), m_groupname(strings.at(1)) { - setSizeHint(0, QSize(65, 45)); - setFlags(Qt::ItemIsSelectable | Qt::ItemIsDragEnabled | Qt::ItemIsEnabled | Qt::ItemIsEditable); - setIcon(0, KIcon("folder")); - setToolTip(1, "" + i18n("Folder")); - //kDebug() << "Constructed as folder, with clipId: " << m_clipId << ", and groupname: " << m_groupname; +ProjectItem::ProjectItem(QTreeWidgetItem * parent, DocClipBase *clip) : + QTreeWidgetItem(parent, PROJECTCLIPTYPE), + m_clip(clip), + m_clipId(clip->getId()) + +{ + buildItem(); } -ProjectItem::ProjectItem(QTreeWidget * parent, DocClipBase *clip) - : QTreeWidgetItem(parent) { - setSizeHint(0, QSize(65, 45)); - setFlags(Qt::ItemIsSelectable | Qt::ItemIsDragEnabled | Qt::ItemIsEnabled | Qt::ItemIsEditable); - m_clip = clip; - m_clipId = clip->getId(); - QString name = m_clip->getProperty("name"); - if (name.isEmpty()) name = KUrl(m_clip->getProperty("resource")).fileName(); - m_clipType = (CLIPTYPE) m_clip->getProperty("type").toInt(); - if (m_clipType != UNKNOWN) slotSetToolTip(); - setText(1, name); - setText(2, m_clip->description()); - if ((m_clip->clipType() == AV || m_clip->clipType() == AUDIO) && KdenliveSettings::audiothumbnails()) m_clip->askForAudioThumbs(); - //setFlags(Qt::NoItemFlags); - //kDebug() << "Constructed with clipId: " << m_clipId; -} - -ProjectItem::ProjectItem(QTreeWidgetItem * parent, DocClipBase *clip) - : QTreeWidgetItem(parent) { - setSizeHint(0, QSize(65, 45)); - setFlags(Qt::ItemIsSelectable | Qt::ItemIsDragEnabled | Qt::ItemIsEnabled | Qt::ItemIsEditable); - m_clip = clip; - m_clipId = clip->getId(); +void ProjectItem::buildItem() +{ + setSizeHint(0, QSize(itemHeight * 3, itemHeight)); + if (m_clip->isPlaceHolder()) setFlags(Qt::ItemIsSelectable | Qt::ItemIsEnabled | Qt::ItemIsDropEnabled); + else setFlags(Qt::ItemIsSelectable | Qt::ItemIsDragEnabled | Qt::ItemIsEnabled | Qt::ItemIsEditable | Qt::ItemIsDropEnabled); QString name = m_clip->getProperty("name"); if (name.isEmpty()) name = KUrl(m_clip->getProperty("resource")).fileName(); m_clipType = (CLIPTYPE) m_clip->getProperty("type").toInt(); - setText(1, name); - setText(2, m_clip->description()); - if ((m_clip->clipType() == AV || m_clip->clipType() == AUDIO) && KdenliveSettings::audiothumbnails()) m_clip->askForAudioThumbs(); - //setFlags(Qt::NoItemFlags); - //kDebug() << "Constructed with clipId: " << m_clipId; + setText(0, name); + setText(1, m_clip->description()); + GenTime duration = m_clip->duration(); + QString durationText; + if (duration != GenTime()) { + durationText = Timecode::getEasyTimecode(duration, KdenliveSettings::project_fps()); + } + if (m_clipType == PLAYLIST) { + // Check if the playlist xml contains a proxy inside, and inform user + if (playlistHasProxies(m_clip->fileURL().path())) { + durationText.prepend(i18n("Contains proxies") + " / "); + } + } + if (!durationText.isEmpty()) setData(0, DurationRole, durationText); } +ProjectItem::~ProjectItem() +{ +} -ProjectItem::~ProjectItem() { +//static +int ProjectItem::itemDefaultHeight() +{ + return itemHeight; } -int ProjectItem::numReferences() const { +int ProjectItem::numReferences() const +{ if (!m_clip) return 0; return m_clip->numReferences(); } -const QString &ProjectItem::clipId() const { +const QString &ProjectItem::clipId() const +{ return m_clipId; } -CLIPTYPE ProjectItem::clipType() const { +CLIPTYPE ProjectItem::clipType() const +{ return m_clipType; } -int ProjectItem::clipMaxDuration() const { +int ProjectItem::clipMaxDuration() const +{ return m_clip->getProperty("duration").toInt(); } -bool ProjectItem::isGroup() const { - return m_clipType == FOLDER; -} - -QStringList ProjectItem::names() const { +QStringList ProjectItem::names() const +{ QStringList result; result.append(text(0)); result.append(text(1)); @@ -114,55 +114,59 @@ QStringList ProjectItem::names() const { return result; } -QDomElement ProjectItem::toXml() const { +QDomElement ProjectItem::toXml() const +{ return m_clip->toXML(); } -const KUrl ProjectItem::clipUrl() const { - if (m_clipType != COLOR && m_clipType != VIRTUAL && m_clipType != UNKNOWN && m_clipType != FOLDER) +const KUrl ProjectItem::clipUrl() const +{ + if (m_clipType != COLOR && m_clipType != VIRTUAL && m_clipType != UNKNOWN) return KUrl(m_clip->getProperty("resource")); else return KUrl(); } -void ProjectItem::changeDuration(int frames) { - setData(1, DurationRole, Timecode::getEasyTimecode(GenTime(frames, KdenliveSettings::project_fps()), KdenliveSettings::project_fps())); +void ProjectItem::changeDuration(int frames) +{ + QString itemdata = data(0, DurationRole).toString(); + if (itemdata.contains('/')) itemdata = itemdata.section('/', 0, 0) + "/ "; + else itemdata.clear(); + setData(0, DurationRole, itemdata + Timecode::getEasyTimecode(GenTime(frames, KdenliveSettings::project_fps()), KdenliveSettings::project_fps())); } -void ProjectItem::setProperties(QMap props) { +void ProjectItem::setProperties(QMap props) +{ if (m_clip == NULL) return; m_clip->setProperties(props); } -QString ProjectItem::getClipHash() const { +QString ProjectItem::getClipHash() const +{ if (m_clip == NULL) return QString(); return m_clip->getClipHash(); } -void ProjectItem::setProperty(const QString &key, const QString &value) { +void ProjectItem::setProperty(const QString &key, const QString &value) +{ if (m_clip == NULL) return; m_clip->setProperty(key, value); } -void ProjectItem::clearProperty(const QString &key) { +void ProjectItem::clearProperty(const QString &key) +{ if (m_clip == NULL) return; m_clip->clearProperty(key); } -const QString ProjectItem::groupName() const { - return m_groupname; -} - -void ProjectItem::setGroupName(const QString name) { - m_groupname = name; - setText(1, name); -} - -DocClipBase *ProjectItem::referencedClip() { +DocClipBase *ProjectItem::referencedClip() +{ return m_clip; } -void ProjectItem::slotSetToolTip() { - QString tip = ""; +void ProjectItem::slotSetToolTip() +{ + QString tip = ""; + if (m_clip->isPlaceHolder()) tip.append(i18n("Missing") + " | "); switch (m_clipType) { case AUDIO: tip.append(i18n("Audio clip") + "
" + clipUrl().path()); @@ -180,10 +184,11 @@ void ProjectItem::slotSetToolTip() { tip.append(i18n("Image clip") + "

" + clipUrl().path()); break; case TEXT: - tip.append(i18n("Text clip")); + if (!clipUrl().isEmpty() && m_clip->getProperty("xmldata").isEmpty()) tip.append(i18n("Template text clip") + "

" + clipUrl().path()); + else tip.append(i18n("Text clip") + "
" + clipUrl().path()); break; case SLIDESHOW: - tip.append(i18n("Slideshow clip")); + tip.append(i18n("Slideshow clip") + "
" + clipUrl().directory()); break; case VIRTUAL: tip.append(i18n("Virtual clip")); @@ -196,55 +201,103 @@ void ProjectItem::slotSetToolTip() { break; } - setToolTip(1, tip); + setToolTip(0, tip); } -void ProjectItem::setProperties(const QMap < QString, QString > &attributes, const QMap < QString, QString > &metadata) { +void ProjectItem::setProperties(const QMap < QString, QString > &attributes, const QMap < QString, QString > &metadata) +{ if (m_clip == NULL) return; - //setFlags(Qt::ItemIsSelectable | Qt::ItemIsEditable | Qt::ItemIsDragEnabled | Qt::ItemIsEnabled); + + QString prefix; + if (m_clipType == UNKNOWN) { + QString cliptype = attributes.value("type"); + if (cliptype == "audio") m_clipType = AUDIO; + else if (cliptype == "video") m_clipType = VIDEO; + else if (cliptype == "av") m_clipType = AV; + else if (cliptype == "playlist") m_clipType = PLAYLIST; + else m_clipType = AV; + + m_clip->setClipType(m_clipType); + slotSetToolTip(); + if (m_clipType == PLAYLIST) { + // Check if the playlist xml contains a proxy inside, and inform user + if (playlistHasProxies(m_clip->fileURL().path())) { + prefix = i18n("Contains proxies") + " / "; + } + } + } if (attributes.contains("duration")) { - //if (m_clipType == AUDIO || m_clipType == VIDEO || m_clipType == AV) - //m_clip->setProperty("duration", attributes["duration"]); - GenTime duration = GenTime(attributes["duration"].toInt(), KdenliveSettings::project_fps()); - setData(1, DurationRole, Timecode::getEasyTimecode(duration, KdenliveSettings::project_fps())); + GenTime duration = GenTime(attributes.value("duration").toInt(), KdenliveSettings::project_fps()); + QString itemdata = data(0, DurationRole).toString(); + if (itemdata.contains('/')) itemdata = itemdata.section('/', 0, 0) + "/ "; + else itemdata.clear(); + if (prefix.isEmpty()) prefix = itemdata; + setData(0, DurationRole, prefix + Timecode::getEasyTimecode(duration, KdenliveSettings::project_fps())); m_clip->setDuration(duration); - //kDebug() << "//// LOADED CLIP, DURATION SET TO: " << duration.frames(KdenliveSettings::project_fps()); } else { // No duration known, use an arbitrary one until it is. } - - //extend attributes -reh - - if (m_clipType == UNKNOWN) { - if (attributes.contains("type")) { - if (attributes["type"] == "audio") - m_clipType = AUDIO; - else if (attributes["type"] == "video") - m_clipType = VIDEO; - else if (attributes["type"] == "av") - m_clipType = AV; - else if (attributes["type"] == "playlist") - m_clipType = PLAYLIST; - } else { - m_clipType = AV; - } - m_clip->setClipType(m_clipType); - slotSetToolTip(); - } m_clip->setProperties(attributes); - - if ((m_clipType == AV || m_clipType == AUDIO) && KdenliveSettings::audiothumbnails()) m_clip->askForAudioThumbs(); + m_clip->setMetadata(metadata); if (m_clip->description().isEmpty()) { if (metadata.contains("description")) { - m_clip->setProperty("description", metadata["description"]); - setText(2, m_clip->description()); + m_clip->setProperty("description", metadata.value("description")); + setText(1, m_clip->description()); } else if (metadata.contains("comment")) { - m_clip->setProperty("description", metadata["comment"]); - setText(2, m_clip->description()); + m_clip->setProperty("description", metadata.value("comment")); + setText(1, m_clip->description()); } } } +void ProjectItem::setProxyStatus(PROXYSTATUS status, int progress) +{ + if (progress > 0) setData(0, ProxyRole, progress); + else setData(0, ProxyRole, status); +} + +bool ProjectItem::hasProxy() const +{ + if (m_clip == NULL) return false; + if (m_clip->getProperty("proxy").isEmpty() || m_clip->getProperty("proxy") == "-" || data(0, ProxyRole).toInt() == PROXYCRASHED) return false; + return true; +} + +bool ProjectItem::isProxyReady() const +{ + return (data(0, ProxyRole).toInt() == PROXYDONE); +} + +bool ProjectItem::isProxyRunning() const +{ + int s = data(0, ProxyRole).toInt(); + if (s == PROXYWAITING || s == CREATINGPROXY || s > 0) return true; + return false; +} + +bool ProjectItem::playlistHasProxies(const QString path) +{ + kDebug()<<"// CHECKING FOR PROXIES"; + QFile file(path); + QDomDocument doc; + if (!file.open(QIODevice::ReadOnly)) + return false; + if (!doc.setContent(&file)) { + file.close(); + return false; + } + file.close(); + QString root = doc.documentElement().attribute("root"); + QDomNodeList kdenliveProducers = doc.elementsByTagName("kdenlive_producer"); + for (int i = 0; i < kdenliveProducers.count(); i++) { + QString proxy = kdenliveProducers.at(i).toElement().attribute("proxy"); + if (!proxy.isEmpty() && proxy != "-") return true; + } + return false; +} + + +