28 if (
"unknown" == element.text() )
43 const double xmin = element.attribute( u
"xmin"_s ).toDouble();
46 const double ymin = element.attribute( u
"ymin"_s ).toDouble();
49 const double zmin = element.attribute( u
"zmin"_s ).toDouble();
52 const double xmax = element.attribute( u
"xmax"_s ).toDouble();
55 const double ymax = element.attribute( u
"ymax"_s ).toDouble();
58 const double zmax = element.attribute( u
"zmax"_s ).toDouble();
68 const QDomNode xminNode = element.namedItem( u
"xmin"_s );
69 const QDomNode yminNode = element.namedItem( u
"ymin"_s );
70 const QDomNode xmaxNode = element.namedItem( u
"xmax"_s );
71 const QDomNode ymaxNode = element.namedItem( u
"ymax"_s );
73 QDomElement exElement = xminNode.toElement();
74 const double xmin = exElement.text().toDouble();
77 exElement = yminNode.toElement();
78 const double ymin = exElement.text().toDouble();
81 exElement = xmaxNode.toElement();
82 const double xmax = exElement.text().toDouble();
85 exElement = ymaxNode.toElement();
86 const double ymax = exElement.text().toDouble();
99 unitsString = u
"unknown"_s;
101 QDomElement unitsNode = doc.createElement( u
"units"_s );
102 unitsNode.appendChild( doc.createTextNode( unitsString ) );
108 QDomElement elemExtent3D = doc.createElement( elementName );
109 elemExtent3D.setAttribute( u
"xMin"_s, box.
xMinimum() );
110 elemExtent3D.setAttribute( u
"yMin"_s, box.
yMinimum() );
111 elemExtent3D.setAttribute( u
"zMin"_s, box.
zMinimum() );
112 elemExtent3D.setAttribute( u
"xMax"_s, box.
xMaximum() );
113 elemExtent3D.setAttribute( u
"yMax"_s, box.
yMaximum() );
114 elemExtent3D.setAttribute( u
"zMax"_s, box.
zMaximum() );
121 QDomElement xMin = doc.createElement( u
"xmin"_s );
122 QDomElement yMin = doc.createElement( u
"ymin"_s );
123 QDomElement xMax = doc.createElement( u
"xmax"_s );
124 QDomElement yMax = doc.createElement( u
"ymax"_s );
131 xMin.appendChild( xMinText );
132 yMin.appendChild( yMinText );
133 xMax.appendChild( xMaxText );
134 yMax.appendChild( yMaxText );
136 QDomElement extentNode = doc.createElement( elementName );
137 extentNode.appendChild( xMin );
138 extentNode.appendChild( yMin );
139 extentNode.appendChild( xMax );
140 extentNode.appendChild( yMax );
146 QDomElement element = doc.createElement( u
"Option"_s );
147 switch ( value.userType() )
149 case QMetaType::Type::UnknownType:
151 element.setAttribute( u
"type"_s, u
"invalid"_s );
155 case QMetaType::Type::QVariantMap:
157 const QVariantMap map = value.toMap();
159 for (
auto option = map.constBegin(); option != map.constEnd(); ++option )
161 QDomElement optionElement =
writeVariant( option.value(), doc );
162 optionElement.setAttribute( u
"name"_s, option.key() );
163 element.appendChild( optionElement );
164 element.setAttribute( u
"type"_s, u
"Map"_s );
169 case QMetaType::Type::QVariantList:
171 const QVariantList list = value.toList();
173 const auto constList = list;
174 for (
const QVariant &value : constList )
176 const QDomElement valueElement =
writeVariant( value, doc );
177 element.appendChild( valueElement );
178 element.setAttribute( u
"type"_s, u
"List"_s );
183 case QMetaType::Type::QStringList:
185 const QStringList list = value.toStringList();
187 const auto constList = list;
188 for (
const QString &value : constList )
190 const QDomElement valueElement =
writeVariant( value, doc );
191 element.appendChild( valueElement );
192 element.setAttribute( u
"type"_s, u
"StringList"_s );
197 case QMetaType::Type::QRect:
199 element.setAttribute( u
"type"_s,
"QRect" );
201 const QRect rect = value.toRect();
202 element.setAttribute( u
"x"_s, rect.x() );
203 element.setAttribute( u
"y"_s, rect.y() );
204 element.setAttribute( u
"width"_s, rect.width() );
205 element.setAttribute( u
"height"_s, rect.height() );
209 case QMetaType::Type::Int:
210 case QMetaType::Type::UInt:
211 case QMetaType::Type::Bool:
212 case QMetaType::Type::Double:
213 case QMetaType::Type::LongLong:
214 case QMetaType::Type::ULongLong:
215 case QMetaType::Type::QString:
216 element.setAttribute( u
"type"_s, QVariant::typeToName(
static_cast<QMetaType::Type
>( value.userType() ) ) );
217 element.setAttribute( u
"value"_s, value.toString() );
220 case QMetaType::Type::QChar:
221 element.setAttribute( u
"type"_s, QVariant::typeToName(
static_cast<QMetaType::Type
>( value.userType() ) ) );
225 case QMetaType::Type::QColor:
226 element.setAttribute( u
"type"_s, u
"color"_s );
227 element.setAttribute( u
"value"_s, value.value< QColor >().isValid() ?
QgsColorUtils::colorToString( value.value< QColor >() ) : QString() );
230 case QMetaType::Type::QDateTime:
231 element.setAttribute( u
"type"_s, u
"datetime"_s );
232 element.setAttribute( u
"value"_s, value.value< QDateTime >().isValid() ? value.toDateTime().toString( Qt::ISODate ) : QString() );
235 case QMetaType::Type::QDate:
236 element.setAttribute( u
"type"_s, u
"date"_s );
237 element.setAttribute( u
"value"_s, value.value< QDate >().isValid() ? value.toDate().toString( Qt::ISODate ) : QString() );
240 case QMetaType::Type::QTime:
241 element.setAttribute( u
"type"_s, u
"time"_s );
242 element.setAttribute( u
"value"_s, value.value< QTime >().isValid() ? value.toTime().toString( Qt::ISODate ) : QString() );
247 if ( value.userType() == qMetaTypeId<QgsProperty>() )
249 element.setAttribute( u
"type"_s, u
"QgsProperty"_s );
251 element.appendChild( propertyElem );
254 else if ( value.userType() == qMetaTypeId<QgsCoordinateReferenceSystem>() )
256 element.setAttribute( u
"type"_s, u
"QgsCoordinateReferenceSystem"_s );
261 else if ( value.userType() == qMetaTypeId< QgsGeometry>() )
263 element.setAttribute( u
"type"_s, u
"QgsGeometry"_s );
265 element.setAttribute( u
"value"_s, geom.
asWkt() );
268 else if ( value.userType() == qMetaTypeId<QgsProcessingOutputLayerDefinition>() )
271 element.appendChild( valueElement );
272 element.setAttribute( u
"type"_s, u
"QgsProcessingOutputLayerDefinition"_s );
275 else if ( value.userType() == qMetaTypeId<QgsProcessingFeatureSourceDefinition>() )
278 element.appendChild( valueElement );
279 element.setAttribute( u
"type"_s, u
"QgsProcessingFeatureSourceDefinition"_s );
282 else if ( value.userType() == qMetaTypeId<QgsRemappingSinkDefinition>() )
285 element.appendChild( valueElement );
286 element.setAttribute( u
"type"_s, u
"QgsRemappingSinkDefinition"_s );
291 Q_ASSERT_X(
false,
"QgsXmlUtils::writeVariant", u
"unsupported %1variant type %2"_s
292 .arg( value.userType() >= QMetaType::Type::User ?
"user " : QString() ).arg( value.metaType().name() ).toLocal8Bit() );
302 const QString type = element.attribute( u
"type"_s );
304 if ( type ==
"invalid"_L1 )
308 else if ( type ==
"int"_L1 )
310 return element.attribute( u
"value"_s ).toInt();
312 else if ( type ==
"uint"_L1 )
314 return element.attribute( u
"value"_s ).toUInt();
316 else if ( type ==
"qlonglong"_L1 )
318 return element.attribute( u
"value"_s ).toLongLong();
320 else if ( type ==
"qulonglong"_L1 )
322 return element.attribute( u
"value"_s ).toULongLong();
324 else if ( type ==
"double"_L1 )
326 return element.attribute( u
"value"_s ).toDouble();
328 else if ( type ==
"QString"_L1 )
330 const QString res = element.attribute( u
"value"_s );
331 return res.isEmpty() ? QVariant() : res;
333 else if ( type ==
"QChar"_L1 )
335 const QString res = element.attribute( u
"value"_s );
336 return res.isEmpty() ? QVariant() : res.at( 0 );
338 else if ( type ==
"bool"_L1 )
340 return element.attribute( u
"value"_s ) ==
"true"_L1;
342 else if ( type ==
"color"_L1 )
346 else if ( type ==
"datetime"_L1 )
348 return element.attribute( u
"value"_s ).isEmpty() ? QVariant() : QDateTime::fromString( element.attribute( u
"value"_s ), Qt::ISODate );
350 else if ( type ==
"date"_L1 )
352 return element.attribute( u
"value"_s ).isEmpty() ? QVariant() : QDate::fromString( element.attribute( u
"value"_s ), Qt::ISODate );
354 else if ( type ==
"time"_L1 )
356 return element.attribute( u
"value"_s ).isEmpty() ? QVariant() : QTime::fromString( element.attribute( u
"value"_s ), Qt::ISODate );
358 else if ( type ==
"Map"_L1 )
361 const QDomNodeList options = element.childNodes();
363 for (
int i = 0; i < options.count(); ++i )
365 const QDomElement elem = options.at( i ).toElement();
366 if ( elem.tagName() ==
"Option"_L1 )
367 map.insert( elem.attribute( u
"name"_s ),
readVariant( elem ) );
371 else if ( type ==
"List"_L1 )
374 const QDomNodeList values = element.childNodes();
375 for (
int i = 0; i < values.count(); ++i )
377 const QDomElement elem = values.at( i ).toElement();
382 else if ( type ==
"StringList"_L1 )
385 const QDomNodeList values = element.childNodes();
386 for (
int i = 0; i < values.count(); ++i )
388 const QDomElement elem = values.at( i ).toElement();
393 else if ( type ==
"QRect"_L1 )
395 const int x = element.attribute(
"x" ).toInt();
396 const int y = element.attribute(
"y" ).toInt();
397 const int width = element.attribute(
"width" ).toInt();
398 const int height = element.attribute(
"height" ).toInt();
400 return QRect( x, y, width, height );
402 else if ( type ==
"QgsProperty"_L1 )
404 const QDomNodeList values = element.childNodes();
405 if ( values.isEmpty() )
414 else if ( type ==
"QgsCoordinateReferenceSystem"_L1 )
418 return crs.
isValid() ? crs : QVariant();
420 else if ( type ==
"QgsGeometry"_L1 )
423 return !g.
isNull() ? g : QVariant();
425 else if ( type ==
"QgsProcessingOutputLayerDefinition"_L1 )
428 const QDomNodeList values = element.childNodes();
429 if ( values.isEmpty() )
437 else if ( type ==
"QgsProcessingFeatureSourceDefinition"_L1 )
440 const QDomNodeList values = element.childNodes();
441 if ( values.isEmpty() )
449 else if ( type ==
"QgsRemappingSinkDefinition"_L1 )
452 const QDomNodeList values = element.childNodes();
453 if ( values.isEmpty() )
457 return QVariant::fromValue( res );
DistanceUnit
Units of distance.
@ Unknown
Unknown distance unit.
@ Degrees
Degrees, for planar geographic CRS distance measurements.
A 3-dimensional box composed of x, y, z coordinates.
double yMaximum() const
Returns the maximum y value.
void setZMinimum(double z)
Sets the minimum z value.
void setYMaximum(double y)
Sets the maximum y value.
void setZMaximum(double z)
Sets the maximum z value.
double xMinimum() const
Returns the minimum x value.
double zMaximum() const
Returns the maximum z value.
double xMaximum() const
Returns the maximum x value.
void setXMaximum(double x)
Sets the maximum x value.
void setYMinimum(double y)
Sets the minimum y value.
double zMinimum() const
Returns the minimum z value.
double yMinimum() const
Returns the minimum y value.
void setXMinimum(double x)
Sets the minimum x value.
static QColor colorFromString(const QString &string)
Decodes a string into a color value.
static QString colorToString(const QColor &color)
Encodes a color into a string value.
Represents a coordinate reference system (CRS).
bool isValid() const
Returns whether this CRS is correctly initialized and usable.
bool readXml(const QDomNode &node)
Restores state from the given DOM node.
bool writeXml(QDomNode &node, QDomDocument &doc) const
Stores state to the given Dom node in the given document.
A geometry is the spatial representation of a feature.
static Q_INVOKABLE QgsGeometry fromWkt(const QString &wkt)
Creates a new geometry from a WKT string.
Q_INVOKABLE QString asWkt(int precision=17) const
Exports the geometry to WKT.
Encapsulates settings relating to a feature source input to a processing algorithm.
bool loadVariant(const QVariantMap &map)
Loads this source definition from a QVariantMap, wrapped in a QVariant.
QVariant toVariant() const
Saves this source definition to a QVariantMap, wrapped in a QVariant.
Encapsulates settings relating to a feature sink or output raster layer for a processing algorithm.
bool loadVariant(const QVariantMap &map)
Loads this output layer definition from a QVariantMap, wrapped in a QVariant.
QVariant toVariant() const
Saves this output layer definition to a QVariantMap, wrapped in a QVariant.
A store for object properties.
QVariant toVariant() const
Saves this property to a QVariantMap, wrapped in a QVariant.
bool loadVariant(const QVariant &property)
Loads this property from a QVariantMap, wrapped in a QVariant.
A rectangle specified with double values.
void setYMinimum(double y)
Set the minimum y value.
void setXMinimum(double x)
Set the minimum x value.
void setYMaximum(double y)
Set the maximum y value.
void setXMaximum(double x)
Set the maximum x value.
Defines the parameters used to remap features when creating a QgsRemappingProxyFeatureSink.
QVariant toVariant() const
Saves this remapping definition to a QVariantMap, wrapped in a QVariant.
bool loadVariant(const QVariantMap &map)
Loads this remapping definition from a QVariantMap, wrapped in a QVariant.
static Q_INVOKABLE QString encodeUnit(Qgis::DistanceUnit unit)
Encodes a distance unit to a string.
static Q_INVOKABLE Qgis::DistanceUnit decodeDistanceUnit(const QString &string, bool *ok=nullptr)
Decodes a distance unit from a string.
static bool isNull(const QVariant &variant, bool silenceNullWarnings=false)
Returns true if the specified variant should be considered a NULL value.
static QDomElement writeVariant(const QVariant &value, QDomDocument &doc)
Write a QVariant to a QDomElement.
static QgsBox3D readBox3D(const QDomElement &element)
Decodes a DOM element to a 3D box.
static QVariant readVariant(const QDomElement &element)
Read a QVariant from a QDomElement.
static Qgis::DistanceUnit readMapUnits(const QDomElement &element)
Decodes a distance unit from a DOM element.
static QDomElement writeRectangle(const QgsRectangle &rect, QDomDocument &doc, const QString &elementName=u"extent"_s)
Encodes a rectangle to a DOM element.
static QgsRectangle readRectangle(const QDomElement &element)
static QDomElement writeBox3D(const QgsBox3D &box, QDomDocument &doc, const QString &elementName=u"extent3D"_s)
Encodes a 3D box to a DOM element.
static QDomElement writeMapUnits(Qgis::DistanceUnit units, QDomDocument &doc)
Encodes a distance unit to a DOM element.
QString qgsDoubleToString(double a, int precision=17)
Returns a string representation of a double.