QGIS API Documentation  3.20.0-Odense (decaadbb31)
qgsscalebarsettings.cpp
Go to the documentation of this file.
1 /***************************************************************************
2  qgsscalebarsettings.cpp
3  -----------------------
4  begin : January 2020
5  copyright : (C) 2020 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 
17 #include "qgsscalebarsettings.h"
18 #include "qgsapplication.h"
19 #include "qgsnumericformat.h"
20 #include "qgsbasicnumericformat.h"
21 #include "qgslinesymbollayer.h"
22 #include "qgssymbol.h"
23 #include "qgsfillsymbollayer.h"
24 #include "qgslinesymbol.h"
25 #include "qgsfillsymbol.h"
26 
28 {
29  mTextFormat.setSize( 12.0 );
31  mTextFormat.setColor( QColor( 0, 0, 0 ) );
32 
33  mNumericFormat = std::make_unique< QgsBasicNumericFormat >();
34 
35  mLineSymbol = std::make_unique< QgsLineSymbol >();
36  mLineSymbol->setColor( QColor( 0, 0, 0 ) );
37  mLineSymbol->setWidth( 0.3 );
38  if ( QgsSimpleLineSymbolLayer *line = dynamic_cast< QgsSimpleLineSymbolLayer * >( mLineSymbol->symbolLayer( 0 ) ) )
39  {
40  line->setPenJoinStyle( Qt::MiterJoin );
41  line->setPenCapStyle( Qt::SquareCap );
42  }
43  mLineSymbol->setOutputUnit( QgsUnitTypes::RenderMillimeters );
44  mDivisionLineSymbol.reset( mLineSymbol->clone() );
45  mSubdivisionLineSymbol.reset( mLineSymbol->clone() );
46 
47  mFillSymbol = std::make_unique< QgsFillSymbol >();
48  mFillSymbol->setColor( QColor( 0, 0, 0 ) );
49  if ( QgsSimpleFillSymbolLayer *fill = dynamic_cast< QgsSimpleFillSymbolLayer * >( mFillSymbol->symbolLayer( 0 ) ) )
50  {
51  fill->setStrokeStyle( Qt::NoPen );
52  }
53  mAlternateFillSymbol = std::make_unique< QgsFillSymbol >();
54  mAlternateFillSymbol->setColor( QColor( 255, 255, 255 ) );
55  if ( QgsSimpleFillSymbolLayer *fill = dynamic_cast< QgsSimpleFillSymbolLayer * >( mAlternateFillSymbol->symbolLayer( 0 ) ) )
56  {
57  fill->setStrokeStyle( Qt::NoPen );
58  }
59 }
60 
62  : mNumSegments( other.mNumSegments )
63  , mNumSegmentsLeft( other.mNumSegmentsLeft )
64  , mNumSubdivisions( other.mNumSubdivisions )
65  , mSubdivisionsHeight( other.mSubdivisionsHeight )
66  , mNumUnitsPerSegment( other.mNumUnitsPerSegment )
67  , mNumMapUnitsPerScaleBarUnit( other.mNumMapUnitsPerScaleBarUnit )
68  , mSegmentSizeMode( other.mSegmentSizeMode )
69  , mMinBarWidth( other.mMinBarWidth )
70  , mMaxBarWidth( other.mMaxBarWidth )
71  , mUnitLabeling( other.mUnitLabeling )
72  , mTextFormat( other.mTextFormat )
73  , mHeight( other.mHeight )
74  , mLineSymbol( other.mLineSymbol->clone() )
75  , mDivisionLineSymbol( other.mDivisionLineSymbol->clone() )
76  , mSubdivisionLineSymbol( other.mSubdivisionLineSymbol->clone() )
77  , mFillSymbol( other.mFillSymbol->clone() )
78  , mAlternateFillSymbol( other.mAlternateFillSymbol->clone() )
79  , mLabelBarSpace( other.mLabelBarSpace )
80  , mLabelVerticalPlacement( other.mLabelVerticalPlacement )
81  , mLabelHorizontalPlacement( other.mLabelHorizontalPlacement )
82  , mBoxContentSpace( other.mBoxContentSpace )
83  , mAlignment( other.mAlignment )
84  , mUnits( other.mUnits )
85  , mNumericFormat( other.mNumericFormat->clone() )
86 {
87 
88 }
89 
91 {
92  mNumSegments = other.mNumSegments;
93  mNumSegmentsLeft = other.mNumSegmentsLeft;
94  mNumSubdivisions = other.mNumSubdivisions;
95  mSubdivisionsHeight = other.mSubdivisionsHeight;
96  mNumUnitsPerSegment = other.mNumUnitsPerSegment;
97  mNumMapUnitsPerScaleBarUnit = other.mNumMapUnitsPerScaleBarUnit;
98  mSegmentSizeMode = other.mSegmentSizeMode;
99  mMinBarWidth = other.mMinBarWidth;
100  mMaxBarWidth = other.mMaxBarWidth;
101  mUnitLabeling = other.mUnitLabeling;
102  mTextFormat = other.mTextFormat;
103  mLineSymbol.reset( other.mLineSymbol->clone() );
104  mDivisionLineSymbol.reset( other.mDivisionLineSymbol->clone() );
105  mSubdivisionLineSymbol.reset( other.mSubdivisionLineSymbol->clone() );
106  mFillSymbol.reset( other.mFillSymbol->clone() );
107  mAlternateFillSymbol.reset( other.mAlternateFillSymbol->clone() );
108  mHeight = other.mHeight;
109  mLabelBarSpace = other.mLabelBarSpace;
110  mLabelVerticalPlacement = other.mLabelVerticalPlacement;
111  mLabelHorizontalPlacement = other.mLabelHorizontalPlacement;
112  mBoxContentSpace = other.mBoxContentSpace;
113  mAlignment = other.mAlignment;
114  mUnits = other.mUnits;
115  mNumericFormat.reset( other.mNumericFormat->clone() );
116  return *this;
117 }
118 
120 {
121  return mFillSymbol->color();
122 }
123 
124 void QgsScaleBarSettings::setFillColor( const QColor &color )
125 {
126  mFillSymbol->setColor( color );
127 }
128 
130 {
131  return mAlternateFillSymbol->color();
132 }
133 
134 void QgsScaleBarSettings::setFillColor2( const QColor &color )
135 {
136  mAlternateFillSymbol->setColor( color );
137 }
138 
140 {
141  return mLineSymbol->color();
142 }
143 
144 void QgsScaleBarSettings::setLineColor( const QColor &color )
145 {
146  for ( QgsLineSymbol *symbol : { mLineSymbol.get(), mDivisionLineSymbol.get(), mSubdivisionLineSymbol.get() } )
147  {
148  symbol->setColor( color );
149  }
150 }
151 
153 {
154  return mLineSymbol->width();
155 }
156 
158 {
159  for ( QgsLineSymbol *symbol : { mLineSymbol.get(), mDivisionLineSymbol.get(), mSubdivisionLineSymbol.get() } )
160  {
161  symbol->setWidth( width );
162  symbol->setOutputUnit( QgsUnitTypes::RenderMillimeters );
163  }
164 }
165 
167 {
168  QPen pen( mLineSymbol->color() );
169  if ( QgsSimpleLineSymbolLayer *line = dynamic_cast< QgsSimpleLineSymbolLayer * >( mLineSymbol->symbolLayer( 0 ) ) )
170  {
171  pen.setJoinStyle( line->penJoinStyle() );
172  pen.setCapStyle( line->penCapStyle() );
173  }
174  pen.setWidthF( mLineSymbol->width() );
175  return pen;
176 }
177 
178 void QgsScaleBarSettings::setPen( const QPen &pen )
179 {
180  for ( QgsLineSymbol *symbol : { mLineSymbol.get(), mDivisionLineSymbol.get(), mSubdivisionLineSymbol.get() } )
181  {
182  symbol->setColor( pen.color() );
183  symbol->setWidth( pen.widthF() );
184  symbol->setOutputUnit( QgsUnitTypes::RenderMillimeters );
185  if ( QgsSimpleLineSymbolLayer *line = dynamic_cast< QgsSimpleLineSymbolLayer * >( symbol->symbolLayer( 0 ) ) )
186  {
187  line->setPenJoinStyle( pen.joinStyle() );
188  line->setPenCapStyle( pen.capStyle() );
189  }
190  }
191 }
192 
194 {
195  return mLineSymbol.get();
196 }
197 
199 {
200  mLineSymbol.reset( symbol );
201 }
202 
204 {
205  return mDivisionLineSymbol.get();
206 }
207 
209 {
210  mDivisionLineSymbol.reset( symbol );
211 }
212 
214 {
215  return mSubdivisionLineSymbol.get();
216 }
217 
219 {
220  mSubdivisionLineSymbol.reset( symbol );
221 }
222 
224 {
225  return mFillSymbol.get();
226 }
227 
229 {
230  mFillSymbol.reset( symbol );
231 }
232 
234 {
235  return mAlternateFillSymbol.get();
236 }
237 
239 {
240  mAlternateFillSymbol.reset( symbol );
241 }
242 
244 {
245  QBrush b;
246  b.setColor( mFillSymbol->color() );
247  if ( QgsSimpleFillSymbolLayer *fill = dynamic_cast< QgsSimpleFillSymbolLayer * >( mFillSymbol->symbolLayer( 0 ) ) )
248  {
249  b.setStyle( fill->brushStyle() );
250  }
251 
252  return b;
253 }
254 
255 void QgsScaleBarSettings::setBrush( const QBrush &brush )
256 {
257  mFillSymbol->setColor( brush.color() );
258  if ( QgsSimpleFillSymbolLayer *fill = dynamic_cast< QgsSimpleFillSymbolLayer * >( mFillSymbol->symbolLayer( 0 ) ) )
259  {
260  fill->setBrushStyle( brush.style() );
261  }
262 }
263 
265 {
266  QBrush b;
267  b.setColor( mAlternateFillSymbol->color() );
268  if ( QgsSimpleFillSymbolLayer *fill = dynamic_cast< QgsSimpleFillSymbolLayer * >( mAlternateFillSymbol->symbolLayer( 0 ) ) )
269  {
270  b.setStyle( fill->brushStyle() );
271  }
272 
273  return b;
274 }
275 
276 void QgsScaleBarSettings::setBrush2( const QBrush &brush )
277 {
278  mAlternateFillSymbol->setColor( brush.color() );
279  if ( QgsSimpleFillSymbolLayer *fill = dynamic_cast< QgsSimpleFillSymbolLayer * >( mAlternateFillSymbol->symbolLayer( 0 ) ) )
280  {
281  fill->setBrushStyle( brush.style() );
282  }
283 }
284 
285 Qt::PenJoinStyle QgsScaleBarSettings::lineJoinStyle() const
286 {
287  if ( QgsSimpleLineSymbolLayer *line = dynamic_cast< QgsSimpleLineSymbolLayer * >( mLineSymbol->symbolLayer( 0 ) ) )
288  {
289  return line->penJoinStyle();
290  }
291  return Qt::MiterJoin;
292 }
293 
294 void QgsScaleBarSettings::setLineJoinStyle( Qt::PenJoinStyle style )
295 {
296  for ( QgsLineSymbol *symbol : { mLineSymbol.get(), mDivisionLineSymbol.get(), mSubdivisionLineSymbol.get() } )
297  {
298  if ( QgsSimpleLineSymbolLayer *line = dynamic_cast< QgsSimpleLineSymbolLayer * >( symbol->symbolLayer( 0 ) ) )
299  {
300  line->setPenJoinStyle( style );
301  }
302  }
303 }
304 
305 Qt::PenCapStyle QgsScaleBarSettings::lineCapStyle() const
306 {
307  if ( QgsSimpleLineSymbolLayer *line = dynamic_cast< QgsSimpleLineSymbolLayer * >( mLineSymbol->symbolLayer( 0 ) ) )
308  {
309  return line->penCapStyle();
310  }
311  return Qt::FlatCap;
312 }
313 
314 void QgsScaleBarSettings::setLineCapStyle( Qt::PenCapStyle style )
315 {
316  for ( QgsLineSymbol *symbol : { mLineSymbol.get(), mDivisionLineSymbol.get(), mSubdivisionLineSymbol.get() } )
317  {
318  if ( QgsSimpleLineSymbolLayer *line = dynamic_cast< QgsSimpleLineSymbolLayer * >( symbol->symbolLayer( 0 ) ) )
319  {
320  line->setPenCapStyle( style );
321  }
322  }
323 }
324 
326 {
327  return mNumericFormat.get();
328 }
329 
331 {
332  mNumericFormat.reset( format );
333 }
334 
336 
A fill symbol type, for rendering Polygon and MultiPolygon geometries.
Definition: qgsfillsymbol.h:30
A line symbol type, for rendering LineString and MultiLineString geometries.
Definition: qgslinesymbol.h:30
A numeric formatter allows for formatting a numeric value for display, using a variety of different f...
The QgsScaleBarSettings class stores the appearance and layout settings for scalebar drawing with Qgs...
void setSubdivisionLineSymbol(QgsLineSymbol *symbol)
Sets the line symbol used to render the scalebar subdivisions (only used for some scalebar types).
Q_DECL_DEPRECATED QColor fillColor() const
Returns the color used for fills in the scalebar.
QgsLineSymbol * lineSymbol() const
Returns the line symbol used to render the scalebar (only used for some scalebar types).
QgsLineSymbol * subdivisionLineSymbol() const
Returns the line symbol used to render the scalebar subdivisions (only used for some scalebar types).
Q_DECL_DEPRECATED QColor fillColor2() const
Returns the secondary color used for fills in the scalebar.
void setAlternateFillSymbol(QgsFillSymbol *symbol)
Sets the secondary fill symbol used to render the scalebar (only used for some scalebar types).
const QgsNumericFormat * numericFormat() const
Returns the numeric format used for numbers in the scalebar.
Q_DECL_DEPRECATED void setFillColor(const QColor &color)
Sets the color used for fills in the scalebar.
Q_DECL_DEPRECATED void setFillColor2(const QColor &color)
Sets the secondary color used for fills in the scalebar.
Q_DECL_DEPRECATED void setLineCapStyle(Qt::PenCapStyle style)
Sets the cap style used when drawing the lines in the scalebar.
void setFillSymbol(QgsFillSymbol *symbol)
Sets the primary fill symbol used to render the scalebar (only used for some scalebar types).
Q_DECL_DEPRECATED void setLineJoinStyle(Qt::PenJoinStyle style)
Sets the join style used when drawing the lines in the scalebar.
Q_DECL_DEPRECATED QPen pen() const
Returns the pen used for drawing outlines in the scalebar.
Q_DECL_DEPRECATED void setPen(const QPen &pen)
Sets the pen used for drawing outlines in the scalebar.
Q_DECL_DEPRECATED void setBrush(const QBrush &brush)
Sets the primary brush used for filling the scalebar.
Q_DECL_DEPRECATED void setBrush2(const QBrush &brush)
Sets the secondary brush used for filling the scalebar.
Q_DECL_DEPRECATED void setLineColor(const QColor &color)
Sets the color used for lines in the scalebar.
void setLineSymbol(QgsLineSymbol *symbol)
Sets the line symbol used to render the scalebar (only used for some scalebar types).
void setDivisionLineSymbol(QgsLineSymbol *symbol)
Sets the line symbol used to render the scalebar divisions (only used for some scalebar types).
Q_DECL_DEPRECATED void setLineWidth(double width)
Sets the line width in millimeters for lines in the scalebar.
QgsFillSymbol * alternateFillSymbol() const
Returns the secondary fill symbol used to render the scalebar (only used for some scalebar types).
QgsFillSymbol * fillSymbol() const
Returns the primary fill symbol used to render the scalebar (only used for some scalebar types).
Q_DECL_DEPRECATED double lineWidth() const
Returns the line width in millimeters for lines in the scalebar.
Q_DECL_DEPRECATED QBrush brush2() const
Returns the secondary brush for the scalebar.
void setNumericFormat(QgsNumericFormat *format)
Sets the numeric format used for numbers in the scalebar.
QgsScaleBarSettings()
Constructor for QgsScaleBarSettings.
Q_DECL_DEPRECATED QColor lineColor() const
Returns the color used for lines in the scalebar.
Q_DECL_DEPRECATED Qt::PenCapStyle lineCapStyle() const
Returns the cap style used for drawing lines in the scalebar.
QgsScaleBarSettings & operator=(const QgsScaleBarSettings &other)
Q_DECL_DEPRECATED Qt::PenJoinStyle lineJoinStyle() const
Returns the join style used for drawing lines in the scalebar.
Q_DECL_DEPRECATED QBrush brush() const
Returns the primary brush used for filling the scalebar.
QgsLineSymbol * divisionLineSymbol() const
Returns the line symbol used to render the scalebar divisions (only used for some scalebar types).
A simple line symbol layer, which renders lines using a line in a variety of styles (e....
void setColor(const QColor &color)
Sets the color that text will be rendered in.
void setSize(double size)
Sets the size for rendered text.
void setSizeUnit(QgsUnitTypes::RenderUnit unit)
Sets the units for the size of rendered text.
@ RenderPoints
Points (e.g., for font sizes)
Definition: qgsunittypes.h:173
@ RenderMillimeters
Millimeters.
Definition: qgsunittypes.h:169