18#ifndef QGSLAYOUTITEMMAPGRID_H
19#define QGSLAYOUTITEMMAPGRID_H
108 QList< QgsLayoutItemMapGrid * >
asList()
const;
154 void draw( QPainter *painter )
override;
174 void setBlendMode(
const QPainter::CompositionMode mode ) { mBlendMode = mode; }
180 QPainter::CompositionMode
blendMode()
const {
return mBlendMode; }
182 bool usesAdvancedEffects()
const override;
188 double maxExtension()
const;
196 void calculateMaxExtension(
double &top,
double &right,
double &bottom,
double &left )
const;
198 void setEnabled(
bool enabled )
override;
224 void setIntervalX(
double interval );
240 void setIntervalY(
double interval );
256 void setOffsetX(
double offset );
264 double offsetX()
const {
return mGridOffsetX; }
272 void setOffsetY(
double offset );
280 double offsetY()
const {
return mGridOffsetY; }
302 void setMinimumIntervalWidth(
double width );
324 void setMaximumIntervalWidth(
double width );
349 void setCrossLength(
const double length );
365 void setGridLineWidth(
double width );
374 void setGridLineColor(
const QColor &color );
472 Q_DECL_DEPRECATED
void setAnnotationFont(
const QFont &font )
SIP_DEPRECATED;
488 Q_DECL_DEPRECATED
void setAnnotationFontColor( const QColor &color )
SIP_DEPRECATED;
496 Q_DECL_DEPRECATED QColor annotationFontColor() const
SIP_DEPRECATED;
549 void setAnnotationFrameDistance(
const double distance );
593 void setAnnotationExpression(
const QString &expression );
675 void setFrameWidth(
const double width );
803 void setFrameMargin(
const double margin );
818 void setFramePenSize(
const double width );
879 void refresh()
override;
903 GridExtension() =
default;
917 left = std::max( left, value );
920 right = std::max( right, value );
923 top = std::max( top, value );
926 bottom = std::max( bottom, value );
934 void UpdateAll(
double value )
936 left = std::max( left, value );
937 right = std::max( right, value );
938 top = std::max( top, value );
939 bottom = std::max( bottom, value );
943 struct GridLineAnnotation
960 GridLineAnnotation startAnnotation;
961 GridLineAnnotation endAnnotation;
963 mutable QList< GridLine > mGridLines;
966 mutable bool mTransformDirty =
true;
971 double mGridIntervalX = 0.0;
973 double mGridIntervalY = 0.0;
975 double mGridOffsetX = 0.0;
977 double mGridOffsetY = 0.0;
980 QgsTextFormat mAnnotationFormat;
983 int mGridAnnotationPrecision = 3;
985 bool mShowGridAnnotation =
false;
1006 double mAnnotationFrameDistance = 1.0;
1018 QString mGridAnnotationExpressionString;
1019 mutable std::unique_ptr< QgsExpression > mGridAnnotationExpression;
1024 double mGridFrameWidth = 2.0;
1025 double mGridFramePenThickness = 0.3;
1026 QColor mGridFramePenColor = QColor( 0, 0, 0 );
1027 QColor mGridFrameFillColor1 = Qt::white;
1028 QColor mGridFrameFillColor2 = Qt::black;
1029 double mCrossLength = 3.0;
1030 double mGridFrameMargin = 0.0;
1031 bool mRotatedTicksEnabled =
false;
1033 double mRotatedTicksMinimumAngle = 0.0;
1034 double mRotatedTicksMarginToCorner = 0.0;
1035 bool mRotatedAnnotationsEnabled =
false;
1037 double mRotatedAnnotationsMinimumAngle = 0.0;
1038 double mRotatedAnnotationsMarginToCorner = 0.0;
1040 double mMinimumIntervalWidth = 50;
1041 double mMaximumIntervalWidth = 100;
1052 std::unique_ptr< QgsLineSymbol > mGridLineSymbol;
1053 std::unique_ptr< QgsMarkerSymbol > mGridMarkerSymbol;
1055 QgsCoordinateReferenceSystem mCRS;
1059 QPainter::CompositionMode mBlendMode = QPainter::CompositionMode_SourceOver;
1061 mutable QList< QPair< double, QPolygonF > > mTransformedXLines;
1062 mutable QList< QPair< double, QPolygonF > > mTransformedYLines;
1063 mutable QList< QgsPointXY > mTransformedIntersections;
1064 QRectF mPrevPaintRect;
1065 mutable QPolygonF mPrevMapPolygon;
1067 bool mEvaluatedEnabled =
true;
1068 double mEvaluatedIntervalX = 0;
1069 double mEvaluatedIntervalY = 0;
1070 double mEvaluatedOffsetX = 0;
1071 double mEvaluatedOffsetY = 0;
1072 double mEvaluatedGridFrameWidth = 0;
1073 double mEvaluatedGridFrameMargin = 0;
1074 double mEvaluatedAnnotationFrameDistance = 0;
1075 double mEvaluatedCrossLength = 0;
1076 double mEvaluatedGridFrameLineThickness = 0;
1077 std::unique_ptr< QgsProperty > mDrawAnnotationProperty;
1090 void updateGridLinesAnnotationsPositions()
const;
1096 void drawGridFrame( QPainter *p, GridExtension *extension =
nullptr )
const;
1105 void drawCoordinateAnnotations( QgsRenderContext &context, QgsExpressionContext &expressionContext, GridExtension *extension =
nullptr )
const;
1111 void drawCoordinateAnnotation( QgsRenderContext &context, GridLineAnnotation annot,
const QString &annotationString,
Qgis::MapGridAnnotationType coordinateType, GridExtension *extension =
nullptr )
const;
1113 QString gridAnnotationString(
double value,
Qgis::MapGridAnnotationType coord, QgsExpressionContext &expressionContext,
bool isGeographic )
const;
1119 int xGridLines()
const;
1125 int yGridLines()
const;
1127 int xGridLinesCrsTransform(
const QgsRectangle &bbox,
const QgsCoordinateTransform &t )
const;
1129 int yGridLinesCrsTransform(
const QgsRectangle &bbox,
const QgsCoordinateTransform &t )
const;
1131 void drawGridLine(
const QLineF &line, QgsRenderContext &context )
const;
1133 void drawGridLine(
const QPolygonF &line, QgsRenderContext &context )
const;
1149 int crsGridParams( QgsRectangle &crsRect, QgsCoordinateTransform &inverseTransform )
const;
1151 static QList<QPolygonF> trimLinesToMap(
const QPolygonF &line,
const QgsRectangle &rect );
1153 QPolygonF scalePolygon(
const QPolygonF &polygon,
double scale )
const;
1156 void drawGridCrsTransform( QgsRenderContext &context,
double dotsPerMM,
bool calculateLinesOnly =
false )
const;
1158 void drawGridNoTransform( QgsRenderContext &context,
double dotsPerMM,
bool calculateLinesOnly =
false )
const;
1160 void createDefaultGridLineSymbol();
1162 void createDefaultGridMarkerSymbol();
1164 void drawGridMarker( QPointF point, QgsRenderContext &context )
const;
1166 void drawGridFrameZebra( QPainter *p, GridExtension *extension =
nullptr )
const;
1168 void drawGridFrameZebraBorder( QPainter *p,
Qgis::MapGridBorderSide border,
double *extension =
nullptr )
const;
1170 void drawGridFrameTicks( QPainter *p, GridExtension *extension =
nullptr )
const;
1172 void drawGridFrameLine( QPainter *p, GridExtension *extension =
nullptr )
const;
1174 void calculateCrsTransformLines()
const;
1179 void refreshDataDefinedProperties();
1182 double mapWidth()
const;
MapGridTickLengthMode
Map grid tick length mode (useful for rotated grids).
@ OrthogonalTicks
Align ticks orthogonaly.
QFlags< MapGridFrameSideFlag > MapGridFrameSideFlags
Flags for controlling which side of the map a frame is drawn on.
MapGridAnnotationPosition
Position for map grid annotations.
@ OutsideMapFrame
Draw annotations outside the map frame.
MapGridUnit
Units for map grid values.
@ MapUnits
Grid units follow map units.
MapGridBorderSide
Border sides for map grid annotations.
MapGridFrameSideFlag
Flags for controlling which side of the map a frame is drawn on.
MapGridComponentVisibility
Visibility display settings for map grid annotations and frames.
@ ShowAll
Show both latitude and longitude annotations/divisions.
MapGridStyle
Map grid drawing styles.
@ Lines
Draw lines for grid.
MapGridAnnotationType
Annotation coordinate type.
MapGridFrameStyle
Style for map grid frames.
@ NoFrame
Disable grid frame.
MapGridAnnotationDirection
Direction of grid annotations.
@ Horizontal
Draw annotations horizontally.
MapGridAnnotationFormat
Format for displaying map grid annotations.
@ Decimal
Decimal degrees, use - for S/W coordinates.
Represents a coordinate reference system (CRS).
Expression contexts are used to encapsulate the parameters around which a QgsExpression should be eva...
void calculateMaxGridExtension(double &top, double &right, double &bottom, double &left) const
Calculates the maximum distance grids within the stack extend beyond the QgsLayoutItemMap's item rect...
void removeGrid(const QString &gridId)
Removes a grid with matching gridId from the stack and deletes the corresponding QgsLayoutItemMapGrid...
double maxGridExtension() const
Calculates the maximum distance grids within the stack extend beyond the QgsLayoutItemMap's item rect...
void addGrid(QgsLayoutItemMapGrid *grid)
Adds a new map grid to the stack and takes ownership of the grid.
QgsLayoutItemMapGrid * grid(const QString &gridId) const
Returns a reference to a grid with matching gridId within the stack.
void moveGridUp(const QString &gridId)
Moves a grid with matching gridId up the stack, causing it to be rendered above other grids.
void moveGridDown(const QString &gridId)
Moves a grid with matching gridId down the stack, causing it to be rendered below other grids.
QgsLayoutItemMapGridStack(QgsLayoutItemMap *map)
Constructor for QgsLayoutItemMapGridStack, attached to the specified map.
An individual grid which is drawn above the map content in a QgsLayoutItemMap.
void setRotatedTicksLengthMode(const Qgis::MapGridTickLengthMode mode)
Sets the tick length calculation mode.
bool rotatedAnnotationsEnabled() const
Gets whether annotations rotation for rotated or reprojected grids is enabled.
QString annotationExpression() const
Returns the expression used for drawing grid annotations.
double rotatedTicksMarginToCorner() const
Gets the margin to corners (in canvas units) below which outwards facing ticks are not drawn.
void setFrameFillColor2(const QColor &color)
Sets the second fill color used for the grid frame.
void setFrameStyle(const Qgis::MapGridFrameStyle style)
Sets the grid frame style.
double frameWidth() const
Gets the grid frame width in layout units.
void draw(QPainter *painter) override
Draws the item on to a destination painter.
double crossLength() const
Retrieves the length (in layout units) of the cross segments drawn for the grid.
void setRotatedTicksMinimumAngle(const double angle)
Sets the minimum angle (in degrees) below which ticks are not drawn.
QPainter::CompositionMode blendMode() const
Retrieves the blending mode used for drawing the grid.
void setAnnotationEnabled(const bool enabled)
Sets whether annotations should be shown for the grid.
QgsTextFormat annotationTextFormat() const
Returns the text format used when rendering grid annotations.
double framePenSize() const
Retrieves the width of the stroke drawn in the grid frame.
void setFramePenColor(const QColor &color)
Sets the color of the stroke drawn in the grid frame.
void setRotatedTicksEnabled(const bool state)
Enable/disable ticks rotation for rotated or reprojected grids.
Qgis::MapGridUnit units() const
Returns the units used for grid measurements such as the interval and offset for grid lines.
Qgis::MapGridStyle style() const
Returns the grid's style, which controls how the grid is drawn over the map's contents.
double rotatedTicksMinimumAngle() const
Gets the minimum angle (in degrees) below which ticks are not drawn.
Qgis::MapGridTickLengthMode rotatedAnnotationsLengthMode() const
Returns the annotation length calculation mode.
Qgis::MapGridFrameStyle frameStyle() const
Returns the grid frame style.
friend class QgsLayoutItemMap
double offsetY() const
Returns the offset for grid lines in the y-direction.
void crsChanged()
Emitted whenever the grid's CRS is changed.
void setRotatedAnnotationsMinimumAngle(const double angle)
Sets the minimum angle (in degrees) below which annotations are not drawn.
double rotatedAnnotationsMinimumAngle() const
Gets the minimum angle (in degrees) below which annotations are not drawn.
void setAnnotationTextFormat(const QgsTextFormat &format)
Sets the text format to use when rendering grid annotations.
QgsLayoutItemMapGrid(const QString &name, QgsLayoutItemMap *map)
Constructor for QgsLayoutItemMapGrid.
Qgis::MapGridTickLengthMode rotatedTicksLengthMode() const
Returns the grid frame style.
~QgsLayoutItemMapGrid() override
void setBlendMode(const QPainter::CompositionMode mode)
Sets the blending mode used for drawing the grid.
bool annotationEnabled() const
Returns whether annotations are shown for the grid.
friend class TestQgsLayoutMapGrid
QColor framePenColor() const
Retrieves the color of the stroke drawn in the grid frame.
void setRotatedTicksMarginToCorner(const double margin)
Sets the margin to corners (in canvas units) below which outwards facing ticks are not drawn.
void setAnnotationPrecision(const int precision)
Sets the coordinate precision for grid annotations.
QColor frameFillColor2() const
Retrieves the second fill color for the grid frame.
void setRotatedAnnotationsLengthMode(const Qgis::MapGridTickLengthMode mode)
Sets the annotation length calculation mode.
QgsCoordinateReferenceSystem crs() const
Retrieves the CRS for the grid.
void setRotatedAnnotationsMarginToCorner(const double margin)
Sets the margin to corners (in canvas units) below which outwards facing annotations are not drawn.
double rotatedAnnotationsMarginToCorner() const
Gets the margin to corners (in canvas units) below which outwards facing annotations are not drawn.
double offsetX() const
Returns the offset for grid lines in the x-direction.
bool rotatedTicksEnabled() const
Gets whether ticks rotation for rotated or reprojected grids is enabled.
double annotationFrameDistance() const
Returns the distance between the map frame and annotations.
double intervalY() const
Returns the interval between grid lines in the y-direction.
void setCrs(const QgsCoordinateReferenceSystem &crs)
Sets the crs for the grid.
double minimumIntervalWidth() const
Returns the minimum width (in millimeters) for grid segments.
QColor frameFillColor1() const
Retrieves the first fill color for the grid frame.
void setRotatedAnnotationsEnabled(const bool state)
Enable/disable annotations rotation for rotated or reprojected grids.
void setAnnotationFormat(const Qgis::MapGridAnnotationFormat format)
Sets the format for drawing grid annotations.
void setFrameFillColor1(const QColor &color)
Sets the first fill color used for the grid frame.
double frameMargin() const
Sets the grid frame Margin (in layout units).
Qgis::MapGridAnnotationFormat annotationFormat() const
Returns the format for drawing grid annotations.
int annotationPrecision() const
Returns the coordinate precision for grid annotations, which is the number of decimal places shown wh...
double maximumIntervalWidth() const
Returns the maximum width (in millimeters) for grid segments.
double intervalX() const
Returns the interval between grid lines in the x-direction.
virtual bool writeXml(QDomElement &element, QDomDocument &doc, const QgsReadWriteContext &context) const
Stores the state of the item stack in a DOM node, where element is the DOM element corresponding to a...
virtual bool readXml(const QDomElement &element, const QDomDocument &doc, const QgsReadWriteContext &context)=0
Sets the item stack's state from a DOM document, where element is a DOM node corresponding to a 'Layo...
QList< QgsLayoutItemMapItem * > asList() const
Returns a list of QgsLayoutItemMapItems contained by the stack.
QgsLayoutItemMapItemStack(QgsLayoutItemMap *map)
Constructor for QgsLayoutItemMapItemStack, attached to the specified map.
QgsLayoutItemMapItem & operator[](int index)
Returns a reference to an item at the specified index within the stack.
QString name() const
Returns the friendly display name for the item.
QgsLayoutItemMapItem(const QString &name, QgsLayoutItemMap *map)
Constructor for QgsLayoutItemMapItem, attached to the specified map.
bool enabled() const
Returns whether the item will be drawn.
const QgsLayoutItemMap * map() const
Returns the layout item map for the item.
Layout graphical items for displaying a map.
A line symbol type, for rendering LineString and MultiLineString geometries.
A marker symbol type, for rendering Point and MultiPoint geometries.
A container for the context for various read/write operations on objects.
Contains information about the context of a rendering operation.
An interface for classes which can visit style entity (e.g.
Container for all settings relating to text rendering.
double ANALYSIS_EXPORT angle(QgsPoint *p1, QgsPoint *p2, QgsPoint *p3, QgsPoint *p4)
Calculates the angle between two segments (in 2 dimension, z-values are ignored).