QGIS API Documentation  3.20.0-Odense (decaadbb31)
qgscoordinateboundspreviewmapwidget.cpp
Go to the documentation of this file.
1 /***************************************************************************
2  * qgscoordinateboundspreviewmapwidget.h *
3  * Copyright (C) 2019 by Nyall Dawson *
4  * nyall dot dawson at gmail dot com *
5  * *
6  * This program is free software; you can redistribute it and/or modify *
7  * it under the terms of the GNU General Public License as published by *
8  * the Free Software Foundation; either version 2 of the License, or *
9  * (at your option) any later version. *
10  ***************************************************************************/
12 #include "qgsrubberband.h"
13 #include "qgsvertexmarker.h"
14 #include "qgsapplication.h"
15 #include "qgsvectorlayer.h"
16 #include "qgsmaptoolpan.h"
17 
19  : QgsMapCanvas( parent )
20 {
21  mPreviewBand = new QgsRubberBand( this, QgsWkbTypes::PolygonGeometry );
22  mPreviewBand->setWidth( 4 );
23 
24  mCanvasPreviewBand = new QgsRubberBand( this, QgsWkbTypes::PolygonGeometry );
25  mCanvasPreviewBand->setWidth( 4 );
26  QColor rectColor = QColor( 185, 84, 210, 60 );
27  mCanvasPreviewBand->setColor( rectColor );
28 
29  mCanvasCenterMarker = new QgsVertexMarker( this );
30  mCanvasCenterMarker->setIconType( QgsVertexMarker::ICON_CROSS );
31  mCanvasCenterMarker->setColor( QColor( 185, 84, 210 ) );
32  mCanvasCenterMarker->setPenWidth( 3 );
33 
34  QgsCoordinateReferenceSystem srs( QStringLiteral( "EPSG:4326" ) );
35  setDestinationCrs( srs );
36 
37  QString layerPath = QgsApplication::pkgDataPath() + QStringLiteral( "/resources/data/world_map.gpkg|layername=countries" );
38  mLayers << new QgsVectorLayer( layerPath );
39  setLayers( mLayers );
40  setMapTool( new QgsMapToolPan( this ) );
41  setPreviewJobsEnabled( true );
42 }
43 
45 {
46  qDeleteAll( mLayers );
47  delete mPreviewBand;
48  delete mCanvasPreviewBand;
49  delete mCanvasCenterMarker;
50 }
51 
53 {
54  if ( !qgsDoubleNear( rect.area(), 0.0 ) )
55  {
56  QgsGeometry geom;
57  if ( rect.xMinimum() > rect.xMaximum() )
58  {
59  QgsRectangle rect1 = QgsRectangle( -180, rect.yMinimum(), rect.xMaximum(), rect.yMaximum() );
60  QgsRectangle rect2 = QgsRectangle( rect.xMinimum(), rect.yMinimum(), 180, rect.yMaximum() );
61  geom = QgsGeometry::fromRect( rect1 );
62  geom.addPart( QgsGeometry::fromRect( rect2 ) );
63  }
64  else
65  {
66  geom = QgsGeometry::fromRect( rect );
67  }
68  mPreviewBand->setToGeometry( geom, nullptr );
69  mPreviewBand->setColor( QColor( 255, 0, 0, 65 ) );
71  extent.scale( 1.1 );
72  setExtent( extent );
73  refresh();
74  mPreviewBand->show();
75  }
76  else
77  {
78  mPreviewBand->hide();
80  }
81 }
82 
84 {
85  return mCanvasRect;
86 }
87 
89 {
90  mCanvasRect = rect;
91  mCanvasPreviewBand->setToGeometry( QgsGeometry::fromRect( mCanvasRect ), nullptr );
92  mCanvasPreviewBand->show();
93  mCanvasCenterMarker->setCenter( rect.center() );
94  mCanvasCenterMarker->show();
95 }
static QString pkgDataPath()
Returns the common root path of all application data directories.
void setPreviewRect(const QgsRectangle &rect)
Sets the "preview" rectangle for the bounds overview map.
QgsCoordinateBoundsPreviewMapWidget(QWidget *parent=nullptr)
Constructor for QgsCoordinateBoundsPreviewMapWidget.
void setCanvasRect(const QgsRectangle &rect)
Sets the canvas bounds rectangle for the bounds overview map.
QgsRectangle canvasRect() const
Returns the current canvas bounds rectangle shown in the map.
This class represents a coordinate reference system (CRS).
A geometry is the spatial representation of a feature.
Definition: qgsgeometry.h:124
OperationResult addPart(const QVector< QgsPointXY > &points, QgsWkbTypes::GeometryType geomType=QgsWkbTypes::UnknownGeometry)
Adds a new part to a the geometry.
static QgsGeometry fromRect(const QgsRectangle &rect) SIP_HOLDGIL
Creates a new geometry from a QgsRectangle.
QgsRectangle boundingBox() const
Returns the bounding box of the geometry.
Map canvas is a class for displaying all GIS data types on a canvas.
Definition: qgsmapcanvas.h:86
void zoomToFullExtent()
Zoom to the full extent of all layers currently visible in the canvas.
void setLayers(const QList< QgsMapLayer * > &layers)
Sets the list of layers that should be shown in the canvas.
void setExtent(const QgsRectangle &r, bool magnified=false)
Sets the extent of the map canvas to the specified rectangle.
void setPreviewJobsEnabled(bool enabled)
Sets whether canvas map preview jobs (low priority render jobs which render portions of the view just...
void setDestinationCrs(const QgsCoordinateReferenceSystem &crs)
Sets destination coordinate reference system.
void setMapTool(QgsMapTool *mapTool, bool clean=false)
Sets the map tool currently being used on the canvas.
QgsRectangle extent() const
Returns the current zoom extent of the map canvas.
void refresh()
Repaints the canvas map.
A map tool for panning the map.
Definition: qgsmaptoolpan.h:33
A rectangle specified with double values.
Definition: qgsrectangle.h:42
void scale(double scaleFactor, const QgsPointXY *c=nullptr)
Scale the rectangle around its center point.
Definition: qgsrectangle.h:256
double yMaximum() const SIP_HOLDGIL
Returns the y maximum value (top side of rectangle).
Definition: qgsrectangle.h:193
double xMaximum() const SIP_HOLDGIL
Returns the x maximum value (right side of rectangle).
Definition: qgsrectangle.h:183
double xMinimum() const SIP_HOLDGIL
Returns the x minimum value (left side of rectangle).
Definition: qgsrectangle.h:188
double yMinimum() const SIP_HOLDGIL
Returns the y minimum value (bottom side of rectangle).
Definition: qgsrectangle.h:198
double area() const SIP_HOLDGIL
Returns the area of the rectangle.
Definition: qgsrectangle.h:239
QgsPointXY center() const SIP_HOLDGIL
Returns the center point of the rectangle.
Definition: qgsrectangle.h:251
A class for drawing transient features (e.g.
Definition: qgsrubberband.h:51
void setWidth(int width)
Sets the width of the line.
void setColor(const QColor &color)
Sets the color for the rubberband.
void setToGeometry(const QgsGeometry &geom, QgsVectorLayer *layer)
Sets this rubber band to geom.
Represents a vector layer which manages a vector based data sets.
A class for marking vertices of features using e.g.
void setPenWidth(int width)
void setCenter(const QgsPointXY &point)
Sets the center point of the marker, in map coordinates.
void setIconType(int iconType)
void setColor(const QColor &color)
Sets the stroke color for the marker.
bool qgsDoubleNear(double a, double b, double epsilon=4 *std::numeric_limits< double >::epsilon())
Compare two doubles (but allow some difference)
Definition: qgis.h:598