Class: QgsVectorTileWriter¶
Takes care of writing vector tiles.
The intended use is to set up the class by setting the destination URI,
extent, zoom level range and input vector layers. Then with a call to
writeTiles() the data gets written. In case of a failure,
errorMessage() returns the cause of the problem during
writing.
The syntax of destination URIs is the same like the data source string used by vector tile layers: parameters are encoded as a HTTP query string, where “type” key determines the type of the destination container, the “url” key is normally the path. Currently supported types:
- “xyz” - tile data written as local files, using a template where {x},{y},{z} are replaced by the actual tile column, row and zoom level numbers, e.g.: file:///home/qgis/tiles/{z}/{x}/{y}.pbf 
- “mbtiles” - tile data written to a new MBTiles file, the “url” key should be ordinary file system path, e.g.: /home/qgis/output.mbtiles 
Currently the writer only support MVT encoding of data.
Metadata support: it is possible to pass a QVariantMap with metadata. This is backend dependent. Currently only “mbtiles” source type supports writing of metadata. The key-value pairs will be written to the “metadata” table in the MBTiles file. Some useful metadata keys listed here, but see MBTiles spec for more details:
- “name” - human-readable name of the tileset 
- “bounds” - extent in WGS 84: “minlon,minlat,maxlon,maxlat” 
- “center” - default view of the map: “longitude,latitude,zoomlevel” 
- “minzoom” - lowest zoom level 
- “maxzoom” - highest zoom level 
- “attribution” - string that explains the sources of data 
- “description” - descriptions of the content 
- “type” - whether this is an overlay or a basemap 
- “version” - version of the tileset 
Vector tile writer always writes “format” and “json” metadata. If not specified in metadata by the client, tile writer also writes “name”, “bounds”, “minzoom” and “maxzoom”.
Added in version 3.14.
Methods
| Returns error message related to the previous call to  | |
| Returns calculated extent that combines extent of all input layers | |
| Sets where and how the vector tiles will be written. | |
| Sets extent of vector tile output. | |
| Sets vector layers and their configuration for output of vector tiles | |
| Sets the maximum zoom level of tiles. | |
| Sets that will be written to the output dataset. | |
| Sets the minimum zoom level of tiles. | |
| Sets zoom level 0 tile matrix | |
| Sets coordinate transform context for transforms between layers and tile matrix CRS | |
| Encodes single MVT tile | |
| Writes vector tiles according to the configuration. | 
- class qgis.core.QgsVectorTileWriter[source]¶
- Bases: - object- class Layer[source]¶
- Bases: - object- Configuration of a single input vector layer to be included in the output. - Added in version 3.14. - QgsVectorTileWriter.Layer(layer: Optional[QgsVectorLayer]) Constructs an entry for a vector layer - QgsVectorTileWriter.Layer(a0: QgsVectorTileWriter.Layer) - filterExpression(self) str[source]¶
- Returns filter expression. If not empty, only features matching the expression will be used - Return type:
- str 
 
 - layer(self) QgsVectorLayer | None[source]¶
- Returns vector layer of this entry - Return type:
- Optional[QgsVectorLayer] 
 
 - layerName(self) str[source]¶
- Returns layer name in the output. If not set, - layer()->:py:func:~Layer.name will be used.- Return type:
- str 
 
 - maxZoom(self) int[source]¶
- Returns maximum zoom level at which this layer will be used. Negative value means no max. zoom level - Return type:
- int 
 
 - minZoom(self) int[source]¶
- Returns minimum zoom level at which this layer will be used. Negative value means no min. zoom level - Return type:
- int 
 
 - setFilterExpression(self, expr: str | None)[source]¶
- Sets filter expression. If not empty, only features matching the expression will be used - Parameters:
- expr (Optional[str]) 
 
 - setLayerName(self, name: str | None)[source]¶
- Sets layer name in the output. If not set, - layer()->:py:func:~Layer.name will be used.- Parameters:
- name (Optional[str]) 
 
 
 - errorMessage(self) str[source]¶
- Returns error message related to the previous call to - writeTiles(). Will return an empty string if writing was successful.- Return type:
- str 
 
 - fullExtent(self) QgsRectangle[source]¶
- Returns calculated extent that combines extent of all input layers - Return type:
 
 - setDestinationUri(self, uri: str | None)[source]¶
- Sets where and how the vector tiles will be written. See the class description about the syntax of destination URIs. - Parameters:
- uri (Optional[str]) 
 
 - setExtent(self, extent: QgsRectangle)[source]¶
- Sets extent of vector tile output. If unset, it will use the full extent of all input layers combined - Parameters:
- extent (QgsRectangle) 
 
 - setLayers(self, layers: Iterable[QgsVectorTileWriter.Layer])[source]¶
- Sets vector layers and their configuration for output of vector tiles - Parameters:
- layers (Iterable[QgsVectorTileWriter.Layer]) 
 
 - setMaxZoom(self, maxZoom: int)[source]¶
- Sets the maximum zoom level of tiles. Allowed values are in interval [0,24] - Parameters:
- maxZoom (int) 
 
 - setMetadata(self, metadata: Dict[str, Any])[source]¶
- Sets that will be written to the output dataset. See class description for more on metadata support - Parameters:
- metadata (Dict[str, Any]) 
 
 - setMinZoom(self, minZoom: int)[source]¶
- Sets the minimum zoom level of tiles. Allowed values are in interval [0,24] - Parameters:
- minZoom (int) 
 
 - setRootTileMatrix(self, tileMatrix: QgsTileMatrix) bool[source]¶
- Sets zoom level 0 tile matrix - Parameters:
- tileMatrix (QgsTileMatrix) 
- Return type:
- bool 
 
 - setTransformContext(self, transformContext: QgsCoordinateTransformContext)[source]¶
- Sets coordinate transform context for transforms between layers and tile matrix CRS - Parameters:
- transformContext (QgsCoordinateTransformContext) 
 
 - writeSingleTile(self, tileID: QgsTileXYZ, feedback: QgsFeedback | None = None, buffer: int = 256, resolution: int = 4096) QByteArray[source]¶
- Encodes single MVT tile - Parameters:
- tileID (QgsTileXYZ) – Tile identifier 
- feedback (Optional[QgsFeedback] = None) – optional, provide cancellation functionality 
- resolution (int = 4096) – the resolution of coordinates of geometries within the tile. The default is 4096 
- buffer (int = 256) – size of the buffer zone around tile edges in integer tile coordinates. The default is 256 (~6%) 
 
 - Returns a QByteArray with the encoded data - Added in version 3.22. - Return type:
- QByteArray 
 
 - writeTiles(self, feedback: QgsFeedback | None = None) bool[source]¶
- Writes vector tiles according to the configuration. Returns - Trueon success (upon failure one can get error cause using- errorMessage())- If a pointer to a feedback object is provided, it can be used to track progress or provide cancellation functionality. - Parameters:
- feedback (Optional[QgsFeedback] = None) 
- Return type:
- bool