X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fmarkerdialog.cpp;h=a3935e5ad396d1d72224b465616c6caaa13f2b1b;hb=e74ed82c3ebc6b5b86106632f5dabdc524ac695a;hp=91b0b37f253fed5f22243e8df91bf6d5cf2f08d7;hpb=bb16260e8b6ff70ecf3606380090ed9b62764199;p=kdenlive diff --git a/src/markerdialog.cpp b/src/markerdialog.cpp index 91b0b37f..a3935e5a 100644 --- a/src/markerdialog.cpp +++ b/src/markerdialog.cpp @@ -18,40 +18,110 @@ ***************************************************************************/ +#include "markerdialog.h" +#include "kthumb.h" +#include "kdenlivesettings.h" + +#include #include -#include "markerdialog.h" -MarkerDialog::MarkerDialog(DocClipBase *clip, CommentedTime t, Timecode tc, QWidget * parent): QDialog(parent), m_tc(tc), m_clip(clip), m_marker(t) { +MarkerDialog::MarkerDialog(DocClipBase *clip, CommentedTime t, Timecode tc, const QString &caption, QWidget * parent) : + QDialog(parent), + m_producer(NULL), + m_profile(NULL), + m_clip(clip) +{ setFont(KGlobalSettings::toolBarFont()); - m_fps = m_tc.fps(); - m_view.setupUi(this); - m_view.marker_position->setText(tc.getTimecode(t.time(), tc.fps())); - m_view.marker_comment->setText(t.comment()); - connect(m_view.position_up, SIGNAL(clicked()), this, SLOT(slotTimeUp())); - connect(m_view.position_down, SIGNAL(clicked()), this, SLOT(slotTimeDown())); - m_view.marker_comment->selectAll(); - m_view.marker_comment->setFocus(); + setupUi(this); + setWindowTitle(caption); + + m_in = new TimecodeDisplay(tc, this); + inputLayout->addWidget(m_in); + m_in->setValue(t.time()); + + m_previewTimer = new QTimer(this); + + if (m_clip != NULL) { + m_in->setRange(0, m_clip->duration().frames(tc.fps())); + m_previewTimer->setInterval(500); + connect(m_previewTimer, SIGNAL(timeout()), this, SLOT(slotUpdateThumb())); + m_profile = new Mlt::Profile((char*) KdenliveSettings::current_profile().data()); + m_dar = m_profile->dar(); + QDomDocument doc; + QDomElement mlt = doc.createElement("mlt"); + QDomElement play = doc.createElement("mlt"); + doc.appendChild(mlt); + mlt.appendChild(play); + play.appendChild(doc.importNode(clip->toXML(), true)); + //char *tmp = doc.toString().toUtf8().data(); + m_producer = new Mlt::Producer(*m_profile, "xml-string", doc.toString().toUtf8().data()); + //delete[] tmp; + int width = 100.0 * m_dar; + if (width % 2 == 1) width++; + QPixmap p(width, 100); + QString colour = clip->getProperty("colour"); + int swidth = (int) (100.0 * m_profile->width() / m_profile->height() + 0.5); + + switch (m_clip->clipType()) { + case VIDEO: + case AV: + case SLIDESHOW: + case PLAYLIST: + connect(this, SIGNAL(updateThumb()), m_previewTimer, SLOT(start())); + case IMAGE: + case TEXT: + p = QPixmap::fromImage(KThumb::getFrame(m_producer, m_in->getValue(), swidth, width, 100)); + break; + case COLOR: + colour = colour.replace(0, 2, "#"); + p.fill(QColor(colour.left(7))); + break; + default: + p.fill(Qt::black); + } + + if (!p.isNull()) { + clip_thumb->setFixedWidth(p.width()); + clip_thumb->setFixedHeight(p.height()); + clip_thumb->setPixmap(p); + } + connect(m_in, SIGNAL(editingFinished()), this, SIGNAL(updateThumb())); + } else { + clip_thumb->setHidden(true); + } + + marker_comment->setText(t.comment()); + marker_comment->selectAll(); + marker_comment->setFocus(); + adjustSize(); } - -void MarkerDialog::slotTimeUp() { - int duration = m_tc.getFrameCount(m_view.marker_position->text(), m_fps); - if (duration >= m_clip->duration().frames(m_fps)) return; - duration ++; - m_view.marker_position->setText(m_tc.getTimecode(GenTime(duration, m_fps), m_fps)); +MarkerDialog::~MarkerDialog() +{ + delete m_previewTimer; + delete m_producer; + delete m_profile; } -void MarkerDialog::slotTimeDown() { - int duration = m_tc.getFrameCount(m_view.marker_position->text(), m_fps); - if (duration <= 0) return; - duration --; - m_view.marker_position->setText(m_tc.getTimecode(GenTime(duration, m_fps), m_fps)); +void MarkerDialog::slotUpdateThumb() +{ + m_previewTimer->stop(); + int pos = m_in->getValue(); + int width = 100.0 * m_dar; + int swidth = (int) (100.0 * m_profile->width() / m_profile->height() + 0.5); + if (width % 2 == 1) width++; + QPixmap p = QPixmap::fromImage(KThumb::getFrame(m_producer, pos, swidth, width, 100)); + if (!p.isNull()) + clip_thumb->setPixmap(p); + else + kDebug() << "!!!!!!!!!!! ERROR CREATING THUMB"; } -CommentedTime MarkerDialog::newMarker() { - return CommentedTime(GenTime(m_tc.getFrameCount(m_view.marker_position->text(), m_fps), m_fps), m_view.marker_comment->text()); +CommentedTime MarkerDialog::newMarker() +{ + return CommentedTime(m_in->gentime(), marker_comment->text()); } #include "markerdialog.moc"