QGIS API Documentation 3.99.0-Master (2fe06baccd8)
Loading...
Searching...
No Matches
qgsscalewidget.cpp
Go to the documentation of this file.
1/***************************************************************************
2 qgsscalewidget.cpp
3 --------------------------------------
4 Date : 08.01.2015
5 Copyright : (C) 2014 Denis Rouzaud
7***************************************************************************
8* *
9* This program is free software; you can redistribute it and/or modify *
10* it under the terms of the GNU General Public License as published by *
11* the Free Software Foundation; either version 2 of the License, or *
12* (at your option) any later version. *
13* *
14***************************************************************************/
15
16#include "qgsscalewidget.h"
17
18#include "qgsapplication.h"
19#include "qgslayoutitemmap.h"
20#include "qgslayoutmanager.h"
21#include "qgsmapcanvas.h"
22#include "qgsprintlayout.h"
23#include "qgsproject.h"
24
25#include <QHBoxLayout>
26#include <QMenu>
27
28#include "moc_qgsscalewidget.cpp"
29
31 : QWidget( parent )
32{
33 QHBoxLayout *layout = new QHBoxLayout( this );
34 layout->setContentsMargins( 0, 0, 0, 0 );
35 layout->setSpacing( 6 );
36
37 mScaleComboBox = new QgsScaleComboBox( this );
38 layout->addWidget( mScaleComboBox );
39
40 mCurrentScaleButton = new QToolButton( this );
41 mCurrentScaleButton->setToolTip( tr( "Set to current canvas scale" ) );
42 mCurrentScaleButton->setIcon( QgsApplication::getThemeIcon( QStringLiteral( "/mActionMapIdentification.svg" ) ) );
43
44 mMenu = new QMenu( this );
45 mCurrentScaleButton->setMenu( mMenu );
46 mCurrentScaleButton->setPopupMode( QToolButton::MenuButtonPopup );
47 connect( mMenu, &QMenu::aboutToShow, this, &QgsScaleWidget::menuAboutToShow );
48
49 layout->addWidget( mCurrentScaleButton );
50 mCurrentScaleButton->hide();
51
52 connect( mScaleComboBox, &QgsScaleComboBox::scaleChanged, this, &QgsScaleWidget::scaleChanged );
53 connect( mCurrentScaleButton, &QAbstractButton::clicked, this, &QgsScaleWidget::setScaleFromCanvas );
54}
55
57{
58 mShowCurrentScaleButton = showCurrentScaleButton;
59 mCurrentScaleButton->setVisible( mShowCurrentScaleButton && mCanvas );
60}
61
63{
64 mCanvas = canvas;
65 mCurrentScaleButton->setVisible( mShowCurrentScaleButton && mCanvas );
66}
67
69{
70 return mScaleComboBox->isNull();
71}
72
74{
75 mScaleComboBox->setAllowNull( allowNull );
76}
77
79{
80 return mScaleComboBox->allowNull();
81}
82
83void QgsScaleWidget::setPredefinedScales( const QVector<double> &scales )
84{
85 mScaleComboBox->setPredefinedScales( scales );
86}
87
89{
90 if ( !mCanvas )
91 return;
92
93 setScale( mCanvas->scale() );
94}
95
97{
98 mScaleComboBox->setNull();
99}
100
102{
103 mScaleComboBox->setScale( scale );
104}
105
106void QgsScaleWidget::menuAboutToShow()
107{
108 mMenu->clear();
109
110 double scale = mCanvas->scale();
111 QAction *canvasScaleAction = new QAction( QgsApplication::getThemeIcon( QStringLiteral( "/mActionMapIdentification.svg" ) ), tr( "Use Current Map Canvas Scale (1:%1)" ).arg( qgsDoubleToString( scale, 0 ) ), mMenu );
112 connect( canvasScaleAction, &QAction::triggered, this, [this, scale] { setScale( scale ); } );
113 mMenu->addAction( canvasScaleAction );
114
115 bool first = true;
116 if ( QgsLayoutManager *manager = QgsProject::instance()->layoutManager() )
117 {
118 const QList<QgsPrintLayout *> layouts = manager->printLayouts();
119 for ( const QgsPrintLayout *layout : layouts )
120 {
121 QList<QgsLayoutItemMap *> maps;
122 layout->layoutItems( maps );
123 if ( maps.empty() )
124 continue;
125
126 if ( first )
127 mMenu->addSeparator();
128
129 first = false;
130
131 QMenu *layoutMenu = new QMenu( layout->name(), mMenu );
132 for ( const QgsLayoutItemMap *map : std::as_const( maps ) )
133 {
134 scale = map->scale();
135 QAction *mapScaleAction = new QAction( tr( "%1 (1:%2)" ).arg( map->displayName(), qgsDoubleToString( scale, 0 ) ), mMenu );
136 connect( mapScaleAction, &QAction::triggered, this, [this, scale] { setScale( scale ); } );
137 layoutMenu->addAction( mapScaleAction );
138 }
139 mMenu->addMenu( layoutMenu );
140 }
141 }
142}
static QIcon getThemeIcon(const QString &name, const QColor &fillColor=QColor(), const QColor &strokeColor=QColor())
Helper to get a theme icon.
Map canvas is a class for displaying all GIS data types on a canvas.
double scale() const
Returns the last reported scale of the canvas.
static QgsProject * instance()
Returns the QgsProject singleton instance.
A combobox which lets the user select map scale from predefined list and highlights nearest to curren...
void scaleChanged(double scale)
Emitted when user has finished editing/selecting a new scale.
bool isNull() const
Returns true if the widget is currently set to a "null" value.
void scaleChanged(double scale)
Emitted when user has finished editing/selecting a new scale.
void setScaleFromCanvas()
Assigns the current scale from the map canvas, if set.
bool allowNull() const
Returns true if the widget can be set to a NULL value.
void setMapCanvas(QgsMapCanvas *canvas)
Set the map canvas associated to the current button.
void setShowCurrentScaleButton(bool showCurrentScaleButton)
Sets whether to show a button to set the scale to the current scale of the map canvas next to the com...
void setNull()
Sets the widget to the null value.
void setPredefinedScales(const QVector< double > &scales)
Sets the list of predefined scales to show in the widget.
bool showCurrentScaleButton
void setScale(double scale)
Set the selected scale from a double.
QgsScaleWidget(QWidget *parent=nullptr)
QgsScaleWidget creates a combobox which lets the user select map scale from predefined list and highl...
void setAllowNull(bool allowNull)
Sets whether the scale widget can be set to a NULL value.
QString qgsDoubleToString(double a, int precision=17)
Returns a string representation of a double.
Definition qgis.h:6524