QGIS API Documentation 3.99.0-Master (26c88405ac0)
Loading...
Searching...
No Matches
qgslayoutpdfexportoptionsdialog.cpp
Go to the documentation of this file.
1/***************************************************************************
2 qgslayoutpdfexportoptionsdialog.cpp
3 -------------------------------------
4 begin : August 2019
5 copyright : (C) 2019 by Nyall Dawson
6 email : nyall dot dawson at gmail dot com
7 ***************************************************************************/
8/***************************************************************************
9 * *
10 * This program is free software; you can redistribute it and/or modify *
11 * it under the terms of the GNU General Public License as published by *
12 * the Free Software Foundation; either version 2 of the License, or *
13 * (at your option) any later version. *
14 * *
15 ***************************************************************************/
16
18
19#include "qgis.h"
22#include "qgsgui.h"
23#include "qgshelp.h"
24#include "qgslayertree.h"
26#include "qgsproject.h"
27#include "qgssettings.h"
28
29#include <QCheckBox>
30#include <QMenu>
31#include <QPushButton>
32
33#include "moc_qgslayoutpdfexportoptionsdialog.cpp"
34
35QgsLayoutPdfExportOptionsDialog::QgsLayoutPdfExportOptionsDialog( QWidget *parent, bool allowGeospatialPdfExport, const QString &geospatialPdfReason, const QStringList &geospatialPdfLayerOrder, Qt::WindowFlags flags )
36 : QDialog( parent, flags )
37{
38 setupUi( this );
39
40 mGeospatialPdfStructureTreeMenu = new QMenu( this );
41
42 mTextRenderFormatComboBox->addItem( tr( "Always Export Text as Paths (Recommended)" ), static_cast<int>( Qgis::TextRenderFormat::AlwaysOutlines ) );
43 mTextRenderFormatComboBox->addItem( tr( "Always Export Text as Text Objects" ), static_cast<int>( Qgis::TextRenderFormat::AlwaysText ) );
44 mTextRenderFormatComboBox->addItem( tr( "Prefer Exporting Text as Text Objects" ), static_cast<int>( Qgis::TextRenderFormat::PreferText ) );
45
46 mGeospatialPdfAvailable = allowGeospatialPdfExport && QgsAbstractGeospatialPdfExporter::geospatialPDFCreationAvailable();
47 mGeospatialPDFGroupBox->setEnabled( mGeospatialPdfAvailable );
48 mGeospatialPDFGroupBox->setChecked( false );
49 if ( !mGeospatialPdfAvailable )
50 {
51 mGeospatialPDFOptionsStackedWidget->setCurrentIndex( 0 );
52 mGeospatialPdfUnavailableReason->setText( geospatialPdfReason.isEmpty() ? QgsAbstractGeospatialPdfExporter::geospatialPDFAvailabilityExplanation() : geospatialPdfReason );
53 // avoid showing reason in disabled text color - we want it to stand out
54 QPalette p = mGeospatialPdfUnavailableReason->palette();
55 p.setColor( QPalette::Disabled, QPalette::WindowText, QPalette::WindowText );
56 mGeospatialPdfUnavailableReason->setPalette( p );
57 mGeospatialPDFOptionsStackedWidget->removeWidget( mGeospatialPDFOptionsStackedWidget->widget( 1 ) );
58 }
59 else
60 {
61 mGeospatialPDFOptionsStackedWidget->setCurrentIndex( 1 );
62 }
63
64 mComboImageCompression->addItem( tr( "Lossy (JPEG)" ), false );
65 mComboImageCompression->addItem( tr( "Lossless" ), true );
66
67 const QStringList themes = QgsProject::instance()->mapThemeCollection()->mapThemes();
68 for ( const QString &theme : themes )
69 {
70 QListWidgetItem *item = new QListWidgetItem( theme );
71 item->setFlags( item->flags() | Qt::ItemIsUserCheckable );
72 item->setCheckState( Qt::Unchecked );
73 mThemesList->addItem( item );
74 }
75
76 QList<QgsMapLayer *> order = QgsProject::instance()->layerTreeRoot()->layerOrder();
77 for ( auto it = geospatialPdfLayerOrder.rbegin(); it != geospatialPdfLayerOrder.rend(); ++it )
78 {
79 for ( int i = 0; i < order.size(); ++i )
80 {
81 if ( order.at( i )->id() == *it )
82 {
83 order.move( i, 0 );
84 break;
85 }
86 }
87 }
88 mGeospatialPdfStructureModel = new QgsGeospatialPdfLayerTreeModel( order, this );
89 mGeospatialPdfStructureProxyModel = new QgsGeospatialPdfLayerFilteredTreeModel( mGeospatialPdfStructureModel, this );
90 mGeospatialPdfStructureTree->setModel( mGeospatialPdfStructureProxyModel );
91 mGeospatialPdfStructureTree->resizeColumnToContents( 0 );
92 mGeospatialPdfStructureTree->header()->show();
93 mGeospatialPdfStructureTree->setSelectionMode( QAbstractItemView::SingleSelection );
94 mGeospatialPdfStructureTree->setSelectionBehavior( QAbstractItemView::SelectRows );
95
96 mGeospatialPdfStructureTree->setDragEnabled( true );
97 mGeospatialPdfStructureTree->setAcceptDrops( true );
98 mGeospatialPdfStructureTree->setDragDropMode( QAbstractItemView::InternalMove );
99 mGeospatialPdfStructureTree->setDefaultDropAction( Qt::MoveAction );
100
101 mGeospatialPdfStructureTree->setContextMenuPolicy( Qt::CustomContextMenu );
102 connect( mGeospatialPdfStructureTree, &QTreeView::customContextMenuRequested, this, [this]( const QPoint &point ) {
103 const QModelIndex index = mGeospatialPdfStructureTree->indexAt( point );
104 if ( index.isValid() )
105 showContextMenuForGeospatialPdfStructure( point, mGeospatialPdfStructureProxyModel->mapToSource( index ) );
106 } );
107
108 connect( mHelpButtonBox, &QDialogButtonBox::helpRequested, this, &QgsLayoutPdfExportOptionsDialog::showHelp );
110}
111
113{
114 mTextRenderFormatComboBox->setCurrentIndex( mTextRenderFormatComboBox->findData( static_cast<int>( format ) ) );
115}
116
118{
119 return static_cast<Qgis::TextRenderFormat>( mTextRenderFormatComboBox->currentData().toInt() );
120}
121
123{
124 mForceVectorCheckBox->setChecked( force );
125}
126
128{
129 return mForceVectorCheckBox->isChecked();
130}
131
133{
134 mAppendGeoreferenceCheckbox->setEnabled( enabled );
135}
136
138{
139 mAppendGeoreferenceCheckbox->setChecked( enabled );
140}
141
143{
144 return mAppendGeoreferenceCheckbox->isChecked();
145}
146
148{
149 mIncludeMetadataCheckbox->setChecked( enabled );
150}
151
153{
154 return mIncludeMetadataCheckbox->isChecked();
155}
156
158{
159 mDisableRasterTilingCheckBox->setChecked( disabled );
160}
161
163{
164 return mDisableRasterTilingCheckBox->isChecked();
165}
166
168{
169 mSimplifyGeometriesCheckbox->setChecked( enabled );
170}
171
173{
174 return mSimplifyGeometriesCheckbox->isChecked();
175}
176
178{
179 mComboImageCompression->setCurrentIndex( mComboImageCompression->findData( enabled ) );
180}
181
183{
184 return mComboImageCompression->currentData().toBool();
185}
186
188{
189 if ( !mGeospatialPdfAvailable )
190 return;
191
192 mGeospatialPDFGroupBox->setChecked( enabled );
193}
194
196{
197 if ( !mGeospatialPdfAvailable )
198 return false;
199
200 return mGeospatialPDFGroupBox->isChecked();
201}
202
204{
205 if ( !mGeospatialPdfAvailable )
206 return;
207
208 mIncludeMapThemesCheck->setChecked( !themes.isEmpty() );
209 for ( int i = 0; i < mThemesList->count(); ++i )
210 {
211 QListWidgetItem *item = mThemesList->item( i );
212 item->setCheckState( themes.contains( item->text() ) ? Qt::Checked : Qt::Unchecked );
213 }
214}
215
217{
218 QStringList res;
219 if ( !mGeospatialPdfAvailable )
220 return res;
221
222 if ( !mIncludeMapThemesCheck || !mIncludeMapThemesCheck->isChecked() )
223 return res;
224
225 res.reserve( mThemesList->count() );
226 for ( int i = 0; i < mThemesList->count(); ++i )
227 {
228 QListWidgetItem *item = mThemesList->item( i );
229 if ( item->checkState() == Qt::Checked )
230 res << item->text();
231 }
232 return res;
233}
234
236{
237 QStringList order;
238 for ( int row = 0; row < mGeospatialPdfStructureProxyModel->rowCount(); ++row )
239 {
240 order << mGeospatialPdfStructureProxyModel->data( mGeospatialPdfStructureProxyModel->index( row, 0 ), static_cast<int>( QgsMapLayerModel::CustomRole::LayerId ) ).toString();
241 }
242 return order;
243}
244
246{
247 // we don't explicitly expose a "group order" widget in the dialog -- rather
248 // we use the ordering of the layers, and build the group ordering based
249 // on grouped layers which appear first
250 QStringList groupOrder;
251 for ( int row = 0; row < mGeospatialPdfStructureProxyModel->rowCount(); ++row )
252 {
253 const QString group = mGeospatialPdfStructureProxyModel->data( mGeospatialPdfStructureProxyModel->index( row, QgsGeospatialPdfLayerTreeModel::GroupColumn ), Qt::DisplayRole ).toString().trimmed();
254 if ( !group.isEmpty() && !groupOrder.contains( group ) )
255 groupOrder << group;
256 }
257 return groupOrder;
258}
259
261{
262 mOpenAfterExportingCheckBox->setChecked( enabled );
263}
264
266{
267 return mOpenAfterExportingCheckBox->isChecked();
268}
269
270void QgsLayoutPdfExportOptionsDialog::showHelp()
271{
272 QgsHelp::openHelp( QStringLiteral( "print_composer/create_output.html" ) );
273}
274
275void QgsLayoutPdfExportOptionsDialog::showContextMenuForGeospatialPdfStructure( QPoint point, const QModelIndex &index )
276{
277 mGeospatialPdfStructureTreeMenu->clear();
278
279 switch ( index.column() )
280 {
283 {
284 QAction *selectAll = new QAction( tr( "Select All" ), mGeospatialPdfStructureTreeMenu );
285 mGeospatialPdfStructureTreeMenu->addAction( selectAll );
286 connect( selectAll, &QAction::triggered, this, [this, index] {
287 mGeospatialPdfStructureModel->checkAll( true, QModelIndex(), index.column() );
288 } );
289 QAction *deselectAll = new QAction( tr( "Deselect All" ), mGeospatialPdfStructureTreeMenu );
290 mGeospatialPdfStructureTreeMenu->addAction( deselectAll );
291 connect( deselectAll, &QAction::triggered, this, [this, index] {
292 mGeospatialPdfStructureModel->checkAll( false, QModelIndex(), index.column() );
293 } );
294 break;
295 }
296
297 default:
298 break;
299 }
300
301 if ( !mGeospatialPdfStructureTreeMenu->actions().empty() )
302 {
303 mGeospatialPdfStructureTreeMenu->exec( mGeospatialPdfStructureTree->mapToGlobal( point ) );
304 }
305}
TextRenderFormat
Options for rendering text.
Definition qgis.h:2826
@ PreferText
Render text as text objects, unless doing so results in rendering artifacts or poor quality rendering...
Definition qgis.h:2829
@ AlwaysOutlines
Always render text using path objects (AKA outlines/curves). This setting guarantees the best quality...
Definition qgis.h:2827
@ AlwaysText
Always render text as text objects. While this mode preserves text objects as text for post-processin...
Definition qgis.h:2828
static QString geospatialPDFAvailabilityExplanation()
Returns a user-friendly, translated string explaining why Geospatial PDF export support is not availa...
static bool geospatialPDFCreationAvailable()
Returns true if the current QGIS build is capable of Geospatial PDF support.
Layer tree model for Geo-PDF layers.
@ InitiallyVisible
Initial visibility state.
static void enableAutoGeometryRestore(QWidget *widget, const QString &key=QString())
Register the widget to allow its position to be automatically saved and restored when open and closed...
Definition qgsgui.cpp:221
static void openHelp(const QString &key)
Opens help topic for the given help key using default system web browser.
Definition qgshelp.cpp:38
QList< QgsMapLayer * > layerOrder() const
The order in which layers will be rendered on the canvas.
void setExportGeospatialPdf(bool enabled)
Sets whether to export a Geospatial PDF.
void setOpenAfterExporting(bool enabled)
Sets whether to open the pdf after exporting it.
QStringList exportThemes() const
Returns the list of export themes.
bool geometriesSimplified() const
Returns whether geometry simplification is enabled.
bool losslessImageExport() const
Returns whether lossless image compression is enabled.
void setLosslessImageExport(bool enabled)
Sets whether to use lossless image compression.
bool exportGeospatialPdf() const
Returns whether Geospatial PDF export is enabled.
bool openAfterExporting() const
Returns whether the pdf should be opened after exporting it.
bool georeferencingEnabled() const
Returns whether georeferencing is enabled.
void setRasterTilingDisabled(bool disabled)
Sets whether to disable raster tiling.
bool forceVector() const
Returns whether vector output is being forced.
void setGeometriesSimplified(bool enabled)
Sets whether to simplify geometries.
bool metadataEnabled() const
Returns whether metadata is enabled.
void setGeoreferencingEnabled(bool enabled)
Sets whether to enable georeferencing.
void setMetadataEnabled(bool enabled)
Sets whether to enable metadata.
void enableGeoreferencingOptions(bool enabled)
Sets whether to enable georeferencing options.
QStringList geospatialPdfGroupOrder() const
Returns a list of groups in the desired order they should appear in a generated Geospatial PDF file.
QgsLayoutPdfExportOptionsDialog(QWidget *parent=nullptr, bool allowGeospatialPdfExport=true, const QString &geospatialPdfReason=QString(), const QStringList &geospatialPdfLayerOrder=QStringList(), Qt::WindowFlags flags=Qt::WindowFlags())
Constructor for QgsLayoutPdfExportOptionsDialog.
QStringList geospatialPdfLayerOrder() const
Returns a list of map layer IDs in the desired order they should appear in a generated Geospatial PDF...
void setTextRenderFormat(Qgis::TextRenderFormat format)
Sets the text render format.
Qgis::TextRenderFormat textRenderFormat() const
Returns the current text render format.
bool rasterTilingDisabled() const
Returns whether raster tiling is disabled.
void setForceVector(bool force)
Set whether to force vector output.
void setExportThemes(const QStringList &themes)
Sets the list of export themes.
@ LayerId
Stores the map layer ID.
static QgsProject * instance()
Returns the QgsProject singleton instance.
QgsMapThemeCollection * mapThemeCollection
Definition qgsproject.h:118
QgsLayerTree * layerTreeRoot() const
Returns pointer to the root (invisible) node of the project's layer tree.