You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
kipi-plugins/kipi-plugins/batchprocessimages/resizeoptionsdialog.cpp

374 lines
18 KiB

/* ============================================================
*
* This file is a part of kipi-plugins project
* http://www.kipi-plugins.org
*
* Date : 2004-10-01
* Description : a kipi plugin to batch process images
*
* Copyright (C) 2004-2007 by Gilles Caulier <caulier dot gilles at gmail dot com>
*
* This program is free software; you can redistribute it
* and/or modify it under the terms of the GNU General
* Public License as published by the Free Software Foundation;
* either version 2, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* ============================================================ */
// Include files for TQt
#include <tqvbox.h>
#include <tqlayout.h>
#include <tqwidget.h>
#include <tqwhatsthis.h>
#include <tqlabel.h>
#include <tqpushbutton.h>
#include <tqgroupbox.h>
#include <tqcombobox.h>
#include <tqcheckbox.h>
#include <tqcolor.h>
// Include files for KDE
#include <tdelocale.h>
#include <knuminput.h>
#include <kcolorbutton.h>
#include <tdemessagebox.h>
// Local includes
#include "resizeoptionsdialog.h"
#include "resizeoptionsdialog.moc"
namespace KIPIBatchProcessImagesPlugin
{
ResizeOptionsDialog::ResizeOptionsDialog(TQWidget *parent, int ResizeType)
: KDialogBase( parent, "ResizeOptionsDialog", true,
i18n("Image-Resize Options"), Ok|Cancel, Ok, false)
{
m_Type = ResizeType;
TQWidget* box = new TQWidget( this );
setMainWidget(box);
TQVBoxLayout *dvlay = new TQVBoxLayout( box, 10, spacingHint() );
TQString whatsThis;
if (m_Type == 0) // Proportional (1 dim.)
{
TQGroupBox * groupBox1 = new TQGroupBox( 1, TQt::Horizontal, i18n("Resize Options"), box );
m_size = new KIntNumInput(640, groupBox1);
m_size->setRange(10, 10000, 1, true );
m_size->setLabel( i18n("New size (pixels):") );
TQWhatsThis::add( m_size, i18n("<p>The new images' size in pixels.") );
m_quality = new KIntNumInput(75, groupBox1);
m_quality->setRange(0, 100, 1, true);
m_quality->setLabel( i18n("Image quality (percent):") );
TQWhatsThis::add( m_quality, i18n("<p>Quality for JPEG images.") );
m_label_resizeFilter = new TQLabel (i18n("Filter name:"), groupBox1);
m_resizeFilter = new TQComboBox( false, groupBox1 );
m_resizeFilter->insertItem(i18n("Filter name","Bessel"));
m_resizeFilter->insertItem(i18n("Filter name","Blackman"));
m_resizeFilter->insertItem(i18n("Filter name","Box"));
m_resizeFilter->insertItem(i18n("Filter name","Catrom"));
m_resizeFilter->insertItem(i18n("Filter name","Cubic"));
m_resizeFilter->insertItem(i18n("Filter name","Gaussian"));
m_resizeFilter->insertItem(i18n("Filter name","Hermite"));
m_resizeFilter->insertItem(i18n("Filter name","Hanning"));
m_resizeFilter->insertItem(i18n("Filter name","Hamming"));
m_resizeFilter->insertItem(i18n("Filter name","Lanczos"));
m_resizeFilter->insertItem(i18n("Filter name","Mitchell"));
m_resizeFilter->insertItem(i18n("Filter name","Point"));
m_resizeFilter->insertItem(i18n("Filter name","Quadratic"));
m_resizeFilter->insertItem(i18n("Filter name","Sinc"));
m_resizeFilter->insertItem(i18n("Filter name","Triangle"));
TQWhatsThis::add( m_resizeFilter, i18n("<p>Select here the filter name for the resize-image process. "
"This filter will be used like a kernel convolution process "
"during the increased image size rendering. The default filter "
"is 'Lanczos'.") );
m_label_resizeFilter->setBuddy( m_resizeFilter );
dvlay->addWidget( groupBox1 );
m_label_size = new TQLabel ( i18n("Note: the images will be resized to\n"
"this size. The width or the height of the\n"
"images will be automatically\n"
"selected in depending of the images orientation.\n"
"The images' aspect ratios are preserved."), box);
dvlay->addWidget( m_label_size );
}
if (m_Type == 1) // Proportional (2 dim.)
{
TQGroupBox * groupBox1 = new TQGroupBox( 2, TQt::Horizontal, i18n("Size Settings"), box );
m_label_Width = new TQLabel (i18n("Width (pixels):"), groupBox1);
m_Width = new KIntNumInput(1024, groupBox1);
m_Width->setRange(100, 10000, 1, true );
TQWhatsThis::add( m_Width, i18n("<p>The new images' width in pixels."));
m_label_Width->setBuddy( m_Width );
m_label_Height = new TQLabel (i18n("Height (pixels):"), groupBox1);
m_Height = new KIntNumInput(768, groupBox1);
m_Height->setRange(100, 10000, 1, true );
TQWhatsThis::add( m_Height, i18n("<p>The new images' height in pixels."));
m_label_Height->setBuddy( m_Height );
m_label_quality = new TQLabel (i18n("Image quality (percent):"), groupBox1);
m_quality = new KIntNumInput(75, groupBox1);
m_quality->setRange(0, 100, 1, true);
TQWhatsThis::add( m_quality, i18n("<p>Quality for JPEG images.") );
m_label_quality->setBuddy(m_quality);
dvlay->addWidget( groupBox1 );
TQGroupBox * groupBox2 = new TQGroupBox( 2, TQt::Horizontal, i18n("Rendering Settings"), box );
m_label_bgColor = new TQLabel(i18n("Background color:"), groupBox2);
TQColor bgColor = TQColor( 0, 0, 0 ); // Black per default.
m_button_bgColor = new KColorButton( bgColor, groupBox2 );
TQWhatsThis::add( m_button_bgColor, i18n( "<p>You can select here the background color to "
"be used when adapting the images' sizes." ));
m_label_bgColor->setBuddy( m_button_bgColor );
m_label_resizeFilter = new TQLabel (i18n("Filter name:"), groupBox2);
m_resizeFilter = new TQComboBox( false, groupBox2 );
m_resizeFilter->insertItem(i18n("Filter name","Bessel"));
m_resizeFilter->insertItem(i18n("Filter name","Blackman"));
m_resizeFilter->insertItem(i18n("Filter name","Box"));
m_resizeFilter->insertItem(i18n("Filter name","Catrom"));
m_resizeFilter->insertItem(i18n("Filter name","Cubic"));
m_resizeFilter->insertItem(i18n("Filter name","Gaussian"));
m_resizeFilter->insertItem(i18n("Filter name","Hermite"));
m_resizeFilter->insertItem(i18n("Filter name","Hanning"));
m_resizeFilter->insertItem(i18n("Filter name","Hamming"));
m_resizeFilter->insertItem(i18n("Filter name","Lanczos"));
m_resizeFilter->insertItem(i18n("Filter name","Mitchell"));
m_resizeFilter->insertItem(i18n("Filter name","Point"));
m_resizeFilter->insertItem(i18n("Filter name","Quadratic"));
m_resizeFilter->insertItem(i18n("Filter name","Sinc"));
m_resizeFilter->insertItem(i18n("Filter name","Triangle"));
TQWhatsThis::add( m_resizeFilter, i18n("<p>Select here the filter name for the resize-image process. "
"This filter will be used like a kernel convolution process "
"during the increased image size rendering. The default filter "
"is 'Lanczos'.") );
m_label_resizeFilter->setBuddy( m_resizeFilter );
m_label_border = new TQLabel (i18n("Border size (pixels):"), groupBox2);
m_Border = new KIntNumInput(100, groupBox2);
m_Border->setRange(0, 1000, 1, true );
TQWhatsThis::add( m_Border, i18n("<p>The border size around the images in pixels."));
m_label_border->setBuddy( m_Border );
dvlay->addWidget( groupBox2 );
}
if (m_Type == 2) // Non proportional
{
TQGroupBox * groupBox1 = new TQGroupBox( 1, TQt::Horizontal, i18n("Resize Options"), box );
m_fixedWidth = new KIntNumInput(640, groupBox1);
m_fixedWidth->setRange(10, 10000, 1, true );
m_fixedWidth->setLabel( i18n("New width (pixels):") );
TQWhatsThis::add( m_fixedWidth, i18n("<p>The new images' width in pixels.") );
m_fixedHeight = new KIntNumInput(480, groupBox1);
m_fixedHeight->setRange(10, 10000, 1, true );
m_fixedHeight->setLabel( i18n("New height (pixels):") );
TQWhatsThis::add( m_fixedHeight, i18n("<p>The new images' height in pixels.") );
m_quality = new KIntNumInput(75, groupBox1);
m_quality->setRange(0, 100, 1, true);
m_quality->setLabel( i18n("Image quality (percent):") );
TQWhatsThis::add( m_quality, i18n("<p>Quality for JPEG images.") );
m_label_resizeFilter = new TQLabel (i18n("Filter name:"), groupBox1);
m_resizeFilter = new TQComboBox( false, groupBox1 );
m_resizeFilter->insertItem(i18n("Filter name","Bessel"));
m_resizeFilter->insertItem(i18n("Filter name","Blackman"));
m_resizeFilter->insertItem(i18n("Filter name","Box"));
m_resizeFilter->insertItem(i18n("Filter name","Catrom"));
m_resizeFilter->insertItem(i18n("Filter name","Cubic"));
m_resizeFilter->insertItem(i18n("Filter name","Gaussian"));
m_resizeFilter->insertItem(i18n("Filter name","Hermite"));
m_resizeFilter->insertItem(i18n("Filter name","Hanning"));
m_resizeFilter->insertItem(i18n("Filter name","Hamming"));
m_resizeFilter->insertItem(i18n("Filter name","Lanczos"));
m_resizeFilter->insertItem(i18n("Filter name","Mitchell"));
m_resizeFilter->insertItem(i18n("Filter name","Point"));
m_resizeFilter->insertItem(i18n("Filter name","Quadratic"));
m_resizeFilter->insertItem(i18n("Filter name","Sinc"));
m_resizeFilter->insertItem(i18n("Filter name","Triangle"));
TQWhatsThis::add( m_resizeFilter, i18n("<p>Select here the filter name for the resize-image process. "
"This filter will be used like a kernel convolution process "
"during the increased image size rendering. The default filter "
"is 'Lanczos'.") );
m_label_resizeFilter->setBuddy( m_resizeFilter );
dvlay->addWidget( groupBox1 );
}
if (m_Type == 3) // Prepare to print
{
m_customSettings = new TQCheckBox( i18n("Use custom settings"), box);
TQWhatsThis::add( m_customSettings, i18n("<p>If this option is enabled, "
"all printing settings can be customized."));
dvlay->addWidget( m_customSettings );
TQGroupBox * groupBox1 = new TQGroupBox( 2, TQt::Horizontal, i18n("Printing Standard Settings"), box );
m_label_paperSize = new TQLabel (i18n("Paper size (cm):"), groupBox1);
m_paperSize = new TQComboBox( false, groupBox1 );
m_paperSize->insertItem("9x13");
m_paperSize->insertItem("10x15");
m_paperSize->insertItem("13x19");
m_paperSize->insertItem("15x21");
m_paperSize->insertItem("18x24");
m_paperSize->insertItem("20x30");
m_paperSize->insertItem("21x30");
m_paperSize->insertItem("30x40");
m_paperSize->insertItem("30x45");
m_paperSize->insertItem("40x50");
m_paperSize->insertItem("50x75");
TQWhatsThis::add( m_paperSize, i18n("<p>The standard photographic paper sizes in centimeters."));
m_label_paperSize->setBuddy( m_paperSize );
m_label_printDpi = new TQLabel (i18n("Print resolution (dpi):"), groupBox1);
m_printDpi = new TQComboBox( false, groupBox1 );
m_printDpi->insertItem("75");
m_printDpi->insertItem("150");
m_printDpi->insertItem("300");
m_printDpi->insertItem("600");
m_printDpi->insertItem("1200");
m_printDpi->insertItem("1400");
m_printDpi->insertItem("2400");
TQWhatsThis::add( m_printDpi, i18n("<p>The standard print resolutions in dots per inch."));
m_label_printDpi->setBuddy( m_printDpi );
dvlay->addWidget( groupBox1 );
TQGroupBox * groupBox2 = new TQGroupBox( 2, TQt::Horizontal, i18n("Printing Custom Settings"), box );
m_label_customXSize = new TQLabel (i18n("Paper width (cm):"), groupBox2);
m_customXSize = new KIntNumInput(10, groupBox2);
m_customXSize->setRange(1, 100, 1, true );
TQWhatsThis::add( m_customXSize, i18n("<p>The customized width of the photographic paper size "
"in centimeters."));
m_label_customXSize->setBuddy( m_customXSize );
m_label_customYSize = new TQLabel (i18n("Paper height (cm):"), groupBox2);
m_customYSize = new KIntNumInput(15, groupBox2);
m_customYSize->setRange(1, 100, 1, true );
TQWhatsThis::add( m_customYSize, i18n("<p>The customized height of the photographic paper size "
"in centimeters."));
m_label_customYSize->setBuddy( m_customYSize );
m_label_customDpi = new TQLabel (i18n("Print resolution (dpi):"), groupBox2);
m_customDpi = new KIntNumInput(300, groupBox2);
m_customDpi->setRange(10, 5000, 10, true );
TQWhatsThis::add( m_customDpi, i18n("<p>The customized print resolution in dots per inch."));
m_label_customDpi->setBuddy( m_customDpi );
dvlay->addWidget( groupBox2 );
TQGroupBox * groupBox3 = new TQGroupBox( 2, TQt::Horizontal, i18n("Rendering Settings"), box );
m_label_backgroundColor = new TQLabel(i18n("Background color:"), groupBox3);
TQColor backgroundColor = TQColor( 255, 255, 255 ); // White per default.
m_button_backgroundColor = new KColorButton( backgroundColor, groupBox3 );
TQWhatsThis::add( m_button_backgroundColor, i18n( "<p>You can select here the background color to "
"be used when adapting the images' sizes." ));
m_label_backgroundColor->setBuddy( m_button_backgroundColor );
m_label_resizeFilter = new TQLabel (i18n("Filter name:"), groupBox3);
m_resizeFilter = new TQComboBox( false, groupBox3 );
m_resizeFilter->insertItem(i18n("Filter name","Bessel"));
m_resizeFilter->insertItem(i18n("Filter name","Blackman"));
m_resizeFilter->insertItem(i18n("Filter name","Box"));
m_resizeFilter->insertItem(i18n("Filter name","Catrom"));
m_resizeFilter->insertItem(i18n("Filter name","Cubic"));
m_resizeFilter->insertItem(i18n("Filter name","Gaussian"));
m_resizeFilter->insertItem(i18n("Filter name","Hermite"));
m_resizeFilter->insertItem(i18n("Filter name","Hanning"));
m_resizeFilter->insertItem(i18n("Filter name","Hamming"));
m_resizeFilter->insertItem(i18n("Filter name","Lanczos"));
m_resizeFilter->insertItem(i18n("Filter name","Mitchell"));
m_resizeFilter->insertItem(i18n("Filter name","Point"));
m_resizeFilter->insertItem(i18n("Filter name","Quadratic"));
m_resizeFilter->insertItem(i18n("Filter name","Sinc"));
m_resizeFilter->insertItem(i18n("Filter name","Triangle"));
TQWhatsThis::add( m_resizeFilter, i18n("<p>Select here the filter name for the resize-image process. "
"This filter will be used like a kernel convolution process "
"during the increased image size rendering. The default filter "
"is 'Lanczos'.") );
m_label_resizeFilter->setBuddy( m_resizeFilter );
m_label_marging = new TQLabel (i18n("Margin size (mm):"), groupBox3);
m_marging = new KIntNumInput(1, groupBox3);
m_marging->setRange(0, 80, 1, true );
TQWhatsThis::add( m_marging, i18n("<p>The margin around the images in millimeters."));
m_label_marging->setBuddy( m_marging );
m_label_quality = new TQLabel (i18n("Image quality (percent):"), groupBox3);
m_quality = new KIntNumInput(75, groupBox3);
m_quality->setRange(0, 100, 1, true);
TQWhatsThis::add( m_quality, i18n("<p>Quality for JPEG images.") );
m_label_quality->setBuddy(m_quality);
dvlay->addWidget( groupBox3 );
connect(m_customSettings, TQT_SIGNAL( toggled(bool) ),
this, TQT_SLOT( slotCustomSettingsEnabled(bool) ) );
slotCustomSettingsEnabled(false);
}
}
ResizeOptionsDialog::~ResizeOptionsDialog()
{
}
void ResizeOptionsDialog::slotCustomSettingsEnabled(bool val)
{
m_label_paperSize->setEnabled( !val );
m_paperSize->setEnabled( !val );
m_label_printDpi->setEnabled( !val );
m_printDpi->setEnabled( !val );
m_label_customXSize->setEnabled( val );
m_customXSize->setEnabled( val );
m_label_customYSize->setEnabled( val );
m_customYSize->setEnabled( val );
m_label_customDpi->setEnabled( val );
m_customDpi->setEnabled( val );
}
void ResizeOptionsDialog::slotOk()
{
if (m_Type == 3) // Prepare to print
{
if (m_customSettings->isChecked() == true)
{
if (m_customXSize > m_customYSize)
{
KMessageBox::sorry(this, i18n("You must enter a custom height greater than the custom width: "
"the photographic paper must be vertically orientated."));
return;
}
}
}
accept();
}
} // NameSpace KIPIBatchProcessImagesPlugin