QGIS API Documentation 4.1.0-Master (64dc32379c2)
Loading...
Searching...
No Matches
qgsjsonutils.h
Go to the documentation of this file.
1/***************************************************************************
2 qgsjsonutils.h
3 -------------
4 Date : May 206
5 Copyright : (C) 2016 Nyall Dawson
6 Email : nyall dot dawson at gmail dot com
7 ***************************************************************************
8 * *
9 * This program is free software; you can redistribute it and/or modify *
10 * it under the terms of the GNU General Public License as published by *
11 * the Free Software Foundation; either version 2 of the License, or *
12 * (at your option) any later version. *
13 * *
14 ***************************************************************************/
15
16#ifndef QGSJSONUTILS_H
17#define QGSJSONUTILS_H
18
19#include "qgis_core.h"
22#include "qgsfeature.h"
23#include "qgsfields.h"
24
25#include <QJsonObject>
26#include <QPointer>
27
28#ifndef SIP_RUN
29#include <nlohmann/json_fwd.hpp>
30using namespace nlohmann;
31#endif
32
33class QTextCodec;
34
43
44class CORE_EXPORT QgsJsonExporter
45{
46 public:
54
61 void setPrecision( int precision ) { mPrecision = precision; }
62
67 int precision() const { return mPrecision; }
68
74 void setIncludeGeometry( bool includeGeometry ) { mIncludeGeometry = includeGeometry; }
75
80 bool includeGeometry() const { return mIncludeGeometry; }
81
87 void setIncludeAttributes( bool includeAttributes ) { mIncludeAttributes = includeAttributes; }
88
93 bool includeAttributes() const { return mIncludeAttributes; }
94
102 void setIncludeRelated( bool includeRelated ) { mIncludeRelatedAttributes = includeRelated; }
103
108 bool includeRelated() const { return mIncludeRelatedAttributes; }
109
115 void setAttributeDisplayName( bool displayName ) { mAttributeDisplayName = displayName; }
116
121
122 bool attributeDisplayName() const { return mAttributeDisplayName; }
123
130 void setVectorLayer( QgsVectorLayer *vectorLayer );
131
136 QgsVectorLayer *vectorLayer() const;
137
145 void setSourceCrs( const QgsCoordinateReferenceSystem &crs );
146
152 QgsCoordinateReferenceSystem sourceCrs() const;
153
159 void setTransformGeometries( bool activate ) { mTransformGeometries = activate; }
160
170 void setAttributes( const QgsAttributeList &attributes ) { mAttributeIndexes = attributes; }
171
180 QgsAttributeList attributes() const { return mAttributeIndexes; }
181
189 void setExcludedAttributes( const QgsAttributeList &attributes ) { mExcludedAttributeIndexes = attributes; }
190
197 QgsAttributeList excludedAttributes() const { return mExcludedAttributeIndexes; }
198
205 void setUseFieldFormatters( bool useFieldFormatters ) { mUseFieldFormatters = useFieldFormatters; }
206
213 bool useFieldFormatters() const { return mUseFieldFormatters; }
214
227 QString exportFeature( const QgsFeature &feature, const QVariantMap &extraProperties = QVariantMap(), const QVariant &id = QVariant(), int indent = -1, const QString &featureType = QString() ) const;
228
239 json exportFeatureToJsonObject( const QgsFeature &feature, const QVariantMap &extraProperties = QVariantMap(), const QVariant &id = QVariant(), const QString &featureType = QString() ) const
240 SIP_SKIP;
241
242
250 QString exportFeatures( const QgsFeatureList &features, int indent = -1 ) const;
251
259 json exportFeaturesToJsonObject( const QgsFeatureList &features ) const SIP_SKIP;
260
270 void setDestinationCrs( const QgsCoordinateReferenceSystem &destinationCrs );
271
272 private:
274 int mPrecision;
275
280 QgsAttributeList mAttributeIndexes;
281
283 QgsAttributeList mExcludedAttributeIndexes;
284
286 bool mIncludeGeometry = true;
287
289 bool mIncludeAttributes = true;
290
292 bool mIncludeRelatedAttributes = false;
293
295 QPointer< QgsVectorLayer > mLayer;
296
298
299 QgsCoordinateTransform mTransform;
300
301 bool mAttributeDisplayName = false;
302
303 bool mTransformGeometries = true;
304
305 QgsCoordinateReferenceSystem mDestinationCrs;
306
307 bool mUseFieldFormatters = true;
308};
309
315
316class CORE_EXPORT QgsJsonUtils
317{
318 Q_GADGET
319
320 public:
329 static QgsFeatureList stringToFeatureList( const QString &string, const QgsFields &fields = QgsFields(), QTextCodec *encoding SIP_PYARGREMOVE6 = nullptr );
330
338 static QgsFields stringToFields( const QString &string, QTextCodec *encoding SIP_PYARGREMOVE6 = nullptr );
339
346 Q_INVOKABLE static QString encodeValue( const QVariant &value );
347
356 static QString exportAttributes( const QgsFeature &feature, QgsVectorLayer *layer = nullptr, const QVector<QVariant> &attributeWidgetCaches = QVector<QVariant>() );
357
369 static json exportAttributesToJsonObject( const QgsFeature &feature, QgsVectorLayer *layer = nullptr, const QVector<QVariant> &attributeWidgetCaches = QVector<QVariant>(), bool useFieldFormatters = true )
370 SIP_SKIP;
371
379 Q_INVOKABLE static QVariantList parseArray( const QString &json, QMetaType::Type type = QMetaType::Type::UnknownType );
380
389 Q_INVOKABLE Q_DECL_DEPRECATED static QVariantList parseArray( const QString &json, QVariant::Type type ) SIP_DEPRECATED;
390
399 static QgsGeometry geometryFromGeoJson( const json &geometry ) SIP_SKIP;
400
408 static QgsGeometry geometryFromGeoJson( const QString &geometry );
409
415 static json jsonFromVariant( const QVariant &v ) SIP_SKIP;
416
424 static QVariant parseJson( const std::string &jsonString ) SIP_SKIP;
425
433 static QVariant parseJson( const std::string &jsonString, QString &error ) SIP_SKIP;
434
440 static QVariant parseJson( const QString &jsonString ) SIP_SKIP;
441
447 static QVariant jsonToVariant( const json &value ) SIP_SKIP;
448
456 static void addCrsInfo( json &value, const QgsCoordinateReferenceSystem &crs ) SIP_SKIP;
457};
458
459#endif // QGSJSONUTILS_H
Represents a coordinate reference system (CRS).
Handles coordinate transforms between two coordinate systems.
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
Definition qgsfeature.h:60
Container of fields for a vector layer.
Definition qgsfields.h:46
A geometry is the spatial representation of a feature.
void setIncludeGeometry(bool includeGeometry)
Sets whether to include geometry in the JSON exports.
void setIncludeRelated(bool includeRelated)
Sets whether to include attributes of features linked via references in the JSON exports.
void setPrecision(int precision)
Sets the maximum number of decimal places to use in geometry coordinates.
void setAttributes(const QgsAttributeList &attributes)
Sets the list of attributes to include in the JSON exports.
bool attributeDisplayName() const
Returns whether original names of attributes or aliases are printed.
QgsAttributeList excludedAttributes() const
Returns a list of attributes which will be specifically excluded from the JSON exports.
void setUseFieldFormatters(bool useFieldFormatters)
Sets whether field formatters (of type KeyValue, List, ValueRelation, ValueMap) are used to export ra...
void setIncludeAttributes(bool includeAttributes)
Sets whether to include attributes in the JSON exports.
bool useFieldFormatters() const
Returned whether field formatters (of type KeyValue, List, ValueRelation, ValueMap) are used to expor...
QgsVectorLayer * vectorLayer() const
Returns the associated vector layer, if set.
void setTransformGeometries(bool activate)
Sets whether geometries should be transformed in EPSG 4326 (default behavior) or just keep as it is.
void setAttributeDisplayName(bool displayName)
Sets whether to print original names of attributes or aliases if defined.
QgsAttributeList attributes() const
Returns the list of attributes which will be included in the JSON exports, or an empty list if all at...
void setExcludedAttributes(const QgsAttributeList &attributes)
Sets a list of attributes to specifically exclude from the JSON exports.
bool includeAttributes() const
Returns whether attributes will be included in the JSON exports.
int precision() const
Returns the maximum number of decimal places to use in geometry coordinates.
bool includeRelated() const
Returns whether attributes of related (child) features will be included in the JSON exports.
QgsJsonExporter(QgsVectorLayer *vectorLayer=nullptr, int precision=6)
Constructor for QgsJsonExporter.
bool includeGeometry() const
Returns whether geometry will be included in the JSON exports.
Helper utilities for working with JSON and GeoJSON conversions.
static QgsGeometry geometryFromGeoJson(const json &geometry)
Parses a GeoJSON "geometry" value to a QgsGeometry object.
static QString exportAttributes(const QgsFeature &feature, QgsVectorLayer *layer=nullptr, const QVector< QVariant > &attributeWidgetCaches=QVector< QVariant >())
Exports all attributes from a QgsFeature as a JSON map type.
static QgsFeatureList stringToFeatureList(const QString &string, const QgsFields &fields=QgsFields(), QTextCodec *encoding SIP_PYARGREMOVE6=nullptr)
Attempts to parse a GeoJSON string to a collection of features.
static Q_INVOKABLE QString encodeValue(const QVariant &value)
Encodes a value to a JSON string representation, adding appropriate quotations and escaping where req...
static QVariant parseJson(const std::string &jsonString)
Converts JSON jsonString to a QVariant, in case of parsing error an invalid QVariant is returned and ...
static void addCrsInfo(json &value, const QgsCoordinateReferenceSystem &crs)
Add crs information entry in json object regarding old GeoJSON specification format if it differs fro...
static Q_INVOKABLE QVariantList parseArray(const QString &json, QMetaType::Type type=QMetaType::Type::UnknownType)
Parse a simple array (depth=1).
static json exportAttributesToJsonObject(const QgsFeature &feature, QgsVectorLayer *layer=nullptr, const QVector< QVariant > &attributeWidgetCaches=QVector< QVariant >(), bool useFieldFormatters=true)
Exports all attributes from a QgsFeature as a json object.
static QVariant jsonToVariant(const json &value)
Converts a JSON value to a QVariant, in case of parsing error an invalid QVariant is returned.
static QgsFields stringToFields(const QString &string, QTextCodec *encoding SIP_PYARGREMOVE6=nullptr)
Attempts to retrieve the fields from a GeoJSON string representing a collection of features.
static json jsonFromVariant(const QVariant &v)
Converts a QVariant v to a json object.
Represents a vector layer which manages a vector based dataset.
#define SIP_DEPRECATED
Definition qgis_sip.h:113
#define SIP_SKIP
Definition qgis_sip.h:133
#define SIP_PYARGREMOVE6
Definition qgis_sip.h:163
QList< QgsFeature > QgsFeatureList
QList< int > QgsAttributeList
Definition qgsfield.h:30