98 #include <QPainterPath>
100 #include <QProgressDialog>
104 #include <QStringBuilder>
106 #include <QUndoCommand>
109 #include <QRegularExpression>
113 #ifdef TESTPROVIDERLIB
119 const QString &qmlStyle,
120 const QString &sldStyle,
121 const QString &styleName,
122 const QString &styleDescription,
123 const QString &uiFileContent,
137 QStringList &descriptions,
155 const QString &baseName,
156 const QString &providerKey,
160 , mAuxiliaryLayer( nullptr )
161 , mAuxiliaryLayerKey( QString() )
162 , mReadExtentFromXml( options.readExtentFromXml )
172 mGeometryOptions = std::make_unique<QgsGeometryOptions>();
176 mStoredExpressionManager->setParent(
this );
179 mJoinBuffer->setParent(
this );
184 if ( !vectorLayerPath.isEmpty() && !
mProviderKey.isEmpty() )
187 QgsDataProvider::ReadFlags providerFlags = QgsDataProvider::ReadFlags();
192 setDataSource( vectorLayerPath, baseName, providerKey, providerOptions, providerFlags );
197 if ( !mAttributeAliasMap.contains(
field.
name() ) )
198 mAttributeAliasMap.insert(
field.
name(), QString() );
204 if ( !mTemporalProperties->
isActive() )
223 mSimplifyMethod.
setThreshold( settings.
value( QStringLiteral(
"qgis/simplifyDrawingTol" ), mSimplifyMethod.
threshold() ).toFloat() );
235 delete mDataProvider;
238 delete mExpressionFieldBuffer;
240 delete mDiagramLayerSettings;
241 delete mDiagramRenderer;
246 delete mConditionalStyles;
247 delete mStoredExpressionManager;
249 if ( mFeatureCounter )
250 mFeatureCounter->
cancel();
252 qDeleteAll( mRendererGenerators );
278 QList<QgsVectorLayerJoinInfo> joins =
vectorJoins();
279 const auto constJoins = joins;
299 for (
const QgsAction &action : constActions )
336 auto constraintIt = constraints.constBegin();
337 for ( ; constraintIt != constraints.constEnd(); ++ constraintIt )
377 return mDataProvider && mDataProvider->
isSqlQuery();
424 p.setPen( QColor( 50, 100, 120, 200 ) );
425 p.setBrush( QColor( 200, 200, 210, 120 ) );
426 p.drawEllipse( x - m, y - m, m * 2 + 1, m * 2 + 1 );
430 p.setPen( QColor( 255, 0, 0 ) );
431 p.drawLine( x - m, y + m, x + m, y - m );
432 p.drawLine( x - m, y - m, x + m, y + m );
442 mSelectedFeatureIds.insert( fid );
443 mPreviousSelectedFeatureIds.clear();
450 mSelectedFeatureIds.unite( featureIds );
451 mPreviousSelectedFeatureIds.clear();
458 mSelectedFeatureIds.remove( fid );
459 mPreviousSelectedFeatureIds.clear();
466 mSelectedFeatureIds.subtract( featureIds );
467 mPreviousSelectedFeatureIds.clear();
480 .setFilterRect( rect )
482 .setNoAttributes() );
487 newSelection << feat.
id();
516 newSelection << feat.
id();
538 bool matches = exp.
evaluate( &context ).toBool();
542 newSelection << feat.
id();
546 newSelection << feat.
id();
565 newSelection = mSelectedFeatureIds + ids;
569 newSelection = mSelectedFeatureIds - ids;
573 newSelection = mSelectedFeatureIds.intersect( ids );
577 QgsFeatureIds deselectedFeatures = mSelectedFeatureIds - newSelection;
578 mSelectedFeatureIds = newSelection;
579 mPreviousSelectedFeatureIds.clear();
587 if ( !intersectingIds.isEmpty() )
589 QgsDebugMsgLevel( QStringLiteral(
"Trying to select and deselect the same item at the same time. Unsure what to do. Selecting dubious items." ), 3 );
592 mSelectedFeatureIds -= deselectIds;
593 mSelectedFeatureIds += selectIds;
594 mPreviousSelectedFeatureIds.clear();
602 ids.subtract( mSelectedFeatureIds );
617 .setFilterRect( rect )
619 .setNoAttributes() );
627 if ( mSelectedFeatureIds.contains( fet.
id() ) )
629 deselectIds << fet.
id();
633 selectIds << fet.
id();
642 if ( mSelectedFeatureIds.isEmpty() )
647 mPreviousSelectedFeatureIds = previous;
652 if ( mPreviousSelectedFeatureIds.isEmpty() || !mSelectedFeatureIds.empty() )
660 return mDataProvider;
665 return mDataProvider;
670 return mTemporalProperties;
675 if (
isValid() && mDataProvider && mDataProvider->
encoding() != encoding )
684 delete mDiagramRenderer;
685 mDiagramRenderer = r;
702 if ( !
isValid() || !
isSpatial() || mSelectedFeatureIds.isEmpty() || !mDataProvider )
714 .setFilterFids( mSelectedFeatureIds )
715 .setNoAttributes() );
728 .setNoAttributes() );
732 if ( mSelectedFeatureIds.contains( fet.
id() ) )
743 if ( retval.
width() == 0.0 || retval.
height() == 0.0 )
752 retval.
set( -1.0, -1.0, 1.0, 1.0 );
761 return mLabelsEnabled &&
static_cast< bool >( mLabeling );
766 mLabelsEnabled = enabled;
771 if ( !mDiagramRenderer || !mDiagramLayerSettings )
774 QList<QgsDiagramSettings> settingList = mDiagramRenderer->
diagramSettings();
775 if ( !settingList.isEmpty() )
777 return settingList.at( 0 ).enabled;
784 if ( !mSymbolFeatureCounted )
787 return mSymbolFeatureCountMap.value( legendKey, -1 );
792 if ( !mSymbolFeatureCounted )
795 return mSymbolFeatureIdMap.value( legendKey,
QgsFeatureIds() );
799 if ( ( mSymbolFeatureCounted || mFeatureCounter ) && !( storeSymbolFids && mSymbolFeatureIdMap.isEmpty() ) )
800 return mFeatureCounter;
802 mSymbolFeatureCountMap.clear();
803 mSymbolFeatureIdMap.clear();
808 return mFeatureCounter;
810 if ( !mDataProvider )
813 return mFeatureCounter;
818 return mFeatureCounter;
821 if ( !mFeatureCounter || ( storeSymbolFids && mSymbolFeatureIdMap.isEmpty() ) )
824 connect( mFeatureCounter, &
QgsTask::taskCompleted,
this, &QgsVectorLayer::onFeatureCounterCompleted, Qt::UniqueConnection );
825 connect( mFeatureCounter, &
QgsTask::taskTerminated,
this, &QgsVectorLayer::onFeatureCounterTerminated, Qt::UniqueConnection );
829 return mFeatureCounter;
835 if ( force || !mReadExtentFromXml || ( mReadExtentFromXml && mXmlExtent.
isNull() ) )
836 mValidExtent =
false;
847 if ( !mDefaultValueOnUpdateFields.isEmpty() )
852 int size = mFields.
size();
853 for (
int idx : std::as_const( mDefaultValueOnUpdateFields ) )
855 if ( idx < 0 || idx >= size )
872 if ( !mValidExtent && mLazyExtent && mReadExtentFromXml && !mXmlExtent.
isNull() )
874 updateExtent( mXmlExtent );
879 if ( !mValidExtent && mLazyExtent && mDataProvider && mDataProvider->
isValid() )
882 updateExtent( mDataProvider->
extent() );
887 QgsDebugMsgLevel( QStringLiteral(
"Extent of layer: %1" ).arg( mExtent.toString() ), 3 );
893 if ( !
isValid() || !mDataProvider )
895 QgsDebugMsgLevel( QStringLiteral(
"invoked with invalid layer or null mDataProvider" ), 3 );
913 if ( mEditBuffer && !mDataProvider->
transaction() )
916 for ( QgsFeatureMap::const_iterator it = addedFeatures.constBegin(); it != addedFeatures.constEnd(); ++it )
918 if ( it->hasGeometry() )
929 .setNoAttributes() );
948 updateExtent( rect );
964 if ( !
isValid() || !mDataProvider )
966 QgsDebugMsgLevel( QStringLiteral(
"invoked with invalid layer or null mDataProvider" ), 3 );
967 return customProperty( QStringLiteral(
"storedSubsetString" ) ).toString();
974 if ( !
isValid() || !mDataProvider )
976 QgsDebugMsgLevel( QStringLiteral(
"invoked with invalid layer or null mDataProvider or while editing" ), 3 );
980 else if ( mEditBuffer )
1009 double maximumSimplificationScale = mSimplifyMethod.
maximumScale();
1012 return !( maximumSimplificationScale > 1 && renderContext.
rendererScale() <= maximumSimplificationScale );
1019 return mConditionalStyles;
1024 if ( !
isValid() || !mDataProvider )
1042 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1046 if ( mGeometryOptions->isActive() )
1049 mGeometryOptions->apply( geom );
1053 bool success = mEditBuffer->
addFeature( feature );
1060 success = mJoinBuffer->
addFeature( feature );
1068 if ( !mEditBuffer || !mDataProvider )
1074 if ( currentFeature.
isValid() )
1076 bool hasChanged =
false;
1077 bool hasError =
false;
1089 QgsDebugMsgLevel( QStringLiteral(
"geometry of feature %1 could not be changed." ).arg( updatedFeature.
id() ), 3 );
1096 for (
int attr = 0; attr < fa.count(); ++attr )
1106 QgsDebugMsgLevel( QStringLiteral(
"attribute %1 of feature %2 could not be changed." ).arg( attr ).arg( updatedFeature.
id() ), 3 );
1111 if ( hasChanged && !mDefaultValueOnUpdateFields.isEmpty() && !skipDefaultValues )
1112 updateDefaultValues( updatedFeature.
id(), updatedFeature );
1118 QgsDebugMsgLevel( QStringLiteral(
"feature %1 could not be retrieved" ).arg( updatedFeature.
id() ), 3 );
1126 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1130 bool result = utils.
insertVertex( x, y, atFeatureId, beforeVertex );
1139 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1143 bool result = utils.
insertVertex( point, atFeatureId, beforeVertex );
1152 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1156 bool result = utils.
moveVertex( x, y, atFeatureId, atVertex );
1165 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1169 bool result = utils.
moveVertex( p, atFeatureId, atVertex );
1178 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1203 int count = mSelectedFeatureIds.size();
1216 *deletedCount = deleted;
1219 return deleted == count;
1222 static const QgsPointSequence vectorPointXY2pointSequence(
const QVector<QgsPointXY> &points )
1225 pts.reserve( points.size() );
1226 QVector<QgsPointXY>::const_iterator it = points.constBegin();
1227 while ( it != points.constEnd() )
1236 return addRing( vectorPointXY2pointSequence( ring ), featureId );
1241 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1248 if ( !mSelectedFeatureIds.isEmpty() )
1250 result = utils.
addRing( ring, mSelectedFeatureIds, featureId );
1264 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1285 if ( !mSelectedFeatureIds.isEmpty() )
1287 result = utils.
addRing(
static_cast< QgsCurve *
>( ring->
clone() ), mSelectedFeatureIds, featureId );
1303 pts.reserve( points.size() );
1304 for ( QList<QgsPointXY>::const_iterator it = points.constBegin(); it != points.constEnd() ; ++it )
1311 #if QT_VERSION < QT_VERSION_CHECK(6, 0, 0)
1314 return addPart( vectorPointXY2pointSequence( points ) );
1320 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1325 if ( mSelectedFeatureIds.empty() )
1330 else if ( mSelectedFeatureIds.size() > 1 )
1346 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1351 if ( mSelectedFeatureIds.empty() )
1356 else if ( mSelectedFeatureIds.size() > 1 )
1373 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1386 return splitParts( vectorPointXY2pointSequence( splitLine ), topologicalEditing );
1391 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1395 return utils.
splitParts( splitLine, topologicalEditing );
1400 return splitFeatures( vectorPointXY2pointSequence( splitLine ), topologicalEditing );
1407 bool preserveCircular =
false;
1408 return splitFeatures( &splitLineString, topologyTestPoints, preserveCircular, topologicalEditing );
1413 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1417 return utils.
splitFeatures( curve, topologyTestPoints, preserveCircular, topologicalEditing );
1422 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1436 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1445 if ( !
mValid || !mEditBuffer || !mDataProvider )
1463 if ( !
isValid() || !mDataProvider )
1520 if ( mDataProvider )
1532 if ( !mRenderer->
accept( visitor ) )
1536 if ( !mLabeling->
accept( visitor ) )
1547 QDomNode pkeyNode = layer_node.namedItem( QStringLiteral(
"provider" ) );
1549 if ( pkeyNode.isNull() )
1555 QDomElement pkeyElt = pkeyNode.toElement();
1565 else if (
mDataSource.contains( QLatin1String(
"dbname=" ) ) )
1575 QgsDataProvider::ReadFlags
flags;
1586 const QDomElement elem = layer_node.toElement();
1589 if ( elem.hasAttribute( QStringLiteral(
"wkbType" ) ) )
1590 mWkbType =
qgsEnumKeyToValue( elem.attribute( QStringLiteral(
"wkbType" ) ), mWkbType );
1593 QDomElement pkeyElem = pkeyNode.toElement();
1594 if ( !pkeyElem.isNull() )
1596 QString encodingString = pkeyElem.attribute( QStringLiteral(
"encoding" ) );
1597 if ( mDataProvider && !encodingString.isEmpty() )
1604 mJoinBuffer->
readXml( layer_node );
1609 mSetLegendFromStyle =
false;
1619 QDomNode depsNode = layer_node.namedItem( QStringLiteral(
"dataDependencies" ) );
1620 QDomNodeList depsNodes = depsNode.childNodes();
1621 QSet<QgsMapLayerDependency> sources;
1622 for (
int i = 0; i < depsNodes.count(); i++ )
1624 QString
source = depsNodes.at( i ).toElement().attribute( QStringLiteral(
"id" ) );
1629 if ( !mSetLegendFromStyle )
1635 mReadExtentFromXml =
true;
1637 if ( mReadExtentFromXml )
1639 const QDomNode extentNode = layer_node.namedItem( QStringLiteral(
"extent" ) );
1640 if ( !extentNode.isNull() )
1647 const QDomNode asNode = layer_node.namedItem( QStringLiteral(
"auxiliaryLayer" ) );
1648 const QDomElement asElem = asNode.toElement();
1649 if ( !asElem.isNull() )
1651 mAuxiliaryLayerKey = asElem.attribute( QStringLiteral(
"key" ) );
1655 mServerProperties->readXml( layer_node );
1662 void QgsVectorLayer::setDataSourcePrivate(
const QString &dataSource,
const QString &baseName,
const QString &provider,
1669 setDataProvider( provider, options,
flags );
1679 bool loadDefaultStyleFlag =
false;
1682 loadDefaultStyleFlag =
true;
1688 std::unique_ptr< QgsScopedRuntimeProfile > profile;
1690 profile = std::make_unique< QgsScopedRuntimeProfile >( tr(
"Load layer style" ), QStringLiteral(
"projectload" ) );
1692 bool defaultLoadedFlag =
false;
1701 std::unique_ptr< QgsFeatureRenderer > defaultRenderer( mDataProvider->
createRenderer() );
1702 if ( defaultRenderer )
1704 defaultLoadedFlag =
true;
1711 mSetLegendFromStyle =
false;
1715 if ( !defaultLoadedFlag && loadDefaultStyleFlag )
1721 if ( !defaultLoadedFlag &&
isSpatial() )
1727 if ( !mSetLegendFromStyle )
1732 std::unique_ptr< QgsAbstractVectorLayerLabeling > defaultLabeling( mDataProvider->
createLabeling() );
1733 if ( defaultLabeling )
1740 styleChangedSignalBlocker.release();
1750 std::unique_ptr< QgsFeatureRenderer > defaultRenderer( mDataProvider->
createRenderer() );
1751 if ( defaultRenderer )
1766 delete mDataProvider;
1773 if ( provider.compare( QLatin1String(
"postgres" ) ) == 0 )
1775 const QString checkUnicityKey { QStringLiteral(
"checkPrimaryKeyUnicity" ) };
1777 if ( ! uri.hasParam( checkUnicityKey ) )
1779 uri.setParam( checkUnicityKey, mReadExtentFromXml ?
"0" :
"1" );
1784 std::unique_ptr< QgsScopedRuntimeProfile > profile;
1786 profile = std::make_unique< QgsScopedRuntimeProfile >( tr(
"Create %1 provider" ).arg( provider ), QStringLiteral(
"projectload" ) );
1789 if ( !mDataProvider )
1796 mDataProvider->setParent(
this );
1799 QgsDebugMsgLevel( QStringLiteral(
"Instantiated the data provider plugin" ), 2 );
1809 profile->switchTask( tr(
"Read layer metadata" ) );
1816 newMetadata.
combine( &mMetadata );
1819 QgsDebugMsgLevel( QStringLiteral(
"Set Data provider QgsLayerMetadata identifier[%1]" ).arg(
metadata().identifier() ), 4 );
1826 mWkbType = mDataProvider->
wkbType();
1845 profile->switchTask( tr(
"Read layer fields" ) );
1856 const QRegularExpression reg( R
"lit("[^"]+"\."([^"] + )"( \([^)]+\))?)lit" );
1857 const QRegularExpressionMatch match = reg.match(
name() );
1858 if ( match.hasMatch() )
1860 QStringList stuff = match.capturedTexts();
1861 QString lName = stuff[1];
1865 QMap<QString, QgsMapLayer *>::const_iterator it;
1866 for ( it = layers.constBegin(); it != layers.constEnd() && ( *it )->name() != lName; ++it )
1869 if ( it != layers.constEnd() && stuff.size() > 2 )
1871 lName +=
'.' + stuff[2].mid( 2, stuff[2].length() - 3 );
1874 if ( !lName.isEmpty() )
1884 else if ( provider == QLatin1String(
"ogr" ) )
1888 if (
mDataSource.right( 10 ) == QLatin1String(
"|layerid=0" ) )
1891 else if ( provider == QLatin1String(
"memory" ) )
1908 QDomDocument &document,
1913 QDomElement mapLayerNode = layer_node.toElement();
1915 if ( mapLayerNode.isNull() || (
"maplayer" != mapLayerNode.nodeName() ) )
1928 if ( mDataProvider )
1930 QDomElement provider = document.createElement( QStringLiteral(
"provider" ) );
1931 provider.setAttribute( QStringLiteral(
"encoding" ), mDataProvider->
encoding() );
1932 QDomText providerText = document.createTextNode(
providerType() );
1933 provider.appendChild( providerText );
1934 layer_node.appendChild( provider );
1938 mJoinBuffer->
writeXml( layer_node, document );
1941 QDomElement dependenciesElement = document.createElement( QStringLiteral(
"layerDependencies" ) );
1947 QDomElement depElem = document.createElement( QStringLiteral(
"layer" ) );
1948 depElem.setAttribute( QStringLiteral(
"id" ), dep.layerId() );
1949 dependenciesElement.appendChild( depElem );
1951 layer_node.appendChild( dependenciesElement );
1954 QDomElement dataDependenciesElement = document.createElement( QStringLiteral(
"dataDependencies" ) );
1959 QDomElement depElem = document.createElement( QStringLiteral(
"layer" ) );
1960 depElem.setAttribute( QStringLiteral(
"id" ), dep.layerId() );
1961 dataDependenciesElement.appendChild( depElem );
1963 layer_node.appendChild( dataDependenciesElement );
1966 mExpressionFieldBuffer->
writeXml( layer_node, document );
1971 QDomElement asElem = document.createElement( QStringLiteral(
"auxiliaryLayer" ) );
1972 if ( mAuxiliaryLayer )
1974 const QString pkField = mAuxiliaryLayer->joinInfo().targetFieldName();
1975 asElem.setAttribute( QStringLiteral(
"key" ), pkField );
1977 layer_node.appendChild( asElem );
1980 mServerProperties->writeXml( layer_node, document );
1984 return writeSymbology( layer_node, document, errorMsg, context );
2001 QStringList theURIParts = src.split(
'|' );
2003 src = theURIParts.join( QLatin1Char(
'|' ) );
2007 QStringList theURIParts = src.split(
'?' );
2009 src = theURIParts.join( QLatin1Char(
'?' ) );
2011 else if (
providerType() == QLatin1String(
"delimitedtext" ) )
2013 QUrl urlSource = QUrl::fromEncoded( src.toLatin1() );
2015 urlDest.setQuery( urlSource.query() );
2016 src = QString::fromLatin1( urlDest.toEncoded() );
2018 else if (
providerType() == QLatin1String(
"memory" ) )
2023 else if (
providerType() == QLatin1String(
"virtual" ) )
2025 QUrl urlSource = QUrl::fromEncoded( src.toLatin1() );
2026 QStringList theURIParts;
2028 QUrlQuery query = QUrlQuery( urlSource.query() );
2029 QList<QPair<QString, QString> > queryItems = query.queryItems();
2031 for (
int i = 0; i < queryItems.size(); i++ )
2033 QString key = queryItems.at( i ).first;
2034 QString value = queryItems.at( i ).second;
2035 if ( key == QLatin1String(
"layer" ) )
2038 theURIParts = value.split(
':' );
2039 theURIParts[1] = QUrl::fromPercentEncoding( theURIParts[1].toUtf8() );
2041 if ( theURIParts[0] == QLatin1String(
"delimitedtext" ) )
2043 QUrl urlSource = QUrl( theURIParts[1] );
2045 urlDest.setQuery( urlSource.query() );
2046 theURIParts[1] = QUrl::toPercentEncoding( urlDest.toString(), QByteArray(
"" ), QByteArray(
":" ) );
2051 theURIParts[1] = QUrl::toPercentEncoding( theURIParts[1] );
2054 queryItems[i].second = theURIParts.join( QLatin1Char(
':' ) ) ;
2058 query.setQueryItems( queryItems );
2060 QUrl urlDest = QUrl( urlSource );
2061 urlDest.setQuery( query.query() );
2062 src = QString::fromLatin1( urlDest.toEncoded() );
2076 if ( provider == QLatin1String(
"spatialite" ) )
2082 else if ( provider == QLatin1String(
"ogr" ) )
2084 QStringList theURIParts = src.split(
'|' );
2086 src = theURIParts.join( QLatin1Char(
'|' ) );
2088 else if ( provider == QLatin1String(
"gpx" ) )
2090 QStringList theURIParts = src.split(
'?' );
2092 src = theURIParts.join( QLatin1Char(
'?' ) );
2094 else if ( provider == QLatin1String(
"delimitedtext" ) )
2096 QUrl urlSource = QUrl::fromEncoded( src.toLatin1() );
2098 if ( !src.startsWith( QLatin1String(
"file:" ) ) )
2100 QUrl file = QUrl::fromLocalFile( src.left( src.indexOf(
'?' ) ) );
2101 urlSource.setScheme( QStringLiteral(
"file" ) );
2102 urlSource.setPath( file.path() );
2105 QUrl urlDest = QUrl::fromLocalFile( context.
pathResolver().
readPath( urlSource.toLocalFile() ) );
2106 urlDest.setQuery( urlSource.query() );
2107 src = QString::fromLatin1( urlDest.toEncoded() );
2109 else if ( provider == QLatin1String(
"virtual" ) )
2111 QUrl urlSource = QUrl::fromEncoded( src.toLatin1() );
2112 QStringList theURIParts;
2114 QUrlQuery query = QUrlQuery( urlSource.query() );
2115 QList<QPair<QString, QString> > queryItems = query.queryItems();
2117 for (
int i = 0; i < queryItems.size(); i++ )
2119 QString key = queryItems.at( i ).first;
2120 QString value = queryItems.at( i ).second;
2121 if ( key == QLatin1String(
"layer" ) )
2124 theURIParts = value.split(
':' );
2125 theURIParts[1] = QUrl::fromPercentEncoding( theURIParts[1].toUtf8() );
2127 if ( theURIParts[0] == QLatin1String(
"delimitedtext" ) )
2129 QUrl urlSource = QUrl( theURIParts[1] );
2131 if ( !theURIParts[1].startsWith( QLatin1String(
"file:" ) ) )
2133 QUrl file = QUrl::fromLocalFile( theURIParts[1].left( theURIParts[1].indexOf(
'?' ) ) );
2134 urlSource.setScheme( QStringLiteral(
"file" ) );
2135 urlSource.setPath( file.path() );
2138 QUrl urlDest = QUrl::fromLocalFile( context.
pathResolver().
readPath( urlSource.toLocalFile() ) );
2139 urlDest.setQuery( urlSource.query() );
2141 theURIParts[1] = urlDest.toString();
2148 theURIParts[1] = QUrl::toPercentEncoding( theURIParts[1] );
2149 queryItems[i].second = theURIParts.join( QLatin1Char(
':' ) ) ;
2153 query.setQueryItems( queryItems );
2155 QUrl urlDest = QUrl( urlSource );
2156 urlDest.setQuery( query.query() );
2157 src = QString::fromLatin1( urlDest.toEncoded() );
2179 if ( categories.testFlag(
Fields ) )
2181 if ( !mExpressionFieldBuffer )
2183 mExpressionFieldBuffer->
readXml( layerNode );
2195 QDomNodeList referencedLayersNodeList = layerNode.toElement().elementsByTagName( QStringLiteral(
"referencedLayers" ) );
2196 if ( referencedLayersNodeList.size() > 0 )
2198 const QDomNodeList relationNodes { referencedLayersNodeList.at( 0 ).childNodes() };
2199 for (
int i = 0; i < relationNodes.length(); ++i )
2201 const QDomElement relationElement = relationNodes.at( i ).toElement();
2208 QDomNodeList referencingLayersNodeList = layerNode.toElement().elementsByTagName( QStringLiteral(
"referencingLayers" ) );
2209 if ( referencingLayersNodeList.size() > 0 )
2211 const QDomNodeList relationNodes { referencingLayersNodeList.at( 0 ).childNodes() };
2212 for (
int i = 0; i < relationNodes.length(); ++i )
2214 const QDomElement relationElement = relationNodes.at( i ).toElement();
2220 QDomElement layerElement = layerNode.toElement();
2224 readStyle( layerNode, errorMessage, context, categories );
2226 if ( categories.testFlag(
MapTips ) )
2227 mMapTipTemplate = layerNode.namedItem( QStringLiteral(
"mapTip" ) ).toElement().text();
2230 mDisplayExpression = layerNode.namedItem( QStringLiteral(
"previewExpression" ) ).toElement().text();
2233 QString
displayField = layerNode.namedItem( QStringLiteral(
"displayfield" ) ).toElement().text();
2237 if ( mMapTipTemplate.isEmpty() && categories.testFlag(
MapTips ) )
2247 if ( categories.testFlag(
Actions ) )
2248 mActions->
readXml( layerNode );
2250 if ( categories.testFlag(
Fields ) )
2255 QDomNode aliasesNode = layerNode.namedItem( QStringLiteral(
"aliases" ) );
2256 if ( !aliasesNode.isNull() )
2258 QDomElement aliasElem;
2260 QDomNodeList aliasNodeList = aliasesNode.toElement().elementsByTagName( QStringLiteral(
"alias" ) );
2261 for (
int i = 0; i < aliasNodeList.size(); ++i )
2263 aliasElem = aliasNodeList.at( i ).toElement();
2266 if ( aliasElem.hasAttribute( QStringLiteral(
"field" ) ) )
2268 field = aliasElem.attribute( QStringLiteral(
"field" ) );
2272 int index = aliasElem.attribute( QStringLiteral(
"index" ) ).toInt();
2274 if ( index >= 0 && index <
fields().count() )
2280 if ( !aliasElem.attribute( QStringLiteral(
"name" ) ).isEmpty() )
2283 alias = context.
projectTranslator()->
translate( QStringLiteral(
"project:layers:%1:fieldaliases" ).arg( layerNode.namedItem( QStringLiteral(
"id" ) ).toElement().text() ), aliasElem.attribute( QStringLiteral(
"name" ) ) );
2284 QgsDebugMsgLevel(
"context" + QStringLiteral(
"project:layers:%1:fieldaliases" ).arg( layerNode.namedItem( QStringLiteral(
"id" ) ).toElement().text() ) +
" source " + aliasElem.attribute( QStringLiteral(
"name" ) ), 3 );
2289 alias = context.
projectTranslator()->
translate( QStringLiteral(
"project:layers:%1:fieldaliases" ).arg( layerNode.namedItem( QStringLiteral(
"id" ) ).toElement().text() ),
field );
2290 QgsDebugMsgLevel(
"context" + QStringLiteral(
"project:layers:%1:fieldaliases" ).arg( layerNode.namedItem( QStringLiteral(
"id" ) ).toElement().text() ) +
" source " +
field, 3 );
2292 if ( alias == aliasElem.attribute( QStringLiteral(
"field" ) ) )
2296 QgsDebugMsgLevel(
"field " +
field +
" origalias " + aliasElem.attribute( QStringLiteral(
"name" ) ) +
" trans " + alias, 3 );
2297 mAttributeAliasMap.insert(
field, alias );
2302 mDefaultExpressionMap.clear();
2303 QDomNode defaultsNode = layerNode.namedItem( QStringLiteral(
"defaults" ) );
2304 if ( !defaultsNode.isNull() )
2306 QDomNodeList defaultNodeList = defaultsNode.toElement().elementsByTagName( QStringLiteral(
"default" ) );
2307 for (
int i = 0; i < defaultNodeList.size(); ++i )
2309 QDomElement defaultElem = defaultNodeList.at( i ).toElement();
2311 QString
field = defaultElem.attribute( QStringLiteral(
"field" ), QString() );
2312 QString expression = defaultElem.attribute( QStringLiteral(
"expression" ), QString() );
2313 bool applyOnUpdate = defaultElem.attribute( QStringLiteral(
"applyOnUpdate" ), QStringLiteral(
"0" ) ) == QLatin1String(
"1" );
2314 if (
field.isEmpty() || expression.isEmpty() )
2322 mFieldConstraints.clear();
2323 mFieldConstraintStrength.clear();
2324 QDomNode constraintsNode = layerNode.namedItem( QStringLiteral(
"constraints" ) );
2325 if ( !constraintsNode.isNull() )
2327 QDomNodeList constraintNodeList = constraintsNode.toElement().elementsByTagName( QStringLiteral(
"constraint" ) );
2328 for (
int i = 0; i < constraintNodeList.size(); ++i )
2330 QDomElement constraintElem = constraintNodeList.at( i ).toElement();
2332 QString
field = constraintElem.attribute( QStringLiteral(
"field" ), QString() );
2333 int constraints = constraintElem.attribute( QStringLiteral(
"constraints" ), QStringLiteral(
"0" ) ).toInt();
2334 if (
field.isEmpty() || constraints == 0 )
2337 mFieldConstraints.insert(
field,
static_cast< QgsFieldConstraints::Constraints
>( constraints ) );
2339 int uniqueStrength = constraintElem.attribute( QStringLiteral(
"unique_strength" ), QStringLiteral(
"1" ) ).toInt();
2340 int notNullStrength = constraintElem.attribute( QStringLiteral(
"notnull_strength" ), QStringLiteral(
"1" ) ).toInt();
2341 int expStrength = constraintElem.attribute( QStringLiteral(
"exp_strength" ), QStringLiteral(
"1" ) ).toInt();
2348 mFieldConstraintExpressions.clear();
2349 QDomNode constraintExpressionsNode = layerNode.namedItem( QStringLiteral(
"constraintExpressions" ) );
2350 if ( !constraintExpressionsNode.isNull() )
2352 QDomNodeList constraintNodeList = constraintExpressionsNode.toElement().elementsByTagName( QStringLiteral(
"constraint" ) );
2353 for (
int i = 0; i < constraintNodeList.size(); ++i )
2355 QDomElement constraintElem = constraintNodeList.at( i ).toElement();
2357 QString
field = constraintElem.attribute( QStringLiteral(
"field" ), QString() );
2358 QString exp = constraintElem.attribute( QStringLiteral(
"exp" ), QString() );
2359 QString desc = constraintElem.attribute( QStringLiteral(
"desc" ), QString() );
2360 if (
field.isEmpty() || exp.isEmpty() )
2363 mFieldConstraintExpressions.insert(
field, qMakePair( exp, desc ) );
2371 if ( categories.testFlag(
Fields ) || categories.testFlag(
Forms ) )
2375 QDomElement widgetsElem = layerNode.namedItem( QStringLiteral(
"fieldConfiguration" ) ).toElement();
2376 QDomNodeList fieldConfigurationElementList = widgetsElem.elementsByTagName( QStringLiteral(
"field" ) );
2377 for (
int i = 0; i < fieldConfigurationElementList.size(); ++i )
2379 const QDomElement fieldConfigElement = fieldConfigurationElementList.at( i ).toElement();
2380 const QDomElement fieldWidgetElement = fieldConfigElement.elementsByTagName( QStringLiteral(
"editWidget" ) ).at( 0 ).toElement();
2382 QString fieldName = fieldConfigElement.attribute( QStringLiteral(
"name" ) );
2384 if ( categories.testFlag(
Fields ) )
2388 if ( categories.testFlag(
Forms ) )
2390 const QString widgetType = fieldWidgetElement.attribute( QStringLiteral(
"type" ) );
2391 const QDomElement cfgElem = fieldConfigElement.elementsByTagName( QStringLiteral(
"config" ) ).at( 0 ).toElement();
2392 const QDomElement optionsElem = cfgElem.childNodes().at( 0 ).toElement();
2394 if ( widgetType == QLatin1String(
"ValueRelation" ) )
2396 optionsMap[ QStringLiteral(
"Value" ) ] = context.
projectTranslator()->
translate( QStringLiteral(
"project:layers:%1:fields:%2:valuerelationvalue" ).arg( layerNode.namedItem( QStringLiteral(
"id" ) ).toElement().text(), fieldName ), optionsMap[ QStringLiteral(
"Value" ) ].toString() );
2399 mFieldWidgetSetups[fieldName] = setup;
2406 if ( categories.testFlag(
Fields ) )
2408 const QList<QPair<QString, QgsField::ConfigurationFlag>> legacyConfig
2413 for (
const auto &config : legacyConfig )
2415 QDomNode excludeNode = layerNode.namedItem( config.first );
2416 if ( !excludeNode.isNull() )
2418 QDomNodeList attributeNodeList = excludeNode.toElement().elementsByTagName( QStringLiteral(
"attribute" ) );
2419 for (
int i = 0; i < attributeNodeList.size(); ++i )
2421 QString fieldName = attributeNodeList.at( i ).toElement().text();
2422 if ( !mFieldConfigurationFlags.contains( fieldName ) )
2423 mFieldConfigurationFlags[fieldName] = config.second;
2425 mFieldConfigurationFlags[fieldName].setFlag( config.second,
true );
2432 mGeometryOptions->readXml( layerNode.namedItem( QStringLiteral(
"geometryOptions" ) ) );
2434 if ( categories.testFlag(
Forms ) )
2435 mEditFormConfig.
readXml( layerNode, context );
2439 mAttributeTableConfig.
readXml( layerNode );
2440 mConditionalStyles->
readXml( layerNode, context );
2441 mStoredExpressionManager->
readXml( layerNode );
2447 QDomElement mapLayerNode = layerNode.toElement();
2449 && mapLayerNode.attribute( QStringLiteral(
"readOnly" ), QStringLiteral(
"0" ) ).toInt() == 1 )
2454 if ( categories.testFlag(
Legend ) )
2458 const QDomElement legendElem = layerNode.firstChildElement( QStringLiteral(
"legend" ) );
2459 if ( !legendElem.isNull() )
2464 mSetLegendFromStyle =
true;
2492 if ( !rendererElement.isNull() )
2512 if ( categories.testFlag(
Labeling ) )
2516 QDomElement labelingElement = node.firstChildElement( QStringLiteral(
"labeling" ) );
2518 if ( labelingElement.isNull() ||
2519 ( labelingElement.attribute( QStringLiteral(
"type" ) ) == QLatin1String(
"simple" ) && labelingElement.firstChildElement( QStringLiteral(
"settings" ) ).isNull() ) )
2527 labeling = readLabelingFromCustomProperties();
2535 if ( node.toElement().hasAttribute( QStringLiteral(
"labelsEnabled" ) ) )
2536 mLabelsEnabled = node.toElement().attribute( QStringLiteral(
"labelsEnabled" ) ).toInt();
2538 mLabelsEnabled =
true;
2544 QDomNode blendModeNode = node.namedItem( QStringLiteral(
"blendMode" ) );
2545 if ( !blendModeNode.isNull() )
2547 QDomElement e = blendModeNode.toElement();
2552 QDomNode featureBlendModeNode = node.namedItem( QStringLiteral(
"featureBlendMode" ) );
2553 if ( !featureBlendModeNode.isNull() )
2555 QDomElement e = featureBlendModeNode.toElement();
2563 QDomNode layerTransparencyNode = node.namedItem( QStringLiteral(
"layerTransparency" ) );
2564 if ( !layerTransparencyNode.isNull() )
2566 QDomElement e = layerTransparencyNode.toElement();
2567 setOpacity( 1.0 - e.text().toInt() / 100.0 );
2569 QDomNode layerOpacityNode = node.namedItem( QStringLiteral(
"layerOpacity" ) );
2570 if ( !layerOpacityNode.isNull() )
2572 QDomElement e = layerOpacityNode.toElement();
2576 const bool hasScaleBasedVisibiliy { node.attributes().namedItem( QStringLiteral(
"hasScaleBasedVisibilityFlag" ) ).nodeValue() ==
'1' };
2579 const double maxScale { node.attributes().namedItem( QStringLiteral(
"maxScale" ) ).nodeValue().toDouble( &ok ) };
2584 const double minScale { node.attributes().namedItem( QStringLiteral(
"minScale" ) ).nodeValue().toDouble( &ok ) };
2590 QDomElement e = node.toElement();
2593 mSimplifyMethod.
setSimplifyHints(
static_cast< QgsVectorSimplifyMethod::SimplifyHints
>( e.attribute( QStringLiteral(
"simplifyDrawingHints" ), QStringLiteral(
"1" ) ).toInt() ) );
2595 mSimplifyMethod.
setThreshold( e.attribute( QStringLiteral(
"simplifyDrawingTol" ), QStringLiteral(
"1" ) ).toFloat() );
2596 mSimplifyMethod.
setForceLocalOptimization( e.attribute( QStringLiteral(
"simplifyLocal" ), QStringLiteral(
"1" ) ).toInt() );
2597 mSimplifyMethod.
setMaximumScale( e.attribute( QStringLiteral(
"simplifyMaxScale" ), QStringLiteral(
"1" ) ).toFloat() );
2600 mRenderer->
setReferenceScale( e.attribute( QStringLiteral(
"symbologyReferenceScale" ), QStringLiteral(
"-1" ) ).toDouble() );
2604 if ( categories.testFlag(
Diagrams ) )
2608 delete mDiagramRenderer;
2609 mDiagramRenderer =
nullptr;
2610 QDomElement singleCatDiagramElem = node.firstChildElement( QStringLiteral(
"SingleCategoryDiagramRenderer" ) );
2611 if ( !singleCatDiagramElem.isNull() )
2614 mDiagramRenderer->
readXml( singleCatDiagramElem, context );
2616 QDomElement linearDiagramElem = node.firstChildElement( QStringLiteral(
"LinearlyInterpolatedDiagramRenderer" ) );
2617 if ( !linearDiagramElem.isNull() )
2619 if ( linearDiagramElem.hasAttribute( QStringLiteral(
"classificationAttribute" ) ) )
2622 int idx = linearDiagramElem.attribute( QStringLiteral(
"classificationAttribute" ) ).toInt();
2623 if ( idx >= 0 && idx < mFields.
count() )
2624 linearDiagramElem.setAttribute( QStringLiteral(
"classificationField" ), mFields.
at( idx ).
name() );
2628 mDiagramRenderer->
readXml( linearDiagramElem, context );
2631 if ( mDiagramRenderer )
2633 QDomElement diagramSettingsElem = node.firstChildElement( QStringLiteral(
"DiagramLayerSettings" ) );
2634 if ( !diagramSettingsElem.isNull() )
2636 bool oldXPos = diagramSettingsElem.hasAttribute( QStringLiteral(
"xPosColumn" ) );
2637 bool oldYPos = diagramSettingsElem.hasAttribute( QStringLiteral(
"yPosColumn" ) );
2638 bool oldShow = diagramSettingsElem.hasAttribute( QStringLiteral(
"showColumn" ) );
2639 if ( oldXPos || oldYPos || oldShow )
2645 int xPosColumn = diagramSettingsElem.attribute( QStringLiteral(
"xPosColumn" ) ).toInt();
2646 if ( xPosColumn >= 0 && xPosColumn < mFields.
count() )
2651 int yPosColumn = diagramSettingsElem.attribute( QStringLiteral(
"yPosColumn" ) ).toInt();
2652 if ( yPosColumn >= 0 && yPosColumn < mFields.
count() )
2657 int showColumn = diagramSettingsElem.attribute( QStringLiteral(
"showColumn" ) ).toInt();
2658 if ( showColumn >= 0 && showColumn < mFields.
count() )
2661 QDomElement propertiesElem = diagramSettingsElem.ownerDocument().createElement( QStringLiteral(
"properties" ) );
2668 ddp.
writeXml( propertiesElem, defs );
2669 diagramSettingsElem.appendChild( propertiesElem );
2672 delete mDiagramLayerSettings;
2674 mDiagramLayerSettings->
readXml( diagramSettingsElem );
2680 styleChangedSignalBlocker.release();
2690 QDomElement layerElement = node.toElement();
2693 ( void )
writeStyle( node, doc, errorMessage, context, categories );
2696 mGeometryOptions->writeXml( node );
2701 if ( !legendElement.isNull() )
2702 node.appendChild( legendElement );
2709 QDomElement referencedLayersElement = doc.createElement( QStringLiteral(
"referencedLayers" ) );
2710 node.appendChild( referencedLayersElement );
2713 for (
const auto &rel : constReferencingRelations )
2722 QDomElement referencingLayersElement = doc.createElement( QStringLiteral(
"referencingLayers" ) );
2723 node.appendChild( referencedLayersElement );
2726 for (
const auto &rel : constReferencedRelations )
2737 if ( categories.testFlag(
Fields ) || categories.testFlag(
Forms ) )
2739 QDomElement fieldConfigurationElement;
2741 fieldConfigurationElement = doc.createElement( QStringLiteral(
"fieldConfiguration" ) );
2742 node.appendChild( fieldConfigurationElement );
2746 QDomElement fieldElement = doc.createElement( QStringLiteral(
"field" ) );
2747 fieldElement.setAttribute( QStringLiteral(
"name" ),
field.
name() );
2748 fieldConfigurationElement.appendChild( fieldElement );
2750 if ( categories.testFlag(
Fields ) )
2755 if ( categories.testFlag(
Forms ) )
2760 QDomElement editWidgetElement = doc.createElement( QStringLiteral(
"editWidget" ) );
2761 fieldElement.appendChild( editWidgetElement );
2763 QDomElement editWidgetConfigElement = doc.createElement( QStringLiteral(
"config" ) );
2766 editWidgetElement.appendChild( editWidgetConfigElement );
2772 if ( categories.testFlag(
Fields ) )
2775 QDomElement aliasElem = doc.createElement( QStringLiteral(
"aliases" ) );
2778 QDomElement aliasEntryElem = doc.createElement( QStringLiteral(
"alias" ) );
2779 aliasEntryElem.setAttribute( QStringLiteral(
"field" ),
field.
name() );
2781 aliasEntryElem.setAttribute( QStringLiteral(
"name" ),
field.
alias() );
2782 aliasElem.appendChild( aliasEntryElem );
2784 node.appendChild( aliasElem );
2787 QDomElement defaultsElem = doc.createElement( QStringLiteral(
"defaults" ) );
2790 QDomElement defaultElem = doc.createElement( QStringLiteral(
"default" ) );
2791 defaultElem.setAttribute( QStringLiteral(
"field" ),
field.
name() );
2794 defaultsElem.appendChild( defaultElem );
2796 node.appendChild( defaultsElem );
2799 QDomElement constraintsElem = doc.createElement( QStringLiteral(
"constraints" ) );
2802 QDomElement constraintElem = doc.createElement( QStringLiteral(
"constraint" ) );
2803 constraintElem.setAttribute( QStringLiteral(
"field" ),
field.
name() );
2808 constraintsElem.appendChild( constraintElem );
2810 node.appendChild( constraintsElem );
2813 QDomElement constraintExpressionsElem = doc.createElement( QStringLiteral(
"constraintExpressions" ) );
2816 QDomElement constraintExpressionElem = doc.createElement( QStringLiteral(
"constraint" ) );
2817 constraintExpressionElem.setAttribute( QStringLiteral(
"field" ),
field.
name() );
2820 constraintExpressionsElem.appendChild( constraintExpressionElem );
2822 node.appendChild( constraintExpressionsElem );
2825 if ( !mExpressionFieldBuffer )
2833 mExpressionFieldBuffer->
writeXml( node, doc );
2838 if ( categories.testFlag(
Actions ) )
2843 mAttributeTableConfig.
writeXml( node );
2844 mConditionalStyles->
writeXml( node, doc, context );
2845 mStoredExpressionManager->
writeXml( node );
2848 if ( categories.testFlag(
Forms ) )
2849 mEditFormConfig.
writeXml( node, context );
2853 node.toElement().setAttribute( QStringLiteral(
"readOnly" ), mReadOnly );
2858 QDomElement prevExpElem = doc.createElement( QStringLiteral(
"previewExpression" ) );
2859 QDomText prevExpText = doc.createTextNode( mDisplayExpression );
2860 prevExpElem.appendChild( prevExpText );
2861 node.appendChild( prevExpElem );
2865 if ( categories.testFlag(
MapTips ) )
2867 QDomElement mapTipElem = doc.createElement( QStringLiteral(
"mapTip" ) );
2868 QDomText mapTipText = doc.createTextNode( mMapTipTemplate );
2869 mapTipElem.appendChild( mapTipText );
2870 node.toElement().appendChild( mapTipElem );
2879 QDomElement mapLayerNode = node.toElement();
2892 QDomElement rendererElement = mRenderer->
save( doc, context );
2893 node.appendChild( rendererElement );
2897 if ( categories.testFlag(
Labeling ) )
2901 QDomElement labelingElement = mLabeling->
save( doc, context );
2902 node.appendChild( labelingElement );
2904 mapLayerNode.setAttribute( QStringLiteral(
"labelsEnabled" ), mLabelsEnabled ? QStringLiteral(
"1" ) : QStringLiteral(
"0" ) );
2910 mapLayerNode.setAttribute( QStringLiteral(
"simplifyDrawingHints" ), QString::number( mSimplifyMethod.
simplifyHints() ) );
2911 mapLayerNode.setAttribute( QStringLiteral(
"simplifyAlgorithm" ), QString::number( mSimplifyMethod.
simplifyAlgorithm() ) );
2912 mapLayerNode.setAttribute( QStringLiteral(
"simplifyDrawingTol" ), QString::number( mSimplifyMethod.
threshold() ) );
2913 mapLayerNode.setAttribute( QStringLiteral(
"simplifyLocal" ), mSimplifyMethod.
forceLocalOptimization() ? 1 : 0 );
2914 mapLayerNode.setAttribute( QStringLiteral(
"simplifyMaxScale" ), QString::number( mSimplifyMethod.
maximumScale() ) );
2926 QDomElement blendModeElem = doc.createElement( QStringLiteral(
"blendMode" ) );
2928 blendModeElem.appendChild( blendModeText );
2929 node.appendChild( blendModeElem );
2932 QDomElement featureBlendModeElem = doc.createElement( QStringLiteral(
"featureBlendMode" ) );
2934 featureBlendModeElem.appendChild( featureBlendModeText );
2935 node.appendChild( featureBlendModeElem );
2941 QDomElement layerOpacityElem = doc.createElement( QStringLiteral(
"layerOpacity" ) );
2942 QDomText layerOpacityText = doc.createTextNode( QString::number(
opacity() ) );
2943 layerOpacityElem.appendChild( layerOpacityText );
2944 node.appendChild( layerOpacityElem );
2945 mapLayerNode.setAttribute( QStringLiteral(
"hasScaleBasedVisibilityFlag" ),
hasScaleBasedVisibility() ? 1 : 0 );
2946 mapLayerNode.setAttribute( QStringLiteral(
"maxScale" ),
maximumScale() );
2947 mapLayerNode.setAttribute( QStringLiteral(
"minScale" ),
minimumScale() );
2949 mapLayerNode.setAttribute( QStringLiteral(
"symbologyReferenceScale" ), mRenderer ? mRenderer->
referenceScale() : -1 );
2952 if ( categories.testFlag(
Diagrams ) && mDiagramRenderer )
2954 mDiagramRenderer->
writeXml( mapLayerNode, doc, context );
2955 if ( mDiagramLayerSettings )
2956 mDiagramLayerSettings->
writeXml( mapLayerNode, doc );
2965 QDomElement nameElem = node.firstChildElement( QStringLiteral(
"Name" ) );
2966 if ( nameElem.isNull() )
2968 errorMessage = QStringLiteral(
"Warning: Name element not found within NamedLayer while it's required." );
2984 readSldLabeling( node );
2986 styleChangedSignalBlocker.release();
2994 Q_UNUSED( errorMessage )
2996 QVariantMap localProps = QVariantMap( props );
3005 QDomElement nameNode = doc.createElement( QStringLiteral(
"se:Name" ) );
3006 nameNode.appendChild( doc.createTextNode(
name() ) );
3007 node.appendChild( nameNode );
3009 QDomElement userStyleElem = doc.createElement( QStringLiteral(
"UserStyle" ) );
3010 node.appendChild( userStyleElem );
3012 QDomElement nameElem = doc.createElement( QStringLiteral(
"se:Name" ) );
3013 nameElem.appendChild( doc.createTextNode(
name() ) );
3015 userStyleElem.appendChild( nameElem );
3017 QDomElement featureTypeStyleElem = doc.createElement( QStringLiteral(
"se:FeatureTypeStyle" ) );
3018 userStyleElem.appendChild( featureTypeStyleElem );
3020 mRenderer->
toSld( doc, featureTypeStyleElem, localProps );
3023 mLabeling->
toSld( featureTypeStyleElem, localProps );
3032 if ( !mEditBuffer || !mDataProvider )
3037 if ( mGeometryOptions->isActive() )
3038 mGeometryOptions->apply( geom );
3047 if ( !skipDefaultValue && !mDefaultValueOnUpdateFields.isEmpty() )
3048 updateDefaultValues( fid );
3056 bool result =
false;
3070 if ( mEditBuffer && mDataProvider )
3079 if ( result && !skipDefaultValues && !mDefaultValueOnUpdateFields.isEmpty() )
3080 updateDefaultValues( fid );
3095 for (
auto it = newValues.constBegin(); it != newValues.constEnd(); ++it )
3097 const int field = it.key();
3098 const QVariant newValue = it.value();
3101 if ( oldValues.contains(
field ) )
3102 oldValue = oldValues[
field];
3107 newValuesJoin[
field] = newValue;
3108 oldValuesJoin[
field] = oldValue;
3115 newValuesNotJoin[
field] = newValue;
3116 oldValuesNotJoin[
field] = oldValue;
3125 if ( ! newValuesJoin.isEmpty() && mJoinBuffer )
3130 if ( ! newValuesNotJoin.isEmpty() && mEditBuffer && mDataProvider )
3135 if ( result && !skipDefaultValues && !mDefaultValueOnUpdateFields.isEmpty() )
3137 updateDefaultValues( fid );
3145 if ( !mEditBuffer || !mDataProvider )
3153 if ( attIndex < 0 || attIndex >=
fields().count() )
3157 mFields[ attIndex ].setAlias( QString() );
3158 if ( mAttributeAliasMap.contains(
name ) )
3160 mAttributeAliasMap.remove(
name );
3162 mEditFormConfig.setFields( mFields );
3169 if ( index < 0 || index >=
fields().count() )
3176 if ( mExpressionFieldBuffer )
3192 if ( !mEditBuffer || !mDataProvider )
3208 if ( attIndex < 0 || attIndex >=
fields().count() )
3213 mAttributeAliasMap.insert(
name, aliasString );
3214 mFields[ attIndex ].setAlias( aliasString );
3215 mEditFormConfig.setFields( mFields );
3221 if ( index < 0 || index >=
fields().count() )
3229 if ( index >= 0 && index < mFields.
count() )
3237 return mAttributeAliasMap;
3242 QSet<QString> excludeList;
3243 QMap< QString, QgsField::ConfigurationFlags >::const_iterator flagsIt = mFieldConfigurationFlags.constBegin();
3244 for ( ; flagsIt != mFieldConfigurationFlags.constEnd(); ++flagsIt )
3248 excludeList << flagsIt.key();
3256 QMap< QString, QgsField::ConfigurationFlags >::iterator flagsIt = mFieldConfigurationFlags.begin();
3257 for ( ; flagsIt != mFieldConfigurationFlags.end(); ++flagsIt )
3266 QSet<QString> excludeList;
3267 QMap< QString, QgsField::ConfigurationFlags >::const_iterator flagsIt = mFieldConfigurationFlags.constBegin();
3268 for ( ; flagsIt != mFieldConfigurationFlags.constEnd(); ++flagsIt )
3272 excludeList << flagsIt.key();
3280 QMap< QString, QgsField::ConfigurationFlags >::iterator flagsIt = mFieldConfigurationFlags.begin();
3281 for ( ; flagsIt != mFieldConfigurationFlags.end(); ++flagsIt )
3290 if ( index < 0 || index >=
fields().count() )
3299 if ( !mEditBuffer || !mDataProvider )
3307 bool deleted =
false;
3310 QList<int> attrList = qgis::setToList( qgis::listToSet( attrs ) );
3312 std::sort( attrList.begin(), attrList.end(), std::greater<int>() );
3314 for (
int attr : std::as_const( attrList ) )
3330 if ( context && context->
cascade )
3333 const bool hasRelationsOrJoins = !relations.empty() || mJoinBuffer->
containsJoins();
3334 if ( hasRelationsOrJoins )
3339 if ( handledFeatureIds.contains( fid ) )
3347 handledFeatureIds << fid;
3365 while ( relatedFeaturesIt.
nextFeature( childFeature ) )
3367 childFeatureIds.insert( childFeature.
id() );
3369 if ( childFeatureIds.count() > 0 )
3371 relation.referencingLayer()->startEditing();
3372 relation.referencingLayer()->deleteFeatures( childFeatureIds, context );
3392 bool res = deleteFeatureCascade( fid, context );
3405 const auto constFids = fids;
3407 res = deleteFeatureCascade( fid, context ) && res;
3411 mSelectedFeatureIds.subtract( fids );
3426 if ( !mDataProvider )
3427 return pkAttributesList;
3430 for (
int i = 0; i < mFields.
count(); ++i )
3434 pkAttributesList << i;
3437 return pkAttributesList;
3442 if ( !mDataProvider )
3453 if ( mEditBuffer && !deletedFeatures.empty() )
3455 if ( addedFeatures.size() > deletedFeatures.size() )
3456 return QgsFeatureSource::FeatureAvailability::FeaturesAvailable;
3458 return QgsFeatureSource::FeatureAvailability::FeaturesMaybeAvailable;
3461 if ( ( !mEditBuffer || addedFeatures.empty() ) && mDataProvider && mDataProvider->
empty() )
3462 return QgsFeatureSource::FeatureAvailability::NoFeaturesAvailable;
3464 return QgsFeatureSource::FeatureAvailability::FeaturesAvailable;
3469 mCommitErrors.clear();
3471 if ( !mDataProvider )
3473 mCommitErrors << tr(
"ERROR: no provider" );
3479 mCommitErrors << tr(
"ERROR: layer not editable" );
3485 if ( !mAllowCommit )
3488 mCommitChangesActive =
true;
3490 mCommitChangesActive =
false;
3492 if ( !mDeletedFids.empty() )
3495 mDeletedFids.clear();
3503 mEditBuffer =
nullptr;
3535 return mCommitErrors;
3545 if ( !mDataProvider )
3547 mCommitErrors << tr(
"ERROR: no provider" );
3573 mEditBuffer =
nullptr;
3578 if ( rollbackExtent )
3589 return mSelectedFeatureIds.size();
3594 return mSelectedFeatureIds;
3600 features.reserve( mSelectedFeatureIds.count() );
3603 if ( mSelectedFeatureIds.count() <= 8 )
3607 const auto constMSelectedFeatureIds = mSelectedFeatureIds;
3620 features.push_back( f );
3629 if ( mSelectedFeatureIds.isEmpty() )
3635 if ( mSelectedFeatureIds.count() == 1 )
3636 request.
setFilterFid( *mSelectedFeatureIds.constBegin() );
3645 if ( !mEditBuffer || !mDataProvider )
3648 if ( mGeometryOptions->isActive() )
3650 for (
auto feature = features.begin(); feature != features.end(); ++feature )
3653 mGeometryOptions->apply( geom );
3695 if ( !mDisplayExpression.isEmpty() || mFields.
isEmpty() )
3697 return mDisplayExpression;
3702 if ( !candidateName.isEmpty() )
3715 return ( mEditBuffer && mDataProvider );
3724 bool QgsVectorLayer::isReadOnly()
const
3732 if ( readonly && mEditBuffer )
3735 mReadOnly = readonly;
3742 if ( ! mDataProvider )
3751 return mEditBuffer && mEditBuffer->
isModified();
3756 bool auxiliaryField =
false;
3760 return auxiliaryField;
3767 auxiliaryField =
true;
3770 return auxiliaryField;
3781 if ( r != mRenderer )
3785 mSymbolFeatureCounted =
false;
3786 mSymbolFeatureCountMap.clear();
3787 mSymbolFeatureIdMap.clear();
3798 mRendererGenerators << generator;
3804 for (
int i = mRendererGenerators.count() - 1; i >= 0; --i )
3806 if ( mRendererGenerators.at( i )->id() ==
id )
3808 delete mRendererGenerators.at( i );
3809 mRendererGenerators.removeAt( i );
3816 QList< const QgsFeatureRendererGenerator * > res;
3824 if ( !mDataProvider )
3830 QString ignoredError;
3834 mEditCommandActive =
true;
3840 if ( !mDataProvider )
3845 mEditCommandActive =
false;
3846 if ( !mDeletedFids.isEmpty() )
3850 mSelectedFeatureIds.subtract( mDeletedFids );
3853 mDeletedFids.clear();
3860 if ( !mDataProvider )
3871 std::unique_ptr< QUndoCommand > command = std::make_unique< QUndoCommand >();
3872 command->setObsolete(
true );
3875 mEditCommandActive =
false;
3876 mDeletedFids.clear();
3882 return mJoinBuffer->
addJoin( joinInfo );
3888 return mJoinBuffer->
removeJoin( joinLayerId );
3921 if ( oi < 0 || oi >= mExpressionFieldBuffer->
expressions().size() )
3924 return mExpressionFieldBuffer->
expressions().at( oi ).cachedExpression.expression();
3935 if ( !mDataProvider )
3940 mFields = mDataProvider->
fields();
3950 if ( mExpressionFieldBuffer )
3954 QMap< QString, QString >::const_iterator aliasIt = mAttributeAliasMap.constBegin();
3955 for ( ; aliasIt != mAttributeAliasMap.constEnd(); ++aliasIt )
3961 mFields[ index ].setAlias( aliasIt.value() );
3965 QMap< QString, QgsField::ConfigurationFlags >::const_iterator flagsIt = mFieldConfigurationFlags.constBegin();
3966 for ( ; flagsIt != mFieldConfigurationFlags.constEnd(); ++flagsIt )
3972 mFields[index].setConfigurationFlags( flagsIt.value() );
3976 mDefaultValueOnUpdateFields.clear();
3977 QMap< QString, QgsDefaultValue >::const_iterator defaultIt = mDefaultExpressionMap.constBegin();
3978 for ( ; defaultIt != mDefaultExpressionMap.constEnd(); ++defaultIt )
3980 int index = mFields.
lookupField( defaultIt.key() );
3984 mFields[ index ].setDefaultValueDefinition( defaultIt.value() );
3985 if ( defaultIt.value().applyOnUpdate() )
3986 mDefaultValueOnUpdateFields.insert( index );
3989 QMap< QString, QgsFieldConstraints::Constraints >::const_iterator constraintIt = mFieldConstraints.constBegin();
3990 for ( ; constraintIt != mFieldConstraints.constEnd(); ++constraintIt )
3992 int index = mFields.
lookupField( constraintIt.key() );
4005 mFields[ index ].setConstraints( constraints );
4008 QMap< QString, QPair< QString, QString > >::const_iterator constraintExpIt = mFieldConstraintExpressions.constBegin();
4009 for ( ; constraintExpIt != mFieldConstraintExpressions.constEnd(); ++constraintExpIt )
4011 int index = mFields.
lookupField( constraintExpIt.key() );
4022 mFields[ index ].setConstraints( constraints );
4026 for ( ; constraintStrengthIt != mFieldConstraintStrength.constEnd(); ++constraintStrengthIt )
4028 int index = mFields.
lookupField( constraintStrengthIt.key().first );
4038 constraints.
setConstraintStrength( constraintStrengthIt.key().second, constraintStrengthIt.value() );
4039 mFields[ index ].setConstraints( constraints );
4042 auto fieldWidgetIterator = mFieldWidgetSetups.constBegin();
4043 for ( ; fieldWidgetIterator != mFieldWidgetSetups.constEnd(); ++ fieldWidgetIterator )
4045 int index = mFields.
indexOf( fieldWidgetIterator.key() );
4049 mFields[index].setEditorWidgetSetup( fieldWidgetIterator.value() );
4052 if ( oldFields != mFields )
4055 mEditFormConfig.setFields( mFields );
4063 if ( index < 0 || index >= mFields.
count() || !mDataProvider )
4067 if ( expression.isEmpty() )
4071 std::unique_ptr< QgsExpressionContext > tempContext;
4076 evalContext = tempContext.get();
4109 if ( index < 0 || index >= mFields.
count() )
4114 mDefaultExpressionMap.insert( mFields.
at( index ).
name(), definition );
4118 mDefaultExpressionMap.remove( mFields.
at( index ).
name() );
4125 if ( index < 0 || index >= mFields.
count() )
4134 if ( !mDataProvider )
4149 if ( mEditBuffer && ! mDataProvider->
transaction() )
4153 for (
const QVariant &v : constUniqueValues )
4155 vals << v.toString();
4159 QMapIterator< QgsFeatureId, QgsFeature > addedIt( added );
4160 while ( addedIt.hasNext() && ( limit < 0 ||
uniqueValues.count() < limit ) )
4163 QVariant v = addedIt.value().attribute( index );
4166 QString vs = v.toString();
4167 if ( !vals.contains( vs ) )
4176 while ( it.hasNext() && ( limit < 0 ||
uniqueValues.count() < limit ) )
4179 QVariant v = it.value().value( index );
4182 QString vs = v.toString();
4183 if ( !vals.contains( vs ) )
4216 .setSubsetOfAttributes( attList ) );
4219 QVariant currentValue;
4220 QHash<QString, QVariant> val;
4224 val.insert( currentValue.toString(), currentValue );
4225 if ( limit >= 0 && val.size() >= limit )
4231 return qgis::listToSet( val.values() );
4235 Q_ASSERT_X(
false,
"QgsVectorLayer::uniqueValues()",
"Unknown source of the field!" );
4241 QStringList results;
4242 if ( !mDataProvider )
4257 if ( mEditBuffer && ! mDataProvider->
transaction() )
4260 QMapIterator< QgsFeatureId, QgsFeature > addedIt( added );
4261 while ( addedIt.hasNext() && ( limit < 0 || results.count() < limit ) && ( !feedback || !feedback->
isCanceled() ) )
4264 QVariant v = addedIt.value().attribute( index );
4267 QString vs = v.toString();
4268 if ( vs.contains( substring, Qt::CaseInsensitive ) && !results.contains( vs ) )
4276 while ( it.hasNext() && ( limit < 0 || results.count() < limit ) && ( !feedback || !feedback->
isCanceled() ) )
4279 QVariant v = it.value().value( index );
4282 QString vs = v.toString();
4283 if ( vs.contains( substring, Qt::CaseInsensitive ) && !results.contains( vs ) )
4314 QString fieldName = mFields.
at( index ).
name();
4315 request.
setFilterExpression( QStringLiteral(
"\"%1\" ILIKE '%%2%'" ).arg( fieldName, substring ) );
4319 QString currentValue;
4322 currentValue = f.
attribute( index ).toString();
4323 if ( !results.contains( currentValue ) )
4324 results << currentValue;
4326 if ( ( limit >= 0 && results.size() >= limit ) || ( feedback && feedback->
isCanceled() ) )
4336 Q_ASSERT_X(
false,
"QgsVectorLayer::uniqueStringsMatching()",
"Unknown source of the field!" );
4343 minimumOrMaximumValue( index, &minimum,
nullptr );
4350 minimumOrMaximumValue( index,
nullptr, &maximum );
4356 minimumOrMaximumValue( index, &minimum, &maximum );
4359 void QgsVectorLayer::minimumOrMaximumValue(
int index, QVariant *minimum, QVariant *maximum )
const
4362 *minimum = QVariant();
4364 *maximum = QVariant();
4366 if ( !mDataProvider )
4386 if ( mEditBuffer && ! mDataProvider->
transaction() )
4389 QMapIterator< QgsFeatureId, QgsFeature > addedIt( added );
4390 while ( addedIt.hasNext() )
4393 const QVariant v = addedIt.value().attribute( index );
4401 while ( it.hasNext() )
4404 const QVariant v = it.value().value( index );
4440 .setSubsetOfAttributes( attList ) );
4443 bool firstValue =
true;
4446 const QVariant currentValue = f.
attribute( index );
4447 if ( currentValue.isNull() )
4453 *minimum = currentValue;
4455 *maximum = currentValue;
4460 if ( minimum && currentValue.isValid() &&
qgsVariantLessThan( currentValue, *minimum ) )
4461 *minimum = currentValue;
4463 *maximum = currentValue;
4470 Q_ASSERT_X(
false,
"QgsVectorLayer::minimumOrMaximumValue()",
"Unknown source of the field!" );
4482 if ( !mDataProvider )
4485 *
error = tr(
"Layer is invalid" );
4491 if ( attrIndex >= 0 )
4498 bool providerOk =
false;
4499 QVariant val = mDataProvider->
aggregate(
aggregate, attrIndex, parameters, context, providerOk, fids );
4513 c.setFidsFilter( *fids );
4514 c.setParameters( parameters );
4515 bool aggregateOk =
false;
4516 const QVariant result =
c.calculate(
aggregate, fieldOrExpression, context, &aggregateOk, feedback );
4519 if ( !aggregateOk &&
error )
4537 return mFeatureBlendMode;
4540 void QgsVectorLayer::readSldLabeling(
const QDomNode &node )
4545 QDomElement element = node.toElement();
4546 if ( element.isNull() )
4549 QDomElement userStyleElem = element.firstChildElement( QStringLiteral(
"UserStyle" ) );
4550 if ( userStyleElem.isNull() )
4552 QgsDebugMsgLevel( QStringLiteral(
"Info: UserStyle element not found." ), 4 );
4556 QDomElement featTypeStyleElem = userStyleElem.firstChildElement( QStringLiteral(
"FeatureTypeStyle" ) );
4557 if ( featTypeStyleElem.isNull() )
4559 QgsDebugMsgLevel( QStringLiteral(
"Info: FeatureTypeStyle element not found." ), 4 );
4564 QDomElement mergedFeatTypeStyle = featTypeStyleElem.cloneNode(
false ).toElement();
4569 bool needRuleBasedLabeling =
false;
4572 while ( !featTypeStyleElem.isNull() )
4574 QDomElement ruleElem = featTypeStyleElem.firstChildElement( QStringLiteral(
"Rule" ) );
4575 while ( !ruleElem.isNull() )
4579 bool hasTextSymbolizer =
false;
4580 bool hasRuleBased =
false;
4581 QDomElement ruleChildElem = ruleElem.firstChildElement();
4582 while ( !ruleChildElem.isNull() )
4585 if ( ruleChildElem.localName() == QLatin1String(
"Filter" ) ||
4586 ruleChildElem.localName() == QLatin1String(
"MinScaleDenominator" ) ||
4587 ruleChildElem.localName() == QLatin1String(
"MaxScaleDenominator" ) )
4589 hasRuleBased =
true;
4592 else if ( ruleChildElem.localName() == QLatin1String(
"TextSymbolizer" ) )
4594 QgsDebugMsgLevel( QStringLiteral(
"Info: TextSymbolizer element found" ), 4 );
4595 hasTextSymbolizer =
true;
4598 ruleChildElem = ruleChildElem.nextSiblingElement();
4601 if ( hasTextSymbolizer )
4606 mergedFeatTypeStyle.appendChild( ruleElem.cloneNode().toElement() );
4610 QgsDebugMsgLevel( QStringLiteral(
"Info: Filter or Min/MaxScaleDenominator element found: need a RuleBasedLabeling" ), 4 );
4611 needRuleBasedLabeling =
true;
4616 if ( ruleCount > 1 )
4618 QgsDebugMsgLevel( QStringLiteral(
"Info: More Rule elements found: need a RuleBasedLabeling" ), 4 );
4619 needRuleBasedLabeling =
true;
4623 if ( ruleCount == 0 )
4625 needRuleBasedLabeling =
false;
4628 ruleElem = ruleElem.nextSiblingElement( QStringLiteral(
"Rule" ) );
4630 featTypeStyleElem = featTypeStyleElem.nextSiblingElement( QStringLiteral(
"FeatureTypeStyle" ) );
4633 if ( ruleCount == 0 )
4635 QgsDebugMsgLevel( QStringLiteral(
"Info: No TextSymbolizer element." ), 4 );
4639 QDomElement ruleElem = mergedFeatTypeStyle.firstChildElement( QStringLiteral(
"Rule" ) );
4641 if ( needRuleBasedLabeling )
4645 while ( !ruleElem.isNull() )
4648 QString label, description, filterExp;
4649 int scaleMinDenom = 0, scaleMaxDenom = 0;
4653 QDomElement childElem = ruleElem.firstChildElement();
4654 while ( !childElem.isNull() )
4656 if ( childElem.localName() == QLatin1String(
"Name" ) )
4660 if ( label.isEmpty() )
4661 label = childElem.firstChild().nodeValue();
4663 else if ( childElem.localName() == QLatin1String(
"Description" ) )
4666 QDomElement titleElem = childElem.firstChildElement( QStringLiteral(
"Title" ) );
4667 if ( !titleElem.isNull() )
4669 label = titleElem.firstChild().nodeValue();
4672 QDomElement abstractElem = childElem.firstChildElement( QStringLiteral(
"Abstract" ) );
4673 if ( !abstractElem.isNull() )
4675 description = abstractElem.firstChild().nodeValue();
4678 else if ( childElem.localName() == QLatin1String(
"Abstract" ) )
4681 description = childElem.firstChild().nodeValue();
4683 else if ( childElem.localName() == QLatin1String(
"Title" ) )
4686 label = childElem.firstChild().nodeValue();
4688 else if ( childElem.localName() == QLatin1String(
"Filter" ) )
4704 else if ( childElem.localName() == QLatin1String(
"MinScaleDenominator" ) )
4707 int v = childElem.firstChild().nodeValue().toInt( &ok );
4711 else if ( childElem.localName() == QLatin1String(
"MaxScaleDenominator" ) )
4714 int v = childElem.firstChild().nodeValue().toInt( &ok );
4718 else if ( childElem.localName() == QLatin1String(
"TextSymbolizer" ) )
4720 readSldTextSymbolizer( childElem, settings );
4723 childElem = childElem.nextSiblingElement();
4729 ruleElem = ruleElem.nextSiblingElement();
4739 QDomElement textSymbolizerElem = ruleElem.firstChildElement( QStringLiteral(
"TextSymbolizer" ) );
4741 if ( readSldTextSymbolizer( textSymbolizerElem, s ) )
4749 bool QgsVectorLayer::readSldTextSymbolizer(
const QDomNode &node,
QgsPalLayerSettings &settings )
const
4751 if ( node.localName() != QLatin1String(
"TextSymbolizer" ) )
4753 QgsDebugMsgLevel( QStringLiteral(
"Not a TextSymbolizer element: %1" ).arg( node.localName() ), 3 );
4756 QDomElement textSymbolizerElem = node.toElement();
4758 QDomElement labelElem = textSymbolizerElem.firstChildElement( QStringLiteral(
"Label" ) );
4759 if ( !labelElem.isNull() )
4761 QDomElement propertyNameElem = labelElem.firstChildElement( QStringLiteral(
"PropertyName" ) );
4762 if ( !propertyNameElem.isNull() )
4767 QString labelAttribute = propertyNameElem.text();
4771 int fieldIndex = mFields.
lookupField( labelAttribute );
4772 if ( fieldIndex == -1 )
4776 if ( !exp.hasEvalError() )
4782 QgsDebugMsgLevel( QStringLiteral(
"SLD label attribute error: %1" ).arg( exp.evalErrorString() ), 3 );
4788 QgsDebugMsgLevel( QStringLiteral(
"Info: PropertyName element not found." ), 4 );
4799 if ( textSymbolizerElem.hasAttribute( QStringLiteral(
"uom" ) ) )
4804 QString fontFamily = QStringLiteral(
"Sans-Serif" );
4805 int fontPointSize = 10;
4807 int fontWeight = -1;
4808 bool fontItalic =
false;
4809 bool fontUnderline =
false;
4812 QDomElement fontElem = textSymbolizerElem.firstChildElement( QStringLiteral(
"Font" ) );
4813 if ( !fontElem.isNull() )
4816 for ( QgsStringMap::iterator it = fontSvgParams.begin(); it != fontSvgParams.end(); ++it )
4818 QgsDebugMsgLevel( QStringLiteral(
"found fontSvgParams %1: %2" ).arg( it.key(), it.value() ), 4 );
4820 if ( it.key() == QLatin1String(
"font-family" ) )
4822 fontFamily = it.value();
4824 else if ( it.key() == QLatin1String(
"font-style" ) )
4826 fontItalic = ( it.value() == QLatin1String(
"italic" ) ) || ( it.value() == QLatin1String(
"Italic" ) );
4828 else if ( it.key() == QLatin1String(
"font-size" ) )
4831 int fontSize = it.value().toInt( &ok );
4834 fontPointSize = fontSize;
4835 fontUnitSize = sldUnitSize;
4838 else if ( it.key() == QLatin1String(
"font-weight" ) )
4840 if ( ( it.value() == QLatin1String(
"bold" ) ) || ( it.value() == QLatin1String(
"Bold" ) ) )
4841 fontWeight = QFont::Bold;
4843 else if ( it.key() == QLatin1String(
"font-underline" ) )
4845 fontUnderline = ( it.value() == QLatin1String(
"underline" ) ) || ( it.value() == QLatin1String(
"Underline" ) );
4851 QFont font( fontFamily, fontPointSize, fontWeight, fontItalic );
4852 font.setUnderline( fontUnderline );
4854 format.
setSize( fontPointSize );
4858 QDomElement fillElem = textSymbolizerElem.firstChildElement( QStringLiteral(
"Fill" ) );
4860 Qt::BrushStyle textBrush = Qt::SolidPattern;
4862 if ( textColor.isValid() )
4864 QgsDebugMsgLevel( QStringLiteral(
"Info: textColor %1." ).arg( QVariant( textColor ).toString() ), 4 );
4871 QDomElement haloElem = textSymbolizerElem.firstChildElement( QStringLiteral(
"Halo" ) );
4872 if ( !haloElem.isNull() )
4877 QDomElement radiusElem = haloElem.firstChildElement( QStringLiteral(
"Radius" ) );
4878 if ( !radiusElem.isNull() )
4881 double bufferSize = radiusElem.text().toDouble( &ok );
4884 bufferSettings.
setSize( bufferSize );
4889 QDomElement haloFillElem = haloElem.firstChildElement( QStringLiteral(
"Fill" ) );
4891 Qt::BrushStyle bufferBrush = Qt::SolidPattern;
4893 if ( bufferColor.isValid() )
4895 QgsDebugMsgLevel( QStringLiteral(
"Info: bufferColor %1." ).arg( QVariant( bufferColor ).toString() ), 4 );
4896 bufferSettings.
setColor( bufferColor );
4901 QDomElement labelPlacementElem = textSymbolizerElem.firstChildElement( QStringLiteral(
"LabelPlacement" ) );
4902 if ( !labelPlacementElem.isNull() )
4905 QDomElement pointPlacementElem = labelPlacementElem.firstChildElement( QStringLiteral(
"PointPlacement" ) );
4906 if ( !pointPlacementElem.isNull() )
4914 QDomElement displacementElem = pointPlacementElem.firstChildElement( QStringLiteral(
"Displacement" ) );
4915 if ( !displacementElem.isNull() )
4917 QDomElement displacementXElem = displacementElem.firstChildElement( QStringLiteral(
"DisplacementX" ) );
4918 if ( !displacementXElem.isNull() )
4921 double xOffset = displacementXElem.text().toDouble( &ok );
4928 QDomElement displacementYElem = displacementElem.firstChildElement( QStringLiteral(
"DisplacementY" ) );
4929 if ( !displacementYElem.isNull() )
4932 double yOffset = displacementYElem.text().toDouble( &ok );
4940 QDomElement anchorPointElem = pointPlacementElem.firstChildElement( QStringLiteral(
"AnchorPoint" ) );
4941 if ( !anchorPointElem.isNull() )
4943 QDomElement anchorPointXElem = anchorPointElem.firstChildElement( QStringLiteral(
"AnchorPointX" ) );
4944 if ( !anchorPointXElem.isNull() )
4947 double xOffset = anchorPointXElem.text().toDouble( &ok );
4954 QDomElement anchorPointYElem = anchorPointElem.firstChildElement( QStringLiteral(
"AnchorPointY" ) );
4955 if ( !anchorPointYElem.isNull() )
4958 double yOffset = anchorPointYElem.text().toDouble( &ok );
4967 QDomElement rotationElem = pointPlacementElem.firstChildElement( QStringLiteral(
"Rotation" ) );
4968 if ( !rotationElem.isNull() )
4971 double rotation = rotationElem.text().toDouble( &ok );
4981 QDomElement linePlacementElem = labelPlacementElem.firstChildElement( QStringLiteral(
"LinePlacement" ) );
4982 if ( !linePlacementElem.isNull() )
4991 QDomElement vendorOptionElem = textSymbolizerElem.firstChildElement( QStringLiteral(
"VendorOption" ) );
4992 while ( !vendorOptionElem.isNull() && vendorOptionElem.localName() == QLatin1String(
"VendorOption" ) )
4994 QString optionName = vendorOptionElem.attribute( QStringLiteral(
"name" ) );
4995 QString optionValue;
4996 if ( vendorOptionElem.firstChild().nodeType() == QDomNode::TextNode )
4998 optionValue = vendorOptionElem.firstChild().nodeValue();
5002 if ( vendorOptionElem.firstChild().nodeType() == QDomNode::ElementNode &&
5003 vendorOptionElem.firstChild().localName() == QLatin1String(
"Literal" ) )
5005 QgsDebugMsg( vendorOptionElem.firstChild().localName() );
5006 optionValue = vendorOptionElem.firstChild().firstChild().nodeValue();
5010 QgsDebugMsg( QStringLiteral(
"unexpected child of %1 named %2" ).arg( vendorOptionElem.localName(), optionName ) );
5014 if ( !optionName.isEmpty() && !optionValue.isEmpty() )
5016 vendorOptions[ optionName ] = optionValue;
5019 vendorOptionElem = vendorOptionElem.nextSiblingElement();
5021 if ( !vendorOptions.isEmpty() )
5023 for ( QgsStringMap::iterator it = vendorOptions.begin(); it != vendorOptions.end(); ++it )
5025 if ( it.key() == QLatin1String(
"underlineText" ) && it.value() == QLatin1String(
"true" ) )
5027 font.setUnderline(
true );
5030 else if ( it.key() == QLatin1String(
"strikethroughText" ) && it.value() == QLatin1String(
"true" ) )
5032 font.setStrikeOut(
true );
5035 else if ( it.key() == QLatin1String(
"maxDisplacement" ) )
5039 else if ( it.key() == QLatin1String(
"followLine" ) && it.value() == QLatin1String(
"true" ) )
5050 else if ( it.key() == QLatin1String(
"maxAngleDelta" ) )
5053 double angle = it.value().toDouble( &ok );
5061 else if ( it.key() == QLatin1String(
"conflictResolution" ) && it.value() == QLatin1String(
"false" ) )
5065 else if ( it.key() == QLatin1String(
"forceLeftToRight" ) && it.value() == QLatin1String(
"false" ) )
5069 else if ( it.key() == QLatin1String(
"group" ) && it.value() == QLatin1String(
"yes" ) )
5073 else if ( it.key() == QLatin1String(
"labelAllGroup" ) && it.value() == QLatin1String(
"true" ) )
5087 return mEditFormConfig;
5096 mEditFormConfig.onRelationsLoaded();
5102 return mMapTipTemplate;
5107 if ( mMapTipTemplate == mapTip )
5110 mMapTipTemplate = mapTip;
5145 if ( !mDiagramLayerSettings )
5147 *mDiagramLayerSettings = s;
5153 QString myMetadata = QStringLiteral(
"<html><head></head>\n<body>\n" );
5158 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"Information from provider" ) + QStringLiteral(
"</h1>\n<hr>\n" );
5159 myMetadata += QLatin1String(
"<table class=\"list-view\">\n" );
5164 myMetadata += QStringLiteral(
"<tr><td class=\"highlight\">" ) + tr(
"Storage" ) + QStringLiteral(
"</td><td>" ) +
storageType() + QStringLiteral(
"</td></tr>\n" );
5170 myMetadata += QStringLiteral(
"<tr><td class=\"highlight\">" ) + tr(
"Comment" ) + QStringLiteral(
"</td><td>" ) +
dataComment() + QStringLiteral(
"</td></tr>\n" );
5177 myMetadata += QStringLiteral(
"<tr><td class=\"highlight\">" ) + tr(
"Encoding" ) + QStringLiteral(
"</td><td>" ) + provider->
encoding() + QStringLiteral(
"</td></tr>\n" );
5192 myMetadata += QStringLiteral(
"<tr><td class=\"highlight\">" ) + tr(
"Geometry" ) + QStringLiteral(
"</td><td>" ) + typeString + QStringLiteral(
"</td></tr>\n" );
5196 myMetadata += QStringLiteral(
"<tr><td class=\"highlight\">" ) + tr(
"Extent" ) + QStringLiteral(
"</td><td>" ) +
extent().
toString() + QStringLiteral(
"</td></tr>\n" );
5200 QLocale locale = QLocale();
5201 locale.setNumberOptions( locale.numberOptions() &= ~QLocale::NumberOption::OmitGroupSeparator );
5202 myMetadata += QStringLiteral(
"<tr><td class=\"highlight\">" )
5203 + tr(
"Feature count" ) + QStringLiteral(
"</td><td>" )
5205 + QStringLiteral(
"</td></tr>\n" );
5208 myMetadata += QLatin1String(
"</table>\n<br><br>" );
5217 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"Identification" ) + QStringLiteral(
"</h1>\n<hr>\n" );
5219 myMetadata += QLatin1String(
"<br><br>\n" );
5222 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"Extent" ) + QStringLiteral(
"</h1>\n<hr>\n" );
5224 myMetadata += QLatin1String(
"<br><br>\n" );
5227 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"Access" ) + QStringLiteral(
"</h1>\n<hr>\n" );
5229 myMetadata += QLatin1String(
"<br><br>\n" );
5232 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"Fields" ) + QStringLiteral(
"</h1>\n<hr>\n<table class=\"list-view\">\n" );
5236 if ( !pkAttrList.isEmpty() )
5238 myMetadata += QStringLiteral(
"<tr><td class=\"highlight\">" ) + tr(
"Primary key attributes" ) + QStringLiteral(
"</td><td>" );
5239 const auto constPkAttrList = pkAttrList;
5240 for (
int idx : constPkAttrList )
5244 myMetadata += QLatin1String(
"</td></tr>\n" );
5250 myMetadata += QStringLiteral(
"<tr><td class=\"highlight\">" ) + tr(
"Count" ) + QStringLiteral(
"</td><td>" ) + QString::number( myFields.
size() ) + QStringLiteral(
"</td></tr>\n" );
5252 myMetadata += QLatin1String(
"</table>\n<br><table width=\"100%\" class=\"tabular-view\">\n" );
5253 myMetadata += QLatin1String(
"<tr><th>" ) + tr(
"Field" ) + QLatin1String(
"</th><th>" ) + tr(
"Type" ) + QLatin1String(
"</th><th>" ) + tr(
"Length" ) + QLatin1String(
"</th><th>" ) + tr(
"Precision" ) + QLatin1String(
"</th><th>" ) + tr(
"Comment" ) + QLatin1String(
"</th></tr>\n" );
5255 for (
int i = 0; i < myFields.
size(); ++i )
5260 rowClass = QStringLiteral(
"class=\"odd-row\"" );
5261 myMetadata += QLatin1String(
"<tr " ) + rowClass + QLatin1String(
"><td>" ) + myField.
name() + QLatin1String(
"</td><td>" ) + myField.
typeName() + QLatin1String(
"</td><td>" ) + QString::number( myField.
length() ) + QLatin1String(
"</td><td>" ) + QString::number( myField.
precision() ) + QLatin1String(
"</td><td>" ) + myField.
comment() + QLatin1String(
"</td></tr>\n" );
5265 myMetadata += QLatin1String(
"</table>\n<br><br>" );
5268 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"Contacts" ) + QStringLiteral(
"</h1>\n<hr>\n" );
5270 myMetadata += QLatin1String(
"<br><br>\n" );
5273 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"Links" ) + QStringLiteral(
"</h1>\n<hr>\n" );
5275 myMetadata += QLatin1String(
"<br><br>\n" );
5278 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"History" ) + QStringLiteral(
"</h1>\n<hr>\n" );
5280 myMetadata += QLatin1String(
"<br><br>\n" );
5282 myMetadata += QLatin1String(
"\n</body>\n</html>\n" );
5286 void QgsVectorLayer::invalidateSymbolCountedFlag()
5288 mSymbolFeatureCounted =
false;
5291 void QgsVectorLayer::onFeatureCounterCompleted()
5294 mFeatureCounter =
nullptr;
5297 void QgsVectorLayer::onFeatureCounterTerminated()
5299 mFeatureCounter =
nullptr;
5302 void QgsVectorLayer::onJoinedFieldsChanged()
5308 void QgsVectorLayer::onFeatureDeleted(
QgsFeatureId fid )
5310 if ( mEditCommandActive || mCommitChangesActive )
5312 mDeletedFids << fid;
5316 mSelectedFeatureIds.remove( fid );
5323 void QgsVectorLayer::onRelationsLoaded()
5325 mEditFormConfig.onRelationsLoaded();
5328 void QgsVectorLayer::onSymbolsCounted()
5330 if ( mFeatureCounter )
5332 mSymbolFeatureCounted =
true;
5346 return mWeakRelations;
5366 bool useAsDefault,
const QString &uiFileContent, QString &msgError )
5369 QString sldStyle, qmlStyle;
5370 QDomDocument qmlDocument, sldDocument;
5373 if ( !msgError.isNull() )
5377 qmlStyle = qmlDocument.toString();
5380 if ( !msgError.isNull() )
5384 sldStyle = sldDocument.toString();
5388 description, uiFileContent, useAsDefault, msgError );
5402 QString joinKey = mAuxiliaryLayerKey;
5403 if ( !key.isEmpty() )
5406 if ( storage.
isValid() && !joinKey.isEmpty() )
5429 mAuxiliaryLayerKey.clear();
5431 if ( mAuxiliaryLayer )
5444 mAuxiliaryLayer.reset( alayer );
5445 if ( mAuxiliaryLayer )
5446 mAuxiliaryLayer->setParent(
this );
5452 return mAuxiliaryLayer.get();
5457 return mAuxiliaryLayer.get();
5463 QString returnMessage;
5464 QString qml, errorMsg;
5469 if ( !qml.isEmpty() )
5471 QDomDocument myDocument( QStringLiteral(
"qgis" ) );
5472 myDocument.setContent( qml );
5474 returnMessage = QObject::tr(
"Loaded from Provider" );
5484 return returnMessage;
5489 if ( mDataProvider )
5494 void QgsVectorLayer::emitDataChanged()
5496 if ( mDataChangedFired )
5501 mDataChangedFired =
true;
5503 mDataChangedFired =
false;
5506 void QgsVectorLayer::onAfterCommitChangesDependency()
5508 mDataChangedFired =
true;
5510 mDataChangedFired =
false;
5515 QSet<QgsMapLayerDependency> deps;
5516 const auto constODeps = oDeps;
5523 QSet<QgsMapLayerDependency> toAdd = deps -
dependencies();
5540 if ( mDataProvider )
5561 if ( ! toAdd.isEmpty() )
5569 if ( fieldIndex < 0 || fieldIndex >= mFields.
count() || !mDataProvider )
5570 return QgsFieldConstraints::Constraints();
5585 QMap< QgsFieldConstraints::Constraint, QgsFieldConstraints::ConstraintStrength > m;
5587 if ( fieldIndex < 0 || fieldIndex >= mFields.
count() )
5590 QString
name = mFields.
at( fieldIndex ).
name();
5593 for ( ; conIt != mFieldConstraintStrength.constEnd(); ++conIt )
5595 if ( conIt.key().first ==
name )
5597 m[ conIt.key().second ] = mFieldConstraintStrength.value( conIt.key() );
5606 if ( index < 0 || index >= mFields.
count() )
5612 QgsFieldConstraints::Constraints constraints = mFieldConstraints.value(
name, QgsFieldConstraints::Constraints() );
5613 constraints |= constraint;
5614 mFieldConstraints.insert(
name, constraints );
5616 mFieldConstraintStrength.insert( qMakePair(
name, constraint ), strength );
5623 if ( index < 0 || index >= mFields.
count() )
5629 QgsFieldConstraints::Constraints constraints = mFieldConstraints.value(
name, QgsFieldConstraints::Constraints() );
5630 constraints &= ~constraint;
5631 mFieldConstraints.insert(
name, constraints );
5633 mFieldConstraintStrength.remove( qMakePair(
name, constraint ) );
5640 if ( index < 0 || index >= mFields.
count() )
5648 if ( index < 0 || index >= mFields.
count() )
5656 if ( index < 0 || index >= mFields.
count() )
5659 if ( expression.isEmpty() )
5661 mFieldConstraintExpressions.remove( mFields.
at( index ).
name() );
5665 mFieldConstraintExpressions.insert( mFields.
at( index ).
name(), qMakePair( expression, description ) );
5672 if ( index < 0 || index >= mFields.
count() )
5675 mFieldConfigurationFlags.insert( mFields.
at( index ).
name(),
flags );
5681 if ( index < 0 || index >= mFields.
count() )
5684 flags.setFlag( flag, active );
5691 if ( index < 0 || index >= mFields.
count() )
5699 if ( index < 0 || index >= mFields.
count() )
5703 mFieldWidgetSetups.remove( mFields.
at( index ).
name() );
5705 mFieldWidgetSetups.insert( mFields.
at( index ).
name(), setup );
5712 if ( index < 0 || index >= mFields.
count() )
5721 if (
customProperty( QStringLiteral(
"labeling" ) ).toString() == QLatin1String(
"pal" ) )
5723 if (
customProperty( QStringLiteral(
"labeling/enabled" ), QVariant(
false ) ).toBool() )
5727 settings.readFromLayerCustomProperties(
this );
5734 for (
const QString &key : constCustomPropertyKeys )
5736 if ( key.startsWith( QLatin1String(
"labeling/" ) ) )
5746 return mAllowCommit;
5760 return mGeometryOptions.get();
5770 return mReadExtentFromXml;
5773 void QgsVectorLayer::onDirtyTransaction(
const QString &sql,
const QString &name )
5776 if ( tr && mEditBuffer )
5778 qobject_cast<QgsVectorLayerEditPassthrough *>( mEditBuffer )->update( tr, sql,
name );
5784 QList<QgsVectorLayer *> layers;
5785 QMap<QgsVectorLayer *, QgsFeatureIds>::const_iterator i;
5788 if ( includeAuxiliaryLayers || !qobject_cast< QgsAuxiliaryLayer * >( i.key() ) )
5789 layers.append( i.key() );
5796 return mHandledFeatures[layer];
GeometryOperationResult
Success or failure of a geometry operation.
@ InvalidInputGeometryType
The input geometry (ring, part, split line, etc.) has not the correct geometry type.
@ Success
Operation succeeded.
@ SelectionIsEmpty
No features were selected.
@ AddRingNotInExistingFeature
The input ring doesn't have any existing ring to fit into.
@ AddRingNotClosed
The input ring is not closed.
@ SelectionIsGreaterThanOne
More than one features were selected.
@ LayerNotEditable
Cannot edit layer.
VertexMarkerType
Editing vertex markers, used for showing vertices during a edit operation.
@ SemiTransparentCircle
Semi-transparent circle marker.
VectorEditResult
Specifies the result of a vector layer edit operation.
@ Success
Edit operation was successful.
@ InvalidLayer
Edit failed due to invalid layer.
SelectBehavior
Specifies how a selection should be applied.
@ SetSelection
Set selection, removing any existing selection.
@ AddToSelection
Add selection to current selection.
@ IntersectSelection
Modify current selection to include only select features which match.
@ RemoveFromSelection
Remove from current selection.
virtual bool writeXml(QDomElement &collectionElem, const QgsPropertiesDefinition &definitions) const
Writes the current state of the property collection into an XML element.
Abstract base class - its implementations define different approaches to the labeling of a vector lay...
virtual bool accept(QgsStyleEntityVisitorInterface *visitor) const
Accepts the specified symbology visitor, causing it to visit all symbols associated with the labeling...
virtual void toSld(QDomNode &parent, const QVariantMap &props) const
Writes the SE 1.1 TextSymbolizer element based on the current layer labeling settings.
static QgsAbstractVectorLayerLabeling * create(const QDomElement &element, const QgsReadWriteContext &context)
Try to create instance of an implementation based on the XML data.
virtual QDomElement save(QDomDocument &doc, const QgsReadWriteContext &context) const =0
Returns labeling configuration as XML element.
Storage and management of actions associated with a layer.
bool writeXml(QDomNode &layer_node) const
Writes the actions out in XML format.
QList< QgsAction > actions(const QString &actionScope=QString()) const
Returns a list of actions that are available in the given action scope.
QUuid addAction(QgsAction::ActionType type, const QString &name, const QString &command, bool capture=false)
Add an action with the given name and action details.
bool readXml(const QDomNode &layer_node)
Reads the actions in in XML format.
Utility class that encapsulates an action based on vector attributes.
Utility class for calculating aggregates for a field (or expression) over the features from a vector ...
Aggregate
Available aggregates to calculate.
static QgsRuntimeProfiler * profiler()
Returns the application runtime profiler.
static QgsTaskManager * taskManager()
Returns the application's task manager, used for managing application wide background task handling.
This is a container for configuration of the attribute table.
bool isEmpty() const
Returns true if the configuration is empty, ie it contains no columns.
void readXml(const QDomNode &node)
Deserialize to XML on layer load.
void update(const QgsFields &fields)
Update the configuration with the given fields.
void writeXml(QDomNode &node) const
Serialize to XML on layer save.
Class allowing to manage the auxiliary storage for a vector layer.
QgsVectorLayerJoinInfo joinInfo() const
Returns information to use for joining with primary key and so on.
Class providing some utility methods to manage auxiliary storage.
QgsAuxiliaryLayer * createAuxiliaryLayer(const QgsField &field, QgsVectorLayer *layer) const
Creates an auxiliary layer for a vector layer.
bool isValid() const
Returns the status of the auxiliary storage currently defined.
The QgsConditionalLayerStyles class holds conditional style information for a layer.
bool readXml(const QDomNode &node, const QgsReadWriteContext &context)
Reads the condition styles state from a DOM node.
bool writeXml(QDomNode &node, QDomDocument &doc, const QgsReadWriteContext &context) const
Writes the condition styles state to a DOM node.
This class represents a coordinate reference system (CRS).
bool isValid() const
Returns whether this CRS is correctly initialized and usable.
Contains information about the context in which a coordinate transform is executed.
Abstract base class for curved geometry type.
virtual bool isClosed() const SIP_HOLDGIL
Returns true if the curve is closed.
QgsCurve * clone() const override=0
Clones the geometry by performing a deep copy.
virtual bool leaveUpdateMode()
Leave update mode.
@ FlagLoadDefaultStyle
Reset the layer's style to the default for the datasource.
@ FlagTrustDataSource
Trust datasource config (primary key unicity, geometry type and srid, etc). Improves provider load ti...
QgsCoordinateTransformContext transformContext() const
Returns data provider coordinate transform context.
virtual QgsCoordinateReferenceSystem crs() const =0
Returns the coordinate system for the data source.
void dataChanged()
Emitted whenever a change is made to the data provider which may have caused changes in the provider'...
void fullExtentCalculated()
Emitted whenever a deferred extent calculation is completed by the provider.
virtual QString subsetString() const
Returns the subset definition string (typically sql) currently in use by the layer and used by the pr...
virtual QgsLayerMetadata layerMetadata() const
Returns layer metadata collected from the provider's source.
virtual bool isValid() const =0
Returns true if this is a valid layer.
virtual QString dataSourceUri(bool expandAuthConfig=false) const
Gets the data source specification.
virtual void updateExtents()
Update the extents of the layer.
virtual bool setSubsetString(const QString &subset, bool updateFeatureCount=true)
Set the subset string used to create a subset of features in the layer.
virtual void reloadData()
Reloads the data from the source for providers with data caches to synchronize, changes in the data s...
virtual bool enterUpdateMode()
Enter update mode.
virtual QgsRectangle extent() const =0
Returns the extent of the layer.
virtual void setTransformContext(const QgsCoordinateTransformContext &transformContext)
Sets data coordinate transform context to transformContext.
Class for storing the component parts of a RDBMS data source URI (e.g.
void setConnection(const QString &aHost, const QString &aPort, const QString &aDatabase, const QString &aUsername, const QString &aPassword, SslMode sslmode=SslPrefer, const QString &authConfigId=QString())
Sets all connection related members at once.
QString uri(bool expandAuthConfig=true) const
Returns the complete URI as a string.
QString username() const
Returns the username stored in the URI.
QString host() const
Returns the host name stored in the URI.
bool useEstimatedMetadata() const
Returns true if estimated metadata should be used for the connection.
QString password() const
Returns the password stored in the URI.
QString port() const
Returns the port stored in the URI.
QString database() const
Returns the database name stored in the URI.
void setDatabase(const QString &database)
Sets the URI database name.
The QgsDefaultValue class provides a container for managing client side default values for fields.
Q_GADGET QString expression
bool isValid() const
Returns if this default value should be applied.
Stores the settings for rendering of all diagrams for a layer.
@ PositionX
X-coordinate data defined diagram position.
@ Show
Whether to show the diagram.
@ PositionY
Y-coordinate data defined diagram position.
void readXml(const QDomElement &elem)
Reads the diagram settings from a DOM element.
void writeXml(QDomElement &layerElem, QDomDocument &doc) const
Writes the diagram settings to a DOM element.
Evaluates and returns the diagram settings relating to a diagram for a specific feature.
virtual void writeXml(QDomElement &layerElem, QDomDocument &doc, const QgsReadWriteContext &context) const =0
Writes diagram state to a DOM element.
virtual QList< QgsDiagramSettings > diagramSettings() const =0
Returns list with all diagram settings in the renderer.
virtual void readXml(const QDomElement &elem, const QgsReadWriteContext &context)=0
Reads diagram state from a DOM element.
void clear()
Clear error messages.
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.
static QList< QgsExpressionContextScope * > globalProjectLayerScopes(const QgsMapLayer *layer)
Creates a list of three scopes: global, layer's project and layer.
static QgsExpressionContextScope * layerScope(const QgsMapLayer *layer)
Creates a new scope which contains variables and functions relating to a QgsMapLayer.
Expression contexts are used to encapsulate the parameters around which a QgsExpression should be eva...
QgsExpressionContextScope * popScope()
Removes the last scope from the expression context and return it.
void appendScope(QgsExpressionContextScope *scope)
Appends a scope to the end of the context.
void setFeature(const QgsFeature &feature)
Convenience function for setting a feature for the context.
Buffers information about expression fields for a vector layer.
void removeExpression(int index)
Remove an expression from the buffer.
void updateFields(QgsFields &flds)
Adds fields with the expressions buffered in this object to a QgsFields object.
void writeXml(QDomNode &layer_node, QDomDocument &document) const
Saves expressions to xml under the layer node.
void readXml(const QDomNode &layer_node)
Reads expressions from project file.
QList< QgsExpressionFieldBuffer::ExpressionField > expressions() const
void addExpression(const QString &exp, const QgsField &fld)
Add an expression to the buffer.
void updateExpression(int index, const QString &exp)
Changes the expression at a given index.
void renameExpression(int index, const QString &name)
Renames an expression field at a given index.
An expression node which takes it value from a feature's field.
Class for parsing and evaluation of expressions (formerly called "search strings").
bool prepare(const QgsExpressionContext *context)
Gets the expression ready for evaluation - find out column indexes.
QString expression() const
Returns the original, unmodified expression string.
bool hasParserError() const
Returns true if an error occurred when parsing the input expression.
QString evalErrorString() const
Returns evaluation error.
QString parserErrorString() const
Returns parser error.
bool isField() const
Checks whether an expression consists only of a single field reference.
QSet< QString > referencedColumns() const
Gets list of columns referenced by the expression.
static QString quotedColumnRef(QString name)
Returns a quoted column reference (in double quotes)
const QgsExpressionNode * rootNode() const
Returns the root node of the expression.
bool hasEvalError() const
Returns true if an error occurred when evaluating last input.
static int expressionToLayerFieldIndex(const QString &expression, const QgsVectorLayer *layer)
Attempts to resolve an expression to a field index from the given layer.
bool needsGeometry() const
Returns true if the expression uses feature geometry for some computation.
QVariant evaluate()
Evaluate the feature and return the result.
Wrapper for iterator of features from vector data provider or vector layer.
bool nextFeature(QgsFeature &f)
An interface for objects which generate feature renderers for vector layers.
static QgsFeatureRenderer * defaultRenderer(QgsWkbTypes::GeometryType geomType)
Returns a new renderer - used by default in vector layers.
virtual void toSld(QDomDocument &doc, QDomElement &element, const QVariantMap &props=QVariantMap()) const
used from subclasses to create SLD Rule elements following SLD v1.1 specs
virtual QDomElement save(QDomDocument &doc, const QgsReadWriteContext &context)
Stores renderer properties to an XML element.
double referenceScale() const
Returns the symbology reference scale.
static QgsFeatureRenderer * loadSld(const QDomNode &node, QgsWkbTypes::GeometryType geomType, QString &errorMessage)
Create a new renderer according to the information contained in the UserStyle element of a SLD style ...
void setReferenceScale(double scale)
Sets the symbology reference scale.
static QgsFeatureRenderer * load(QDomElement &symbologyElem, const QgsReadWriteContext &context)
create a renderer from XML element
virtual bool accept(QgsStyleEntityVisitorInterface *visitor) const
Accepts the specified symbology visitor, causing it to visit all symbols associated with the renderer...
This class wraps a request for features to a vector layer (or directly its vector data provider).
QgsFeatureRequest & setFilterFids(const QgsFeatureIds &fids)
Sets the feature IDs that should be fetched.
QgsFeatureRequest & setFlags(QgsFeatureRequest::Flags flags)
Sets flags that affect how features will be fetched.
QgsFeatureRequest & setSubsetOfAttributes(const QgsAttributeList &attrs)
Set a subset of attributes that will be fetched.
QgsFeatureRequest & setFilterExpression(const QString &expression)
Set the filter expression.
@ SubsetOfAttributes
Fetch only a subset of attributes (setSubsetOfAttributes sets this flag)
@ ExactIntersect
Use exact geometry intersection (slower) instead of bounding boxes.
@ NoGeometry
Geometry is not required. It may still be returned if e.g. required for a filter condition.
QgsFeatureRequest & setExpressionContext(const QgsExpressionContext &context)
Sets the expression context used to evaluate filter expressions.
QgsFeatureRequest & setNoAttributes()
Set that no attributes will be fetched.
QgsFeatureRequest & setFilterFid(QgsFeatureId fid)
Sets the feature ID that should be fetched.
virtual bool addFeature(QgsFeature &feature, QgsFeatureSink::Flags flags=QgsFeatureSink::Flags())
Adds a single feature to the sink.
virtual QSet< QVariant > uniqueValues(int fieldIndex, int limit=-1) const
Returns the set of unique values contained within the specified fieldIndex from this source.
SpatialIndexPresence
Enumeration of spatial index presence states.
@ SpatialIndexUnknown
Spatial index presence cannot be determined, index may or may not exist.
FeatureAvailability
Possible return value for hasFeatures() to determine if a source is empty.
virtual QgsFeatureIds allFeatureIds() const
Returns a list of all feature IDs for features present in the source.
virtual SpatialIndexPresence hasSpatialIndex() const
Returns an enum value representing the presence of a valid spatial index on the source,...
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
bool setAttribute(int field, const QVariant &attr)
Sets an attribute's value by field index.
bool hasGeometry() const
Returns true if the feature has an associated geometry.
bool isValid() const
Returns the validity of this feature.
QVariant attribute(const QString &name) const
Lookup attribute value by attribute name.
void setGeometry(const QgsGeometry &geometry)
Set the feature's geometry.
Base class for feedback objects to be used for cancellation of something running in a worker thread.
bool isCanceled() const SIP_HOLDGIL
Tells whether the operation has been canceled already.
Stores information about constraints which may be present on a field.
ConstraintStrength
Strength of constraints.
void setConstraintStrength(Constraint constraint, ConstraintStrength strength)
Sets the strength of a constraint.
void setConstraintExpression(const QString &expression, const QString &description=QString())
Set the constraint expression for the field.
@ ConstraintOriginProvider
Constraint was set at data provider.
@ ConstraintOriginLayer
Constraint was set by layer.
ConstraintStrength constraintStrength(Constraint constraint) const
Returns the strength of a field constraint, or ConstraintStrengthNotSet if the constraint is not pres...
ConstraintOrigin constraintOrigin(Constraint constraint) const
Returns the origin of a field constraint, or ConstraintOriginNotSet if the constraint is not present ...
QString constraintExpression() const
Returns the constraint expression for the field, if set.
Constraint
Constraints which may be present on a field.
@ ConstraintNotNull
Field may not be null.
@ ConstraintUnique
Field must have a unique value.
@ ConstraintExpression
Field has an expression constraint set. See constraintExpression().
QString constraintDescription() const
Returns the descriptive name for the constraint expression.
Q_GADGET Constraints constraints
void setConstraint(Constraint constraint, ConstraintOrigin origin=ConstraintOriginLayer)
Sets a constraint on the field.
Encapsulate a field in an attribute table or data source.
QString typeName() const
Gets the field type.
QString displayName() const
Returns the name to use when displaying this field.
ConfigurationFlags configurationFlags
QgsDefaultValue defaultValueDefinition
QgsFieldConstraints constraints
ConfigurationFlag
Configuration flags for fields These flags are meant to be user-configurable and are not describing a...
@ HideFromWfs
Field is not available if layer is served as WFS from QGIS server.
@ None
No flag is defined.
@ HideFromWms
Field is not available if layer is served as WMS from QGIS server.
QgsEditorWidgetSetup editorWidgetSetup() const
Gets the editor widget setup for the field.
Container of fields for a vector layer.
int indexFromName(const QString &fieldName) const
Gets the field index from the field name.
int indexOf(const QString &fieldName) const
Gets the field index from the field name.
@ OriginExpression
Field is calculated from an expression.
@ OriginEdit
Field has been temporarily added in editing mode (originIndex = index in the list of added attributes...
@ OriginUnknown
It has not been specified where the field comes from.
@ OriginJoin
Field comes from a joined layer (originIndex / 1000 = index of the join, originIndex % 1000 = index w...
@ OriginProvider
Field comes from the underlying data provider of the vector layer (originIndex = index in provider's ...
int count() const
Returns number of items.
FieldOrigin fieldOrigin(int fieldIdx) const
Returns the field's origin (value from an enumeration).
bool isEmpty() const
Checks whether the container is empty.
int size() const
Returns number of items.
QgsField at(int i) const
Returns the field at particular index (must be in range 0..N-1).
int fieldOriginIndex(int fieldIdx) const
Returns the field's origin index (its meaning is specific to each type of origin).
int lookupField(const QString &fieldName) const
Looks up field's index from the field name.
QStringList names() const
Returns a list with field names.
The QgsGeometryOptions class contains options to automatically adjust geometries to constraints on a ...
A geometry is the spatial representation of a feature.
bool equals(const QgsGeometry &geometry) const
Test if this geometry is exactly equal to another geometry.
QgsWkbTypes::GeometryType type
QgsRectangle boundingBox() const
Returns the bounding box of the geometry.
void setMergeLines(bool merge)
Sets whether connected line features with identical label text should be merged prior to generating l...
Line string geometry type, with support for z-dimension and m-values.
static void warning(const QString &msg)
Goes to qWarning.
This class models dependencies with or between map layers.
static QString typeToString(QgsMapLayerType type)
Converts a map layer type to a string value.
virtual void readXml(const QDomElement &elem, const QgsReadWriteContext &context)
Reads configuration from a DOM element previously written by writeXml()
virtual QDomElement writeXml(QDomDocument &doc, const QgsReadWriteContext &context) const
Writes configuration to a DOM element, to be used later with readXml()
static QgsMapLayerLegend * defaultVectorLegend(QgsVectorLayer *vl)
Create new legend implementation for vector layer.
Base class for utility classes that encapsulate information necessary for rendering of map layers.
Base class for storage of map layer temporal properties.
Base class for all map layer types.
void readStyleManager(const QDomNode &layerNode)
Read style manager's configuration (if any). To be called by subclasses.
virtual void exportNamedStyle(QDomDocument &doc, QString &errorMsg, const QgsReadWriteContext &context=QgsReadWriteContext(), QgsMapLayer::StyleCategories categories=QgsMapLayer::AllStyleCategories) const
Export the properties of this layer as named style in a QDomDocument.
void dependenciesChanged()
Emitted when dependencies are changed.
void writeStyleManager(QDomNode &layerNode, QDomDocument &doc) const
Write style manager's configuration (if exists). To be called by subclasses.
QgsMapLayerLegend * legend() const
Can be nullptr.
virtual bool importNamedStyle(QDomDocument &doc, QString &errorMsg, QgsMapLayer::StyleCategories categories=QgsMapLayer::AllStyleCategories)
Import the properties of this layer from a QDomDocument.
void editingStopped()
Emitted when edited changes have been successfully written to the data provider.
void recalculateExtents() const
This is used to send a request that any mapcanvas using this layer update its extents.
virtual QgsRectangle extent() const
Returns the extent of the layer.
QString source() const
Returns the source for the layer.
Q_INVOKABLE QVariant customProperty(const QString &value, const QVariant &defaultValue=QVariant()) const
Read a custom property from layer.
int mBlockStyleChangedSignal
If non-zero, the styleChanged signal should not be emitted.
QString providerType() const
Returns the provider type (provider key) for this layer.
void removeCustomProperty(const QString &key)
Remove a custom property from layer.
void setBlendMode(QPainter::CompositionMode blendMode)
Set the blending mode used for rendering a layer.
void configChanged()
Emitted whenever the configuration is changed.
void setMinimumScale(double scale)
Sets the minimum map scale (i.e.
QString publicSource() const
Gets a version of the internal layer definition that has sensitive bits removed (for example,...
QgsMapLayer::LayerFlags flags() const
Returns the flags for this layer.
void editingStarted()
Emitted when editing on this layer has started.
QgsCoordinateReferenceSystem crs
friend class QgsVectorLayer
void writeCustomProperties(QDomNode &layerNode, QDomDocument &doc) const
Write custom properties to project file.
virtual QString loadDefaultStyle(bool &resultFlag)
Retrieve the default style for this layer if one exists (either as a .qml file on disk or as a record...
void triggerRepaint(bool deferredUpdate=false)
Will advise the map canvas (and any other interested party) that this layer requires to be repainted.
QString crsHtmlMetadata() const
Returns a HTML fragment containing the layer's CRS metadata, for use in the htmlMetadata() method.
void setMaximumScale(double scale)
Sets the maximum map scale (i.e.
QgsLayerMetadata metadata
QPainter::CompositionMode blendMode() const
Returns the current blending mode for a layer.
virtual void setOpacity(double opacity)
Sets the opacity for the layer, where opacity is a value between 0 (totally transparent) and 1....
void setFlags(QgsMapLayer::LayerFlags flags)
Returns the flags for this layer.
QSet< QgsMapLayerDependency > mDependencies
List of layers that may modify this layer on modification.
void readCustomProperties(const QDomNode &layerNode, const QString &keyStartsWith=QString())
Read custom properties from project file.
virtual void setMetadata(const QgsLayerMetadata &metadata)
Sets the layer's metadata store.
Q_INVOKABLE void setCustomProperty(const QString &key, const QVariant &value)
Set a custom property for layer.
QString mProviderKey
Data provider key (name of the data provider)
QgsCoordinateTransformContext transformContext() const
Returns the layer data provider coordinate transform context or a default transform context if the la...
void styleChanged()
Signal emitted whenever a change affects the layer's style.
QUndoStack * undoStack()
Returns pointer to layer's undo stack.
void rendererChanged()
Signal emitted when renderer is changed.
virtual QgsError error() const
Gets current status error.
void setScaleBasedVisibility(bool enabled)
Sets whether scale based visibility is enabled for the layer.
void dataSourceChanged()
Emitted whenever the layer's data source has been changed.
bool hasScaleBasedVisibility() const
Returns whether scale based visibility is enabled for the layer.
virtual QString loadNamedStyle(const QString &uri, bool &resultFlag, QgsMapLayer::StyleCategories categories=QgsMapLayer::AllStyleCategories)
Retrieve a named style for this layer if one exists (either as a .qml file on disk or as a record in ...
virtual QgsMapLayer * clone() const =0
Returns a new instance equivalent to this one except for the id which is still unique.
void styleLoaded(QgsMapLayer::StyleCategories categories)
Emitted when a style has been loaded.
void emitStyleChanged()
Triggers an emission of the styleChanged() signal.
void dataChanged()
Data of layer changed.
void willBeDeleted()
Emitted in the destructor when the layer is about to be deleted, but it is still in a perfectly valid...
void setName(const QString &name)
Set the display name of the layer.
virtual void setExtent(const QgsRectangle &rect)
Sets the extent.
virtual void resolveReferences(QgsProject *project)
Resolve references to other layers (kept as layer IDs after reading XML) into layer objects.
QString mDataSource
Data source description string, varies by layer type.
@ FlagReadExtentFromXml
Read extent from xml and skip get extent from provider.
@ FlagTrustLayerMetadata
Trust layer metadata. Improves layer load time by skipping expensive checks like primary key unicity,...
@ FlagDontResolveLayers
Don't resolve layer paths or create data providers for layers.
void setValid(bool valid)
Sets whether layer is valid or not.
void readCommonStyle(const QDomElement &layerElement, const QgsReadWriteContext &context, StyleCategories categories=AllStyleCategories)
Read style data common to all layer types.
QgsMapLayer::ReadFlags mReadFlags
Read flags. It's up to the subclass to respect these when restoring state from XML.
void setDataSource(const QString &dataSource, const QString &baseName, const QString &provider, bool loadDefaultStyleFlag=false)
Updates the data source of the layer.
double minimumScale() const
Returns the minimum map scale (i.e.
void repaintRequested(bool deferredUpdate=false)
By emitting this signal the layer tells that either appearance or content have been changed and any v...
virtual void exportSldStyle(QDomDocument &doc, QString &errorMsg) const
Export the properties of this layer as SLD style in a QDomDocument.
Q_INVOKABLE QStringList customPropertyKeys() const
Returns list of all keys within custom properties.
QgsProject * project() const
Returns the parent project if this map layer is added to a project.
void setLegend(QgsMapLayerLegend *legend)
Assign a legend controller to the map layer.
bool mValid
Indicates if the layer is valid and can be drawn.
@ GeometryOptions
Geometry validation configuration.
@ AttributeTable
Attribute table settings: choice and order of columns, conditional styling.
@ LayerConfiguration
General configuration: identifiable, removable, searchable, display expression, read-only.
@ Rendering
Rendering: scale visibility, simplify method, opacity.
@ CustomProperties
Custom properties (by plugins for instance)
@ Fields
Aliases, widgets, WMS/WFS, expressions, constraints, virtual fields.
@ Legend
Legend settings (since QGIS 3.16)
void layerModified()
Emitted when modifications has been done on layer.
void setProviderType(const QString &providerType)
Sets the providerType (provider key)
QString generalHtmlMetadata() const
Returns an HTML fragment containing general metadata information, for use in the htmlMetadata() metho...
void writeCommonStyle(QDomElement &layerElement, QDomDocument &document, const QgsReadWriteContext &context, StyleCategories categories=AllStyleCategories) const
Write style data common to all layer types.
double maximumScale() const
Returns the maximum map scale (i.e.
bool mShouldValidateCrs
true if the layer's CRS should be validated and invalid CRSes are not permitted.
void setCrs(const QgsCoordinateReferenceSystem &srs, bool emitSignal=true)
Sets layer's spatial reference system.
static void logMessage(const QString &message, const QString &tag=QString(), Qgis::MessageLevel level=Qgis::MessageLevel::Warning, bool notifyUser=true)
Adds a message to the log instance (and creates it if necessary).
static QgsExpression * expressionFromOgcFilter(const QDomElement &element, QgsVectorLayer *layer=nullptr)
Parse XML with OGC filter into QGIS expression.
static QgsPainting::BlendMode getBlendModeEnum(QPainter::CompositionMode blendMode)
Returns a BlendMode corresponding to a QPainter::CompositionMode.
static QPainter::CompositionMode getCompositionMode(QgsPainting::BlendMode blendMode)
Returns a QPainter::CompositionMode corresponding to a BlendMode.
BlendMode
Blending modes enum defining the available composition modes that can be used when rendering a layer.
Contains settings for how a map layer will be labeled.
double yOffset
Vertical offset of label.
double maxCurvedCharAngleIn
Maximum angle between inside curved label characters (valid range 20.0 to 60.0).
void setFormat(const QgsTextFormat &format)
Sets the label text formatting settings, e.g., font settings, buffer settings, etc.
bool displayAll
If true, all features will be labelled even when overlaps occur.
double xOffset
Horizontal offset of label.
@ ShowAll
Show upside down for all labels, including dynamic ones.
QgsUnitTypes::RenderUnit offsetUnits
Units for offsets of label.
@ PerimeterCurved
Arranges candidates following the curvature of a polygon's boundary. Applies to polygon layers only.
@ Curved
Arranges candidates following the curvature of a line feature. Applies to line layers only.
@ Horizontal
Arranges horizontal candidates scattered throughout a polygon feature. Applies to polygon layers only...
@ OverPoint
Arranges candidates over a point (or centroid of a polygon), or at a preset offset from the point....
@ AroundPoint
Arranges candidates in a circle around a point (or centroid of a polygon). Applies to point or polygo...
@ Line
Arranges candidates parallel to a generalised line representing the feature or parallel to a polygon'...
double angleOffset
Label rotation, in degrees clockwise.
double maxCurvedCharAngleOut
Maximum angle between outside curved label characters (valid range -20.0 to -95.0)
const QgsLabelLineSettings & lineSettings() const
Returns the label line settings, which contain settings related to how the label engine places and fo...
bool isExpression
true if this label is made from a expression string, e.g., FieldName || 'mm'
UpsideDownLabels upsidedownLabels
Controls whether upside down labels are displayed and how they are handled.
QString fieldName
Name of field (or an expression) to use for label text.
Resolves relative paths into absolute paths and vice versa.
QString writePath(const QString &filename) const
Prepare a filename to save it to the project file.
QString readPath(const QString &filename) const
Turn filename read from the project file to an absolute path.
A class to represent a 2D point.
Point geometry type, with support for z-dimension and m-values.
virtual QString translate(const QString &context, const QString &sourceText, const char *disambiguation=nullptr, int n=-1) const =0
The derived translate() translates with QTranslator and qm file the sourceText.
Encapsulates a QGIS project, including sets of map layers and their styles, layouts,...
QgsRelationManager * relationManager
static QgsProject * instance()
Returns the QgsProject singleton instance.
Q_INVOKABLE QgsMapLayer * mapLayer(const QString &layerId) const
Retrieve a pointer to a registered layer by layer ID.
QgsPathResolver pathResolver() const
Returns path resolver object with considering whether the project uses absolute or relative paths and...
QMap< QString, QgsMapLayer * > mapLayers(const bool validOnly=false) const
Returns a map of all registered layers by layer ID.
A grouped map of multiple QgsProperty objects, each referenced by a integer key value.
void setProperty(int key, const QgsProperty &property)
Adds a property to the collection and takes ownership of it.
Definition for a property.
@ Double
Double value (including negative values)
static QgsProperty fromField(const QString &fieldName, bool isActive=true)
Returns a new FieldBasedProperty created from the specified field name.
QString loadStyle(const QString &providerKey, const QString &uri, QString &errCause)
Loads a layer style defined by uri.
QString getStyleById(const QString &providerKey, const QString &uri, const QString &styleId, QString &errCause)
Gets a layer style defined by styleId.
static QgsProviderRegistry * instance(const QString &pluginPath=QString())
Means of accessing canonical single instance.
bool deleteStyleById(const QString &providerKey, const QString &uri, const QString &styleId, QString &errCause)
Deletes a layer style defined by styleId.
int listStyles(const QString &providerKey, const QString &uri, QStringList &ids, QStringList &names, QStringList &descriptions, QString &errCause)
Lists stored layer styles in the provider defined by providerKey and uri.
bool saveStyle(const QString &providerKey, const QString &uri, const QString &qmlStyle, const QString &sldStyle, const QString &styleName, const QString &styleDescription, const QString &uiFileContent, bool useAsDefault, QString &errCause)
Saves a layer style to provider.
Allows entering a context category and takes care of leaving this category on deletion of the class.
The class is used as a container of context for various read/write operations on other objects.
MAYBE_UNUSED NODISCARD QgsReadWriteContextCategoryPopper enterCategory(const QString &category, const QString &details=QString()) const
Push a category to the stack.
const QgsProjectTranslator * projectTranslator() const
Returns the project translator.
QgsCoordinateTransformContext transformContext() const
Returns data provider coordinate transform context.
const QgsPathResolver & pathResolver() const
Returns path resolver for conversion between relative and absolute paths.
A rectangle specified with double values.
QString toString(int precision=16) const
Returns a string representation of form xmin,ymin : xmax,ymax Coordinates will be truncated to the sp...
double yMaximum() const SIP_HOLDGIL
Returns the y maximum value (top side of rectangle).
double xMaximum() const SIP_HOLDGIL
Returns the x maximum value (right side of rectangle).
double xMinimum() const SIP_HOLDGIL
Returns the x minimum value (left side of rectangle).
double yMinimum() const SIP_HOLDGIL
Returns the y minimum value (bottom side of rectangle).
bool isNull() const
Test if the rectangle is null (all coordinates zero or after call to setMinimal()).
double height() const SIP_HOLDGIL
Returns the height of the rectangle.
void set(const QgsPointXY &p1, const QgsPointXY &p2, bool normalize=true)
Sets the rectangle from two QgsPoints.
void setMinimal() SIP_HOLDGIL
Set a rectangle so that min corner is at max and max corner is at min.
double width() const SIP_HOLDGIL
Returns the width of the rectangle.
void combineExtentWith(const QgsRectangle &rect)
Expands the rectangle so that it covers both the original rectangle and the given rectangle.
void normalize()
Normalize the rectangle so it has non-negative width/height.
QList< QgsRelation > referencedRelations(const QgsVectorLayer *layer=nullptr) const
Gets all relations where this layer is the referenced part (i.e.
QList< QgsRelation > referencingRelations(const QgsVectorLayer *layer=nullptr, int fieldIdx=-2) const
Gets all relations where the specified layer (and field) is the referencing part (i....
void relationsLoaded()
Emitted when the relations were loaded after reading a project.
@ Normal
A normal relation.
@ Composition
Fix relation, related elements are part of the parent and a parent copy will copy any children or del...
Contains information about the context of a rendering operation.
double rendererScale() const
Returns the renderer map scale.
bool useRenderingOptimization() const
Returns true if the rendering optimization (geometry simplification) can be executed.
A child rule for QgsRuleBasedLabeling.
void appendChild(QgsRuleBasedLabeling::Rule *rule)
add child rule, take ownership, sets this as parent
Rule based labeling for a vector layer.
This class is a composition of two QSettings instances:
T flagValue(const QString &key, const T &defaultValue, const Section section=NoSection)
Returns the setting value for a setting based on a flag.
QVariant value(const QString &key, const QVariant &defaultValue=QVariant(), Section section=NoSection) const
Returns the value for setting key.
T enumValue(const QString &key, const T &defaultValue, const Section section=NoSection)
Returns the setting value for a setting based on an enum.
Renders the diagrams for all features with the same settings.
Manages stored expressions regarding creation, modification and storing in the project.
bool writeXml(QDomNode &layerNode) const
Writes the stored expressions out in XML format.
bool readXml(const QDomNode &layerNode)
Reads the stored expressions in in XML format.
An interface for classes which can visit style entity (e.g.
static QgsUnitTypes::RenderUnit decodeSldUom(const QString &str, double *scaleFactor=nullptr)
Decodes a SLD unit of measure string to a render unit.
static QgsStringMap getSvgParameterList(QDomElement &element)
static void mergeScaleDependencies(double mScaleMinDenom, double mScaleMaxDenom, QVariantMap &props)
Merges the local scale limits, if any, with the ones already in the map, if any.
static bool fillFromSld(QDomElement &element, Qt::BrushStyle &brushStyle, QColor &color)
long addTask(QgsTask *task, int priority=0)
Adds a task to the manager.
void taskCompleted()
Will be emitted by task to indicate its successful completion.
void taskTerminated()
Will be emitted by task if it has terminated for any reason other then completion (e....
bool isActive() const
Returns true if the temporal property is active.
Container for settings relating to a text buffer.
void setColor(const QColor &color)
Sets the color for the buffer.
void setEnabled(bool enabled)
Sets whether the text buffer will be drawn.
void setSizeUnit(QgsUnitTypes::RenderUnit unit)
Sets the units used for the buffer size.
void setSize(double size)
Sets the size of the buffer.
Container for all settings relating to text rendering.
void setColor(const QColor &color)
Sets the color that text will be rendered in.
void setSize(double size)
Sets the size for rendered text.
void setFont(const QFont &font)
Sets the font used for rendering text.
void setBuffer(const QgsTextBufferSettings &bufferSettings)
Sets the text's buffer settings.
void setSizeUnit(QgsUnitTypes::RenderUnit unit)
Sets the units for the size of rendered text.
This class allows including a set of layers in a database-side transaction, provided the layer data p...
QString createSavepoint(QString &error)
creates a save point returns empty string on error returns the last created savepoint if it's not dir...
void dirtied(const QString &sql, const QString &name)
Emitted if a sql query is executed and the underlying data is modified.
RenderUnit
Rendering size units.
@ RenderPoints
Points (e.g., for font sizes)
This is the base class for vector data providers.
virtual QString dataComment() const override
Returns a short comment for the data that this provider is providing access to (e....
@ ReadLayerMetadata
Provider can read layer metadata from data store. Since QGIS 3.0. See QgsDataProvider::layerMetadata(...
@ SelectAtId
Fast access to features using their ID.
@ DeleteFeatures
Allows deletion of features.
@ CreateLabeling
Provider can set labeling settings using backend-specific formatting information. Since QGIS 3....
@ CreateRenderer
Provider can create feature renderers using backend-specific formatting information....
QgsWkbTypes::Type wkbType() const override=0
Returns the geometry type which is returned by this layer.
virtual bool isSaveAndLoadStyleToDatabaseSupported() const
It returns false by default.
static const int EditingCapabilities
Bitmask of all provider's editing capabilities.
long long featureCount() const override=0
Number of features in the layer.
virtual QgsFeatureRenderer * createRenderer(const QVariantMap &configuration=QVariantMap()) const
Creates a new vector layer feature renderer, using provider backend specific information.
virtual QString storageType() const
Returns the permanent storage type for this layer as a friendly name.
virtual QStringList uniqueStringsMatching(int index, const QString &substring, int limit=-1, QgsFeedback *feedback=nullptr) const
Returns unique string values of an attribute which contain a specified subset string.
void raiseError(const QString &msg) const
Signals an error in this provider.
virtual bool isSqlQuery() const
Returns true if the layer is a query (SQL) layer.
virtual bool empty() const
Returns true if the layer does not contain any feature.
virtual QgsAttributeList pkAttributeIndexes() const
Returns list of indexes of fields that make up the primary key.
virtual void handlePostCloneOperations(QgsVectorDataProvider *source)
Handles any post-clone operations required after this vector data provider was cloned from the source...
virtual QSet< QgsMapLayerDependency > dependencies() const
Gets the list of layer ids on which this layer depends.
virtual void setEncoding(const QString &e)
Set encoding used for accessing data from layer.
virtual Qgis::VectorLayerTypeFlags vectorLayerTypeFlags() const
Returns the vector layer type flags.
QVariant maximumValue(int index) const override
Returns the maximum value of an attribute.
QgsFields fields() const override=0
Returns the fields associated with this data provider.
QVariant minimumValue(int index) const override
Returns the minimum value of an attribute.
virtual QVariant aggregate(QgsAggregateCalculator::Aggregate aggregate, int index, const QgsAggregateCalculator::AggregateParameters ¶meters, QgsExpressionContext *context, bool &ok, QgsFeatureIds *fids=nullptr) const
Calculates an aggregated value from the layer's features.
QString encoding() const
Returns the encoding which is used for accessing data.
virtual QVariant defaultValue(int fieldIndex) const
Returns any literal default values which are present at the provider for a specified field index.
QgsFieldConstraints::Constraints fieldConstraints(int fieldIndex) const
Returns any constraints which are present at the provider for a specified field index.
virtual QgsTransaction * transaction() const
Returns the transaction this data provider is included in, if any.
virtual QgsAbstractVectorLayerLabeling * createLabeling(const QVariantMap &configuration=QVariantMap()) const
Creates labeling settings, using provider backend specific information.
virtual Q_INVOKABLE QgsVectorDataProvider::Capabilities capabilities() const
Returns flags containing the supported capabilities.
QgsVectorDataProviderTemporalCapabilities * temporalCapabilities() override
Returns the provider's temporal capabilities.
QString capabilitiesString() const
Returns the above in friendly format.
void committedAttributesDeleted(const QString &layerId, const QgsAttributeList &deletedAttributes)
Signals emitted after committing changes.
virtual bool deleteFeature(QgsFeatureId fid)
Delete a feature from the layer (but does not commit it)
QgsFeatureIds deletedFeatureIds() const
Returns a list of deleted feature IDs which are not committed.
QgsChangedAttributesMap changedAttributeValues() const
Returns a map of features with changed attributes values which are not committed.
void committedAttributeValuesChanges(const QString &layerId, const QgsChangedAttributesMap &changedAttributesValues)
virtual bool renameAttribute(int attr, const QString &newName)
Renames an attribute field (but does not commit it)
void geometryChanged(QgsFeatureId fid, const QgsGeometry &geom)
Emitted when a feature's geometry is changed.
virtual bool addAttribute(const QgsField &field)
Adds an attribute field (but does not commit it) returns true if the field was added.
void committedAttributesAdded(const QString &layerId, const QList< QgsField > &addedAttributes)
virtual bool addFeatures(QgsFeatureList &features)
Insert a copy of the given features into the layer (but does not commit it)
virtual bool changeAttributeValues(QgsFeatureId fid, const QgsAttributeMap &newValues, const QgsAttributeMap &oldValues)
Changes values of attributes (but does not commit it).
QgsFeatureMap addedFeatures() const
Returns a map of new features which are not committed.
virtual bool isModified() const
Returns true if the provider has been modified since the last commit.
void updateFields(QgsFields &fields)
Updates fields.
void committedFeaturesAdded(const QString &layerId, const QgsFeatureList &addedFeatures)
void featureDeleted(QgsFeatureId fid)
QgsGeometryMap changedGeometries() const
Returns a map of features with changed geometries which are not committed.
QgsAttributeList deletedAttributeIds() const
Returns a list of deleted attributes fields which are not committed.
void attributeAdded(int idx)
void committedGeometriesChanges(const QString &layerId, const QgsGeometryMap &changedGeometries)
virtual bool addFeature(QgsFeature &f)
Adds a feature.
virtual void rollBack()
Stop editing and discard the edits.
void attributeDeleted(int idx)
void featureAdded(QgsFeatureId fid)
void attributeValueChanged(QgsFeatureId fid, int idx, const QVariant &)
virtual bool commitChanges(QStringList &commitErrors)
Attempts to commit any changes to disk.
virtual bool deleteAttribute(int attr)
Deletes an attribute field (but does not commit it)
virtual bool changeAttributeValue(QgsFeatureId fid, int field, const QVariant &newValue, const QVariant &oldValue=QVariant())
Changed an attribute value (but does not commit it)
virtual bool changeGeometry(QgsFeatureId fid, const QgsGeometry &geom)
Change feature's geometry.
void layerModified()
Emitted when modifications has been done on layer.
void committedFeaturesRemoved(const QString &layerId, const QgsFeatureIds &deletedFeatureIds)
int translateFeature(QgsFeatureId featureId, double dx, double dy)
Translates feature by dx, dy.
bool insertVertex(double x, double y, QgsFeatureId atFeatureId, int beforeVertex)
Insert a new vertex before the given vertex number, in the given ring, item (first number is index 0)...
Q_DECL_DEPRECATED Qgis::GeometryOperationResult addPart(const QVector< QgsPointXY > &ring, QgsFeatureId featureId)
Adds a new part polygon to a multipart feature.
Qgis::VectorEditResult deleteVertex(QgsFeatureId featureId, int vertex)
Deletes a vertex from a feature.
int addTopologicalPoints(const QgsGeometry &geom)
Adds topological points for every vertex of the geometry.
Q_DECL_DEPRECATED Qgis::GeometryOperationResult splitParts(const QVector< QgsPointXY > &splitLine, bool topologicalEditing=false)
Splits parts cut by the given line.
Q_DECL_DEPRECATED Qgis::GeometryOperationResult splitFeatures(const QVector< QgsPointXY > &splitLine, bool topologicalEditing=false)
Splits features cut by the given line.
bool moveVertex(double x, double y, QgsFeatureId atFeatureId, int atVertex)
Moves the vertex at the given position number, ring and item (first number is index 0),...
Q_DECL_DEPRECATED Qgis::GeometryOperationResult addRing(const QVector< QgsPointXY > &ring, const QgsFeatureIds &targetFeatureIds=QgsFeatureIds(), QgsFeatureId *modifiedFeatureId=nullptr)
Adds a ring to polygon/multipolygon features.
Counts the features in a QgsVectorLayer in task.
QHash< QString, long long > symbolFeatureCountMap() const
Returns the count for each symbol.
void cancel() override
Notifies the task that it should terminate.
QHash< QString, QgsFeatureIds > symbolFeatureIdMap() const
Returns the QgsFeatureIds for each symbol.
Manages joined fields for a vector layer.
void resolveReferences(QgsProject *project)
Resolves layer IDs of joined layers using given project's available layers.
bool addJoin(const QgsVectorLayerJoinInfo &joinInfo)
Joins another vector layer to this layer.
void readXml(const QDomNode &layer_node)
Reads joins from project file.
void writeXml(QDomNode &layer_node, QDomDocument &document) const
Saves mVectorJoins to xml under the layer node.
const QgsVectorJoinList & vectorJoins() const
const QgsVectorLayerJoinInfo * joinForFieldIndex(int index, const QgsFields &fields, int &sourceFieldIndex) const
Finds the vector join for a layer field index.
bool changeAttributeValue(QgsFeatureId fid, int field, const QVariant &newValue, const QVariant &oldValue=QVariant())
Changes attribute value in joined layers.
bool removeJoin(const QString &joinLayerId)
Removes a vector layer join.
bool containsJoins() const
Quick way to test if there is any join at all.
bool changeAttributeValues(QgsFeatureId fid, const QgsAttributeMap &newValues, const QgsAttributeMap &oldValues=QgsAttributeMap())
Changes attributes' values in joined layers.
bool addFeatures(QgsFeatureList &features, QgsFeatureSink::Flags flags=QgsFeatureSink::Flags()) override
Adds a list of features in joined layers.
void joinedFieldsChanged()
Emitted whenever the list of joined fields changes (e.g.
void updateFields(QgsFields &fields)
Updates field map with joined attributes.
bool deleteFeature(QgsFeatureId fid, QgsVectorLayer::DeleteContext *context=nullptr) const
Deletes a feature from joined layers.
Defines left outer join from our vector layer to some other vector layer.
QString targetFieldName() const
Returns name of the field of our layer that will be used for join.
QString joinLayerId() const
ID of the joined layer - may be used to resolve reference to the joined layer.
Implementation of threaded rendering for vector layers.
Basic implementation of the labeling interface.
Implementation of map layer temporal properties for vector layers.
void guessDefaultsFromFields(const QgsFields &fields)
Attempts to setup the temporal properties by scanning a set of fields and looking for standard naming...
void setDefaultsFromDataProviderTemporalCapabilities(const QgsDataProviderTemporalCapabilities *capabilities) override
Sets the layers temporal settings to appropriate defaults based on a provider's temporal capabilities...
static QString guessFriendlyIdentifierField(const QgsFields &fields, bool *foundFriendly=nullptr)
Given a set of fields, attempts to pick the "most useful" field for user-friendly identification of f...
Represents a vector layer which manages a vector based data sets.
void setLabeling(QgsAbstractVectorLayerLabeling *labeling)
Sets labeling configuration.
QString attributeDisplayName(int index) const
Convenience function that returns the attribute alias if defined or the field name else.
Q_INVOKABLE QgsWkbTypes::Type wkbType() const FINAL
Returns the WKBType or WKBUnknown in case of error.
QVariant maximumValue(int index) const FINAL
Returns the maximum value for an attribute column or an invalid variant in case of error.
int addExpressionField(const QString &exp, const QgsField &fld)
Add a new field which is calculated by the expression specified.
void committedFeaturesAdded(const QString &layerId, const QgsFeatureList &addedFeatures)
Emitted when features are added to the provider if not in transaction mode.
void setExtent(const QgsRectangle &rect) FINAL
Sets the extent.
Q_DECL_DEPRECATED Qgis::GeometryOperationResult addPart(const QList< QgsPointXY > &ring)
Adds a new part polygon to a multipart feature.
QgsRectangle sourceExtent() const FINAL
Returns the extent of all geometries from the source.
void featureBlendModeChanged(QPainter::CompositionMode blendMode)
Signal emitted when setFeatureBlendMode() is called.
bool labelsEnabled() const
Returns whether the layer contains labels which are enabled and should be drawn.
bool writeSymbology(QDomNode &node, QDomDocument &doc, QString &errorMessage, const QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories=QgsMapLayer::AllStyleCategories) const FINAL
bool isModified() const override
Returns true if the provider has been modified since the last commit.
bool writeStyle(QDomNode &node, QDomDocument &doc, QString &errorMessage, const QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories=QgsMapLayer::AllStyleCategories) const FINAL
void addFeatureRendererGenerator(QgsFeatureRendererGenerator *generator)
Adds a new feature renderer generator to the layer.
Q_DECL_DEPRECATED void setExcludeAttributesWfs(const QSet< QString > &att)
A set of attributes that are not advertised in WFS requests with QGIS server.
Q_INVOKABLE void selectByRect(QgsRectangle &rect, Qgis::SelectBehavior behavior=Qgis::SelectBehavior::SetSelection)
Selects features found within the search rectangle (in layer's coordinates)
void removeFieldAlias(int index)
Removes an alias (a display name) for attributes to display in dialogs.
void setAuxiliaryLayer(QgsAuxiliaryLayer *layer=nullptr)
Sets the current auxiliary layer.
void beforeRemovingExpressionField(int idx)
Will be emitted, when an expression field is going to be deleted from this vector layer.
QString loadDefaultStyle(bool &resultFlag) FINAL
Retrieve the default style for this layer if one exists (either as a .qml file on disk or as a record...
Q_INVOKABLE QgsWkbTypes::GeometryType geometryType() const
Returns point, line or polygon.
void committedGeometriesChanges(const QString &layerId, const QgsGeometryMap &changedGeometries)
Emitted when geometry changes are saved to the provider if not in transaction mode.
void beforeCommitChanges(bool stopEditing)
Emitted before changes are committed to the data provider.
Q_INVOKABLE bool startEditing()
Makes the layer editable.
QMap< QgsFieldConstraints::Constraint, QgsFieldConstraints::ConstraintStrength > fieldConstraintsAndStrength(int fieldIndex) const
Returns a map of constraint with their strength for a specific field of the layer.
bool addJoin(const QgsVectorLayerJoinInfo &joinInfo)
Joins another vector layer to this layer.
QSet< QgsMapLayerDependency > dependencies() const FINAL
Gets the list of dependencies.
QgsMapLayerTemporalProperties * temporalProperties() override
Returns temporal properties associated with the vector layer.
void mapTipTemplateChanged()
Emitted when the map tip changes.
Q_DECL_DEPRECATED Qgis::GeometryOperationResult splitFeatures(const QVector< QgsPointXY > &splitLine, bool topologicalEditing=false)
Splits features cut by the given line.
QgsDefaultValue defaultValueDefinition(int index) const
Returns the definition of the expression used when calculating the default value for a field.
QgsExpressionContextScope * createExpressionContextScope() const FINAL
This method needs to be reimplemented in all classes which implement this interface and return an exp...
QgsMapLayerRenderer * createMapRenderer(QgsRenderContext &rendererContext) FINAL
Returns new instance of QgsMapLayerRenderer that will be used for rendering of given context.
QgsVectorLayerFeatureCounter * countSymbolFeatures(bool storeSymbolFids=false)
Count features for symbols.
QPainter::CompositionMode featureBlendMode() const
Returns the current blending mode for features.
QString constraintExpression(int index) const
Returns the constraint expression for for a specified field index, if set.
bool addAttribute(const QgsField &field)
Add an attribute field (but does not commit it) returns true if the field was added.
void attributeAdded(int idx)
Will be emitted, when a new attribute has been added to this vector layer.
QString capabilitiesString() const
Capabilities for this layer, comma separated and translated.
void deselect(QgsFeatureId featureId)
Deselects feature by its ID.
virtual int listStylesInDatabase(QStringList &ids, QStringList &names, QStringList &descriptions, QString &msgError)
Lists all the style in db split into related to the layer and not related to.
void allowCommitChanged()
Emitted whenever the allowCommitChanged() property of this layer changes.
friend class QgsVectorLayerEditBuffer
void editCommandStarted(const QString &text)
Signal emitted when a new edit command has been started.
void updateFields()
Will regenerate the fields property of this layer by obtaining all fields from the dataProvider,...
bool isSpatial() const FINAL
Returns true if this is a geometry layer and false in case of NoGeometry (table only) or UnknownGeome...
virtual QString loadNamedStyle(const QString &theURI, bool &resultFlag, bool loadFromLocalDb, QgsMapLayer::StyleCategories categories=QgsMapLayer::AllStyleCategories)
Loads a named style from file/local db/datasource db.
void setFieldConstraint(int index, QgsFieldConstraints::Constraint constraint, QgsFieldConstraints::ConstraintStrength strength=QgsFieldConstraints::ConstraintStrengthHard)
Sets a constraint for a specified field index.
bool loadAuxiliaryLayer(const QgsAuxiliaryStorage &storage, const QString &key=QString())
Loads the auxiliary layer for this vector layer.
bool deleteFeature(QgsFeatureId fid, DeleteContext *context=nullptr)
Deletes a feature from the layer (but does not commit it).
bool insertVertex(double x, double y, QgsFeatureId atFeatureId, int beforeVertex)
Inserts a new vertex before the given vertex number, in the given ring, item (first number is index 0...
QgsFeatureIterator getFeatures(const QgsFeatureRequest &request=QgsFeatureRequest()) const FINAL
Queries the layer for features specified in request.
QString htmlMetadata() const FINAL
Obtain a formatted HTML string containing assorted metadata for this layer.
Q_INVOKABLE QgsRectangle boundingBoxOfSelected() const
Returns the bounding box of the selected features. If there is no selection, QgsRectangle(0,...
QgsFields fields() const FINAL
Returns the list of fields of this layer.
bool addFeatures(QgsFeatureList &features, QgsFeatureSink::Flags flags=QgsFeatureSink::Flags()) FINAL
Adds a list of features to the sink.
Q_INVOKABLE QgsFeatureList selectedFeatures() const
Returns a copy of the user-selected features.
QString expressionField(int index) const
Returns the expression used for a given expression field.
bool readSymbology(const QDomNode &layerNode, QString &errorMessage, QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories=QgsMapLayer::AllStyleCategories) FINAL
void removeFeatureRendererGenerator(const QString &id)
Removes the feature renderer with matching id from the layer.
friend class QgsVectorLayerEditPassthrough
void setSimplifyMethod(const QgsVectorSimplifyMethod &simplifyMethod)
Sets the simplification settings for fast rendering of features.
void editCommandDestroyed()
Signal emitted, when an edit command is destroyed.
QgsFieldConstraints::Constraints fieldConstraints(int fieldIndex) const
Returns any constraints which are present for a specified field index.
bool deleteFeatures(const QgsFeatureIds &fids, DeleteContext *context=nullptr)
Deletes a set of features from the layer (but does not commit it)
void setMapTipTemplate(const QString &mapTipTemplate)
The mapTip is a pretty, html representation for feature information.
Q_DECL_DEPRECATED QSet< QString > excludeAttributesWms() const
A set of attributes that are not advertised in WMS requests with QGIS server.
QgsFeatureIds symbolFeatureIds(const QString &legendKey) const
Ids of features rendered with specified legend key.
const QgsDiagramLayerSettings * diagramLayerSettings() const
void removeFieldConstraint(int index, QgsFieldConstraints::Constraint constraint)
Removes a constraint for a specified field index.
int selectedFeatureCount() const
Returns the number of features that are selected in this layer.
virtual QString getStyleFromDatabase(const QString &styleId, QString &msgError)
Returns the named style corresponding to style id provided.
void featuresDeleted(const QgsFeatureIds &fids)
Emitted when features have been deleted.
Qgis::VectorLayerTypeFlags vectorLayerTypeFlags() const
Returns the vector layer type flags.
void setLabelsEnabled(bool enabled)
Sets whether labels should be enabled for the layer.
void subsetStringChanged()
Emitted when the layer's subset string has changed.
void setFieldConfigurationFlags(int index, QgsField::ConfigurationFlags flags)
Sets the configuration flags of the field at given index.
QgsAuxiliaryLayer * auxiliaryLayer()
Returns the current auxiliary layer.
void setCoordinateSystem()
Setup the coordinate system transformation for the layer.
void committedFeaturesRemoved(const QString &layerId, const QgsFeatureIds &deletedFeatureIds)
Emitted when features are deleted from the provider if not in transaction mode.
void updateExpressionField(int index, const QString &exp)
Changes the expression used to define an expression based (virtual) field.
~QgsVectorLayer() override
QgsCoordinateReferenceSystem sourceCrs() const FINAL
Returns the coordinate reference system for features in the source.
void endEditCommand()
Finish edit command and add it to undo/redo stack.
void destroyEditCommand()
Destroy active command and reverts all changes in it.
bool isAuxiliaryField(int index, int &srcIndex) const
Returns true if the field comes from the auxiliary layer, false otherwise.
QgsExpressionContext createExpressionContext() const FINAL
This method needs to be reimplemented in all classes which implement this interface and return an exp...
QList< QgsRelation > referencingRelations(int idx) const
Returns the layer's relations, where the foreign key is on this layer.
Q_DECL_DEPRECATED QSet< QString > excludeAttributesWfs() const
A set of attributes that are not advertised in WFS requests with QGIS server.
Q_DECL_DEPRECATED Qgis::GeometryOperationResult splitParts(const QVector< QgsPointXY > &splitLine, bool topologicalEditing=false)
Splits parts cut by the given line.
void setDefaultValueDefinition(int index, const QgsDefaultValue &definition)
Sets the definition of the expression to use when calculating the default value for a field.
bool diagramsEnabled() const
Returns whether the layer contains diagrams which are enabled and should be drawn.
void setAllowCommit(bool allowCommit)
Controls, if the layer is allowed to commit changes.
bool setDependencies(const QSet< QgsMapLayerDependency > &layers) FINAL
Sets the list of dependencies.
void symbolFeatureCountMapChanged()
Emitted when the feature count for symbols on this layer has been recalculated.
Q_INVOKABLE const QgsFeatureIds & selectedFeatureIds() const
Returns a list of the selected features IDs in this layer.
Qgis::VectorEditResult deleteVertex(QgsFeatureId featureId, int vertex)
Deletes a vertex from a feature.
void setFeatureBlendMode(QPainter::CompositionMode blendMode)
Sets the blending mode used for rendering each feature.
QString constraintDescription(int index) const
Returns the descriptive name for the constraint expression for a specified field index.
void writeCustomSymbology(QDomElement &element, QDomDocument &doc, QString &errorMessage) const
Signal emitted whenever the symbology (QML-file) for this layer is being written.
void setProviderEncoding(const QString &encoding)
Sets the text encoding of the data provider.
bool writeSld(QDomNode &node, QDomDocument &doc, QString &errorMessage, const QVariantMap &props=QVariantMap()) const
Writes the symbology of the layer into the document provided in SLD 1.1 format.
void setDisplayExpression(const QString &displayExpression)
Set the preview expression, used to create a human readable preview string.
virtual bool deleteAttribute(int attr)
Deletes an attribute field (but does not commit it).
void resolveReferences(QgsProject *project) FINAL
Resolves references to other layers (kept as layer IDs after reading XML) into layer objects.
bool changeAttributeValues(QgsFeatureId fid, const QgsAttributeMap &newValues, const QgsAttributeMap &oldValues=QgsAttributeMap(), bool skipDefaultValues=false)
Changes attributes' values for a feature (but does not immediately commit the changes).
bool removeJoin(const QString &joinLayerId)
Removes a vector layer join.
Q_INVOKABLE void invertSelectionInRectangle(QgsRectangle &rect)
Inverts selection of features found within the search rectangle (in layer's coordinates)
void setRenderer(QgsFeatureRenderer *r)
Sets the feature renderer which will be invoked to represent this layer in 2D map views.
Q_INVOKABLE void selectAll()
Select all the features.
bool isEditable() const FINAL
Returns true if the provider is in editing mode.
QStringList commitErrors() const
Returns a list containing any error messages generated when attempting to commit changes to the layer...
QString storageType() const
Returns the permanent storage type for this layer as a friendly name.
bool readExtentFromXml() const
Returns true if the extent is read from the XML document when data source has no metadata,...
QString dataComment() const
Returns a description for this layer as defined in the data provider.
virtual void saveStyleToDatabase(const QString &name, const QString &description, bool useAsDefault, const QString &uiFileContent, QString &msgError)
Saves named and sld style of the layer to the style table in the db.
bool accept(QgsStyleEntityVisitorInterface *visitor) const override
QgsGeometryOptions * geometryOptions() const
Configuration and logic to apply automatically on any edit happening on this layer.
QgsStringMap attributeAliases() const
Returns a map of field name to attribute alias.
Q_INVOKABLE int translateFeature(QgsFeatureId featureId, double dx, double dy)
Translates feature by dx, dy.
virtual void updateExtents(bool force=false)
Update the extents for the layer.
void attributeDeleted(int idx)
Will be emitted, when an attribute has been deleted from this vector layer.
QgsActionManager * actions()
Returns all layer actions defined on this layer.
void beforeEditingStarted()
Emitted before editing on this layer is started.
void committedAttributeValuesChanges(const QString &layerId, const QgsChangedAttributesMap &changedAttributesValues)
Emitted when attribute value changes are saved to the provider if not in transaction mode.
void committedAttributesAdded(const QString &layerId, const QList< QgsField > &addedAttributes)
Emitted when attributes are added to the provider if not in transaction mode.
void setEditFormConfig(const QgsEditFormConfig &editFormConfig)
Sets the editFormConfig (configuration) of the form used to represent this vector layer.
void committedAttributesDeleted(const QString &layerId, const QgsAttributeList &deletedAttributes)
Emitted when attributes are deleted from the provider if not in transaction mode.
QString displayExpression
void displayExpressionChanged()
Emitted when the display expression changes.
QVariant minimumValue(int index) const FINAL
Returns the minimum value for an attribute column or an invalid variant in case of error.
QgsFeatureIterator getSelectedFeatures(QgsFeatureRequest request=QgsFeatureRequest()) const
Returns an iterator of the selected features.
void setEditorWidgetSetup(int index, const QgsEditorWidgetSetup &setup)
The editor widget setup defines which QgsFieldFormatter and editor widget will be used for the field ...
void setConstraintExpression(int index, const QString &expression, const QString &description=QString())
Sets the constraint expression for the specified field index.
Q_INVOKABLE bool rollBack(bool deleteBuffer=true)
Stops a current editing operation and discards any uncommitted edits.
bool readStyle(const QDomNode &node, QString &errorMessage, QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories=QgsMapLayer::AllStyleCategories) FINAL
bool updateFeature(QgsFeature &feature, bool skipDefaultValues=false)
Updates an existing feature in the layer, replacing the attributes and geometry for the feature with ...
Q_INVOKABLE bool commitChanges(bool stopEditing=true)
Attempts to commit to the underlying data provider any buffered changes made since the last to call t...
QgsVectorDataProvider * dataProvider() FINAL
Returns the layer's data provider, it may be nullptr.
bool setReadOnly(bool readonly=true)
Makes layer read-only (editing disabled) or not.
QgsField::ConfigurationFlags fieldConfigurationFlags(int index) const
Returns the configuration flags of the field at given index.
void editFormConfigChanged()
Will be emitted whenever the edit form configuration of this layer changes.
Q_INVOKABLE void modifySelection(const QgsFeatureIds &selectIds, const QgsFeatureIds &deselectIds)
Modifies the current selection on this layer.
void reselect()
Reselects the previous set of selected features.
void select(QgsFeatureId featureId)
Selects feature by its ID.
QgsEditorWidgetSetup editorWidgetSetup(int index) const
The editor widget setup defines which QgsFieldFormatter and editor widget will be used for the field ...
long long featureCount() const FINAL
Returns feature count including changes which have not yet been committed If you need only the count ...
virtual bool deleteStyleFromDatabase(const QString &styleId, QString &msgError)
Deletes a style from the database.
void setReadExtentFromXml(bool readExtentFromXml)
Flag allowing to indicate if the extent has to be read from the XML document when data source has no ...
void afterCommitChanges()
Emitted after changes are committed to the data provider.
QgsVectorLayer * clone() const override
Returns a new instance equivalent to this one.
QgsAttributeTableConfig attributeTableConfig() const
Returns the attribute table configuration object.
bool readSld(const QDomNode &node, QString &errorMessage) FINAL
QgsFeature getFeature(QgsFeatureId fid) const
Queries the layer for the feature with the given id.
Q_INVOKABLE void selectByIds(const QgsFeatureIds &ids, Qgis::SelectBehavior behavior=Qgis::SelectBehavior::SetSelection)
Selects matching features using a list of feature IDs.
QStringList uniqueStringsMatching(int index, const QString &substring, int limit=-1, QgsFeedback *feedback=nullptr) const
Returns unique string values of an attribute which contain a specified subset string.
void raiseError(const QString &msg)
Signals an error related to this vector layer.
void editCommandEnded()
Signal emitted, when an edit command successfully ended.
void supportsEditingChanged()
Emitted when the read only state or the data provider of this layer is changed.
SpatialIndexPresence hasSpatialIndex() const override
void readOnlyChanged()
Emitted when the read only state of this layer is changed.
void removeExpressionField(int index)
Removes an expression field.
virtual void setTransformContext(const QgsCoordinateTransformContext &transformContext) override
Sets the coordinate transform context to transformContext.
void attributeValueChanged(QgsFeatureId fid, int idx, const QVariant &value)
Emitted whenever an attribute value change is done in the edit buffer.
static Q_DECL_DEPRECATED void drawVertexMarker(double x, double y, QPainter &p, Qgis::VertexMarkerType type, int vertexSize)
Draws a vertex symbol at (screen) coordinates x, y.
bool changeAttributeValue(QgsFeatureId fid, int field, const QVariant &newValue, const QVariant &oldValue=QVariant(), bool skipDefaultValues=false)
Changes an attribute value for a feature (but does not immediately commit the changes).
void setFieldConfigurationFlag(int index, QgsField::ConfigurationFlag flag, bool active)
Sets the given configuration flag for the field at given index to be active or not.
bool addFeature(QgsFeature &feature, QgsFeatureSink::Flags flags=QgsFeatureSink::Flags()) FINAL
Adds a single feature to the sink.
Q_INVOKABLE bool deleteSelectedFeatures(int *deletedCount=nullptr, DeleteContext *context=nullptr)
Deletes the selected features.
void setFieldAlias(int index, const QString &aliasString)
Sets an alias (a display name) for attributes to display in dialogs.
friend class QgsVectorLayerFeatureSource
void minimumAndMaximumValue(int index, QVariant &minimum, QVariant &maximum) const
Calculates both the minimum and maximum value for an attribute column.
QgsRectangle extent() const FINAL
Returns the extent of the layer.
Q_DECL_DEPRECATED void setExcludeAttributesWms(const QSet< QString > &att)
A set of attributes that are not advertised in WMS requests with QGIS server.
void setAttributeTableConfig(const QgsAttributeTableConfig &attributeTableConfig)
Sets the attribute table configuration object.
virtual bool setSubsetString(const QString &subset)
Sets the string (typically sql) used to define a subset of the layer.
bool readXml(const QDomNode &layer_node, QgsReadWriteContext &context) FINAL
Reads vector layer specific state from project file Dom node.
FeatureAvailability hasFeatures() const FINAL
Determines if this vector layer has features.
void afterRollBack()
Emitted after changes are rolled back.
QString decodedSource(const QString &source, const QString &provider, const QgsReadWriteContext &context) const FINAL
Called by readLayerXML(), used by derived classes to decode provider's specific data source from proj...
void setDiagramLayerSettings(const QgsDiagramLayerSettings &s)
QList< QgsWeakRelation > weakRelations() const
Returns the layer's weak relations as specified in the layer's style.
void selectionChanged(const QgsFeatureIds &selected, const QgsFeatureIds &deselected, bool clearAndSelect)
Emitted when selection was changed.
void beforeAddingExpressionField(const QString &fieldName)
Will be emitted, when an expression field is going to be added to this vector layer.
bool deleteAttributes(const QList< int > &attrs)
Deletes a list of attribute fields (but does not commit it)
void updatedFields()
Emitted whenever the fields available from this layer have been changed.
QVariant defaultValue(int index, const QgsFeature &feature=QgsFeature(), QgsExpressionContext *context=nullptr) const
Returns the calculated default value for the specified field index.
void featureAdded(QgsFeatureId fid)
Emitted when a new feature has been added to the layer.
QString sourceName() const FINAL
Returns a friendly display name for the source.
QString attributeAlias(int index) const
Returns the alias of an attribute name or a null string if there is no alias.
void featureDeleted(QgsFeatureId fid)
Emitted when a feature has been deleted.
Q_INVOKABLE void removeSelection()
Clear selection.
bool allowCommit() const
Controls, if the layer is allowed to commit changes.
QgsConditionalLayerStyles * conditionalStyles() const
Returns the conditional styles that are set for this layer.
void readCustomSymbology(const QDomElement &element, QString &errorMessage)
Signal emitted whenever the symbology (QML-file) for this layer is being read.
void reload() FINAL
Synchronises with changes in the datasource.
const QList< QgsVectorLayerJoinInfo > vectorJoins() const
bool renameAttribute(int index, const QString &newName)
Renames an attribute field (but does not commit it).
bool isSqlQuery() const
Returns true if the layer is a query (SQL) layer.
bool simplifyDrawingCanbeApplied(const QgsRenderContext &renderContext, QgsVectorSimplifyMethod::SimplifyHint simplifyHint) const
Returns whether the VectorLayer can apply the specified simplification hint.
Q_INVOKABLE void selectByExpression(const QString &expression, Qgis::SelectBehavior behavior=Qgis::SelectBehavior::SetSelection)
Selects matching features using an expression.
void beforeRollBack()
Emitted before changes are rolled back.
QgsAttributeList primaryKeyAttributes() const
Returns the list of attributes which make up the layer's primary keys.
const QgsAbstractVectorLayerLabeling * labeling() const
Access to const labeling configuration.
bool writeXml(QDomNode &layer_node, QDomDocument &doc, const QgsReadWriteContext &context) const FINAL
Writes vector layer specific state to project file Dom node.
QString encodedSource(const QString &source, const QgsReadWriteContext &context) const FINAL
Called by writeLayerXML(), used by derived classes to encode provider's specific data source to proje...
void beginEditCommand(const QString &text)
Create edit command for undo/redo operations.
QString displayField() const
This is a shorthand for accessing the displayExpression if it is a simple field.
const QgsDiagramRenderer * diagramRenderer() const
Q_DECL_DEPRECATED Qgis::GeometryOperationResult addRing(const QVector< QgsPointXY > &ring, QgsFeatureId *featureId=nullptr)
Adds a ring to polygon/multipolygon features.
void setDiagramRenderer(QgsDiagramRenderer *r)
Sets diagram rendering object (takes ownership)
void geometryChanged(QgsFeatureId fid, const QgsGeometry &geometry)
Emitted whenever a geometry change is done in the edit buffer.
QgsEditFormConfig editFormConfig
QList< const QgsFeatureRendererGenerator * > featureRendererGenerators() const
Returns a list of the feature renderer generators owned by the layer.
bool moveVertex(double x, double y, QgsFeatureId atFeatureId, int atVertex)
Moves the vertex at the given position number, ring and item (first number is index 0),...
QgsGeometry getGeometry(QgsFeatureId fid) const
Queries the layer for the geometry at the given id.
int addTopologicalPoints(const QgsGeometry &geom)
Adds topological points for every vertex of the geometry.
const QgsVectorSimplifyMethod & simplifyMethod() const
Returns the simplification settings for fast rendering of features.
void beforeModifiedCheck() const
Emitted when the layer is checked for modifications. Use for last-minute additions.
Q_INVOKABLE void invertSelection()
Selects not selected features and deselects selected ones.
QVariant aggregate(QgsAggregateCalculator::Aggregate aggregate, const QString &fieldOrExpression, const QgsAggregateCalculator::AggregateParameters ¶meters=QgsAggregateCalculator::AggregateParameters(), QgsExpressionContext *context=nullptr, bool *ok=nullptr, QgsFeatureIds *fids=nullptr, QgsFeedback *feedback=nullptr, QString *error=nullptr) const
Calculates an aggregated value from the layer's features.
bool changeGeometry(QgsFeatureId fid, QgsGeometry &geometry, bool skipDefaultValue=false)
Changes a feature's geometry within the layer's edit buffer (but does not immediately commit the chan...
QSet< QVariant > uniqueValues(int fieldIndex, int limit=-1) const FINAL
Calculates a list of unique values contained within an attribute in the layer.
QgsFeatureRenderer * renderer()
Returns the feature renderer used for rendering the features in the layer in 2D map views.
bool forceLocalOptimization() const
Gets where the simplification executes, after fetch the geometries from provider, or when supported,...
void setSimplifyHints(SimplifyHints simplifyHints)
Sets the simplification hints of the vector layer managed.
float maximumScale() const
Gets the maximum scale at which the layer should be simplified.
void setThreshold(float threshold)
Sets the simplification threshold of the vector layer managed.
void setSimplifyAlgorithm(SimplifyAlgorithm simplifyAlgorithm)
Sets the local simplification algorithm of the vector layer managed.
void setForceLocalOptimization(bool localOptimization)
Sets where the simplification executes, after fetch the geometries from provider, or when supported,...
SimplifyHints simplifyHints() const
Gets the simplification hints of the vector layer managed.
SimplifyAlgorithm simplifyAlgorithm() const
Gets the local simplification algorithm of the vector layer managed.
float threshold() const
Gets the simplification threshold of the vector layer managed.
SimplifyHint
Simplification flags for fast rendering of features.
SimplifyAlgorithm
Types of local simplification algorithms that can be used.
void setMaximumScale(float maximumScale)
Sets the maximum scale at which the layer should be simplified.
@ Referencing
The layer is referencing.
@ Referenced
The layer is referenced.
static void writeXml(const QgsVectorLayer *layer, WeakRelationType type, const QgsRelation &relation, QDomNode &node, QDomDocument &doc)
Writes a weak relation infoto an XML structure.
static QgsWeakRelation readXml(const QgsVectorLayer *layer, WeakRelationType type, const QDomNode &node, const QgsPathResolver resolver)
Returns a weak relation for the given layer.
static GeometryType geometryType(Type type) SIP_HOLDGIL
Returns the geometry type for a WKB type, e.g., both MultiPolygon and CurvePolygon would have a Polyg...
static QString geometryDisplayString(GeometryType type) SIP_HOLDGIL
Returns a display string for a geometry type.
GeometryType
The geometry types are used to group QgsWkbTypes::Type in a coarse way.
Type
The WKB type describes the number of dimensions a geometry has.
static QString displayString(Type type) SIP_HOLDGIL
Returns a non-translated display string type for a WKB type, e.g., the geometry name used in WKT geom...
static QDomElement writeVariant(const QVariant &value, QDomDocument &doc)
Write a QVariant to a QDomElement.
static QVariant readVariant(const QDomElement &element)
Read a QVariant from a QDomElement.
static QgsRectangle readRectangle(const QDomElement &element)
QgsMapLayerType
Types of layers that can be added to a map.
@ UnknownCount
Provider returned an unknown feature count.
@ VectorLayer
Vector layer.
double ANALYSIS_EXPORT angle(QgsPoint *p1, QgsPoint *p2, QgsPoint *p3, QgsPoint *p4)
Calculates the angle between two segments (in 2 dimension, z-values are ignored)
As part of the API refactoring and improvements which landed in the Processing API was substantially reworked from the x version This was done in order to allow much of the underlying Processing framework to be ported into c
bool qgsVariantEqual(const QVariant &lhs, const QVariant &rhs)
Compares two QVariant values and returns whether they are equal, two NULL values are always treated a...
bool qgsVariantLessThan(const QVariant &lhs, const QVariant &rhs)
Compares two QVariant values and returns whether the first is less than the second.
bool qgsVariantGreaterThan(const QVariant &lhs, const QVariant &rhs)
Compares two QVariant values and returns whether the first is greater than the second.
QString qgsEnumValueToKey(const T &value)
Returns the value for the given key of an enum.
T qgsFlagKeysToValue(const QString &keys, const T &defaultValue)
Returns the value corresponding to the given keys of a flag.
QMap< QString, QString > QgsStringMap
QString qgsFlagValueToKeys(const T &value)
Returns the value for the given keys of a flag.
T qgsEnumKeyToValue(const QString &key, const T &defaultValue, bool tryValueAsKey=true)
Returns the value corresponding to the given key of an enum.
QVector< QgsPoint > QgsPointSequence
QMap< int, QVariant > QgsAttributeMap
QList< QgsFeature > QgsFeatureList
QSet< QgsFeatureId > QgsFeatureIds
qint64 QgsFeatureId
64 bit feature ids negative numbers are used for uncommitted/newly added features
QList< int > QgsAttributeList
#define QgsDebugMsgLevel(str, level)
QMap< int, QgsPropertyDefinition > QgsPropertiesDefinition
Definition of available properties.
#define RENDERER_TAG_NAME
bool saveStyle_t(const QString &uri, const QString &qmlStyle, const QString &sldStyle, const QString &styleName, const QString &styleDescription, const QString &uiFileContent, bool useAsDefault, QString &errCause)
int listStyles_t(const QString &uri, QStringList &ids, QStringList &names, QStringList &descriptions, QString &errCause)
QString getStyleById_t(const QString &uri, QString styleID, QString &errCause)
bool deleteStyleById_t(const QString &uri, QString styleID, QString &errCause)
QString loadStyle_t(const QString &uri, QString &errCause)
QMap< QgsFeatureId, QgsFeature > QgsFeatureMap
A bundle of parameters controlling aggregate calculation.
Setting options for creating vector data providers.
Context for cascade delete features.
QList< QgsVectorLayer * > handledLayers(bool includeAuxiliaryLayers=true) const
Returns a list of all layers affected by the delete operation.
QMap< QgsVectorLayer *, QgsFeatureIds > mHandledFeatures
QgsFeatureIds handledFeatures(QgsVectorLayer *layer) const
Returns a list of feature IDs from the specified layer affected by the delete operation.
Setting options for loading vector layers.
QgsWkbTypes::Type fallbackWkbType
Fallback geometry type.
bool skipCrsValidation
Controls whether the layer is allowed to have an invalid/unknown CRS.
bool loadDefaultStyle
Set to true if the default layer style should be loaded.
QgsCoordinateTransformContext transformContext
Coordinate transform context.
QgsCoordinateReferenceSystem fallbackCrs
Fallback layer coordinate reference system.