30 : mStyleName( stName )
31 , mLayerName( laName )
32 , mGeometryType( geomType )
46 mStyleName = other.mStyleName;
47 mLayerName = other.mLayerName;
48 mGeometryType = other.mGeometryType;
49 mSymbol.reset( other.mSymbol ? other.mSymbol->clone() :
nullptr );
50 mEnabled = other.mEnabled;
51 mExpression = other.mExpression;
52 mMinZoomLevel = other.mMinZoomLevel;
53 mMaxZoomLevel = other.mMaxZoomLevel;
66 elem.setAttribute( QStringLiteral(
"name" ), mStyleName );
67 elem.setAttribute( QStringLiteral(
"layer" ), mLayerName );
68 elem.setAttribute( QStringLiteral(
"geometry" ),
static_cast<int>( mGeometryType ) );
69 elem.setAttribute( QStringLiteral(
"enabled" ), mEnabled ? QStringLiteral(
"1" ) : QStringLiteral(
"0" ) );
70 elem.setAttribute( QStringLiteral(
"expression" ), mExpression );
71 elem.setAttribute( QStringLiteral(
"min-zoom" ), mMinZoomLevel );
72 elem.setAttribute( QStringLiteral(
"max-zoom" ), mMaxZoomLevel );
74 QDomDocument doc = elem.ownerDocument();
76 symbols[QStringLiteral(
"0" )] = mSymbol.get();
78 elem.appendChild( symbolsElem );
83 mStyleName = elem.attribute( QStringLiteral(
"name" ) );
84 mLayerName = elem.attribute( QStringLiteral(
"layer" ) );
85 mGeometryType =
static_cast<Qgis::GeometryType>( elem.attribute( QStringLiteral(
"geometry" ) ).toInt() );
86 mEnabled = elem.attribute( QStringLiteral(
"enabled" ) ).toInt();
87 mExpression = elem.attribute( QStringLiteral(
"expression" ) );
88 mMinZoomLevel = elem.attribute( QStringLiteral(
"min-zoom" ) ).toInt();
89 mMaxZoomLevel = elem.attribute( QStringLiteral(
"max-zoom" ) ).toInt();
92 QDomElement symbolsElem = elem.firstChildElement( QStringLiteral(
"symbols" ) );
93 if ( !symbolsElem.isNull() )
96 if ( symbolMap.contains( QStringLiteral(
"0" ) ) )
98 mSymbol.reset( symbolMap.take( QStringLiteral(
"0" ) ) );
112 return QStringLiteral(
"basic" );
118 r->mStyles = mStyles;
126 Q_UNUSED( tileRange )
130 if ( layerStyle.isActive( tileZoom ) )
132 if ( !layerStyle.filterExpression().isEmpty() )
137 if (
auto *lSymbol = layerStyle.symbol() )
139 mRequiredFields[layerStyle.layerName()].unite( lSymbol->usedAttributes( context ) );
147 return mRequiredFields;
155 if ( layerStyle.isActive( tileZoom ) )
157 res.insert( layerStyle.layerName() );
172 if ( !layerStyle.symbol() || layerStyle.layerName() != QLatin1String(
"background" ) )
175 if ( layerStyle.isEnabled() )
184 polygon << QPoint( 0, 0 );
185 polygon << QPoint( 0, context.
outputSize().height() );
187 polygon << QPoint( context.
outputSize().width(), 0 );
188 fillSym->
renderPolygon( polygon,
nullptr,
nullptr, context );
203 if ( !layerStyle.isActive( zoomLevel ) || !layerStyle.symbol() || layerStyle.layerName() == QLatin1String(
"background" ) )
210 QgsExpression filterExpression( layerStyle.filterExpression() );
215 if ( layerStyle.layerName().isEmpty() )
218 for (
const auto &features : tileData )
227 if ( featureType == layerStyle.geometryType() )
244 const QgsRectangle boundingBox = f.geometry().boundingBox();
245 centroid.
setGeometry( f.geometry().poleOfInaccessibility( std::min( boundingBox.
width(), boundingBox.
height() ) / 20 ) );
251 else if ( tileData.contains( layerStyle.layerName() ) )
254 for (
const QgsFeature &f : tileData[layerStyle.layerName()] )
261 if ( featureType == layerStyle.geometryType() )
278 const QgsRectangle boundingBox = f.geometry().boundingBox();
279 centroid.
setGeometry( f.geometry().poleOfInaccessibility( std::min( boundingBox.
width(), boundingBox.
height() ) / 20 ) );
296 int featureTileZoom = feature.attribute( QStringLiteral(
"tile_zoom" ) ).toInt( &ok );
298 featureTileZoom = -1;
299 const QString featureTileLayer = feature.attribute( QStringLiteral(
"tile_layer" ) ).toString();
303 if ( ( featureTileZoom >= 0 && !layerStyle.isActive( featureTileZoom ) )
304 || !layerStyle.symbol() || layerStyle.layerName() == QLatin1String(
"background" ) )
307 if ( !layerStyle.layerName().isEmpty() && !featureTileLayer.isEmpty() && layerStyle.layerName() != featureTileLayer )
312 QgsExpression filterExpression( layerStyle.filterExpression() );
323 bool renderedFeature =
false;
324 if ( featureType == layerStyle.geometryType() )
327 renderedFeature =
true;
336 renderedFeature =
true;
343 const QgsRectangle boundingBox = feature.geometry().boundingBox();
344 centroid.
setGeometry( feature.geometry().poleOfInaccessibility( std::min( boundingBox.
width(), boundingBox.
height() ) / 20 ) );
346 renderedFeature =
true;
350 if ( renderedFeature )
365 if ( !layerStyle.isActive( tileZoom ) || !layerStyle.symbol() )
368 if ( layerStyle.layerName() == QLatin1String(
"background" ) )
371 if ( !layerStyle.layerName().isEmpty() && layerStyle.layerName() != layerName )
374 QgsExpression filterExpression( layerStyle.filterExpression() );
381 if ( featureType == layerStyle.geometryType() )
403 QDomDocument doc = elem.ownerDocument();
404 QDomElement elemStyles = doc.createElement( QStringLiteral(
"styles" ) );
407 QDomElement elemStyle = doc.createElement( QStringLiteral(
"style" ) );
408 layerStyle.writeXml( elemStyle, context );
409 elemStyles.appendChild( elemStyle );
411 elem.appendChild( elemStyles );
418 QDomElement elemStyles = elem.firstChildElement( QStringLiteral(
"styles" ) );
419 QDomElement elemStyle = elemStyles.firstChildElement( QStringLiteral(
"style" ) );
420 while ( !elemStyle.isNull() )
423 layerStyle.
readXml( elemStyle, context );
424 mStyles.append( layerStyle );
425 elemStyle = elemStyle.nextSiblingElement( QStringLiteral(
"style" ) );
442 QColor polygonStrokeColor = polygonFillColor;
443 polygonFillColor.setAlpha( 100 );
450 QColor pointStrokeColor = pointFillColor;
451 pointFillColor.setAlpha( 100 );
454 return simpleStyle( polygonFillColor, polygonStrokeColor, polygonStrokeWidth,
455 lineStrokeColor, lineStrokeWidth,
456 pointFillColor, pointStrokeColor, pointSize );
460 const QColor &polygonFillColor,
const QColor &polygonStrokeColor,
double polygonStrokeWidth,
461 const QColor &lineStrokeColor,
double lineStrokeWidth,
462 const QColor &pointFillColor,
const QColor &pointStrokeColor,
double pointSize )
471 lineSymbolLayer->
setColor( lineStrokeColor );
472 lineSymbolLayer->
setWidth( lineStrokeWidth );
478 markerSymbolLayer->
setSize( pointSize );
493 QList<QgsVectorTileBasicRendererStyle> lst;
494 lst << st1 << st2 << st3;
static const double DEFAULT_LINE_WIDTH
The default width (in millimeters) for line symbols.
GeometryType
The geometry types are used to group Qgis::WkbType in a coarse way.
static const double DEFAULT_POINT_SIZE
The default size (in millimeters) for point marker symbols.
static QgsColorSchemeRegistry * colorSchemeRegistry()
Returns the application's color scheme registry, used for managing color schemes.
QColor fetchRandomStyleColor() const
Returns a random color for use with a new symbol style (e.g.
RAII class to pop scope from an expression context on destruction.
Single scope for storing variables and functions for use within a QgsExpressionContext.
void setFields(const QgsFields &fields)
Convenience function for setting a fields for the scope.
void setFeature(const QgsFeature &feature)
Convenience function for setting a feature for the scope.
Handles parsing and evaluation of expressions (formerly called "search strings").
bool prepare(const QgsExpressionContext *context)
Gets the expression ready for evaluation - find out column indexes.
QSet< QString > referencedColumns() const
Gets list of columns referenced by the expression.
QVariant evaluate()
Evaluate the feature and return the result.
bool isValid() const
Checks if this expression is valid.
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
void setGeometry(const QgsGeometry &geometry)
Set the feature's geometry.
Container of fields for a vector layer.
A fill symbol type, for rendering Polygon and MultiPolygon geometries.
void renderPolygon(const QPolygonF &points, const QVector< QPolygonF > *rings, const QgsFeature *f, QgsRenderContext &context, int layer=-1, bool selected=false)
Renders the symbol using the given render context.
A geometry is the spatial representation of a feature.
Qgis::WkbType wkbType() const
Returns type of the geometry as a WKB type (point / linestring / polygon etc.).
virtual void setWidth(double width)
Sets the width of the line symbol layer.
A line symbol type, for rendering LineString and MultiLineString geometries.
virtual void setSize(double size)
Sets the symbol size.
A marker symbol type, for rendering Point and MultiPoint geometries.
A container for the context for various read/write operations on objects.
A rectangle specified with double values.
Contains information about the context of a rendering operation.
QgsExpressionContext & expressionContext()
Gets the expression context.
QSize outputSize() const
Returns the size of the resulting rendered image, in pixels.
Renders polygons using a single fill and stroke color.
void setStrokeWidth(double strokeWidth)
void setFillColor(const QColor &color) override
Sets the fill color for the symbol layer.
void setStrokeColor(const QColor &strokeColor) override
Sets the stroke color for the symbol layer.
A simple line symbol layer, which renders lines using a line in a variety of styles (e....
Simple marker symbol layer, consisting of a rendered shape with solid fill color and a stroke.
void setFillColor(const QColor &color) override
Sets the fill color for the symbol layer.
void setStrokeColor(const QColor &color) override
Sets the marker's stroke color.
static QgsSymbolMap loadSymbols(QDomElement &element, const QgsReadWriteContext &context)
Reads a collection of symbols from XML and returns them in a map. Caller is responsible for deleting ...
static QDomElement saveSymbols(QgsSymbolMap &symbols, const QString &tagName, QDomDocument &doc, const QgsReadWriteContext &context)
Writes a collection of symbols to XML with specified tagName for the top-level element.
virtual void setColor(const QColor &color)
Sets the "representative" color for the symbol layer.
Abstract base class for all rendered symbols.
void renderFeature(const QgsFeature &feature, QgsRenderContext &context, int layer=-1, bool selected=false, bool drawVertexMarker=false, Qgis::VertexMarkerType currentVertexMarkerType=Qgis::VertexMarkerType::SemiTransparentCircle, double currentVertexMarkerSize=0.0)
Render a feature.
void stopRender(QgsRenderContext &context)
Ends the rendering process.
void startRender(QgsRenderContext &context, const QgsFields &fields=QgsFields())
Begins the rendering process for the symbol.
A range of tiles in a tile matrix.
Definition of map rendering of a subset of vector tile data.
QgsVectorTileBasicRendererStyle(const QString &stName=QString(), const QString &laName=QString(), Qgis::GeometryType geomType=Qgis::GeometryType::Unknown)
Constructs a style object.
~QgsVectorTileBasicRendererStyle()
void setFilterExpression(const QString &expr)
Sets filter expression (empty filter means that all features match).
void setSymbol(QgsSymbol *sym)
Sets symbol for rendering. Takes ownership of the symbol.
void writeXml(QDomElement &elem, const QgsReadWriteContext &context) const
Writes object content to given DOM element.
QgsVectorTileBasicRendererStyle & operator=(const QgsVectorTileBasicRendererStyle &other)
void readXml(const QDomElement &elem, const QgsReadWriteContext &context)
Reads object content from given DOM element.
void renderTile(const QgsVectorTileRendererData &tile, QgsRenderContext &context) override
Renders given vector tile. Must be called between startRender/stopRender.
QList< QgsVectorTileBasicRendererStyle > styles() const
Returns list of styles of the renderer.
void readXml(const QDomElement &elem, const QgsReadWriteContext &context) override
Reads renderer's properties from given XML element.
QMap< QString, QSet< QString > > usedAttributes(const QgsRenderContext &) override
Returns field names of sub-layers that will be used for rendering. Must be called between startRender...
QgsVectorTileBasicRenderer()
Constructs renderer with no styles.
void renderSelectedFeatures(const QList< QgsFeature > &selection, QgsRenderContext &context) override
Renders the specified features in a selected state.
void setStyles(const QList< QgsVectorTileBasicRendererStyle > &styles)
Sets list of styles of the renderer.
void startRender(QgsRenderContext &context, int tileZoom, const QgsTileRange &tileRange) override
Initializes rendering. It should be paired with a stopRender() call.
QString type() const override
Returns unique type name of the renderer implementation.
static QList< QgsVectorTileBasicRendererStyle > simpleStyle(const QColor &polygonFillColor, const QColor &polygonStrokeColor, double polygonStrokeWidth, const QColor &lineStrokeColor, double lineStrokeWidth, const QColor &pointFillColor, const QColor &pointStrokeColor, double pointSize)
Returns a list of styles to render all layers with the given fill/stroke colors, stroke widths and ma...
bool willRenderFeature(const QgsFeature &feature, int tileZoom, const QString &layerName, QgsRenderContext &context) override
Returns true if the specified feature will be rendered in the given render context.
QgsVectorTileBasicRenderer * clone() const override
Returns a clone of the renderer.
static QList< QgsVectorTileBasicRendererStyle > simpleStyleWithRandomColors()
Returns a list of styles to render all layers, using random colors.
QSet< QString > requiredLayers(QgsRenderContext &context, int tileZoom) const override
Returns a list of the layers required for rendering.
void renderBackground(QgsRenderContext &context) override
Renders the background if defined.
void writeXml(QDomElement &elem, const QgsReadWriteContext &context) const override
Writes renderer's properties to given XML element.
void stopRender(QgsRenderContext &context) override
Finishes rendering and cleans up any resources.
Contains decoded features of a single vector tile and any other data necessary for rendering of it.
QMap< QString, QgsFields > fields() const
Returns per-layer fields.
QgsVectorTileFeatures features() const
Returns features of the tile grouped by sub-layer names.
int renderZoomLevel() const
Returns the zoom level corresponding to the target render.
static Qgis::GeometryType geometryType(Qgis::WkbType type)
Returns the geometry type for a WKB type, e.g., both MultiPolygon and CurvePolygon would have a Polyg...
QMap< QString, QgsSymbol * > QgsSymbolMap
QList< QgsSymbolLayer * > QgsSymbolLayerList
QMap< QString, QVector< QgsFeature > > QgsVectorTileFeatures
Features of a vector tile, grouped by sub-layer names (key of the map).