X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fprojectitem.cpp;h=12b46be2bff0dde6d12d8a3b5fe4dcc3a74f9139;hb=e7cc204174b626f1970483faf36ec6d9033b1a7f;hp=53fde22ad5b6a345c88800c782b04420d3cd4560;hpb=8244f2dfae1c7d4e7f1bf3ed5098d7994e4230e4;p=kdenlive diff --git a/src/projectitem.cpp b/src/projectitem.cpp index 53fde22a..12b46be2 100644 --- a/src/projectitem.cpp +++ b/src/projectitem.cpp @@ -18,262 +18,223 @@ ***************************************************************************/ -#include -#include -#include -#include +#include "projectitem.h" +#include "timecode.h" +#include "kdenlivesettings.h" +#include "docclipbase.h" #include #include #include +const int DurationRole = Qt::UserRole + 1; +const int itemHeight = 38; -#include "projectitem.h" -#include "timecode.h" - - - const int NameRole = Qt::UserRole; - const int DurationRole = NameRole + 1; - const int FullPathRole = NameRole + 2; - const int ClipTypeRole = NameRole + 3; - -ProjectItem::ProjectItem(QTreeWidget * parent, const QStringList & strings, QDomElement xml, int clipId) - : QTreeWidgetItem(parent, strings, QTreeWidgetItem::UserType), m_clipType(UNKNOWN), m_clipId(clipId), m_isGroup(false), m_groupName(QString::null) +ProjectItem::ProjectItem(QTreeWidget * parent, DocClipBase *clip) : + QTreeWidgetItem(parent, PROJECTCLIPTYPE) { - m_element = xml.cloneNode().toElement(); - setSizeHint(0, QSize(65, 45)); - setFlags(Qt::ItemIsSelectable | Qt::ItemIsDragEnabled | Qt::ItemIsEnabled | Qt::ItemIsEditable); - if (!m_element.isNull()) { - m_element.setAttribute("id", clipId); - QString cType = m_element.attribute("type", QString::null); - if (!cType.isEmpty()) { - m_clipType = (CLIPTYPE) cType.toInt(); - slotSetToolTip(); - } - - if (m_clipType == COLOR || m_clipType == IMAGE) m_element.setAttribute("duration", MAXCLIPDURATION); - else if (m_element.attribute("duration").isEmpty() && !m_element.attribute("out").isEmpty()) { - m_element.setAttribute("duration", m_element.attribute("out").toInt() - m_element.attribute("in").toInt()); - } - } + setSizeHint(0, QSize(itemHeight * 3, itemHeight)); + if (clip->isPlaceHolder()) setFlags(Qt::ItemIsSelectable | Qt::ItemIsEnabled); + else 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(0, name); + setText(1, m_clip->description()); + GenTime duration = m_clip->duration(); + if (duration != GenTime()) setData(0, DurationRole, Timecode::getEasyTimecode(duration, KdenliveSettings::project_fps())); + //setFlags(Qt::NoItemFlags); + //kDebug() << "Constructed with clipId: " << m_clipId; } -ProjectItem::ProjectItem(QTreeWidgetItem * parent, const QStringList & strings, QDomElement xml, int clipId) - : QTreeWidgetItem(parent, strings, QTreeWidgetItem::UserType), m_clipType(UNKNOWN), m_clipId(clipId), m_isGroup(false), m_groupName(QString::null) +ProjectItem::ProjectItem(QTreeWidgetItem * parent, DocClipBase *clip) : + QTreeWidgetItem(parent, PROJECTCLIPTYPE) { - m_element = xml.cloneNode().toElement(); - setSizeHint(0, QSize(65, 45)); - setFlags(Qt::ItemIsSelectable | Qt::ItemIsDragEnabled | Qt::ItemIsEnabled | Qt::ItemIsEditable); - if (!m_element.isNull()) { - m_element.setAttribute("id", clipId); - QString cType = m_element.attribute("type", QString::null); - if (!cType.isEmpty()) { - m_clipType = (CLIPTYPE) cType.toInt(); - slotSetToolTip(); - } - } + setSizeHint(0, QSize(itemHeight * 3, itemHeight)); + if (clip->isPlaceHolder()) setFlags(Qt::ItemIsSelectable | Qt::ItemIsEnabled); + else 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(); + setText(0, name); + setText(1, m_clip->description()); + GenTime duration = m_clip->duration(); + if (duration != GenTime()) setData(0, DurationRole, Timecode::getEasyTimecode(duration, KdenliveSettings::project_fps())); + //setFlags(Qt::NoItemFlags); + //kDebug() << "Constructed with clipId: " << m_clipId; } -ProjectItem::ProjectItem(QTreeWidget * parent, const QStringList & strings, int clipId) - : QTreeWidgetItem(parent, strings, QTreeWidgetItem::UserType), m_element(QDomElement()), m_clipType(UNKNOWN), m_clipId(clipId), m_isGroup(true), m_groupName(strings.at(1)) -{ - setSizeHint(0, QSize(65, 45)); - setFlags(Qt::ItemIsSelectable | Qt::ItemIsDragEnabled | Qt::ItemIsEnabled | Qt::ItemIsEditable); - setIcon(0, KIcon("folder")); -} ProjectItem::~ProjectItem() { } -int ProjectItem::clipId() const +//static +int ProjectItem::itemDefaultHeight() { - return m_clipId; + return itemHeight; } -CLIPTYPE ProjectItem::clipType() const +int ProjectItem::numReferences() const { - return m_clipType; + if (!m_clip) return 0; + return m_clip->numReferences(); } -int ProjectItem::clipMaxDuration() const +const QString &ProjectItem::clipId() const { - return m_element.attribute("duration").toInt(); + return m_clipId; } -bool ProjectItem::isGroup() const +CLIPTYPE ProjectItem::clipType() const { - return m_isGroup; + return m_clipType; } -const QString ProjectItem::groupName() const +int ProjectItem::clipMaxDuration() const { - return m_groupName; + return m_clip->getProperty("duration").toInt(); } QStringList ProjectItem::names() const { - QStringList result; - result.append(text(0)); - result.append(text(1)); - result.append(text(2)); - return result; + QStringList result; + result.append(text(0)); + result.append(text(1)); + result.append(text(2)); + return result; } QDomElement ProjectItem::toXml() const { - return m_element; + return m_clip->toXML(); } const KUrl ProjectItem::clipUrl() const { if (m_clipType != COLOR && m_clipType != VIRTUAL && m_clipType != UNKNOWN) - return KUrl(m_element.attribute("resource")); + return KUrl(m_clip->getProperty("resource")); else return KUrl(); } +void ProjectItem::changeDuration(int frames) +{ + setData(0, DurationRole, Timecode::getEasyTimecode(GenTime(frames, KdenliveSettings::project_fps()), KdenliveSettings::project_fps())); +} + +void ProjectItem::setProperties(QMap props) +{ + if (m_clip == NULL) return; + m_clip->setProperties(props); +} + +QString ProjectItem::getClipHash() const +{ + if (m_clip == NULL) return QString(); + return m_clip->getClipHash(); +} + +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) +{ + if (m_clip == NULL) return; + m_clip->clearProperty(key); +} + +DocClipBase *ProjectItem::referencedClip() +{ + return m_clip; +} void ProjectItem::slotSetToolTip() { - QString tip = ""; - switch (m_clipType) { - case 1: - tip.append(i18n("Audio clip")); - break; - case 2: - tip.append(i18n("Mute video clip")); - break; - case 3: - tip.append(i18n("Video clip")); - break; - case 4: - tip.append(i18n("Color clip")); - setData(1, DurationRole, Timecode::getEasyTimecode(GenTime(m_element.attribute("out", "250").toInt(), 25), 25)); - break; - case 5: - tip.append(i18n("Image clip")); - break; - case 6: - tip.append(i18n("Text clip")); - break; - case 7: - tip.append(i18n("Slideshow clip")); - break; - case 8: - tip.append(i18n("Virtual clip")); - break; - case 9: - tip.append(i18n("Playlist clip")); - break; + QString tip = ""; + if (m_clip->isPlaceHolder()) tip.append(i18n("Missing") + " | "); + switch (m_clipType) { + case AUDIO: + tip.append(i18n("Audio clip") + "
" + clipUrl().path()); + break; + case VIDEO: + tip.append(i18n("Mute video clip") + "

" + clipUrl().path()); + break; + case AV: + tip.append(i18n("Video clip") + "
" + clipUrl().path()); + break; + case COLOR: + tip.append(i18n("Color clip")); + break; + case IMAGE: + tip.append(i18n("Image clip") + "
" + clipUrl().path()); + break; + case TEXT: + 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") + "
" + clipUrl().directory()); + break; + case VIRTUAL: + tip.append(i18n("Virtual clip")); + break; + case PLAYLIST: + tip.append(i18n("Playlist clip") + "
" + clipUrl().path()); + break; default: - tip.append(i18n("Unknown clip")); - break; - } + tip.append(i18n("Unknown clip")); + break; + } - setToolTip(1, tip); + setToolTip(0, tip); } + void ProjectItem::setProperties(const QMap < QString, QString > &attributes, const QMap < QString, QString > &metadata) { - if (attributes.contains("duration")) { - if (m_clipType == AUDIO || m_clipType == VIDEO || m_clipType == AV) m_element.setAttribute("duration", attributes["duration"].toInt()); - m_duration = GenTime(attributes["duration"].toInt(), 25); - setData(1, DurationRole, Timecode::getEasyTimecode(m_duration, 25)); - m_durationKnown = true; - } else { - // No duration known, use an arbitrary one until it is. - m_duration = GenTime(0.0); - m_durationKnown = false; - } - - - //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; - } - } - slotSetToolTip(); - - if (m_element.isNull()) { - QDomDocument doc; - m_element = doc.createElement("producer"); - } - if (m_element.attribute("duration") == QString::null) m_element.setAttribute("duration", attributes["duration"].toInt()); - m_element.setAttribute("resource", attributes["filename"]); - m_element.setAttribute("type", (int) m_clipType); -/* - if (attributes.contains("height")) { - m_height = attributes["height"].toInt(); - } else { - m_height = 0; - } - if (attributes.contains("width")) { - m_width = attributes["width"].toInt(); - } else { - m_width = 0; - } - //decoder name - if (attributes.contains("name")) { - m_decompressor = attributes["name"]; - } else { - m_decompressor = "n/a"; - } - //video type ntsc/pal - if (attributes.contains("system")) { - m_system = attributes["system"]; - } else { - m_system = "n/a"; - } - if (attributes.contains("fps")) { - m_framesPerSecond = attributes["fps"].toInt(); - } else { - // No frame rate known. - m_framesPerSecond = 0; - } - //audio attributes -reh - if (attributes.contains("channels")) { - m_channels = attributes["channels"].toInt(); - } else { - m_channels = 0; - } - if (attributes.contains("format")) { - m_format = attributes["format"]; - } else { - m_format = "n/a"; - } - if (attributes.contains("frequency")) { - m_frequency = attributes["frequency"].toInt(); - } else { - m_frequency = 0; - } - if (attributes.contains("videocodec")) { - m_videoCodec = attributes["videocodec"]; - } - if (attributes.contains("audiocodec")) { - m_audioCodec = attributes["audiocodec"]; - } - - m_metadata = metadata; - - if (m_metadata.contains("description")) { - setDescription (m_metadata["description"]); - } - else if (m_metadata.contains("comment")) { - setDescription (m_metadata["comment"]); - } -*/ + if (m_clip == NULL) return; + //setFlags(Qt::ItemIsSelectable | Qt::ItemIsEditable | Qt::ItemIsDragEnabled | Qt::ItemIsEnabled); + if (attributes.contains("duration")) { + GenTime duration = GenTime(attributes.value("duration").toInt(), KdenliveSettings::project_fps()); + setData(0, DurationRole, Timecode::getEasyTimecode(duration, KdenliveSettings::project_fps())); + m_clip->setDuration(duration); + } else { + // No duration known, use an arbitrary one until it is. + } + + //extend attributes -reh + + 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(); + } + m_clip->setProperties(attributes); + m_clip->setMetadata(metadata); + + if (m_clip->description().isEmpty()) { + if (metadata.contains("description")) { + m_clip->setProperty("description", metadata.value("description")); + setText(1, m_clip->description()); + } else if (metadata.contains("comment")) { + m_clip->setProperty("description", metadata.value("comment")); + setText(1, m_clip->description()); + } + } } -#include "projectitem.moc"