X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fdvdwizardmenu.cpp;h=e9c68835464bab781fb3263e9b9fd962c049ccb5;hb=08a49ce40071207043020d0d8f3c804703ee7af8;hp=9c0c8a7fecbdae6b7b0a04b67b25204f807fe7fb;hpb=66680f4542853db15a215334987677d16b5903dd;p=kdenlive diff --git a/src/dvdwizardmenu.cpp b/src/dvdwizardmenu.cpp index 9c0c8a7f..e9c68835 100644 --- a/src/dvdwizardmenu.cpp +++ b/src/dvdwizardmenu.cpp @@ -20,7 +20,8 @@ #include "dvdwizardmenu.h" #include - +#include +#include "kthumb.h" DvdWizardMenu::DvdWizardMenu(const QString &profile, QWidget *parent) : QWizardPage(parent), @@ -31,7 +32,7 @@ DvdWizardMenu::DvdWizardMenu(const QString &profile, QWidget *parent) : m_view.play_text->setText(i18n("Play")); m_scene = new DvdScene(this); m_view.menu_preview->setScene(m_scene); - + m_view.menu_preview->setMouseTracking(true); connect(m_view.create_menu, SIGNAL(toggled(bool)), m_view.menu_box, SLOT(setEnabled(bool))); connect(m_view.create_menu, SIGNAL(toggled(bool)), this, SIGNAL(completeChanged())); @@ -48,7 +49,6 @@ DvdWizardMenu::DvdWizardMenu(const QString &profile, QWidget *parent) : } else changeProfile(true); - // Create color background m_color = new QGraphicsRectItem(0, 0, m_width, m_height); m_color->setBrush(m_view.background_color->color()); @@ -83,7 +83,6 @@ DvdWizardMenu::DvdWizardMenu(const QString &profile, QWidget *parent) : button->setFont(font); button->setDefaultTextColor(m_view.text_color->color()); button->setZValue(4); - button->setFlags(QGraphicsItem::ItemIsMovable | QGraphicsItem::ItemIsSelectable); QRectF r = button->sceneBoundingRect(); m_scene->addItem(button); button->setPos((m_width - r.width()) / 2, (m_height - r.height()) / 2); @@ -111,6 +110,13 @@ DvdWizardMenu::DvdWizardMenu(const QString &profile, QWidget *parent) : connect(m_scene, SIGNAL(selectionChanged()), this, SLOT(buttonChanged())); connect(m_scene, SIGNAL(changed(const QList &)), this, SIGNAL(completeChanged())); + // red background for error message + KColorScheme scheme(palette().currentColorGroup(), KColorScheme::Window); + QPalette p = m_view.error_message->palette(); + p.setColor(QPalette::Background, scheme.background(KColorScheme::NegativeBackground).color()); + m_view.error_message->setAutoFillBackground(true); + m_view.error_message->setPalette(p); + m_view.menu_box->setEnabled(false); } @@ -127,6 +133,7 @@ DvdWizardMenu::~DvdWizardMenu() bool DvdWizardMenu::isComplete() const { + m_view.error_message->setHidden(true); if (!m_view.create_menu->isChecked()) return true; QList targets; QList list = m_scene->items(); @@ -139,20 +146,30 @@ bool DvdWizardMenu::isComplete() const QList collisions = button->collidingItems(); if (!collisions.isEmpty()) { for (int j = 0; j < collisions.count(); j++) { - if (collisions.at(j)->type() == button->type()) return false; + if (collisions.at(j)->type() == button->type()) { + m_view.error_message->setText(i18n("Buttons overlapping")); + m_view.error_message->setHidden(false); + return false; + } } } targets.append(button->target()); } } if (buttonCount == 0) { - // We need at least one button + //We need at least one button + m_view.error_message->setText(i18n("No button in menu")); + m_view.error_message->setHidden(false); return false; } if (!m_view.background_image->isHidden()) { // Make sure user selected a valid image / video file - if (!QFile::exists(m_view.background_image->url().path())) return false; + if (!QFile::exists(m_view.background_image->url().path())) { + m_view.error_message->setText(i18n("Missing background image")); + m_view.error_message->setHidden(false); + return false; + } } // check that we have a "Play all" entry @@ -160,7 +177,11 @@ bool DvdWizardMenu::isComplete() const // ... or that each video file has a button for (int i = m_view.target_list->count() - 1; i > 0; i--) { // If there is a vob file entry and it has no button assigned, don't allow to go further - if (m_view.target_list->itemIcon(i).isNull() == false && !targets.contains(i)) return false; + if (m_view.target_list->itemIcon(i).isNull() == false && !targets.contains(i)) { + m_view.error_message->setText(i18n("No menu entry for %1", m_view.target_list->itemText(i))); + m_view.error_message->setHidden(false); + return false; + } } return true; } @@ -232,7 +253,6 @@ void DvdWizardMenu::addButton() button->setFont(font); button->setDefaultTextColor(m_view.text_color->color()); button->setZValue(4); - button->setFlags(QGraphicsItem::ItemIsMovable | QGraphicsItem::ItemIsSelectable); QRectF r = button->sceneBoundingRect(); m_scene->addItem(button); button->setPos((m_width - r.width()) / 2, (m_height - r.height()) / 2); @@ -284,7 +304,7 @@ void DvdWizardMenu::updatePreview() void DvdWizardMenu::setTargets(QStringList list, QStringList targetlist) { m_view.target_list->clear(); - m_view.target_list->addItem(i18n("Play All"), "title 1"); + m_view.target_list->addItem(i18n("Play All"), "jump title 1"); int movieCount = 0; for (int i = 0; i < list.count(); i++) { if (targetlist.at(i).contains("chapter")) @@ -302,16 +322,21 @@ void DvdWizardMenu::checkBackgroundType(int ix) if (ix == 0) { m_view.background_color->setVisible(true); m_view.background_image->setVisible(false); + m_view.loop_movie->setVisible(false); if (m_background->scene() != 0) m_scene->removeItem(m_background); } else { m_view.background_color->setVisible(false); m_view.background_image->setVisible(true); if (ix == 1) { + m_view.background_image->clear(); m_view.background_image->setFilter("*"); - m_scene->addItem(m_background); + if (m_background->scene() != 0) m_scene->removeItem(m_background); + m_view.loop_movie->setVisible(false); } else { if (m_background->scene() != 0) m_scene->removeItem(m_background); + m_view.background_image->clear(); m_view.background_image->setFilter("video/mpeg"); + m_view.loop_movie->setVisible(true); } } } @@ -329,13 +354,24 @@ void DvdWizardMenu::buildImage() return; } QPixmap pix; - if (!pix.load(m_view.background_image->url().path())) { - if (m_background->scene() != 0) m_scene->removeItem(m_background); - return; + + if (m_view.background_list->currentIndex() == 1) { + // image background + if (!pix.load(m_view.background_image->url().path())) { + if (m_background->scene() != 0) m_scene->removeItem(m_background); + return; + } + pix = pix.scaled(m_width, m_height); + } else if (m_view.background_list->currentIndex() == 2) { + // video background + int w; + if (m_isPal) w = 768; + else w = 640; + pix = KThumb::getImage(m_view.background_image->url(), 0, w, m_height); + pix = pix.scaled(m_width, m_height); } - pix = pix.scaled(m_width, m_height); m_background->setPixmap(pix); - if (m_view.background_list->currentIndex() == 1) m_scene->addItem(m_background); + m_scene->addItem(m_background); } void DvdWizardMenu::checkBackground() @@ -389,13 +425,14 @@ void DvdWizardMenu::createButtonImages(const QString &img1, const QString &img2, { if (m_view.create_menu->isChecked()) { m_scene->clearSelection(); - QImage img(m_width, m_height, QImage::Format_ARGB8555_Premultiplied); - QPainter p(&img); - p.setRenderHints(QPainter::Antialiasing, false); - p.setRenderHints(QPainter::TextAntialiasing, false); + QImage img(m_width, m_height, QImage::Format_ARGB32_Premultiplied); + img.fill(Qt::transparent); if (m_safeRect->scene() != 0) m_scene->removeItem(m_safeRect); if (m_color->scene() != 0) m_scene->removeItem(m_color); if (m_background->scene() != 0) m_scene->removeItem(m_background); + QPainter p(&img); + p.setRenderHints(QPainter::Antialiasing, false); + p.setRenderHints(QPainter::TextAntialiasing, false); m_scene->render(&p, QRectF(0, 0, m_width, m_height)); p.end(); #if QT_VERSION >= 0x040600 @@ -404,6 +441,7 @@ void DvdWizardMenu::createButtonImages(const QString &img1, const QString &img2, img.setNumColors(4); #endif img.save(img1); + /*QImage saved; if (m_view.menu_profile->currentIndex() < 2) saved = img.scaled(720, 576); @@ -412,6 +450,7 @@ void DvdWizardMenu::createButtonImages(const QString &img1, const QString &img2, saved.save(img1);*/ updateColor(m_view.selected_color->color()); + img.fill(Qt::transparent); p.begin(&img); p.setRenderHints(QPainter::Antialiasing, false); p.setRenderHints(QPainter::TextAntialiasing, false); @@ -431,6 +470,7 @@ void DvdWizardMenu::createButtonImages(const QString &img1, const QString &img2, updateColor(m_view.highlighted_color->color()); + img.fill(Qt::transparent); p.begin(&img); p.setRenderHints(QPainter::Antialiasing, false); p.setRenderHints(QPainter::TextAntialiasing, false); @@ -452,7 +492,7 @@ void DvdWizardMenu::createButtonImages(const QString &img1, const QString &img2, m_scene->addItem(m_safeRect); m_scene->addItem(m_color); - if (m_view.background_list->currentIndex() == 1) m_scene->addItem(m_background); + if (m_view.background_list->currentIndex() > 0) m_scene->addItem(m_background); } } @@ -485,6 +525,11 @@ bool DvdWizardMenu::createMenu() const return m_view.create_menu->isChecked(); } +bool DvdWizardMenu::loopMovie() const +{ + return m_view.loop_movie->isChecked(); +} + bool DvdWizardMenu::menuMovie() const { return m_view.background_list->currentIndex() == 2; @@ -612,7 +657,6 @@ void DvdWizardMenu::loadXml(QDomElement xml) button->setBackMenu(e.attribute("backtomenu").toInt()); button->setDefaultTextColor(m_view.text_color->color()); button->setZValue(4); - button->setFlags(QGraphicsItem::ItemIsMovable | QGraphicsItem::ItemIsSelectable); QRectF r = button->sceneBoundingRect(); m_scene->addItem(button); button->setPos(e.attribute("posx").toDouble(), e.attribute("posy").toDouble());