From 32ce8e20c0e28b9649d6f54a1243082fe69406b8 Mon Sep 17 00:00:00 2001 From: Jean-Baptiste Mardelle Date: Fri, 25 Jun 2010 14:51:35 +0000 Subject: [PATCH] Allow to preserve aspect ratio in render dialog resize option: http://www.kdenlive.org/mantis/view.php?id=1671 svn path=/trunk/kdenlive/; revision=4542 --- src/kdenlivesettings.kcfg | 14 ++ src/renderwidget.cpp | 53 +++++-- src/renderwidget.h | 3 + src/widgets/renderwidget_ui.ui | 268 +++++++++++++++++++++------------ 4 files changed, 229 insertions(+), 109 deletions(-) diff --git a/src/kdenlivesettings.kcfg b/src/kdenlivesettings.kcfg index 58e4058b..2d52c34a 100644 --- a/src/kdenlivesettings.kcfg +++ b/src/kdenlivesettings.kcfg @@ -549,5 +549,19 @@ #000000 + + + + false + + + + 320 + + + + 240 + + diff --git a/src/renderwidget.cpp b/src/renderwidget.cpp index e5979a83..bdfcb7cf 100644 --- a/src/renderwidget.cpp +++ b/src/renderwidget.cpp @@ -88,9 +88,12 @@ RenderWidget::RenderWidget(const QString &projectfolder, QWidget * parent) : m_view.buttonInfo->setDown(true); } else m_view.advanced_params->hide(); - m_view.rescale_size->setInputMask("0099\\x0099"); - m_view.rescale_size->setText("320x240"); - + m_view.rescale_keep->setChecked(KdenliveSettings::rescalekeepratio()); + connect(m_view.rescale_width, SIGNAL(valueChanged(int)), this, SLOT(slotUpdateRescaleWidth(int))); + connect(m_view.rescale_height, SIGNAL(valueChanged(int)), this, SLOT(slotUpdateRescaleHeight(int))); + m_view.rescale_keep->setIcon(KIcon("insert-link")); + m_view.rescale_keep->setToolTip(i18n("Preserve aspect ratio")); + connect(m_view.rescale_keep, SIGNAL(clicked()), this, SLOT(slotSwitchAspectRatio())); connect(m_view.buttonRender, SIGNAL(clicked()), this, SLOT(slotPrepareExport())); connect(m_view.buttonGenerateScript, SIGNAL(clicked()), this, SLOT(slotGenerateScript())); @@ -133,7 +136,7 @@ RenderWidget::RenderWidget(const QString &projectfolder, QWidget * parent) : connect(m_view.buttonClose, SIGNAL(clicked()), this, SLOT(hide())); connect(m_view.buttonClose2, SIGNAL(clicked()), this, SLOT(hide())); connect(m_view.buttonClose3, SIGNAL(clicked()), this, SLOT(hide())); - connect(m_view.rescale, SIGNAL(toggled(bool)), m_view.rescale_size, SLOT(setEnabled(bool))); + connect(m_view.rescale, SIGNAL(toggled(bool)), m_view.rescale_box, SLOT(setEnabled(bool))); connect(m_view.destination_list, SIGNAL(activated(int)), this, SLOT(refreshCategory())); connect(m_view.out_file, SIGNAL(textChanged(const QString &)), this, SLOT(slotUpdateButtons())); connect(m_view.out_file, SIGNAL(urlSelected(const KUrl &)), this, SLOT(slotUpdateButtons(const KUrl &))); @@ -153,7 +156,7 @@ RenderWidget::RenderWidget(const QString &projectfolder, QWidget * parent) : m_view.buttonRender->setEnabled(false); m_view.buttonGenerateScript->setEnabled(false); - m_view.rescale_size->setEnabled(false); + m_view.rescale_box->setEnabled(false); m_view.guides_box->setVisible(false); m_view.open_dvd->setVisible(false); m_view.create_chapter->setVisible(false); @@ -733,8 +736,8 @@ void RenderWidget::slotExport(bool scriptExport, int zoneIn, int zoneOut, const int width; int height; if (m_view.rescale->isChecked() && m_view.rescale->isEnabled()) { - width = m_view.rescale_size->text().section('x', 0, 0).toInt(); - height = m_view.rescale_size->text().section('x', 1, 1).toInt(); + width = m_view.rescale_width->value(); + height = m_view.rescale_height->value(); } else { width = m_profile.width; height = m_profile.height; @@ -926,6 +929,12 @@ void RenderWidget::setProfile(MltVideoProfile profile) if (m_profile.description.contains("pal", Qt::CaseInsensitive) || m_profile.description.contains("25", Qt::CaseInsensitive) || m_profile.description.contains("50", Qt::CaseInsensitive)) m_view.format_selection->setCurrentIndex(0); else m_view.format_selection->setCurrentIndex(1); m_view.scanning_list->setCurrentIndex(0); + m_view.rescale_width->setValue(KdenliveSettings::defaultrescalewidth()); + if (!m_view.rescale_keep->isChecked()) { + m_view.rescale_height->blockSignals(true); + m_view.rescale_height->setValue(KdenliveSettings::defaultrescaleheight()); + m_view.rescale_height->blockSignals(false); + } refreshView(); } @@ -1124,10 +1133,10 @@ void RenderWidget::refreshParams() if (params.contains(" s=") || destination == "audioonly") { // profile has a fixed size, do not allow resize m_view.rescale->setEnabled(false); - m_view.rescale_size->setEnabled(false); + m_view.rescale_box->setEnabled(false); } else { m_view.rescale->setEnabled(true); - m_view.rescale_size->setEnabled(true); + m_view.rescale_box->setEnabled(true); } KUrl url = filenameWithExtension(m_view.out_file->url(), extension); m_view.out_file->setUrl(url); @@ -1780,3 +1789,29 @@ void RenderWidget::missingClips(bool hasMissing) } else m_view.errorLabel->setHidden(true); } +void RenderWidget::slotUpdateRescaleWidth(int val) +{ + KdenliveSettings::setDefaultrescalewidth(val); + if (!m_view.rescale_keep->isChecked()) return; + m_view.rescale_height->blockSignals(true); + m_view.rescale_height->setValue(val * m_profile.height / m_profile.width + 0.5); + KdenliveSettings::setDefaultrescaleheight(m_view.rescale_height->value()); + m_view.rescale_height->blockSignals(false); +} + +void RenderWidget::slotUpdateRescaleHeight(int val) +{ + KdenliveSettings::setDefaultrescaleheight(val); + if (!m_view.rescale_keep->isChecked()) return; + m_view.rescale_width->blockSignals(true); + m_view.rescale_width->setValue(val * m_profile.width / m_profile.height + 0.5); + KdenliveSettings::setDefaultrescaleheight(m_view.rescale_width->value()); + m_view.rescale_width->blockSignals(false); +} + +void RenderWidget::slotSwitchAspectRatio() +{ + KdenliveSettings::setRescalekeepratio(m_view.rescale_keep->isChecked()); + if (m_view.rescale_keep->isChecked()) slotUpdateRescaleWidth(m_view.rescale_width->value()); +} + diff --git a/src/renderwidget.h b/src/renderwidget.h index 7559ac38..5014cde4 100644 --- a/src/renderwidget.h +++ b/src/renderwidget.h @@ -144,6 +144,9 @@ private slots: void slotPlayRendering(QTreeWidgetItem *item, int); void slotStartCurrentJob(); void slotCopyToFavorites(); + void slotUpdateRescaleHeight(int); + void slotUpdateRescaleWidth(int); + void slotSwitchAspectRatio(); private: Ui::RenderWidget_UI m_view; diff --git a/src/widgets/renderwidget_ui.ui b/src/widgets/renderwidget_ui.ui index f8d61166..293b5f75 100644 --- a/src/widgets/renderwidget_ui.ui +++ b/src/widgets/renderwidget_ui.ui @@ -6,8 +6,8 @@ 0 0 - 392 - 535 + 365 + 553 @@ -26,7 +26,7 @@ Render Project - + @@ -34,7 +34,7 @@ - + @@ -44,7 +44,7 @@ - + @@ -61,7 +61,7 @@ - + @@ -75,28 +75,52 @@ - - - - E + + + + Qt::Horizontal - - - - - - S + + + 124 + 23 + - + - - - - D - - + + + + + + ... + + + + + + + E + + + + + + + S + + + + + + + D + + + + - + Qt::Vertical @@ -139,7 +163,7 @@ - + @@ -158,7 +182,7 @@ - + Export audio @@ -168,45 +192,115 @@ - - - - Rescale - - + + + + + + Rescale + + + + + + + + + + true + + + false + + + + 0 + + + + + 0 + + + + + + + x + + + + + + + 0 + + + + + + + ... + + + true + + + + + + + Qt::Horizontal + + + + 40 + 20 + + + + + + + + - - + + - - - - + Open Dvd wizard after rendering - - + + - Timecode overlay + Create chapter file based on guides - + Open browser window after export - + Play after render - + + + + Timecode overlay + + + + @@ -232,9 +326,22 @@ + + + + Qt::Horizontal + + + + 40 + 20 + + + + - + @@ -277,21 +384,28 @@ - + + + + + + + + Render to File - + Generate Script - + Qt::Horizontal @@ -304,54 +418,13 @@ - + Close - - - - Open Dvd wizard after rendering - - - - - - - Create chapter file based on guides - - - - - - - ... - - - - - - - Qt::Horizontal - - - - 124 - 23 - - - - - - - - - - - @@ -553,26 +626,21 @@ QPushButton
kpushbutton.h
- - KLineEdit - QLineEdit -
klineedit.h
-
KComboBox QComboBox
kcombobox.h
+ + KIntNumInput + QWidget +
knuminput.h
+
KTextEdit QTextEdit
ktextedit.h
- - KRestrictedLine - KLineEdit -
krestrictedline.h
-
-- 2.39.2