Fix custom page size handling in the Unix print dialog

There were several problems that i've fixed in a single commit since they are very interwinded

 * The dialog used QPageSize::Custom for two things, the custom sizes coming from
   the printer and the "user can write whatever size they want" size. Now only
   the printer custom sizes use QPageSize::Custom and we use m_realCustomPageSizeIndex
   for the "user can write whatever size they want" one.

 * The dialog stored the QPageSize id as the combo userData, that doesn't work
   when the printer has multiple custom sizes since they all share QPageSize::Custom
   so now it stores the QPageSize itself

Task-number: QTBUG-58733
Change-Id: Ie640a07bb5e24b753db83c091c836e8af4ff126c
Reviewed-by: Andy Shaw <andy.shaw@qt.io>
This commit is contained in:
Albert Astals Cid 2017-12-20 10:41:33 +01:00
parent bc632bc2bf
commit c1aaa13939
3 changed files with 22 additions and 14 deletions

View File

@ -104,10 +104,9 @@ void QCupsPrintEngine::setProperty(PrintEnginePropertyKey key, const QVariant &v
break; break;
case PPK_QPageLayout: { case PPK_QPageLayout: {
QPageLayout pageLayout = value.value<QPageLayout>(); QPageLayout pageLayout = value.value<QPageLayout>();
if (pageLayout.isValid() && d->m_printDevice.isValidPageLayout(pageLayout, d->resolution)) { if (pageLayout.isValid() && (d->m_printDevice.isValidPageLayout(pageLayout, d->resolution) || d->m_printDevice.supportsCustomPageSizes())) {
d->m_pageLayout = pageLayout; d->m_pageLayout = pageLayout;
// Replace the page size with the CUPS page size d->setPageSize(pageLayout.pageSize());
d->setPageSize(d->m_printDevice.supportedPageSize(pageLayout.pageSize()));
} }
break; break;
} }

View File

@ -234,10 +234,14 @@ QPageSetupWidget::QPageSetupWidget(QWidget *parent)
m_printer(nullptr), m_printer(nullptr),
m_outputFormat(QPrinter::PdfFormat), m_outputFormat(QPrinter::PdfFormat),
m_units(QPageLayout::Point), m_units(QPageLayout::Point),
m_blockSignals(false) m_blockSignals(false),
m_realCustomPageSizeIndex(-1)
{ {
m_ui.setupUi(this); m_ui.setupUi(this);
if (!QMetaType::hasRegisteredComparators<QPageSize>())
QMetaType::registerEqualsComparator<QPageSize>();
QVBoxLayout *lay = new QVBoxLayout(m_ui.preview); QVBoxLayout *lay = new QVBoxLayout(m_ui.preview);
m_pagePreview = new QPagePreview(m_ui.preview); m_pagePreview = new QPagePreview(m_ui.preview);
m_pagePreview->setPagePreviewLayout(1, 1); m_pagePreview->setPagePreviewLayout(1, 1);
@ -341,15 +345,18 @@ void QPageSetupWidget::initPageSizes()
m_ui.pageSizeCombo->clear(); m_ui.pageSizeCombo->clear();
m_realCustomPageSizeIndex = -1;
if (m_outputFormat == QPrinter::NativeFormat && !m_printerName.isEmpty()) { if (m_outputFormat == QPrinter::NativeFormat && !m_printerName.isEmpty()) {
QPlatformPrinterSupport *ps = QPlatformPrinterSupportPlugin::get(); QPlatformPrinterSupport *ps = QPlatformPrinterSupportPlugin::get();
if (ps) { if (ps) {
QPrintDevice printDevice = ps->createPrintDevice(m_printerName); QPrintDevice printDevice = ps->createPrintDevice(m_printerName);
const auto pageSizes = printDevice.supportedPageSizes(); const auto pageSizes = printDevice.supportedPageSizes();
for (const QPageSize &pageSize : pageSizes) for (const QPageSize &pageSize : pageSizes)
m_ui.pageSizeCombo->addItem(pageSize.name(), QVariant::fromValue(pageSize.id())); m_ui.pageSizeCombo->addItem(pageSize.name(), QVariant::fromValue(pageSize));
if (m_ui.pageSizeCombo->count() > 0 && printDevice.supportsCustomPageSizes()) { if (m_ui.pageSizeCombo->count() > 0 && printDevice.supportsCustomPageSizes()) {
m_ui.pageSizeCombo->addItem(tr("Custom"), QVariant::fromValue(QPageSize::Custom)); m_ui.pageSizeCombo->addItem(tr("Custom"));
m_realCustomPageSizeIndex = m_ui.pageSizeCombo->count() - 1;
m_blockSignals = false; m_blockSignals = false;
return; return;
} }
@ -359,10 +366,11 @@ void QPageSetupWidget::initPageSizes()
// If PdfFormat or no available printer page sizes, populate with all page sizes // If PdfFormat or no available printer page sizes, populate with all page sizes
for (int id = 0; id < QPageSize::LastPageSize; ++id) { for (int id = 0; id < QPageSize::LastPageSize; ++id) {
if (QPageSize::PageSizeId(id) == QPageSize::Custom) { if (QPageSize::PageSizeId(id) == QPageSize::Custom) {
m_ui.pageSizeCombo->addItem(tr("Custom"), QVariant::fromValue(QPageSize::Custom)); m_ui.pageSizeCombo->addItem(tr("Custom"));
m_realCustomPageSizeIndex = m_ui.pageSizeCombo->count() - 1;
} else { } else {
QPageSize pageSize = QPageSize(QPageSize::PageSizeId(id)); QPageSize pageSize = QPageSize(QPageSize::PageSizeId(id));
m_ui.pageSizeCombo->addItem(pageSize.name(), QVariant::fromValue(pageSize.id())); m_ui.pageSizeCombo->addItem(pageSize.name(), QVariant::fromValue(pageSize));
} }
} }
@ -434,7 +442,9 @@ void QPageSetupWidget::updateWidget()
m_ui.unitCombo->setCurrentIndex(m_ui.unitCombo->findData(QVariant::fromValue(m_units))); m_ui.unitCombo->setCurrentIndex(m_ui.unitCombo->findData(QVariant::fromValue(m_units)));
m_ui.pageSizeCombo->setCurrentIndex(m_ui.pageSizeCombo->findData(QVariant::fromValue(m_pageLayout.pageSize().id()))); const bool isCustom = m_ui.pageSizeCombo->currentIndex() == m_realCustomPageSizeIndex && m_realCustomPageSizeIndex != -1;
if (!isCustom)
m_ui.pageSizeCombo->setCurrentIndex(m_ui.pageSizeCombo->findData(QVariant::fromValue(m_pageLayout.pageSize())));
QMarginsF min; QMarginsF min;
QMarginsF max; QMarginsF max;
@ -467,8 +477,6 @@ void QPageSetupWidget::updateWidget()
m_ui.bottomMargin->setMaximum(max.bottom()); m_ui.bottomMargin->setMaximum(max.bottom());
m_ui.bottomMargin->setValue(m_pageLayout.margins().bottom()); m_ui.bottomMargin->setValue(m_pageLayout.margins().bottom());
bool isCustom = m_ui.pageSizeCombo->currentData().value<QPageSize::PageSizeId>() == QPageSize::Custom;
m_ui.pageWidth->setSuffix(suffix); m_ui.pageWidth->setSuffix(suffix);
m_ui.pageWidth->setValue(m_pageLayout.fullRect(m_units).width()); m_ui.pageWidth->setValue(m_pageLayout.fullRect(m_units).width());
m_ui.pageWidth->setEnabled(isCustom); m_ui.pageWidth->setEnabled(isCustom);
@ -513,10 +521,10 @@ void QPageSetupWidget::pageSizeChanged()
if (m_blockSignals) if (m_blockSignals)
return; return;
QPageSize::PageSizeId id = m_ui.pageSizeCombo->currentData().value<QPageSize::PageSizeId>(); if (m_ui.pageSizeCombo->currentIndex() != m_realCustomPageSizeIndex) {
if (id != QPageSize::Custom) { const QPageSize pageSize = m_ui.pageSizeCombo->currentData().value<QPageSize>();
// TODO Set layout margin min/max to printer custom min/max // TODO Set layout margin min/max to printer custom min/max
m_pageLayout.setPageSize(QPageSize(id)); m_pageLayout.setPageSize(pageSize);
} else { } else {
QSizeF customSize; QSizeF customSize;
if (m_pageLayout.orientation() == QPageLayout::Landscape) if (m_pageLayout.orientation() == QPageLayout::Landscape)

View File

@ -102,6 +102,7 @@ private:
QPageLayout m_pageLayout; QPageLayout m_pageLayout;
QPageLayout::Unit m_units; QPageLayout::Unit m_units;
bool m_blockSignals; bool m_blockSignals;
int m_realCustomPageSizeIndex;
}; };
QT_END_NAMESPACE QT_END_NAMESPACE