-void ClipManager::slotAddTextClipFile(const QString path, const QString xml, const QString group, const QString &groupId) {
- kDebug() << "///// CLIP MANAGER, ADDING CLIP: " << path;
+void ClipManager::slotAddTextClipFile(const QString titleName, const QString imagePath, const QString xml, const QString group, const QString &groupId) {
QDomDocument doc;
QDomElement prod = doc.createElement("producer");
- prod.setAttribute("resource", path + ".png");
- prod.setAttribute("xml", path);
+ prod.setAttribute("resource", imagePath);
+ prod.setAttribute("titlename", titleName);
prod.setAttribute("xmldata", xml);
uint id = m_clipIdCounter++;
prod.setAttribute("id", QString::number(id));
void deleteClip(const QString &clipId);
void slotAddClipFile(const KUrl url, const QString group, const QString &groupId);
void slotAddClipList(const KUrl::List urls, const QString group, const QString &groupId);
- void slotAddTextClipFile(const QString path, const QString xml, const QString group, const QString &groupId);
+ void slotAddTextClipFile(const QString titleName, const QString imagePath, const QString xml, const QString group, const QString &groupId);
void slotAddColorClipFile(const QString name, const QString color, QString duration, const QString group, const QString &groupId);
void slotAddSlideshowClipFile(const QString name, const QString path, int count, const QString duration, const bool loop, const bool fade, const QString &luma_duration, const QString &luma_file, const int softness, const QString group, const QString &groupId);
DocClipBase *getClipById(const QString &clipId);
#include <QGraphicsSvgItem>
#include <QGraphicsView>
#include <QCursor>
+#include <QTextCursor>
#include <QList>
#include <QKeyEvent>
#include <QApplication>
+#include <QTextBlock>
#include "graphicsscenerectmove.h"
if (g) {
if (g->type() == 8) {
QGraphicsTextItem *t = static_cast<QGraphicsTextItem *>(g);
+ m_selectedItem = g;
t->setTextInteractionFlags(Qt::TextEditorInteraction);
}
}
}
void GraphicsSceneRectMove::mousePressEvent(QGraphicsSceneMouseEvent* e) {
+ m_clickPoint = e->screenPos();
QPointF p = e->scenePos();
p += QPoint(-2, -2);
resizeMode = NoResize;
if (m_selectedItem && m_selectedItem->type() == 8) {
// disable text editing
QGraphicsTextItem *t = static_cast<QGraphicsTextItem *>(m_selectedItem);
+ t->textCursor().setPosition(0);
+ QTextBlock cur = t->textCursor().block();
+ t->setTextCursor(QTextCursor(cur));
t->setTextInteractionFlags(Qt::NoTextInteraction);
}
m_selectedItem = NULL;
}
}
if (item != NULL) {
- m_clickPoint = e->scenePos();
+ m_sceneClickPoint = e->scenePos();
m_selectedItem = item;
kDebug() << "///////// ITEM TYPE: " << item->type();
if (item->type() == 8) {
}
QGraphicsScene::mousePressEvent(e);
} else if (m_tool == TITLE_RECTANGLE) {
- m_clickPoint = e->scenePos();
+ m_sceneClickPoint = e->scenePos();
m_selectedItem = NULL;
} else if (m_tool == TITLE_TEXT) {
m_selectedItem = addText(QString());
}
+void GraphicsSceneRectMove::clearTextSelection() {
+ if (m_selectedItem && m_selectedItem->type() == 8) {
+ // disable text editing
+ QGraphicsTextItem *t = static_cast<QGraphicsTextItem *>(m_selectedItem);
+ t->textCursor().setPosition(0);
+ QTextBlock cur = t->textCursor().block();
+ t->setTextCursor(QTextCursor(cur));
+ t->setTextInteractionFlags(Qt::NoTextInteraction);
+ }
+ m_selectedItem = NULL;
+ clearSelection();
+}
//virtual
void GraphicsSceneRectMove::mouseMoveEvent(QGraphicsSceneMouseEvent* e) {
-
+ if ((e->screenPos() - m_clickPoint).manhattanLength() < QApplication::startDragDistance()) {
+ e->accept();
+ return;
+ }
if (m_selectedItem && e->buttons() & Qt::LeftButton) {
if (m_selectedItem->type() == 3 || m_selectedItem->type() == 13 || m_selectedItem->type() == 7) {
QRectF newrect;
newrect.setBottom(newpoint.y() - m_selectedItem->pos().y());
break;
default:
- QPointF diff = e->scenePos() - m_clickPoint;
- m_clickPoint = e->scenePos();
+ QPointF diff = e->scenePos() - m_sceneClickPoint;
+ m_sceneClickPoint = e->scenePos();
m_selectedItem->moveBy(diff.x(), diff.y());
break;
}
QGraphicsScene::mouseMoveEvent(e);
return;
}
- QPointF diff = e->scenePos() - m_clickPoint;
- m_clickPoint = e->scenePos();
+ QPointF diff = e->scenePos() - m_sceneClickPoint;
+ m_sceneClickPoint = e->scenePos();
m_selectedItem->moveBy(diff.x(), diff.y());
}
emit itemMoved();
} else if (m_tool == TITLE_SELECT) {
-
QPointF p = e->scenePos();
p += QPoint(-2, -2);
resizeMode = NoResize;
}
QGraphicsScene::mouseMoveEvent(e);
} else if (m_tool == TITLE_RECTANGLE && e->buttons() & Qt::LeftButton) {
- if (m_selectedItem == NULL && (m_clickPoint.toPoint() - e->scenePos().toPoint()).manhattanLength() >= QApplication::startDragDistance()) {
+ if (m_selectedItem == NULL && (m_clickPoint - e->screenPos()).manhattanLength() >= QApplication::startDragDistance()) {
// create new rect item
- m_selectedItem = addRect(0, 0, e->scenePos().x() - m_clickPoint.x(), e->scenePos().y() - m_clickPoint.y());
+ m_selectedItem = addRect(0, 0, e->scenePos().x() - m_sceneClickPoint.x(), e->scenePos().y() - m_sceneClickPoint.y());
emit newRect((QGraphicsRectItem *) m_selectedItem);
m_selectedItem->setFlags(QGraphicsItem::ItemIsMovable | QGraphicsItem::ItemIsSelectable);
- m_selectedItem->setPos(m_clickPoint);
+ m_selectedItem->setPos(m_sceneClickPoint);
resizeMode = BottomRight;
QGraphicsScene::mouseMoveEvent(e);
}
void setZoom(double s);
void setTool(TITLETOOL tool);
TITLETOOL tool();
+ void clearTextSelection();
protected:
virtual void keyPressEvent(QKeyEvent * keyEvent);
double zoom;
QGraphicsItem* m_selectedItem;
resizeModes resizeMode;
- QPointF m_clickPoint;
+ QPointF m_sceneClickPoint;
TITLETOOL m_tool;
+ QPoint m_clickPoint;
signals:
void itemMoved();
}
}
prod.setAttribute("xmldata", tdoc.toString());
- QString titlesFolder = projectFolder().path() + "/titles/";
- KStandardDirs::makeDir(titlesFolder);
- QString titleName = "title";
- int counter = 0;
- QString path = titlesFolder + titleName + QString::number(counter).rightJustified(3, '0', false);
- while (QFile::exists(path + ".png")) {
- counter++;
- path = titlesFolder + titleName + QString::number(counter).rightJustified(3, '0', false);
- }
- prod.setAttribute("xml", path);
- prod.setAttribute("resource", path + ".png");
+ QStringList titleInfo = TitleWidget::getFreeTitleInfo(projectFolder());
+ prod.setAttribute("titlename", titleInfo.at(0));
+ prod.setAttribute("resource", titleInfo.at(1));
//kDebug()<<"TITLE DATA:\n"<<tdoc.toString();
prod.removeChild(m);
}
if (clip && clip->producer() == NULL) {
clip->setProducer(prods.at(i));
}
+ if (clip->clipType() == TEXT && !QFile::exists(clip->fileURL().path())) {
+ // regenerate text clip image if required
+ kDebug() << "// TITLE: " << clip->getProperty("titlename") << " Preview file: " << clip->getProperty("resource") << " DOES NOT EXIST";
+ QString titlename = clip->getProperty("titlename");
+ QString titleresource;
+ if (titlename.isEmpty()) {
+ QStringList titleInfo = TitleWidget::getFreeTitleInfo(projectFolder());
+ titlename = titleInfo.at(0);
+ titleresource = titleInfo.at(1);
+ clip->setProperty("titlename", titlename);
+ kDebug() << "// New title set to: " << titlename;
+ } else {
+ titleresource = TitleWidget::getTitleResourceFromName(projectFolder(), titlename);
+ }
+ QString titlepath = projectFolder().path() + "/titles/";
+ TitleWidget *dia_ui = new TitleWidget(KUrl(), titlepath, m_render, kapp->activeWindow());
+ QDomDocument doc;
+ doc.setContent(clip->getProperty("xmldata"));
+ dia_ui->setXml(doc);
+ QPixmap pix = dia_ui->renderedPixmap();
+ pix.save(titleresource);
+ clip->setProperty("resource", titleresource);
+ delete dia_ui;
+ clip->producer()->set("force_reload", 1);
+ }
}
}
KStandardDirs::makeDir(titlesFolder);
TitleWidget *dia_ui = new TitleWidget(KUrl(), titlesFolder, m_render, kapp->activeWindow());
if (dia_ui->exec() == QDialog::Accepted) {
- QString titleName = "title";
- int counter = 0;
- QString path = titlesFolder + titleName + QString::number(counter).rightJustified(3, '0', false);
- while (QFile::exists(path + ".png")) {
- counter++;
- path = titlesFolder + titleName + QString::number(counter).rightJustified(3, '0', false);
- }
+ QStringList titleInfo = TitleWidget::getFreeTitleInfo(projectFolder());
QPixmap pix = dia_ui->renderedPixmap();
- pix.save(path + ".png");
+ pix.save(titleInfo.at(1));
//dia_ui->saveTitle(path + ".kdenlivetitle");
- m_clipManager->slotAddTextClipFile(path, dia_ui->xml().toString(), QString(), QString());
+ m_clipManager->slotAddTextClipFile(titleInfo.at(0), titleInfo.at(1), dia_ui->xml().toString(), QString(), QString());
setModified(true);
}
delete dia_ui;
void KThumb::updateClipUrl(KUrl url) {
m_url = url;
+ if (m_producer) {
+ char *tmp = Render::decodedString(url.path());
+ m_producer->set("resource", tmp);
+ delete[] tmp;
+ }
}
//static
void MainWindow::slotShowClipProperties(DocClipBase *clip) {
if (clip->clipType() == TEXT) {
- QString path = clip->getProperty("xml");
- TitleWidget *dia_ui = new TitleWidget(KUrl()/*path + ".kdenlivetitle")*/, path, m_projectMonitor->render, this);
+ QString titlepath = m_activeDocument->projectFolder().path() + "/titles/";
+ QString path = clip->getProperty("resource");
+ TitleWidget *dia_ui = new TitleWidget(KUrl(), titlepath, m_projectMonitor->render, this);
QDomDocument doc;
doc.setContent(clip->getProperty("xmldata"));
dia_ui->setXml(doc);
if (dia_ui->exec() == QDialog::Accepted) {
- kDebug() << "// UPDATUING CLIP TITLE: " << path;
QPixmap pix = dia_ui->renderedPixmap();
- pix.save(path + ".png");
+ pix.save(path);
//slotAddClipFile(KUrl("/tmp/kdenlivetitle.png"), QString(), -1);
//m_clipManager->slotEditTextClipFile(id, dia_ui->xml().toString());
QMap <QString, QString> newprops;
newprops.insert("xmldata", dia_ui->xml().toString());
EditClipCommand *command = new EditClipCommand(m_projectList, clip->getId(), clip->properties(), newprops, true);
m_activeDocument->commandStack()->push(command);
- //setModified(true);
+ m_clipMonitor->refreshMonitor(true);
+ m_activeDocument->setModified(true);
}
delete dia_ui;
#include "kdenlivesettings.h"
#include "slideshowclip.h"
#include "ui_colorclip_ui.h"
+#include "titlewidget.h"
#include "definitions.h"
while (*it) {
ProjectItem *item = static_cast <ProjectItem *>(*it);
if (!item->isGroup()) {
- if (item->referencedClip()->producer() == NULL) emit getFileProperties(item->referencedClip()->toXML(), item->referencedClip()->getId());
- else {
+ if (item->referencedClip()->producer() == NULL) {
+ DocClipBase *clip = item->referencedClip();
+ if (clip->clipType() == TEXT && !QFile::exists(clip->fileURL().path())) {
+ // regenerate text clip image if required
+ TitleWidget *dia_ui = new TitleWidget(KUrl(), QString(), m_render, this);
+ QDomDocument doc;
+ doc.setContent(clip->getProperty("xmldata"));
+ dia_ui->setXml(doc);
+ QPixmap pix = dia_ui->renderedPixmap();
+ pix.save(clip->fileURL().path());
+ delete dia_ui;
+ }
+ emit getFileProperties(clip->toXML(), clip->getId());
+ } else {
slotRefreshClipThumbnail(item, false);
item->changeDuration(item->referencedClip()->producer()->get_playtime());
}
if (!m_commandStack) kDebug() << "!!!!!!!!!!!!!!!! NO CMD STK";
KUrl::List list;
if (givenUrl.isEmpty()) {
- list = KFileDialog::getOpenUrls(KUrl("kfiledialog:///clipfolder"), "application/vnd.kde.kdenlive application/vnd.westley.scenelist application/flv application/vnd.rn-realmedia video/x-dv video/dv video/x-msvideo video/mpeg video/x-ms-wmv audio/mpeg audio/x-mp3 audio/x-wav application/ogg video/mp4 video/quicktime image/gif image/jpeg image/png image/x-bmp image/svg+xml image/tiff image/x-xcf-gimp image/x-vnd.adobe.photoshop image/x-pcx image/x-exr video/mlt-playlist", this);
+ list = KFileDialog::getOpenUrls(KUrl("kfiledialog:///clipfolder"), "application/x-kdenlive application/x-flash-video application/vnd.rn-realmedia video/x-dv video/dv video/x-msvideo video/mpeg video/x-ms-wmv audio/mpeg audio/x-mp3 audio/x-wav application/ogg video/mp4 video/quicktime image/gif image/jpeg image/png image/x-bmp image/svg+xml image/tiff image/x-xcf-gimp image/x-vnd.adobe.photoshop image/x-pcx image/x-exr video/mlt-playlist", this);
} else list.append(givenUrl);
if (list.isEmpty()) return;
KUrl url = KUrl(xml.attribute("resource", QString::null));
Mlt::Producer *producer;
+ if (xml.attribute("type").toInt() == TEXT && !QFile::exists(url.path())) {
+ return;
+ }
if (xml.attribute("type").toInt() == COLOR) {
char *tmp = decodedString("colour:" + xml.attribute("colour"));
producer = new Mlt::Producer(*m_mltProfile, "fezzik", tmp);
doc.appendChild(westley);
westley.appendChild(play);
play.appendChild(doc.importNode(xml, true));
- kDebug() << "/ / / / /CLIP XML: " << doc.toString();
char *tmp = decodedString(doc.toString());
producer = new Mlt::Producer(*m_mltProfile, "westley-xml", tmp);
delete[] tmp;
} else {
- char *tmp = decodedString(url.path());
+ QString urlpath = url.path();
+ /*if (urlpath.contains(':')) {
+ if (!urlpath.startsWith("file:")) urlpath.prepend("file:");
+ char *tmp = decodedString(urlpath);
+ producer = new Mlt::Producer(*m_mltProfile, "avformat", tmp);
+ delete[] tmp;
+ }
+ else {*/
+ char *tmp = decodedString(urlpath);
producer = new Mlt::Producer(*m_mltProfile, tmp);
delete[] tmp;
+ //}
}
if (xml.hasAttribute("out")) producer->set_in_and_out(xml.attribute("in").toInt(), xml.attribute("out").toInt());
if (frameNumber != 0) producer->seek(frameNumber);
mlt_properties properties = MLT_PRODUCER_PROPERTIES(producer->get_producer());
- filePropertyMap["filename"] = url.path();
filePropertyMap["duration"] = QString::number(producer->get_playtime());
//kDebug() << "/////// PRODUCER: " << url.path() << " IS: " << producer.get_playtime();
#include <KDebug>
#include <KGlobalSettings>
#include <KFileDialog>
+#include <KStandardDirs>
#include "titlewidget.h"
#include "kdenlivesettings.h"
TitleWidget::TitleWidget(KUrl url, QString projectPath, Render *render, QWidget *parent): QDialog(parent), m_render(render), m_count(0), m_projectPath(projectPath) {
setupUi(this);
- //frame_properties->
setFont(KGlobalSettings::toolBarFont());
//toolBox->setFont(KGlobalSettings::toolBarFont());
frame_properties->setEnabled(false);
+ rect_properties->setFixedHeight(frame_properties->height() + 4);
+ text_properties->setFixedHeight(frame_properties->height() + 4);
m_frameWidth = render->renderWidth();
m_frameHeight = render->renderHeight();
//connect(newTextButton, SIGNAL(clicked()), this, SLOT(slotNewText()));
QHBoxLayout *layout = new QHBoxLayout;
frame_toolbar->setLayout(layout);
-
+ layout->setContentsMargins(2, 2, 2, 2);
QToolBar *m_toolbar = new QToolBar("titleToolBar", this);
m_buttonRect = m_toolbar->addAction(KIcon("kdenlive-insert-rect"), i18n("Add Rectangle"));
graphicsView->scene()->addItem(m_frameBorder);
initViewports();
-
+ QTimer::singleShot(500, this, SLOT(slotAdjustZoom()));
graphicsView->show();
//graphicsView->setRenderHint(QPainter::Antialiasing);
graphicsView->setInteractive(true);
- QTimer::singleShot(500, this, SLOT(slotAdjustZoom()));
//graphicsView->resize(400, 300);
kDebug() << "// TITLE WIDGWT: " << graphicsView->viewport()->width() << "x" << graphicsView->viewport()->height();
toolBox->setItemEnabled(2, false);
if (!url.isEmpty()) {
m_count = m_titledocument.loadDocument(url, startViewport, endViewport) + 1;
slotSelectTool();
- } else slotRectTool();
+ } else {
+ slotRectTool();
+ }
}
+//static
+QStringList TitleWidget::getFreeTitleInfo(const KUrl &projectUrl) {
+ QStringList result;
+ QString titlePath = projectUrl.path() + "/titles/";
+ KStandardDirs::makeDir(titlePath);
+ QString titleName = "title";
+ int counter = 0;
+ QString path = titlePath + titleName + QString::number(counter).rightJustified(3, '0', false);
+ while (QFile::exists(path + ".png")) {
+ counter++;
+ path = titlePath + titleName + QString::number(counter).rightJustified(3, '0', false);
+ }
+ result.append(titleName + QString::number(counter).rightJustified(3, '0', false));
+ result.append(path + ".png");
+ return result;
+}
+
+QString TitleWidget::getTitleResourceFromName(const KUrl &projectUrl, const QString &titleName) {
+ QStringList result;
+ QString titlePath = projectUrl.path() + "/titles/";
+ KStandardDirs::makeDir(titlePath);
+ return titlePath + titleName + ".png";
+}
//virtual
void TitleWidget::resizeEvent(QResizeEvent * event) {
}
void TitleWidget::slotUpdateZoom(int pos) {
- m_scene->setZoom((double) pos / 7);
- zoom_label->setText("x" + QString::number((double) pos / 7, 'g', 2));
+ m_scene->setZoom((double) pos / 100);
+ zoom_label->setText(QString::number(pos) + "%");
}
void TitleWidget::slotZoom(bool up) {
}
void TitleWidget::slotAdjustZoom() {
- double scalex = graphicsView->width() / (double)(m_frameWidth * 1.2);
+ /*double scalex = graphicsView->width() / (double)(m_frameWidth * 1.2);
double scaley = graphicsView->height() / (double)(m_frameHeight * 1.2);
if (scalex > scaley) scalex = scaley;
- int zoompos = (int)(scalex * 7 + 0.5);
+ int zoompos = (int)(scalex * 7 + 0.5);*/
+ graphicsView->fitInView(m_frameBorder, Qt::KeepAspectRatio);
+ int zoompos = graphicsView->matrix().m11() * 100;
zoom_slider->setValue(zoompos);
graphicsView->centerOn(m_frameBorder);
}
void TitleWidget::slotZoomOneToOne() {
- zoom_slider->setValue(7);
+ zoom_slider->setValue(100);
graphicsView->centerOn(m_frameBorder);
}
value_y->blockSignals(true);
value_w->blockSignals(true);
value_h->blockSignals(true);
- kDebug() << "//////// SELECTION CHANGED; ITEMS: " << l.size();
+ //kDebug() << "//////// SELECTION CHANGED; ITEMS: " << l.size();
if (l.size() == 1) {
if ((l[0])->type() == 8) {
rect_properties->setHidden(true);
//toolBox->setItemEnabled(3, true);
rectFAlpha->setValue(rec->pen().color().alpha());
rectBAlpha->setValue(rec->brush().color().alpha());
- kDebug() << rec->brush().color().alpha();
+ //kDebug() << rec->brush().color().alpha();
QColor fcol = rec->pen().color();
QColor bcol = rec->brush().color();
//fcol.setAlpha(255);
}
void TitleWidget::setXml(QDomDocument doc) {
- m_titledocument.loadFromXml(doc, startViewport, endViewport);
+ m_count = m_titledocument.loadFromXml(doc, startViewport, endViewport);
slotSelectTool();
}
pix.fill(Qt::transparent);
QPainter painter(&pix);
painter.setRenderHint(QPainter::Antialiasing);
- m_scene->clearSelection();
+ m_scene->clearTextSelection();
QPen framepen = m_frameBorder->pen();
m_frameBorder->setPen(Qt::NoPen);
startViewport->setVisible(false);
class TitleWidget : public QDialog , public Ui::TitleWidget_UI {
Q_OBJECT
+
public:
TitleWidget(KUrl url, QString projectPath, Render *render, QWidget *parent = 0);
QDomDocument xml();
void setXml(QDomDocument doc);
+ static QStringList getFreeTitleInfo(const KUrl &projectUrl);
+ static QString getTitleResourceFromName(const KUrl &projectUrl, const QString &titleName);
protected:
virtual void resizeEvent(QResizeEvent * event);
<enum>QFrame::Sunken</enum>
</property>
<layout class="QGridLayout" name="gridLayout_4" >
+ <property name="margin" >
+ <number>2</number>
+ </property>
<item row="0" column="0" >
<layout class="QHBoxLayout" name="horizontalLayout_3" >
<item>
<enum>QFrame::Sunken</enum>
</property>
<layout class="QGridLayout" name="gridLayout_5" >
+ <property name="leftMargin" >
+ <number>2</number>
+ </property>
+ <property name="topMargin" >
+ <number>2</number>
+ </property>
+ <property name="rightMargin" >
+ <number>2</number>
+ </property>
<item row="0" column="0" >
<layout class="QHBoxLayout" name="horizontalLayout_4" >
<item>
<rect>
<x>0</x>
<y>0</y>
- <width>283</width>
- <height>154</height>
+ <width>355</width>
+ <height>168</height>
</rect>
</property>
<attribute name="label" >
<rect>
<x>0</x>
<y>0</y>
- <width>283</width>
- <height>154</height>
+ <width>355</width>
+ <height>158</height>
</rect>
</property>
<attribute name="label" >
<rect>
<x>0</x>
<y>0</y>
- <width>264</width>
- <height>212</height>
+ <width>336</width>
+ <height>210</height>
</rect>
</property>
<attribute name="label" >
<number>1</number>
</property>
<property name="maximum" >
- <number>10</number>
+ <number>150</number>
</property>
<property name="pageStep" >
- <number>2</number>
+ <number>30</number>
</property>
<property name="orientation" >
<enum>Qt::Horizontal</enum>
<enum>QFrame::Raised</enum>
</property>
<layout class="QGridLayout" name="gridLayout" >
+ <property name="margin" >
+ <number>2</number>
+ </property>
<item row="0" column="0" >
<layout class="QHBoxLayout" name="positionLayout" >
<item>
</widget>
</item>
</layout>
+ <zorder>rect_properties</zorder>
+ <zorder>text_properties</zorder>
+ <zorder>splitter</zorder>
+ <zorder>buttonFitZoom</zorder>
+ <zorder>buttonRealSize</zorder>
+ <zorder>zoom_slider</zorder>
+ <zorder>zoom_label</zorder>
+ <zorder>displayBg</zorder>
+ <zorder>buttonBox</zorder>
+ <zorder>frame_properties</zorder>
+ <zorder>frame_toolbar</zorder>
</widget>
<customwidgets>
<customwidget>