92#include <QPainterPath>
94#include <QProgressDialog>
98#include <QStringBuilder>
100#include <QUndoCommand>
103#include <QRegularExpression>
120#ifdef TESTPROVIDERLIB
126 const QString &qmlStyle,
127 const QString &sldStyle,
128 const QString &styleName,
129 const QString &styleDescription,
130 const QString &uiFileContent,
144 QStringList &descriptions,
162 const QString &baseName,
163 const QString &providerKey,
168 , mAuxiliaryLayer( nullptr )
169 , mAuxiliaryLayerKey( QString() )
170 , mReadExtentFromXml( options.readExtentFromXml )
171 , mRefreshRendererTimer( new QTimer( this ) )
182 mGeometryOptions = std::make_unique<QgsGeometryOptions>();
186 mStoredExpressionManager->setParent(
this );
189 mJoinBuffer->setParent(
this );
194 if ( !vectorLayerPath.isEmpty() && !
mProviderKey.isEmpty() )
197 QgsDataProvider::ReadFlags providerFlags = QgsDataProvider::ReadFlags();
205 mDataSourceReadOnly =
true;
207 setDataSource( vectorLayerPath, baseName, providerKey, providerOptions, providerFlags );
212 if ( !mAttributeAliasMap.contains(
field.
name() ) )
213 mAttributeAliasMap.insert(
field.
name(), QString() );
219 if ( !mTemporalProperties->
isActive() )
244 connect( mRefreshRendererTimer, &QTimer::timeout,
this, [ = ] {
triggerRepaint(
true ); } );
253 delete mDataProvider;
256 delete mExpressionFieldBuffer;
258 delete mDiagramLayerSettings;
259 delete mDiagramRenderer;
264 delete mConditionalStyles;
265 delete mStoredExpressionManager;
267 if ( mFeatureCounter )
268 mFeatureCounter->
cancel();
270 qDeleteAll( mRendererGenerators );
291 options.forceReadOnly = mDataSourceReadOnly;
299 QList<QgsVectorLayerJoinInfo> joins =
vectorJoins();
300 const auto constJoins = joins;
320 for (
const QgsAction &action : constActions )
357 auto constraintIt = constraints.constBegin();
358 for ( ; constraintIt != constraints.constEnd(); ++ constraintIt )
374 layer->mElevationProperties = mElevationProperties->
clone();
375 layer->mElevationProperties->setParent( layer );
407 return mDataProvider && mDataProvider->
isSqlQuery();
468 p.setPen( QColor( 50, 100, 120, 200 ) );
469 p.setBrush( QColor( 200, 200, 210, 120 ) );
470 p.drawEllipse( x - m, y - m, m * 2 + 1, m * 2 + 1 );
474 p.setPen( QColor( 255, 0, 0 ) );
475 p.drawLine( x - m, y + m, x + m, y - m );
476 p.drawLine( x - m, y - m, x + m, y + m );
488 mSelectedFeatureIds.insert( fid );
489 mPreviousSelectedFeatureIds.clear();
498 mSelectedFeatureIds.unite( featureIds );
499 mPreviousSelectedFeatureIds.clear();
508 mSelectedFeatureIds.remove( fid );
509 mPreviousSelectedFeatureIds.clear();
518 mSelectedFeatureIds.subtract( featureIds );
519 mPreviousSelectedFeatureIds.clear();
534 .setFilterRect( rect )
536 .setNoAttributes() );
541 newSelection << feat.
id();
554 std::optional< QgsExpressionContext > defaultContext;
558 context = &defaultContext.value();
577 newSelection << feat.
id();
599 bool matches = exp.
evaluate( context ).toBool();
603 newSelection << feat.
id();
607 newSelection << feat.
id();
628 newSelection = mSelectedFeatureIds + ids;
632 newSelection = mSelectedFeatureIds - ids;
636 newSelection = mSelectedFeatureIds.intersect( ids );
640 QgsFeatureIds deselectedFeatures = mSelectedFeatureIds - newSelection;
641 mSelectedFeatureIds = newSelection;
642 mPreviousSelectedFeatureIds.clear();
652 if ( !intersectingIds.isEmpty() )
654 QgsDebugMsgLevel( QStringLiteral(
"Trying to select and deselect the same item at the same time. Unsure what to do. Selecting dubious items." ), 3 );
657 mSelectedFeatureIds -= deselectIds;
658 mSelectedFeatureIds += selectIds;
659 mPreviousSelectedFeatureIds.clear();
669 ids.subtract( mSelectedFeatureIds );
688 .setFilterRect( rect )
690 .setNoAttributes() );
698 if ( mSelectedFeatureIds.contains( fet.
id() ) )
700 deselectIds << fet.
id();
704 selectIds << fet.
id();
715 if ( mSelectedFeatureIds.isEmpty() )
720 mPreviousSelectedFeatureIds = previous;
727 if ( mPreviousSelectedFeatureIds.isEmpty() || !mSelectedFeatureIds.empty() )
738 return mDataProvider;
746 return mDataProvider;
753 return mTemporalProperties;
760 return mElevationProperties;
776 if (
isValid() && mDataProvider && mDataProvider->
encoding() != encoding )
787 delete mDiagramRenderer;
788 mDiagramRenderer = r;
812 if ( !
isValid() || !
isSpatial() || mSelectedFeatureIds.isEmpty() || !mDataProvider )
824 .setFilterFids( mSelectedFeatureIds )
825 .setNoAttributes() );
838 .setNoAttributes() );
842 if ( mSelectedFeatureIds.contains( fet.
id() ) )
853 if ( retval.
width() == 0.0 || retval.
height() == 0.0 )
862 retval.
set( -1.0, -1.0, 1.0, 1.0 );
874 return mLabelsEnabled &&
static_cast< bool >( mLabeling );
881 mLabelsEnabled = enabled;
889 if ( !mDiagramRenderer || !mDiagramLayerSettings )
892 QList<QgsDiagramSettings> settingList = mDiagramRenderer->
diagramSettings();
893 if ( !settingList.isEmpty() )
895 return settingList.at( 0 ).enabled;
904 if ( !mSymbolFeatureCounted )
907 return mSymbolFeatureCountMap.value( legendKey, -1 );
914 if ( !mSymbolFeatureCounted )
917 return mSymbolFeatureIdMap.value( legendKey,
QgsFeatureIds() );
923 if ( ( mSymbolFeatureCounted || mFeatureCounter ) && !( storeSymbolFids && mSymbolFeatureIdMap.isEmpty() ) )
924 return mFeatureCounter;
926 mSymbolFeatureCountMap.clear();
927 mSymbolFeatureIdMap.clear();
932 return mFeatureCounter;
934 if ( !mDataProvider )
937 return mFeatureCounter;
942 return mFeatureCounter;
945 if ( !mFeatureCounter || ( storeSymbolFids && mSymbolFeatureIdMap.isEmpty() ) )
948 connect( mFeatureCounter, &
QgsTask::taskCompleted,
this, &QgsVectorLayer::onFeatureCounterCompleted, Qt::UniqueConnection );
949 connect( mFeatureCounter, &
QgsTask::taskTerminated,
this, &QgsVectorLayer::onFeatureCounterTerminated, Qt::UniqueConnection );
953 return mFeatureCounter;
961 if ( force || !mReadExtentFromXml || ( mReadExtentFromXml && mXmlExtent.
isNull() ) )
962 mValidExtent =
false;
977 if ( !mDefaultValueOnUpdateFields.isEmpty() )
982 int size = mFields.
size();
983 for (
int idx : std::as_const( mDefaultValueOnUpdateFields ) )
985 if ( idx < 0 || idx >= size )
1004 if ( !mValidExtent && mLazyExtent && mReadExtentFromXml && !mXmlExtent.
isNull() )
1006 updateExtent( mXmlExtent );
1007 mValidExtent =
true;
1008 mLazyExtent =
false;
1011 if ( !mValidExtent && mLazyExtent && mDataProvider && mDataProvider->
isValid() )
1014 updateExtent( mDataProvider->
extent() );
1015 mValidExtent =
true;
1016 mLazyExtent =
false;
1019 QgsDebugMsgLevel( QStringLiteral(
"Extent of layer: %1" ).arg( mExtent.toString() ), 3 );
1025 if ( !
isValid() || !mDataProvider )
1027 QgsDebugMsgLevel( QStringLiteral(
"invoked with invalid layer or null mDataProvider" ), 3 );
1031 if ( !mEditBuffer ||
1045 if ( mEditBuffer && !mDataProvider->
transaction() )
1048 for ( QgsFeatureMap::const_iterator it = addedFeatures.constBegin(); it != addedFeatures.constEnd(); ++it )
1050 if ( it->hasGeometry() )
1061 .setNoAttributes() );
1074 if ( rect.xMinimum() > rect.xMaximum() && rect.yMinimum() > rect.yMaximum() )
1080 updateExtent( rect );
1081 mValidExtent =
true;
1100 if ( !
isValid() || !mDataProvider )
1102 QgsDebugMsgLevel( QStringLiteral(
"invoked with invalid layer or null mDataProvider" ), 3 );
1103 return customProperty( QStringLiteral(
"storedSubsetString" ) ).toString();
1112 if ( !
isValid() || !mDataProvider )
1114 QgsDebugMsgLevel( QStringLiteral(
"invoked with invalid layer or null mDataProvider or while editing" ), 3 );
1118 else if ( mEditBuffer )
1150 double maximumSimplificationScale = mSimplifyMethod.
maximumScale();
1153 return !( maximumSimplificationScale > 1 && renderContext.
rendererScale() <= maximumSimplificationScale );
1162 return mConditionalStyles;
1170 if ( !
isValid() || !mDataProvider )
1182 if ( feature.isValid() )
1183 return feature.geometry();
1192 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1196 if ( mGeometryOptions->isActive() )
1199 mGeometryOptions->apply( geom );
1203 bool success = mEditBuffer->
addFeature( feature );
1210 success = mJoinBuffer->
addFeature( feature );
1220 if ( !mEditBuffer || !mDataProvider )
1226 if ( currentFeature.
isValid() )
1228 bool hasChanged =
false;
1229 bool hasError =
false;
1241 QgsDebugMsgLevel( QStringLiteral(
"geometry of feature %1 could not be changed." ).arg( updatedFeature.
id() ), 3 );
1248 for (
int attr = 0; attr < fa.count(); ++attr )
1258 QgsDebugMsgLevel( QStringLiteral(
"attribute %1 of feature %2 could not be changed." ).arg( attr ).arg( updatedFeature.
id() ), 3 );
1263 if ( hasChanged && !mDefaultValueOnUpdateFields.isEmpty() && !skipDefaultValues )
1264 updateDefaultValues( updatedFeature.
id(), updatedFeature );
1270 QgsDebugMsgLevel( QStringLiteral(
"feature %1 could not be retrieved" ).arg( updatedFeature.
id() ), 3 );
1280 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1284 bool result = utils.
insertVertex( x, y, atFeatureId, beforeVertex );
1295 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1299 bool result = utils.
insertVertex( point, atFeatureId, beforeVertex );
1310 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1314 bool result = utils.
moveVertex( x, y, atFeatureId, atVertex );
1325 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1329 bool result = utils.
moveVertex( p, atFeatureId, atVertex );
1340 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1367 int count = mSelectedFeatureIds.size();
1380 *deletedCount = deleted;
1383 return deleted == count;
1386static const QgsPointSequence vectorPointXY2pointSequence(
const QVector<QgsPointXY> &points )
1389 pts.reserve( points.size() );
1390 QVector<QgsPointXY>::const_iterator it = points.constBegin();
1391 while ( it != points.constEnd() )
1402 return addRing( vectorPointXY2pointSequence( ring ), featureId );
1409 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1416 if ( !mSelectedFeatureIds.isEmpty() )
1418 result = utils.
addRing( ring, mSelectedFeatureIds, featureId );
1434 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1455 if ( !mSelectedFeatureIds.isEmpty() )
1457 result = utils.
addRing(
static_cast< QgsCurve *
>( ring->
clone() ), mSelectedFeatureIds, featureId );
1475 pts.reserve( points.size() );
1476 for ( QList<QgsPointXY>::const_iterator it = points.constBegin(); it != points.constEnd() ; ++it )
1483#if QT_VERSION < QT_VERSION_CHECK(6, 0, 0)
1488 return addPart( vectorPointXY2pointSequence( points ) );
1496 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1501 if ( mSelectedFeatureIds.empty() )
1506 else if ( mSelectedFeatureIds.size() > 1 )
1524 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1529 if ( mSelectedFeatureIds.empty() )
1534 else if ( mSelectedFeatureIds.size() > 1 )
1553 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1568 return splitParts( vectorPointXY2pointSequence( splitLine ), topologicalEditing );
1575 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1579 return utils.
splitParts( splitLine, topologicalEditing );
1586 return splitFeatures( vectorPointXY2pointSequence( splitLine ), topologicalEditing );
1595 bool preserveCircular =
false;
1596 return splitFeatures( &splitLineString, topologyTestPoints, preserveCircular, topologicalEditing );
1603 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1607 return utils.
splitFeatures( curve, topologyTestPoints, preserveCircular, topologicalEditing );
1614 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1632 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1643 if ( !
mValid || !mEditBuffer || !mDataProvider )
1668 if ( !
isValid() || !mDataProvider )
1702 if ( mDataProvider )
1718 if ( !mRenderer->
accept( visitor ) )
1722 if ( !mLabeling->
accept( visitor ) )
1735 QDomNode pkeyNode = layer_node.namedItem( QStringLiteral(
"provider" ) );
1737 if ( pkeyNode.isNull() )
1743 QDomElement pkeyElt = pkeyNode.toElement();
1753 else if (
mDataSource.contains( QLatin1String(
"dbname=" ) ) )
1762 const QDomElement elem = layer_node.toElement();
1764 QgsDataProvider::ReadFlags
flags;
1772 mDataSourceReadOnly =
true;
1782 if ( elem.hasAttribute( QStringLiteral(
"wkbType" ) ) )
1783 mWkbType =
qgsEnumKeyToValue( elem.attribute( QStringLiteral(
"wkbType" ) ), mWkbType );
1786 QDomElement pkeyElem = pkeyNode.toElement();
1787 if ( !pkeyElem.isNull() )
1789 QString encodingString = pkeyElem.attribute( QStringLiteral(
"encoding" ) );
1790 if ( mDataProvider && !encodingString.isEmpty() )
1797 mJoinBuffer->
readXml( layer_node );
1802 mSetLegendFromStyle =
false;
1812 QDomNode depsNode = layer_node.namedItem( QStringLiteral(
"dataDependencies" ) );
1813 QDomNodeList depsNodes = depsNode.childNodes();
1814 QSet<QgsMapLayerDependency> sources;
1815 for (
int i = 0; i < depsNodes.count(); i++ )
1817 QString
source = depsNodes.at( i ).toElement().attribute( QStringLiteral(
"id" ) );
1822 if ( !mSetLegendFromStyle )
1828 mReadExtentFromXml =
true;
1830 if ( mReadExtentFromXml )
1832 const QDomNode extentNode = layer_node.namedItem( QStringLiteral(
"extent" ) );
1833 if ( !extentNode.isNull() )
1840 const QDomNode asNode = layer_node.namedItem( QStringLiteral(
"auxiliaryLayer" ) );
1841 const QDomElement asElem = asNode.toElement();
1842 if ( !asElem.isNull() )
1844 mAuxiliaryLayerKey = asElem.attribute( QStringLiteral(
"key" ) );
1848 mServerProperties->readXml( layer_node );
1855void QgsVectorLayer::setDataSourcePrivate(
const QString &dataSource,
const QString &baseName,
const QString &provider,
1864 setDataProvider( provider, options,
flags );
1874 bool loadDefaultStyleFlag =
false;
1877 loadDefaultStyleFlag =
true;
1883 std::unique_ptr< QgsScopedRuntimeProfile > profile;
1885 profile = std::make_unique< QgsScopedRuntimeProfile >( tr(
"Load layer style" ), QStringLiteral(
"projectload" ) );
1887 bool defaultLoadedFlag =
false;
1895 mSetLegendFromStyle =
false;
1900 if ( !defaultLoadedFlag && loadDefaultStyleFlag )
1908 std::unique_ptr< QgsFeatureRenderer > defaultRenderer( mDataProvider->
createRenderer() );
1909 if ( defaultRenderer )
1911 defaultLoadedFlag =
true;
1917 if ( !defaultLoadedFlag &&
isSpatial() )
1923 if ( !mSetLegendFromStyle )
1928 std::unique_ptr< QgsAbstractVectorLayerLabeling > defaultLabeling( mDataProvider->
createLabeling() );
1929 if ( defaultLabeling )
1936 styleChangedSignalBlocker.release();
1953 QStringList ids, names, descriptions;
1954 QString errorMessage;
1956 const int relatedStylesCount {
listStylesInDatabase( ids, names, descriptions, errorMessage ) };
1957 Q_ASSERT( ids.count() == names.count() );
1958 const QString currentStyleName { mStyleManager->currentStyle() };
1959 for (
int i = 0; i < relatedStylesCount; ++i )
1961 if ( names.at( i ) == currentStyleName )
1965 errorMessage.clear();
1967 if ( ! styleXml.isEmpty() && errorMessage.isEmpty() )
1973 QgsDebugMsgLevel( QStringLiteral(
"Error retrieving style %1 from DB: %2" ).arg( ids.at( i ), errorMessage ), 2 );
1983 std::unique_ptr< QgsFeatureRenderer > defaultRenderer( mDataProvider->
createRenderer() );
1984 if ( defaultRenderer )
2000 delete mDataProvider;
2007 if ( provider.compare( QLatin1String(
"postgres" ) ) == 0 )
2009 const QString checkUnicityKey { QStringLiteral(
"checkPrimaryKeyUnicity" ) };
2011 if ( ! uri.hasParam( checkUnicityKey ) )
2013 uri.setParam( checkUnicityKey, mReadExtentFromXml ?
"0" :
"1" );
2018 std::unique_ptr< QgsScopedRuntimeProfile > profile;
2020 profile = std::make_unique< QgsScopedRuntimeProfile >( tr(
"Create %1 provider" ).arg( provider ), QStringLiteral(
"projectload" ) );
2023 if ( !mDataProvider )
2030 mDataProvider->setParent(
this );
2033 QgsDebugMsgLevel( QStringLiteral(
"Instantiated the data provider plugin" ), 2 );
2043 profile->switchTask( tr(
"Read layer metadata" ) );
2050 newMetadata.
combine( &mMetadata );
2053 QgsDebugMsgLevel( QStringLiteral(
"Set Data provider QgsLayerMetadata identifier[%1]" ).arg(
metadata().identifier() ), 4 );
2060 mWkbType = mDataProvider->
wkbType();
2076 if ( !mAttributeSplitPolicy.contains(
field.
name() ) )
2083 profile->switchTask( tr(
"Read layer fields" ) );
2094 const QRegularExpression reg( R
"lit("[^"]+"\."([^"] + )"( \([^)]+\))?)lit" );
2095 const QRegularExpressionMatch match = reg.match(
name() );
2096 if ( match.hasMatch() )
2098 QStringList stuff = match.capturedTexts();
2099 QString lName = stuff[1];
2103 QMap<QString, QgsMapLayer *>::const_iterator it;
2104 for ( it = layers.constBegin(); it != layers.constEnd() && ( *it )->name() != lName; ++it )
2107 if ( it != layers.constEnd() && stuff.size() > 2 )
2109 lName +=
'.' + stuff[2].mid( 2, stuff[2].length() - 3 );
2112 if ( !lName.isEmpty() )
2122 else if ( provider == QLatin1String(
"ogr" ) )
2126 if (
mDataSource.right( 10 ) == QLatin1String(
"|layerid=0" ) )
2129 else if ( provider == QLatin1String(
"memory" ) )
2134 else if ( provider == QLatin1String(
"hana" ) )
2151 QDomDocument &document,
2158 QDomElement mapLayerNode = layer_node.toElement();
2160 if ( mapLayerNode.isNull() || (
"maplayer" != mapLayerNode.nodeName() ) )
2173 if ( mDataProvider )
2175 QDomElement provider = document.createElement( QStringLiteral(
"provider" ) );
2176 provider.setAttribute( QStringLiteral(
"encoding" ), mDataProvider->
encoding() );
2177 QDomText providerText = document.createTextNode(
providerType() );
2178 provider.appendChild( providerText );
2179 layer_node.appendChild( provider );
2183 mJoinBuffer->
writeXml( layer_node, document );
2186 QDomElement dependenciesElement = document.createElement( QStringLiteral(
"layerDependencies" ) );
2192 QDomElement depElem = document.createElement( QStringLiteral(
"layer" ) );
2193 depElem.setAttribute( QStringLiteral(
"id" ), dep.layerId() );
2194 dependenciesElement.appendChild( depElem );
2196 layer_node.appendChild( dependenciesElement );
2199 QDomElement dataDependenciesElement = document.createElement( QStringLiteral(
"dataDependencies" ) );
2204 QDomElement depElem = document.createElement( QStringLiteral(
"layer" ) );
2205 depElem.setAttribute( QStringLiteral(
"id" ), dep.layerId() );
2206 dataDependenciesElement.appendChild( depElem );
2208 layer_node.appendChild( dataDependenciesElement );
2211 mExpressionFieldBuffer->
writeXml( layer_node, document );
2216 QDomElement asElem = document.createElement( QStringLiteral(
"auxiliaryLayer" ) );
2217 if ( mAuxiliaryLayer )
2219 const QString pkField = mAuxiliaryLayer->joinInfo().targetFieldName();
2220 asElem.setAttribute( QStringLiteral(
"key" ), pkField );
2222 layer_node.appendChild( asElem );
2225 mServerProperties->writeXml( layer_node, document );
2229 return writeSymbology( layer_node, document, errorMsg, context );
2268 if ( categories.testFlag(
Fields ) )
2270 if ( !mExpressionFieldBuffer )
2272 mExpressionFieldBuffer->
readXml( layerNode );
2284 QDomNodeList referencedLayersNodeList = layerNode.toElement().elementsByTagName( QStringLiteral(
"referencedLayers" ) );
2285 if ( referencedLayersNodeList.size() > 0 )
2287 const QDomNodeList relationNodes { referencedLayersNodeList.at( 0 ).childNodes() };
2288 for (
int i = 0; i < relationNodes.length(); ++i )
2290 const QDomElement relationElement = relationNodes.at( i ).toElement();
2297 QDomNodeList referencingLayersNodeList = layerNode.toElement().elementsByTagName( QStringLiteral(
"referencingLayers" ) );
2298 if ( referencingLayersNodeList.size() > 0 )
2300 const QDomNodeList relationNodes { referencingLayersNodeList.at( 0 ).childNodes() };
2301 for (
int i = 0; i < relationNodes.length(); ++i )
2303 const QDomElement relationElement = relationNodes.at( i ).toElement();
2309 QDomElement layerElement = layerNode.toElement();
2313 readStyle( layerNode, errorMessage, context, categories );
2315 if ( categories.testFlag(
MapTips ) )
2316 mMapTipTemplate = layerNode.namedItem( QStringLiteral(
"mapTip" ) ).toElement().text();
2319 mDisplayExpression = layerNode.namedItem( QStringLiteral(
"previewExpression" ) ).toElement().text();
2322 QString
displayField = layerNode.namedItem( QStringLiteral(
"displayfield" ) ).toElement().text();
2326 if ( mMapTipTemplate.isEmpty() && categories.testFlag(
MapTips ) )
2336 if ( categories.testFlag(
Actions ) )
2337 mActions->
readXml( layerNode );
2339 if ( categories.testFlag(
Fields ) )
2344 QDomNode aliasesNode = layerNode.namedItem( QStringLiteral(
"aliases" ) );
2345 if ( !aliasesNode.isNull() )
2347 QDomElement aliasElem;
2349 QDomNodeList aliasNodeList = aliasesNode.toElement().elementsByTagName( QStringLiteral(
"alias" ) );
2350 for (
int i = 0; i < aliasNodeList.size(); ++i )
2352 aliasElem = aliasNodeList.at( i ).toElement();
2355 if ( aliasElem.hasAttribute( QStringLiteral(
"field" ) ) )
2357 field = aliasElem.attribute( QStringLiteral(
"field" ) );
2361 int index = aliasElem.attribute( QStringLiteral(
"index" ) ).toInt();
2363 if ( index >= 0 && index <
fields().count() )
2369 if ( !aliasElem.attribute( QStringLiteral(
"name" ) ).isEmpty() )
2372 alias = context.
projectTranslator()->
translate( QStringLiteral(
"project:layers:%1:fieldaliases" ).arg( layerNode.namedItem( QStringLiteral(
"id" ) ).toElement().text() ), aliasElem.attribute( QStringLiteral(
"name" ) ) );
2373 QgsDebugMsgLevel(
"context" + QStringLiteral(
"project:layers:%1:fieldaliases" ).arg( layerNode.namedItem( QStringLiteral(
"id" ) ).toElement().text() ) +
" source " + aliasElem.attribute( QStringLiteral(
"name" ) ), 3 );
2378 alias = context.
projectTranslator()->
translate( QStringLiteral(
"project:layers:%1:fieldaliases" ).arg( layerNode.namedItem( QStringLiteral(
"id" ) ).toElement().text() ),
field );
2379 QgsDebugMsgLevel(
"context" + QStringLiteral(
"project:layers:%1:fieldaliases" ).arg( layerNode.namedItem( QStringLiteral(
"id" ) ).toElement().text() ) +
" source " +
field, 3 );
2381 if ( alias == aliasElem.attribute( QStringLiteral(
"field" ) ) )
2385 QgsDebugMsgLevel(
"field " +
field +
" origalias " + aliasElem.attribute( QStringLiteral(
"name" ) ) +
" trans " + alias, 3 );
2386 mAttributeAliasMap.insert(
field, alias );
2393 const QDomNode splitPoliciesNode = layerNode.namedItem( QStringLiteral(
"splitPolicies" ) );
2394 if ( !splitPoliciesNode.isNull() )
2396 const QDomNodeList splitPolicyNodeList = splitPoliciesNode.toElement().elementsByTagName( QStringLiteral(
"policy" ) );
2397 for (
int i = 0; i < splitPolicyNodeList.size(); ++i )
2399 const QDomElement splitPolicyElem = splitPolicyNodeList.at( i ).toElement();
2400 const QString
field = splitPolicyElem.attribute( QStringLiteral(
"field" ) );
2402 mAttributeSplitPolicy.insert(
field, policy );
2407 mDefaultExpressionMap.clear();
2408 QDomNode defaultsNode = layerNode.namedItem( QStringLiteral(
"defaults" ) );
2409 if ( !defaultsNode.isNull() )
2411 QDomNodeList defaultNodeList = defaultsNode.toElement().elementsByTagName( QStringLiteral(
"default" ) );
2412 for (
int i = 0; i < defaultNodeList.size(); ++i )
2414 QDomElement defaultElem = defaultNodeList.at( i ).toElement();
2416 QString
field = defaultElem.attribute( QStringLiteral(
"field" ), QString() );
2417 QString expression = defaultElem.attribute( QStringLiteral(
"expression" ), QString() );
2418 bool applyOnUpdate = defaultElem.attribute( QStringLiteral(
"applyOnUpdate" ), QStringLiteral(
"0" ) ) == QLatin1String(
"1" );
2419 if (
field.isEmpty() || expression.isEmpty() )
2427 mFieldConstraints.clear();
2428 mFieldConstraintStrength.clear();
2429 QDomNode constraintsNode = layerNode.namedItem( QStringLiteral(
"constraints" ) );
2430 if ( !constraintsNode.isNull() )
2432 QDomNodeList constraintNodeList = constraintsNode.toElement().elementsByTagName( QStringLiteral(
"constraint" ) );
2433 for (
int i = 0; i < constraintNodeList.size(); ++i )
2435 QDomElement constraintElem = constraintNodeList.at( i ).toElement();
2437 QString
field = constraintElem.attribute( QStringLiteral(
"field" ), QString() );
2438 int constraints = constraintElem.attribute( QStringLiteral(
"constraints" ), QStringLiteral(
"0" ) ).toInt();
2439 if (
field.isEmpty() || constraints == 0 )
2442 mFieldConstraints.insert(
field,
static_cast< QgsFieldConstraints::Constraints
>( constraints ) );
2444 int uniqueStrength = constraintElem.attribute( QStringLiteral(
"unique_strength" ), QStringLiteral(
"1" ) ).toInt();
2445 int notNullStrength = constraintElem.attribute( QStringLiteral(
"notnull_strength" ), QStringLiteral(
"1" ) ).toInt();
2446 int expStrength = constraintElem.attribute( QStringLiteral(
"exp_strength" ), QStringLiteral(
"1" ) ).toInt();
2453 mFieldConstraintExpressions.clear();
2454 QDomNode constraintExpressionsNode = layerNode.namedItem( QStringLiteral(
"constraintExpressions" ) );
2455 if ( !constraintExpressionsNode.isNull() )
2457 QDomNodeList constraintNodeList = constraintExpressionsNode.toElement().elementsByTagName( QStringLiteral(
"constraint" ) );
2458 for (
int i = 0; i < constraintNodeList.size(); ++i )
2460 QDomElement constraintElem = constraintNodeList.at( i ).toElement();
2462 QString
field = constraintElem.attribute( QStringLiteral(
"field" ), QString() );
2463 QString exp = constraintElem.attribute( QStringLiteral(
"exp" ), QString() );
2464 QString desc = constraintElem.attribute( QStringLiteral(
"desc" ), QString() );
2465 if (
field.isEmpty() || exp.isEmpty() )
2468 mFieldConstraintExpressions.insert(
field, qMakePair( exp, desc ) );
2476 if ( categories.testFlag(
Fields ) || categories.testFlag(
Forms ) )
2480 QDomElement widgetsElem = layerNode.namedItem( QStringLiteral(
"fieldConfiguration" ) ).toElement();
2481 QDomNodeList fieldConfigurationElementList = widgetsElem.elementsByTagName( QStringLiteral(
"field" ) );
2482 for (
int i = 0; i < fieldConfigurationElementList.size(); ++i )
2484 const QDomElement fieldConfigElement = fieldConfigurationElementList.at( i ).toElement();
2485 const QDomElement fieldWidgetElement = fieldConfigElement.elementsByTagName( QStringLiteral(
"editWidget" ) ).at( 0 ).toElement();
2487 QString fieldName = fieldConfigElement.attribute( QStringLiteral(
"name" ) );
2489 if ( categories.testFlag(
Fields ) )
2493 if ( categories.testFlag(
Forms ) )
2495 const QString widgetType = fieldWidgetElement.attribute( QStringLiteral(
"type" ) );
2496 const QDomElement cfgElem = fieldConfigElement.elementsByTagName( QStringLiteral(
"config" ) ).at( 0 ).toElement();
2497 const QDomElement optionsElem = cfgElem.childNodes().at( 0 ).toElement();
2499 if ( widgetType == QLatin1String(
"ValueRelation" ) )
2501 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() );
2504 mFieldWidgetSetups[fieldName] = setup;
2511 if ( categories.testFlag(
Fields ) )
2513 const QList<QPair<QString, QgsField::ConfigurationFlag>> legacyConfig
2518 for (
const auto &config : legacyConfig )
2520 QDomNode excludeNode = layerNode.namedItem( config.first );
2521 if ( !excludeNode.isNull() )
2523 QDomNodeList attributeNodeList = excludeNode.toElement().elementsByTagName( QStringLiteral(
"attribute" ) );
2524 for (
int i = 0; i < attributeNodeList.size(); ++i )
2526 QString fieldName = attributeNodeList.at( i ).toElement().text();
2527 if ( !mFieldConfigurationFlags.contains( fieldName ) )
2528 mFieldConfigurationFlags[fieldName] = config.second;
2530 mFieldConfigurationFlags[fieldName].setFlag( config.second,
true );
2537 mGeometryOptions->readXml( layerNode.namedItem( QStringLiteral(
"geometryOptions" ) ) );
2539 if ( categories.testFlag(
Forms ) )
2540 mEditFormConfig.
readXml( layerNode, context );
2544 mAttributeTableConfig.
readXml( layerNode );
2545 mConditionalStyles->
readXml( layerNode, context );
2546 mStoredExpressionManager->
readXml( layerNode );
2552 QDomElement mapLayerNode = layerNode.toElement();
2554 && mapLayerNode.attribute( QStringLiteral(
"readOnly" ), QStringLiteral(
"0" ) ).toInt() == 1 )
2559 if ( categories.testFlag(
Legend ) )
2563 const QDomElement legendElem = layerNode.firstChildElement( QStringLiteral(
"legend" ) );
2564 if ( !legendElem.isNull() )
2569 mSetLegendFromStyle =
true;
2599 if ( !rendererElement.isNull() )
2619 if ( categories.testFlag(
Labeling ) )
2623 QDomElement labelingElement = node.firstChildElement( QStringLiteral(
"labeling" ) );
2625 if ( labelingElement.isNull() ||
2626 ( labelingElement.attribute( QStringLiteral(
"type" ) ) == QLatin1String(
"simple" ) && labelingElement.firstChildElement( QStringLiteral(
"settings" ) ).isNull() ) )
2634 labeling = readLabelingFromCustomProperties();
2642 if ( node.toElement().hasAttribute( QStringLiteral(
"labelsEnabled" ) ) )
2643 mLabelsEnabled = node.toElement().attribute( QStringLiteral(
"labelsEnabled" ) ).toInt();
2645 mLabelsEnabled =
true;
2651 QDomNode blendModeNode = node.namedItem( QStringLiteral(
"blendMode" ) );
2652 if ( !blendModeNode.isNull() )
2654 QDomElement e = blendModeNode.toElement();
2659 QDomNode featureBlendModeNode = node.namedItem( QStringLiteral(
"featureBlendMode" ) );
2660 if ( !featureBlendModeNode.isNull() )
2662 QDomElement e = featureBlendModeNode.toElement();
2670 QDomNode layerTransparencyNode = node.namedItem( QStringLiteral(
"layerTransparency" ) );
2671 if ( !layerTransparencyNode.isNull() )
2673 QDomElement e = layerTransparencyNode.toElement();
2674 setOpacity( 1.0 - e.text().toInt() / 100.0 );
2676 QDomNode layerOpacityNode = node.namedItem( QStringLiteral(
"layerOpacity" ) );
2677 if ( !layerOpacityNode.isNull() )
2679 QDomElement e = layerOpacityNode.toElement();
2683 const bool hasScaleBasedVisibiliy { node.attributes().namedItem( QStringLiteral(
"hasScaleBasedVisibilityFlag" ) ).nodeValue() ==
'1' };
2686 const double maxScale { node.attributes().namedItem( QStringLiteral(
"maxScale" ) ).nodeValue().toDouble( &ok ) };
2691 const double minScale { node.attributes().namedItem( QStringLiteral(
"minScale" ) ).nodeValue().toDouble( &ok ) };
2697 QDomElement e = node.toElement();
2700 mSimplifyMethod.
setSimplifyHints(
static_cast< QgsVectorSimplifyMethod::SimplifyHints
>( e.attribute( QStringLiteral(
"simplifyDrawingHints" ), QStringLiteral(
"1" ) ).toInt() ) );
2702 mSimplifyMethod.
setThreshold( e.attribute( QStringLiteral(
"simplifyDrawingTol" ), QStringLiteral(
"1" ) ).toFloat() );
2703 mSimplifyMethod.
setForceLocalOptimization( e.attribute( QStringLiteral(
"simplifyLocal" ), QStringLiteral(
"1" ) ).toInt() );
2704 mSimplifyMethod.
setMaximumScale( e.attribute( QStringLiteral(
"simplifyMaxScale" ), QStringLiteral(
"1" ) ).toFloat() );
2707 mRenderer->
setReferenceScale( e.attribute( QStringLiteral(
"symbologyReferenceScale" ), QStringLiteral(
"-1" ) ).toDouble() );
2711 if ( categories.testFlag(
Diagrams ) )
2715 delete mDiagramRenderer;
2716 mDiagramRenderer =
nullptr;
2717 QDomElement singleCatDiagramElem = node.firstChildElement( QStringLiteral(
"SingleCategoryDiagramRenderer" ) );
2718 if ( !singleCatDiagramElem.isNull() )
2721 mDiagramRenderer->
readXml( singleCatDiagramElem, context );
2723 QDomElement linearDiagramElem = node.firstChildElement( QStringLiteral(
"LinearlyInterpolatedDiagramRenderer" ) );
2724 if ( !linearDiagramElem.isNull() )
2726 if ( linearDiagramElem.hasAttribute( QStringLiteral(
"classificationAttribute" ) ) )
2729 int idx = linearDiagramElem.attribute( QStringLiteral(
"classificationAttribute" ) ).toInt();
2730 if ( idx >= 0 && idx < mFields.
count() )
2731 linearDiagramElem.setAttribute( QStringLiteral(
"classificationField" ), mFields.
at( idx ).
name() );
2735 mDiagramRenderer->
readXml( linearDiagramElem, context );
2738 if ( mDiagramRenderer )
2740 QDomElement diagramSettingsElem = node.firstChildElement( QStringLiteral(
"DiagramLayerSettings" ) );
2741 if ( !diagramSettingsElem.isNull() )
2743 bool oldXPos = diagramSettingsElem.hasAttribute( QStringLiteral(
"xPosColumn" ) );
2744 bool oldYPos = diagramSettingsElem.hasAttribute( QStringLiteral(
"yPosColumn" ) );
2745 bool oldShow = diagramSettingsElem.hasAttribute( QStringLiteral(
"showColumn" ) );
2746 if ( oldXPos || oldYPos || oldShow )
2752 int xPosColumn = diagramSettingsElem.attribute( QStringLiteral(
"xPosColumn" ) ).toInt();
2753 if ( xPosColumn >= 0 && xPosColumn < mFields.
count() )
2758 int yPosColumn = diagramSettingsElem.attribute( QStringLiteral(
"yPosColumn" ) ).toInt();
2759 if ( yPosColumn >= 0 && yPosColumn < mFields.
count() )
2764 int showColumn = diagramSettingsElem.attribute( QStringLiteral(
"showColumn" ) ).toInt();
2765 if ( showColumn >= 0 && showColumn < mFields.
count() )
2768 QDomElement propertiesElem = diagramSettingsElem.ownerDocument().createElement( QStringLiteral(
"properties" ) );
2775 ddp.
writeXml( propertiesElem, defs );
2776 diagramSettingsElem.appendChild( propertiesElem );
2779 delete mDiagramLayerSettings;
2781 mDiagramLayerSettings->
readXml( diagramSettingsElem );
2787 styleChangedSignalBlocker.release();
2799 QDomElement layerElement = node.toElement();
2802 ( void )
writeStyle( node, doc, errorMessage, context, categories );
2805 mGeometryOptions->writeXml( node );
2810 if ( !legendElement.isNull() )
2811 node.appendChild( legendElement );
2818 QDomElement referencedLayersElement = doc.createElement( QStringLiteral(
"referencedLayers" ) );
2819 node.appendChild( referencedLayersElement );
2824 switch ( rel.type() )
2835 QDomElement referencingLayersElement = doc.createElement( QStringLiteral(
"referencingLayers" ) );
2836 node.appendChild( referencedLayersElement );
2839 for (
const QgsRelation &rel : referencedRelations )
2841 switch ( rel.type() )
2853 if ( categories.testFlag(
Fields ) || categories.testFlag(
Forms ) )
2855 QDomElement fieldConfigurationElement;
2857 fieldConfigurationElement = doc.createElement( QStringLiteral(
"fieldConfiguration" ) );
2858 node.appendChild( fieldConfigurationElement );
2862 QDomElement fieldElement = doc.createElement( QStringLiteral(
"field" ) );
2863 fieldElement.setAttribute( QStringLiteral(
"name" ),
field.
name() );
2864 fieldConfigurationElement.appendChild( fieldElement );
2866 if ( categories.testFlag(
Fields ) )
2871 if ( categories.testFlag(
Forms ) )
2876 QDomElement editWidgetElement = doc.createElement( QStringLiteral(
"editWidget" ) );
2877 fieldElement.appendChild( editWidgetElement );
2879 QDomElement editWidgetConfigElement = doc.createElement( QStringLiteral(
"config" ) );
2882 editWidgetElement.appendChild( editWidgetConfigElement );
2888 if ( categories.testFlag(
Fields ) )
2891 QDomElement aliasElem = doc.createElement( QStringLiteral(
"aliases" ) );
2894 QDomElement aliasEntryElem = doc.createElement( QStringLiteral(
"alias" ) );
2895 aliasEntryElem.setAttribute( QStringLiteral(
"field" ),
field.
name() );
2897 aliasEntryElem.setAttribute( QStringLiteral(
"name" ),
field.
alias() );
2898 aliasElem.appendChild( aliasEntryElem );
2900 node.appendChild( aliasElem );
2904 QDomElement splitPoliciesElement = doc.createElement( QStringLiteral(
"splitPolicies" ) );
2907 QDomElement splitPolicyElem = doc.createElement( QStringLiteral(
"policy" ) );
2908 splitPolicyElem.setAttribute( QStringLiteral(
"field" ),
field.
name() );
2910 splitPoliciesElement.appendChild( splitPolicyElem );
2912 node.appendChild( splitPoliciesElement );
2916 QDomElement defaultsElem = doc.createElement( QStringLiteral(
"defaults" ) );
2919 QDomElement defaultElem = doc.createElement( QStringLiteral(
"default" ) );
2920 defaultElem.setAttribute( QStringLiteral(
"field" ),
field.
name() );
2923 defaultsElem.appendChild( defaultElem );
2925 node.appendChild( defaultsElem );
2928 QDomElement constraintsElem = doc.createElement( QStringLiteral(
"constraints" ) );
2931 QDomElement constraintElem = doc.createElement( QStringLiteral(
"constraint" ) );
2932 constraintElem.setAttribute( QStringLiteral(
"field" ),
field.
name() );
2937 constraintsElem.appendChild( constraintElem );
2939 node.appendChild( constraintsElem );
2942 QDomElement constraintExpressionsElem = doc.createElement( QStringLiteral(
"constraintExpressions" ) );
2945 QDomElement constraintExpressionElem = doc.createElement( QStringLiteral(
"constraint" ) );
2946 constraintExpressionElem.setAttribute( QStringLiteral(
"field" ),
field.
name() );
2949 constraintExpressionsElem.appendChild( constraintExpressionElem );
2951 node.appendChild( constraintExpressionsElem );
2954 if ( !mExpressionFieldBuffer )
2962 mExpressionFieldBuffer->
writeXml( node, doc );
2967 if ( categories.testFlag(
Actions ) )
2972 mAttributeTableConfig.
writeXml( node );
2973 mConditionalStyles->
writeXml( node, doc, context );
2974 mStoredExpressionManager->
writeXml( node );
2977 if ( categories.testFlag(
Forms ) )
2978 mEditFormConfig.
writeXml( node, context );
2982 node.toElement().setAttribute( QStringLiteral(
"readOnly" ), mReadOnly );
2987 QDomElement prevExpElem = doc.createElement( QStringLiteral(
"previewExpression" ) );
2988 QDomText prevExpText = doc.createTextNode( mDisplayExpression );
2989 prevExpElem.appendChild( prevExpText );
2990 node.appendChild( prevExpElem );
2994 if ( categories.testFlag(
MapTips ) )
2996 QDomElement mapTipElem = doc.createElement( QStringLiteral(
"mapTip" ) );
2997 QDomText mapTipText = doc.createTextNode( mMapTipTemplate );
2998 mapTipElem.appendChild( mapTipText );
2999 node.toElement().appendChild( mapTipElem );
3010 QDomElement mapLayerNode = node.toElement();
3023 QDomElement rendererElement = mRenderer->
save( doc, context );
3024 node.appendChild( rendererElement );
3028 if ( categories.testFlag(
Labeling ) )
3032 QDomElement labelingElement = mLabeling->
save( doc, context );
3033 node.appendChild( labelingElement );
3035 mapLayerNode.setAttribute( QStringLiteral(
"labelsEnabled" ), mLabelsEnabled ? QStringLiteral(
"1" ) : QStringLiteral(
"0" ) );
3041 mapLayerNode.setAttribute( QStringLiteral(
"simplifyDrawingHints" ), QString::number( mSimplifyMethod.
simplifyHints() ) );
3042 mapLayerNode.setAttribute( QStringLiteral(
"simplifyAlgorithm" ), QString::number( mSimplifyMethod.
simplifyAlgorithm() ) );
3043 mapLayerNode.setAttribute( QStringLiteral(
"simplifyDrawingTol" ), QString::number( mSimplifyMethod.
threshold() ) );
3044 mapLayerNode.setAttribute( QStringLiteral(
"simplifyLocal" ), mSimplifyMethod.
forceLocalOptimization() ? 1 : 0 );
3045 mapLayerNode.setAttribute( QStringLiteral(
"simplifyMaxScale" ), QString::number( mSimplifyMethod.
maximumScale() ) );
3057 QDomElement blendModeElem = doc.createElement( QStringLiteral(
"blendMode" ) );
3059 blendModeElem.appendChild( blendModeText );
3060 node.appendChild( blendModeElem );
3063 QDomElement featureBlendModeElem = doc.createElement( QStringLiteral(
"featureBlendMode" ) );
3065 featureBlendModeElem.appendChild( featureBlendModeText );
3066 node.appendChild( featureBlendModeElem );
3072 QDomElement layerOpacityElem = doc.createElement( QStringLiteral(
"layerOpacity" ) );
3073 QDomText layerOpacityText = doc.createTextNode( QString::number(
opacity() ) );
3074 layerOpacityElem.appendChild( layerOpacityText );
3075 node.appendChild( layerOpacityElem );
3076 mapLayerNode.setAttribute( QStringLiteral(
"hasScaleBasedVisibilityFlag" ),
hasScaleBasedVisibility() ? 1 : 0 );
3077 mapLayerNode.setAttribute( QStringLiteral(
"maxScale" ),
maximumScale() );
3078 mapLayerNode.setAttribute( QStringLiteral(
"minScale" ),
minimumScale() );
3080 mapLayerNode.setAttribute( QStringLiteral(
"symbologyReferenceScale" ), mRenderer ? mRenderer->
referenceScale() : -1 );
3083 if ( categories.testFlag(
Diagrams ) && mDiagramRenderer )
3085 mDiagramRenderer->
writeXml( mapLayerNode, doc, context );
3086 if ( mDiagramLayerSettings )
3087 mDiagramLayerSettings->
writeXml( mapLayerNode, doc );
3098 QDomElement nameElem = node.firstChildElement( QStringLiteral(
"Name" ) );
3099 if ( nameElem.isNull() )
3101 errorMessage = QStringLiteral(
"Warning: Name element not found within NamedLayer while it's required." );
3117 readSldLabeling( node );
3119 styleChangedSignalBlocker.release();
3129 Q_UNUSED( errorMessage )
3131 QVariantMap localProps = QVariantMap( props );
3140 QDomElement nameNode = doc.createElement( QStringLiteral(
"se:Name" ) );
3141 nameNode.appendChild( doc.createTextNode(
name() ) );
3142 node.appendChild( nameNode );
3144 QDomElement userStyleElem = doc.createElement( QStringLiteral(
"UserStyle" ) );
3145 node.appendChild( userStyleElem );
3147 QDomElement nameElem = doc.createElement( QStringLiteral(
"se:Name" ) );
3148 nameElem.appendChild( doc.createTextNode(
name() ) );
3150 userStyleElem.appendChild( nameElem );
3152 QDomElement featureTypeStyleElem = doc.createElement( QStringLiteral(
"se:FeatureTypeStyle" ) );
3153 userStyleElem.appendChild( featureTypeStyleElem );
3155 mRenderer->
toSld( doc, featureTypeStyleElem, localProps );
3158 mLabeling->
toSld( featureTypeStyleElem, localProps );
3169 if ( !mEditBuffer || !mDataProvider )
3174 if ( mGeometryOptions->isActive() )
3175 mGeometryOptions->apply( geom );
3184 if ( !skipDefaultValue && !mDefaultValueOnUpdateFields.isEmpty() )
3185 updateDefaultValues( fid );
3195 bool result =
false;
3209 if ( mEditBuffer && mDataProvider )
3218 if ( result && !skipDefaultValues && !mDefaultValueOnUpdateFields.isEmpty() )
3219 updateDefaultValues( fid );
3236 for (
auto it = newValues.constBegin(); it != newValues.constEnd(); ++it )
3238 const int field = it.key();
3239 const QVariant newValue = it.value();
3242 if ( oldValues.contains(
field ) )
3243 oldValue = oldValues[
field];
3248 newValuesJoin[
field] = newValue;
3249 oldValuesJoin[
field] = oldValue;
3256 newValuesNotJoin[
field] = newValue;
3257 oldValuesNotJoin[
field] = oldValue;
3266 if ( ! newValuesJoin.isEmpty() && mJoinBuffer )
3271 if ( ! newValuesNotJoin.isEmpty() )
3273 if ( mEditBuffer && mDataProvider )
3279 if ( result && !skipDefaultValues && !mDefaultValueOnUpdateFields.isEmpty() )
3281 updateDefaultValues( fid );
3291 if ( !mEditBuffer || !mDataProvider )
3301 if ( attIndex < 0 || attIndex >=
fields().count() )
3305 mFields[ attIndex ].setAlias( QString() );
3306 if ( mAttributeAliasMap.contains(
name ) )
3308 mAttributeAliasMap.remove(
name );
3310 mEditFormConfig.setFields( mFields );
3319 if ( index < 0 || index >=
fields().count() )
3326 if ( mExpressionFieldBuffer )
3342 if ( !mEditBuffer || !mDataProvider )
3360 if ( attIndex < 0 || attIndex >=
fields().count() )
3365 mAttributeAliasMap.insert(
name, aliasString );
3366 mFields[ attIndex ].setAlias( aliasString );
3367 mEditFormConfig.setFields( mFields );
3375 if ( index < 0 || index >=
fields().count() )
3385 if ( index >= 0 && index < mFields.
count() )
3395 return mAttributeAliasMap;
3402 if ( index < 0 || index >=
fields().count() )
3407 mAttributeSplitPolicy.insert(
name, policy );
3408 mFields[ index ].setSplitPolicy( policy );
3409 mEditFormConfig.setFields( mFields );
3417 QSet<QString> excludeList;
3418 QMap< QString, QgsField::ConfigurationFlags >::const_iterator flagsIt = mFieldConfigurationFlags.constBegin();
3419 for ( ; flagsIt != mFieldConfigurationFlags.constEnd(); ++flagsIt )
3423 excludeList << flagsIt.key();
3433 QMap< QString, QgsField::ConfigurationFlags >::iterator flagsIt = mFieldConfigurationFlags.begin();
3434 for ( ; flagsIt != mFieldConfigurationFlags.end(); ++flagsIt )
3445 QSet<QString> excludeList;
3446 QMap< QString, QgsField::ConfigurationFlags >::const_iterator flagsIt = mFieldConfigurationFlags.constBegin();
3447 for ( ; flagsIt != mFieldConfigurationFlags.constEnd(); ++flagsIt )
3451 excludeList << flagsIt.key();
3461 QMap< QString, QgsField::ConfigurationFlags >::iterator flagsIt = mFieldConfigurationFlags.begin();
3462 for ( ; flagsIt != mFieldConfigurationFlags.end(); ++flagsIt )
3473 if ( index < 0 || index >=
fields().count() )
3482 if ( !mEditBuffer || !mDataProvider )
3492 bool deleted =
false;
3495 QList<int> attrList = qgis::setToList( qgis::listToSet( attrs ) );
3497 std::sort( attrList.begin(), attrList.end(), std::greater<int>() );
3499 for (
int attr : std::as_const( attrList ) )
3517 if ( context && context->
cascade )
3520 const bool hasRelationsOrJoins = !relations.empty() || mJoinBuffer->
containsJoins();
3521 if ( hasRelationsOrJoins )
3526 if ( handledFeatureIds.contains( fid ) )
3534 handledFeatureIds << fid;
3546 switch ( relation.strength() )
3554 while ( relatedFeaturesIt.
nextFeature( childFeature ) )
3556 childFeatureIds.insert( childFeature.
id() );
3558 if ( childFeatureIds.count() > 0 )
3560 relation.referencingLayer()->startEditing();
3561 relation.referencingLayer()->deleteFeatures( childFeatureIds, context );
3588 bool res = deleteFeatureCascade( fid, context );
3608 res = deleteFeatureCascade( fid, context ) && res;
3617 mSelectedFeatureIds.subtract( fids );
3637 if ( !mDataProvider )
3638 return pkAttributesList;
3641 for (
int i = 0; i < mFields.
count(); ++i )
3645 pkAttributesList << i;
3648 return pkAttributesList;
3655 if ( !mDataProvider )
3668 if ( mEditBuffer && !deletedFeatures.empty() )
3670 if ( addedFeatures.size() > deletedFeatures.size() )
3671 return QgsFeatureSource::FeatureAvailability::FeaturesAvailable;
3673 return QgsFeatureSource::FeatureAvailability::FeaturesMaybeAvailable;
3676 if ( ( !mEditBuffer || addedFeatures.empty() ) && mDataProvider && mDataProvider->
empty() )
3677 return QgsFeatureSource::FeatureAvailability::NoFeaturesAvailable;
3679 return QgsFeatureSource::FeatureAvailability::FeaturesAvailable;
3689 mCommitErrors.clear();
3691 if ( !mDataProvider )
3693 mCommitErrors << tr(
"ERROR: no provider" );
3699 mCommitErrors << tr(
"ERROR: layer not editable" );
3705 if ( !mAllowCommit )
3708 mCommitChangesActive =
true;
3710 bool success =
false;
3716 mCommitChangesActive =
false;
3718 if ( !mDeletedFids.empty() )
3721 mDeletedFids.clear();
3762 return mCommitErrors;
3777 if ( !mDataProvider )
3779 mCommitErrors << tr(
"ERROR: no provider" );
3805 mEditBuffer =
nullptr;
3810 if ( rollbackExtent )
3823 return mSelectedFeatureIds.size();
3831 return mSelectedFeatureIds;
3839 features.reserve( mSelectedFeatureIds.count() );
3846 features.push_back( f );
3856 if ( mSelectedFeatureIds.isEmpty() )
3862 if ( mSelectedFeatureIds.count() == 1 )
3863 request.
setFilterFid( *mSelectedFeatureIds.constBegin() );
3874 if ( !mEditBuffer || !mDataProvider )
3877 if ( mGeometryOptions->isActive() )
3879 for (
auto feature = features.begin(); feature != features.end(); ++feature )
3882 mGeometryOptions->apply( geom );
3909 if ( exp.isField() )
3932 if ( !mDisplayExpression.isEmpty() || mFields.
isEmpty() )
3934 return mDisplayExpression;
3939 if ( !candidateName.isEmpty() )
3962 return ( mEditBuffer && mDataProvider );
3971 return t != Qgis::GeometryType::Null && t != Qgis::GeometryType::Unknown;
3974bool QgsVectorLayer::isReadOnly()
const
3978 return mDataSourceReadOnly || mReadOnly;
3986 if ( readonly && mEditBuffer )
3990 if ( !readonly && mDataSourceReadOnly )
3993 mReadOnly = readonly;
4002 if ( ! mDataProvider )
4005 if ( mDataSourceReadOnly )
4016 return mEditBuffer && mEditBuffer->
isModified();
4023 bool auxiliaryField =
false;
4027 return auxiliaryField;
4034 auxiliaryField =
true;
4037 return auxiliaryField;
4050 if ( r != mRenderer )
4054 mSymbolFeatureCounted =
false;
4055 mSymbolFeatureCountMap.clear();
4056 mSymbolFeatureIdMap.clear();
4061 if ( refreshRate <= 0 )
4063 mRefreshRendererTimer->stop();
4064 mRefreshRendererTimer->setInterval( 0 );
4068 mRefreshRendererTimer->setInterval( 1000 / refreshRate );
4069 mRefreshRendererTimer->start();
4084 mRendererGenerators << generator;
4092 for (
int i = mRendererGenerators.count() - 1; i >= 0; --i )
4094 if ( mRendererGenerators.at( i )->id() ==
id )
4096 delete mRendererGenerators.at( i );
4097 mRendererGenerators.removeAt( i );
4107 QList< const QgsFeatureRendererGenerator * > res;
4117 if ( !mDataProvider )
4123 QString ignoredError;
4127 mEditCommandActive =
true;
4135 if ( !mDataProvider )
4140 mEditCommandActive =
false;
4141 if ( !mDeletedFids.isEmpty() )
4145 mSelectedFeatureIds.subtract( mDeletedFids );
4148 mDeletedFids.clear();
4157 if ( !mDataProvider )
4168 std::unique_ptr< QUndoCommand > command = std::make_unique< QUndoCommand >();
4169 command->setObsolete(
true );
4172 mEditCommandActive =
false;
4173 mDeletedFids.clear();
4181 return mJoinBuffer->
addJoin( joinInfo );
4188 return mJoinBuffer->
removeJoin( joinLayerId );
4229 if ( oi < 0 || oi >= mExpressionFieldBuffer->
expressions().size() )
4232 return mExpressionFieldBuffer->
expressions().at( oi ).cachedExpression.expression();
4248 if ( !mDataProvider )
4253 mFields = mDataProvider->
fields();
4263 if ( mExpressionFieldBuffer )
4267 for (
auto aliasIt = mAttributeAliasMap.constBegin(); aliasIt != mAttributeAliasMap.constEnd(); ++aliasIt )
4273 mFields[ index ].setAlias( aliasIt.value() );
4276 for (
auto splitPolicyIt = mAttributeSplitPolicy.constBegin(); splitPolicyIt != mAttributeSplitPolicy.constEnd(); ++splitPolicyIt )
4278 int index = mFields.
lookupField( splitPolicyIt.key() );
4282 mFields[ index ].setSplitPolicy( splitPolicyIt.value() );
4286 QMap< QString, QgsField::ConfigurationFlags >::const_iterator flagsIt = mFieldConfigurationFlags.constBegin();
4287 for ( ; flagsIt != mFieldConfigurationFlags.constEnd(); ++flagsIt )
4293 mFields[index].setConfigurationFlags( flagsIt.value() );
4297 mDefaultValueOnUpdateFields.clear();
4298 QMap< QString, QgsDefaultValue >::const_iterator defaultIt = mDefaultExpressionMap.constBegin();
4299 for ( ; defaultIt != mDefaultExpressionMap.constEnd(); ++defaultIt )
4301 int index = mFields.
lookupField( defaultIt.key() );
4305 mFields[ index ].setDefaultValueDefinition( defaultIt.value() );
4306 if ( defaultIt.value().applyOnUpdate() )
4307 mDefaultValueOnUpdateFields.insert( index );
4310 QMap< QString, QgsFieldConstraints::Constraints >::const_iterator constraintIt = mFieldConstraints.constBegin();
4311 for ( ; constraintIt != mFieldConstraints.constEnd(); ++constraintIt )
4313 int index = mFields.
lookupField( constraintIt.key() );
4326 mFields[ index ].setConstraints( constraints );
4329 QMap< QString, QPair< QString, QString > >::const_iterator constraintExpIt = mFieldConstraintExpressions.constBegin();
4330 for ( ; constraintExpIt != mFieldConstraintExpressions.constEnd(); ++constraintExpIt )
4332 int index = mFields.
lookupField( constraintExpIt.key() );
4343 mFields[ index ].setConstraints( constraints );
4347 for ( ; constraintStrengthIt != mFieldConstraintStrength.constEnd(); ++constraintStrengthIt )
4349 int index = mFields.
lookupField( constraintStrengthIt.key().first );
4359 constraints.
setConstraintStrength( constraintStrengthIt.key().second, constraintStrengthIt.value() );
4360 mFields[ index ].setConstraints( constraints );
4363 auto fieldWidgetIterator = mFieldWidgetSetups.constBegin();
4364 for ( ; fieldWidgetIterator != mFieldWidgetSetups.constEnd(); ++ fieldWidgetIterator )
4366 int index = mFields.
indexOf( fieldWidgetIterator.key() );
4370 mFields[index].setEditorWidgetSetup( fieldWidgetIterator.value() );
4373 if ( oldFields != mFields )
4376 mEditFormConfig.setFields( mFields );
4385 if ( index < 0 || index >= mFields.
count() || !mDataProvider )
4389 if ( expression.isEmpty() )
4393 std::unique_ptr< QgsExpressionContext > tempContext;
4398 evalContext = tempContext.get();
4433 if ( index < 0 || index >= mFields.
count() )
4438 mDefaultExpressionMap.insert( mFields.
at( index ).
name(), definition );
4442 mDefaultExpressionMap.remove( mFields.
at( index ).
name() );
4451 if ( index < 0 || index >= mFields.
count() )
4462 if ( !mDataProvider )
4477 if ( mEditBuffer && ! mDataProvider->
transaction() )
4481 for (
const QVariant &v : constUniqueValues )
4483 vals << v.toString();
4487 QMapIterator< QgsFeatureId, QgsFeature > addedIt( added );
4488 while ( addedIt.hasNext() && ( limit < 0 ||
uniqueValues.count() < limit ) )
4491 QVariant v = addedIt.value().attribute( index );
4494 QString vs = v.toString();
4495 if ( !vals.contains( vs ) )
4504 while ( it.hasNext() && ( limit < 0 ||
uniqueValues.count() < limit ) )
4507 QVariant v = it.value().value( index );
4510 QString vs = v.toString();
4511 if ( !vals.contains( vs ) )
4544 .setSubsetOfAttributes( attList ) );
4547 QVariant currentValue;
4548 QHash<QString, QVariant> val;
4552 val.insert( currentValue.toString(), currentValue );
4553 if ( limit >= 0 && val.size() >= limit )
4559 return qgis::listToSet( val.values() );
4563 Q_ASSERT_X(
false,
"QgsVectorLayer::uniqueValues()",
"Unknown source of the field!" );
4571 QStringList results;
4572 if ( !mDataProvider )
4587 if ( mEditBuffer && ! mDataProvider->
transaction() )
4590 QMapIterator< QgsFeatureId, QgsFeature > addedIt( added );
4591 while ( addedIt.hasNext() && ( limit < 0 || results.count() < limit ) && ( !feedback || !feedback->
isCanceled() ) )
4594 QVariant v = addedIt.value().attribute( index );
4597 QString vs = v.toString();
4598 if ( vs.contains( substring, Qt::CaseInsensitive ) && !results.contains( vs ) )
4606 while ( it.hasNext() && ( limit < 0 || results.count() < limit ) && ( !feedback || !feedback->
isCanceled() ) )
4609 QVariant v = it.value().value( index );
4612 QString vs = v.toString();
4613 if ( vs.contains( substring, Qt::CaseInsensitive ) && !results.contains( vs ) )
4644 QString fieldName = mFields.
at( index ).
name();
4645 request.
setFilterExpression( QStringLiteral(
"\"%1\" ILIKE '%%2%'" ).arg( fieldName, substring ) );
4649 QString currentValue;
4652 currentValue = f.
attribute( index ).toString();
4653 if ( !results.contains( currentValue ) )
4654 results << currentValue;
4656 if ( ( limit >= 0 && results.size() >= limit ) || ( feedback && feedback->
isCanceled() ) )
4666 Q_ASSERT_X(
false,
"QgsVectorLayer::uniqueStringsMatching()",
"Unknown source of the field!" );
4675 minimumOrMaximumValue( index, &minimum,
nullptr );
4684 minimumOrMaximumValue( index,
nullptr, &maximum );
4692 minimumOrMaximumValue( index, &minimum, &maximum );
4695void QgsVectorLayer::minimumOrMaximumValue(
int index, QVariant *minimum, QVariant *maximum )
const
4700 *minimum = QVariant();
4702 *maximum = QVariant();
4704 if ( !mDataProvider )
4724 if ( mEditBuffer && ! mDataProvider->
transaction() )
4727 QMapIterator< QgsFeatureId, QgsFeature > addedIt( added );
4728 while ( addedIt.hasNext() )
4731 const QVariant v = addedIt.value().attribute( index );
4739 while ( it.hasNext() )
4742 const QVariant v = it.value().value( index );
4778 .setSubsetOfAttributes( attList ) );
4781 bool firstValue =
true;
4784 const QVariant currentValue = f.
attribute( index );
4791 *minimum = currentValue;
4793 *maximum = currentValue;
4798 if ( minimum && currentValue.isValid() &&
qgsVariantLessThan( currentValue, *minimum ) )
4799 *minimum = currentValue;
4801 *maximum = currentValue;
4808 Q_ASSERT_X(
false,
"QgsVectorLayer::minimumOrMaximumValue()",
"Unknown source of the field!" );
4811void QgsVectorLayer::createEditBuffer()
4847void QgsVectorLayer::clearEditBuffer()
4852 mEditBuffer =
nullptr;
4867 if ( !mDataProvider )
4870 *
error = tr(
"Layer is invalid" );
4876 if ( attrIndex >= 0 )
4883 bool providerOk =
false;
4884 QVariant val = mDataProvider->
aggregate(
aggregate, attrIndex, parameters, context, providerOk, fids );
4898 c.setFidsFilter( *fids );
4899 c.setParameters( parameters );
4900 bool aggregateOk =
false;
4901 const QVariant result =
c.calculate(
aggregate, fieldOrExpression, context, &aggregateOk, feedback );
4904 if ( !aggregateOk &&
error )
4927 return mFeatureBlendMode;
4930void QgsVectorLayer::readSldLabeling(
const QDomNode &node )
4937 QDomElement element = node.toElement();
4938 if ( element.isNull() )
4941 QDomElement userStyleElem = element.firstChildElement( QStringLiteral(
"UserStyle" ) );
4942 if ( userStyleElem.isNull() )
4944 QgsDebugMsgLevel( QStringLiteral(
"Info: UserStyle element not found." ), 4 );
4948 QDomElement featTypeStyleElem = userStyleElem.firstChildElement( QStringLiteral(
"FeatureTypeStyle" ) );
4949 if ( featTypeStyleElem.isNull() )
4951 QgsDebugMsgLevel( QStringLiteral(
"Info: FeatureTypeStyle element not found." ), 4 );
4956 QDomElement mergedFeatTypeStyle = featTypeStyleElem.cloneNode(
false ).toElement();
4961 bool needRuleBasedLabeling =
false;
4964 while ( !featTypeStyleElem.isNull() )
4966 QDomElement ruleElem = featTypeStyleElem.firstChildElement( QStringLiteral(
"Rule" ) );
4967 while ( !ruleElem.isNull() )
4971 bool hasTextSymbolizer =
false;
4972 bool hasRuleBased =
false;
4973 QDomElement ruleChildElem = ruleElem.firstChildElement();
4974 while ( !ruleChildElem.isNull() )
4977 if ( ruleChildElem.localName() == QLatin1String(
"Filter" ) ||
4978 ruleChildElem.localName() == QLatin1String(
"MinScaleDenominator" ) ||
4979 ruleChildElem.localName() == QLatin1String(
"MaxScaleDenominator" ) )
4981 hasRuleBased =
true;
4984 else if ( ruleChildElem.localName() == QLatin1String(
"TextSymbolizer" ) )
4986 QgsDebugMsgLevel( QStringLiteral(
"Info: TextSymbolizer element found" ), 4 );
4987 hasTextSymbolizer =
true;
4990 ruleChildElem = ruleChildElem.nextSiblingElement();
4993 if ( hasTextSymbolizer )
4998 mergedFeatTypeStyle.appendChild( ruleElem.cloneNode().toElement() );
5002 QgsDebugMsgLevel( QStringLiteral(
"Info: Filter or Min/MaxScaleDenominator element found: need a RuleBasedLabeling" ), 4 );
5003 needRuleBasedLabeling =
true;
5008 if ( ruleCount > 1 )
5010 QgsDebugMsgLevel( QStringLiteral(
"Info: More Rule elements found: need a RuleBasedLabeling" ), 4 );
5011 needRuleBasedLabeling =
true;
5015 if ( ruleCount == 0 )
5017 needRuleBasedLabeling =
false;
5020 ruleElem = ruleElem.nextSiblingElement( QStringLiteral(
"Rule" ) );
5022 featTypeStyleElem = featTypeStyleElem.nextSiblingElement( QStringLiteral(
"FeatureTypeStyle" ) );
5025 if ( ruleCount == 0 )
5027 QgsDebugMsgLevel( QStringLiteral(
"Info: No TextSymbolizer element." ), 4 );
5031 QDomElement ruleElem = mergedFeatTypeStyle.firstChildElement( QStringLiteral(
"Rule" ) );
5033 if ( needRuleBasedLabeling )
5037 while ( !ruleElem.isNull() )
5040 QString label, description, filterExp;
5041 int scaleMinDenom = 0, scaleMaxDenom = 0;
5045 QDomElement childElem = ruleElem.firstChildElement();
5046 while ( !childElem.isNull() )
5048 if ( childElem.localName() == QLatin1String(
"Name" ) )
5052 if ( label.isEmpty() )
5053 label = childElem.firstChild().nodeValue();
5055 else if ( childElem.localName() == QLatin1String(
"Description" ) )
5058 QDomElement titleElem = childElem.firstChildElement( QStringLiteral(
"Title" ) );
5059 if ( !titleElem.isNull() )
5061 label = titleElem.firstChild().nodeValue();
5064 QDomElement abstractElem = childElem.firstChildElement( QStringLiteral(
"Abstract" ) );
5065 if ( !abstractElem.isNull() )
5067 description = abstractElem.firstChild().nodeValue();
5070 else if ( childElem.localName() == QLatin1String(
"Abstract" ) )
5073 description = childElem.firstChild().nodeValue();
5075 else if ( childElem.localName() == QLatin1String(
"Title" ) )
5078 label = childElem.firstChild().nodeValue();
5080 else if ( childElem.localName() == QLatin1String(
"Filter" ) )
5096 else if ( childElem.localName() == QLatin1String(
"MinScaleDenominator" ) )
5099 int v = childElem.firstChild().nodeValue().toInt( &ok );
5103 else if ( childElem.localName() == QLatin1String(
"MaxScaleDenominator" ) )
5106 int v = childElem.firstChild().nodeValue().toInt( &ok );
5110 else if ( childElem.localName() == QLatin1String(
"TextSymbolizer" ) )
5112 readSldTextSymbolizer( childElem, settings );
5115 childElem = childElem.nextSiblingElement();
5121 ruleElem = ruleElem.nextSiblingElement();
5131 QDomElement textSymbolizerElem = ruleElem.firstChildElement( QStringLiteral(
"TextSymbolizer" ) );
5133 if ( readSldTextSymbolizer( textSymbolizerElem, s ) )
5141bool QgsVectorLayer::readSldTextSymbolizer(
const QDomNode &node,
QgsPalLayerSettings &settings )
const
5145 if ( node.localName() != QLatin1String(
"TextSymbolizer" ) )
5147 QgsDebugMsgLevel( QStringLiteral(
"Not a TextSymbolizer element: %1" ).arg( node.localName() ), 3 );
5150 QDomElement textSymbolizerElem = node.toElement();
5152 QDomElement labelElem = textSymbolizerElem.firstChildElement( QStringLiteral(
"Label" ) );
5153 if ( !labelElem.isNull() )
5155 QDomElement propertyNameElem = labelElem.firstChildElement( QStringLiteral(
"PropertyName" ) );
5156 if ( !propertyNameElem.isNull() )
5161 QString labelAttribute = propertyNameElem.text();
5165 int fieldIndex = mFields.
lookupField( labelAttribute );
5166 if ( fieldIndex == -1 )
5170 if ( !exp.hasEvalError() )
5176 QgsDebugMsgLevel( QStringLiteral(
"SLD label attribute error: %1" ).arg( exp.evalErrorString() ), 3 );
5182 QgsDebugMsgLevel( QStringLiteral(
"Info: PropertyName element not found." ), 4 );
5193 if ( textSymbolizerElem.hasAttribute( QStringLiteral(
"uom" ) ) )
5198 QString fontFamily = QStringLiteral(
"Sans-Serif" );
5199 int fontPointSize = 10;
5201 int fontWeight = -1;
5202 bool fontItalic =
false;
5203 bool fontUnderline =
false;
5206 QDomElement fontElem = textSymbolizerElem.firstChildElement( QStringLiteral(
"Font" ) );
5207 if ( !fontElem.isNull() )
5210 for ( QgsStringMap::iterator it = fontSvgParams.begin(); it != fontSvgParams.end(); ++it )
5212 QgsDebugMsgLevel( QStringLiteral(
"found fontSvgParams %1: %2" ).arg( it.key(), it.value() ), 4 );
5214 if ( it.key() == QLatin1String(
"font-family" ) )
5216 fontFamily = it.value();
5218 else if ( it.key() == QLatin1String(
"font-style" ) )
5220 fontItalic = ( it.value() == QLatin1String(
"italic" ) ) || ( it.value() == QLatin1String(
"Italic" ) );
5222 else if ( it.key() == QLatin1String(
"font-size" ) )
5225 int fontSize = it.value().toInt( &ok );
5228 fontPointSize = fontSize;
5229 fontUnitSize = sldUnitSize;
5232 else if ( it.key() == QLatin1String(
"font-weight" ) )
5234 if ( ( it.value() == QLatin1String(
"bold" ) ) || ( it.value() == QLatin1String(
"Bold" ) ) )
5235 fontWeight = QFont::Bold;
5237 else if ( it.key() == QLatin1String(
"font-underline" ) )
5239 fontUnderline = ( it.value() == QLatin1String(
"underline" ) ) || ( it.value() == QLatin1String(
"Underline" ) );
5245 QFont font( fontFamily, fontPointSize, fontWeight, fontItalic );
5246 font.setUnderline( fontUnderline );
5248 format.
setSize( fontPointSize );
5252 QDomElement fillElem = textSymbolizerElem.firstChildElement( QStringLiteral(
"Fill" ) );
5254 Qt::BrushStyle textBrush = Qt::SolidPattern;
5256 if ( textColor.isValid() )
5258 QgsDebugMsgLevel( QStringLiteral(
"Info: textColor %1." ).arg( QVariant( textColor ).toString() ), 4 );
5265 QDomElement haloElem = textSymbolizerElem.firstChildElement( QStringLiteral(
"Halo" ) );
5266 if ( !haloElem.isNull() )
5271 QDomElement radiusElem = haloElem.firstChildElement( QStringLiteral(
"Radius" ) );
5272 if ( !radiusElem.isNull() )
5275 double bufferSize = radiusElem.text().toDouble( &ok );
5278 bufferSettings.
setSize( bufferSize );
5283 QDomElement haloFillElem = haloElem.firstChildElement( QStringLiteral(
"Fill" ) );
5285 Qt::BrushStyle bufferBrush = Qt::SolidPattern;
5287 if ( bufferColor.isValid() )
5289 QgsDebugMsgLevel( QStringLiteral(
"Info: bufferColor %1." ).arg( QVariant( bufferColor ).toString() ), 4 );
5290 bufferSettings.
setColor( bufferColor );
5295 QDomElement labelPlacementElem = textSymbolizerElem.firstChildElement( QStringLiteral(
"LabelPlacement" ) );
5296 if ( !labelPlacementElem.isNull() )
5299 QDomElement pointPlacementElem = labelPlacementElem.firstChildElement( QStringLiteral(
"PointPlacement" ) );
5300 if ( !pointPlacementElem.isNull() )
5308 QDomElement displacementElem = pointPlacementElem.firstChildElement( QStringLiteral(
"Displacement" ) );
5309 if ( !displacementElem.isNull() )
5311 QDomElement displacementXElem = displacementElem.firstChildElement( QStringLiteral(
"DisplacementX" ) );
5312 if ( !displacementXElem.isNull() )
5315 double xOffset = displacementXElem.text().toDouble( &ok );
5322 QDomElement displacementYElem = displacementElem.firstChildElement( QStringLiteral(
"DisplacementY" ) );
5323 if ( !displacementYElem.isNull() )
5326 double yOffset = displacementYElem.text().toDouble( &ok );
5334 QDomElement anchorPointElem = pointPlacementElem.firstChildElement( QStringLiteral(
"AnchorPoint" ) );
5335 if ( !anchorPointElem.isNull() )
5337 QDomElement anchorPointXElem = anchorPointElem.firstChildElement( QStringLiteral(
"AnchorPointX" ) );
5338 if ( !anchorPointXElem.isNull() )
5341 double xOffset = anchorPointXElem.text().toDouble( &ok );
5348 QDomElement anchorPointYElem = anchorPointElem.firstChildElement( QStringLiteral(
"AnchorPointY" ) );
5349 if ( !anchorPointYElem.isNull() )
5352 double yOffset = anchorPointYElem.text().toDouble( &ok );
5361 QDomElement rotationElem = pointPlacementElem.firstChildElement( QStringLiteral(
"Rotation" ) );
5362 if ( !rotationElem.isNull() )
5365 double rotation = rotationElem.text().toDouble( &ok );
5375 QDomElement linePlacementElem = labelPlacementElem.firstChildElement( QStringLiteral(
"LinePlacement" ) );
5376 if ( !linePlacementElem.isNull() )
5385 QDomElement vendorOptionElem = textSymbolizerElem.firstChildElement( QStringLiteral(
"VendorOption" ) );
5386 while ( !vendorOptionElem.isNull() && vendorOptionElem.localName() == QLatin1String(
"VendorOption" ) )
5388 QString optionName = vendorOptionElem.attribute( QStringLiteral(
"name" ) );
5389 QString optionValue;
5390 if ( vendorOptionElem.firstChild().nodeType() == QDomNode::TextNode )
5392 optionValue = vendorOptionElem.firstChild().nodeValue();
5396 if ( vendorOptionElem.firstChild().nodeType() == QDomNode::ElementNode &&
5397 vendorOptionElem.firstChild().localName() == QLatin1String(
"Literal" ) )
5399 QgsDebugMsg( vendorOptionElem.firstChild().localName() );
5400 optionValue = vendorOptionElem.firstChild().firstChild().nodeValue();
5404 QgsDebugMsg( QStringLiteral(
"unexpected child of %1 named %2" ).arg( vendorOptionElem.localName(), optionName ) );
5408 if ( !optionName.isEmpty() && !optionValue.isEmpty() )
5410 vendorOptions[ optionName ] = optionValue;
5413 vendorOptionElem = vendorOptionElem.nextSiblingElement();
5415 if ( !vendorOptions.isEmpty() )
5417 for ( QgsStringMap::iterator it = vendorOptions.begin(); it != vendorOptions.end(); ++it )
5419 if ( it.key() == QLatin1String(
"underlineText" ) && it.value() == QLatin1String(
"true" ) )
5421 font.setUnderline(
true );
5424 else if ( it.key() == QLatin1String(
"strikethroughText" ) && it.value() == QLatin1String(
"true" ) )
5426 font.setStrikeOut(
true );
5429 else if ( it.key() == QLatin1String(
"maxDisplacement" ) )
5433 else if ( it.key() == QLatin1String(
"followLine" ) && it.value() == QLatin1String(
"true" ) )
5444 else if ( it.key() == QLatin1String(
"maxAngleDelta" ) )
5447 double angle = it.value().toDouble( &ok );
5455 else if ( it.key() == QLatin1String(
"conflictResolution" ) && it.value() == QLatin1String(
"false" ) )
5459 else if ( it.key() == QLatin1String(
"forceLeftToRight" ) && it.value() == QLatin1String(
"false" ) )
5461 settings.
upsidedownLabels = Qgis::UpsideDownLabelHandling::AlwaysAllowUpsideDown;
5463 else if ( it.key() == QLatin1String(
"group" ) && it.value() == QLatin1String(
"yes" ) )
5467 else if ( it.key() == QLatin1String(
"labelAllGroup" ) && it.value() == QLatin1String(
"true" ) )
5483 return mEditFormConfig;
5494 mEditFormConfig.onRelationsLoaded();
5504 if ( config.isEmpty() )
5540 if ( !mDiagramLayerSettings )
5542 *mDiagramLayerSettings = s;
5550 QString myMetadata = QStringLiteral(
"<html><head></head>\n<body>\n" );
5555 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"Information from provider" ) + QStringLiteral(
"</h1>\n<hr>\n" );
5556 myMetadata += QLatin1String(
"<table class=\"list-view\">\n" );
5561 myMetadata += QStringLiteral(
"<tr><td class=\"highlight\">" ) + tr(
"Storage" ) + QStringLiteral(
"</td><td>" ) +
storageType() + QStringLiteral(
"</td></tr>\n" );
5567 myMetadata += QStringLiteral(
"<tr><td class=\"highlight\">" ) + tr(
"Comment" ) + QStringLiteral(
"</td><td>" ) +
dataComment() + QStringLiteral(
"</td></tr>\n" );
5574 myMetadata += QStringLiteral(
"<tr><td class=\"highlight\">" ) + tr(
"Encoding" ) + QStringLiteral(
"</td><td>" ) + provider->
encoding() + QStringLiteral(
"</td></tr>\n" );
5581 if (
static_cast<int>(
type ) < 0 ||
static_cast< int >(
type ) >
static_cast< int >( Qgis::GeometryType::Null ) )
5589 myMetadata += QStringLiteral(
"<tr><td class=\"highlight\">" ) + tr(
"Geometry" ) + QStringLiteral(
"</td><td>" ) + typeString + QStringLiteral(
"</td></tr>\n" );
5593 myMetadata += QStringLiteral(
"<tr><td class=\"highlight\">" ) + tr(
"Extent" ) + QStringLiteral(
"</td><td>" ) +
extent().
toString() + QStringLiteral(
"</td></tr>\n" );
5597 QLocale locale = QLocale();
5598 locale.setNumberOptions( locale.numberOptions() &= ~QLocale::NumberOption::OmitGroupSeparator );
5599 myMetadata += QStringLiteral(
"<tr><td class=\"highlight\">" )
5600 + tr(
"Feature count" ) + QStringLiteral(
"</td><td>" )
5602 + QStringLiteral(
"</td></tr>\n" );
5605 myMetadata += QLatin1String(
"</table>\n<br><br>" );
5614 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"Identification" ) + QStringLiteral(
"</h1>\n<hr>\n" );
5615 myMetadata += htmlFormatter.identificationSectionHtml( );
5616 myMetadata += QLatin1String(
"<br><br>\n" );
5619 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"Extent" ) + QStringLiteral(
"</h1>\n<hr>\n" );
5620 myMetadata += htmlFormatter.extentSectionHtml(
isSpatial() );
5621 myMetadata += QLatin1String(
"<br><br>\n" );
5624 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"Access" ) + QStringLiteral(
"</h1>\n<hr>\n" );
5625 myMetadata += htmlFormatter.accessSectionHtml( );
5626 myMetadata += QLatin1String(
"<br><br>\n" );
5629 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"Fields" ) + QStringLiteral(
"</h1>\n<hr>\n<table class=\"list-view\">\n" );
5633 if ( !pkAttrList.isEmpty() )
5635 myMetadata += QStringLiteral(
"<tr><td class=\"highlight\">" ) + tr(
"Primary key attributes" ) + QStringLiteral(
"</td><td>" );
5636 const auto constPkAttrList = pkAttrList;
5637 for (
int idx : constPkAttrList )
5641 myMetadata += QLatin1String(
"</td></tr>\n" );
5647 myMetadata += QStringLiteral(
"<tr><td class=\"highlight\">" ) + tr(
"Count" ) + QStringLiteral(
"</td><td>" ) + QString::number( myFields.
size() ) + QStringLiteral(
"</td></tr>\n" );
5649 myMetadata += QLatin1String(
"</table>\n<br><table width=\"100%\" class=\"tabular-view\">\n" );
5650 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" );
5652 for (
int i = 0; i < myFields.
size(); ++i )
5657 rowClass = QStringLiteral(
"class=\"odd-row\"" );
5658 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" );
5662 myMetadata += QLatin1String(
"</table>\n<br><br>" );
5665 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"Contacts" ) + QStringLiteral(
"</h1>\n<hr>\n" );
5666 myMetadata += htmlFormatter.contactsSectionHtml( );
5667 myMetadata += QLatin1String(
"<br><br>\n" );
5670 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"Links" ) + QStringLiteral(
"</h1>\n<hr>\n" );
5671 myMetadata += htmlFormatter.linksSectionHtml( );
5672 myMetadata += QLatin1String(
"<br><br>\n" );
5675 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"History" ) + QStringLiteral(
"</h1>\n<hr>\n" );
5676 myMetadata += htmlFormatter.historySectionHtml( );
5677 myMetadata += QLatin1String(
"<br><br>\n" );
5679 myMetadata += QLatin1String(
"\n</body>\n</html>\n" );
5683void QgsVectorLayer::invalidateSymbolCountedFlag()
5687 mSymbolFeatureCounted =
false;
5690void QgsVectorLayer::onFeatureCounterCompleted()
5695 mFeatureCounter =
nullptr;
5698void QgsVectorLayer::onFeatureCounterTerminated()
5702 mFeatureCounter =
nullptr;
5705void QgsVectorLayer::onJoinedFieldsChanged()
5713void QgsVectorLayer::onFeatureDeleted(
QgsFeatureId fid )
5717 if ( mEditCommandActive || mCommitChangesActive )
5719 mDeletedFids << fid;
5723 mSelectedFeatureIds.remove( fid );
5730void QgsVectorLayer::onRelationsLoaded()
5734 mEditFormConfig.onRelationsLoaded();
5737void QgsVectorLayer::onSymbolsCounted()
5741 if ( mFeatureCounter )
5743 mSymbolFeatureCounted =
true;
5761 return mWeakRelations;
5768 mWeakRelations = relations;
5793 bool useAsDefault,
const QString &uiFileContent, QString &msgError, QgsMapLayer::StyleCategories categories )
5797 QString sldStyle, qmlStyle;
5798 QDomDocument qmlDocument, sldDocument;
5801 if ( !msgError.isNull() )
5805 qmlStyle = qmlDocument.toString();
5808 if ( !msgError.isNull() )
5812 sldStyle = sldDocument.toString();
5816 description, uiFileContent, useAsDefault, msgError );
5832 QString joinKey = mAuxiliaryLayerKey;
5833 if ( !key.isEmpty() )
5836 if ( storage.
isValid() && !joinKey.isEmpty() )
5861 mAuxiliaryLayerKey.clear();
5863 if ( mAuxiliaryLayer )
5876 mAuxiliaryLayer.reset( alayer );
5877 if ( mAuxiliaryLayer )
5878 mAuxiliaryLayer->setParent(
this );
5886 return mAuxiliaryLayer.get();
5893 return mAuxiliaryLayer.get();
5901 QString returnMessage;
5902 QString qml, errorMsg;
5910 if ( !qml.isEmpty() )
5912 QDomDocument myDocument( QStringLiteral(
"qgis" ) );
5913 myDocument.setContent( qml );
5915 returnMessage = QObject::tr(
"Loaded from Provider" );
5922 if ( ! styleName.isEmpty() )
5930 return returnMessage;
5937 if ( mDataProvider )
5942void QgsVectorLayer::emitDataChanged()
5946 if ( mDataChangedFired )
5951 mDataChangedFired =
true;
5953 mDataChangedFired =
false;
5956void QgsVectorLayer::onAfterCommitChangesDependency()
5960 mDataChangedFired =
true;
5962 mDataChangedFired =
false;
5969 QSet<QgsMapLayerDependency> deps;
5970 const auto constODeps = oDeps;
5977 QSet<QgsMapLayerDependency> toAdd = deps -
dependencies();
5994 if ( mDataProvider )
6015 if ( ! toAdd.isEmpty() )
6025 if ( fieldIndex < 0 || fieldIndex >= mFields.
count() || !mDataProvider )
6026 return QgsFieldConstraints::Constraints();
6043 QMap< QgsFieldConstraints::Constraint, QgsFieldConstraints::ConstraintStrength > m;
6045 if ( fieldIndex < 0 || fieldIndex >= mFields.
count() )
6048 QString
name = mFields.
at( fieldIndex ).
name();
6051 for ( ; conIt != mFieldConstraintStrength.constEnd(); ++conIt )
6053 if ( conIt.key().first ==
name )
6055 m[ conIt.key().second ] = mFieldConstraintStrength.value( conIt.key() );
6066 if ( index < 0 || index >= mFields.
count() )
6072 QgsFieldConstraints::Constraints constraints = mFieldConstraints.value(
name, QgsFieldConstraints::Constraints() );
6073 constraints |= constraint;
6074 mFieldConstraints.insert(
name, constraints );
6076 mFieldConstraintStrength.insert( qMakePair(
name, constraint ), strength );
6085 if ( index < 0 || index >= mFields.
count() )
6091 QgsFieldConstraints::Constraints constraints = mFieldConstraints.value(
name, QgsFieldConstraints::Constraints() );
6092 constraints &= ~constraint;
6093 mFieldConstraints.insert(
name, constraints );
6095 mFieldConstraintStrength.remove( qMakePair(
name, constraint ) );
6104 if ( index < 0 || index >= mFields.
count() )
6114 if ( index < 0 || index >= mFields.
count() )
6124 if ( index < 0 || index >= mFields.
count() )
6127 if ( expression.isEmpty() )
6129 mFieldConstraintExpressions.remove( mFields.
at( index ).
name() );
6133 mFieldConstraintExpressions.insert( mFields.
at( index ).
name(), qMakePair( expression, description ) );
6142 if ( index < 0 || index >= mFields.
count() )
6145 mFieldConfigurationFlags.insert( mFields.
at( index ).
name(),
flags );
6153 if ( index < 0 || index >= mFields.
count() )
6156 flags.setFlag( flag, active );
6164 if ( index < 0 || index >= mFields.
count() )
6174 if ( index < 0 || index >= mFields.
count() )
6178 mFieldWidgetSetups.remove( mFields.
at( index ).
name() );
6180 mFieldWidgetSetups.insert( mFields.
at( index ).
name(), setup );
6188 if ( index < 0 || index >= mFields.
count() )
6199 if (
customProperty( QStringLiteral(
"labeling" ) ).toString() == QLatin1String(
"pal" ) )
6201 if (
customProperty( QStringLiteral(
"labeling/enabled" ), QVariant(
false ) ).toBool() )
6205 settings.readFromLayerCustomProperties(
this );
6212 for (
const QString &key : constCustomPropertyKeys )
6214 if ( key.startsWith( QLatin1String(
"labeling/" ) ) )
6226 return mAllowCommit;
6244 return mGeometryOptions.get();
6258 return mReadExtentFromXml;
6261void QgsVectorLayer::onDirtyTransaction(
const QString &sql,
const QString &name )
6266 if ( tr && mEditBuffer )
6268 qobject_cast<QgsVectorLayerEditPassthrough *>( mEditBuffer )->update( tr, sql,
name );
6274 QList<QgsVectorLayer *> layers;
6275 QMap<QgsVectorLayer *, QgsFeatureIds>::const_iterator i;
6278 if ( includeAuxiliaryLayers || !qobject_cast< QgsAuxiliaryLayer * >( i.key() ) )
6279 layers.append( i.key() );
6286 return mHandledFeatures[layer];
The Qgis class provides global constants for use throughout the application.
@ Composition
Fix relation, related elements are part of the parent and a parent copy will copy any children or del...
@ Association
Loose relation, related elements are not part of the parent and a parent copy will not copy any child...
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.
@ OverPoint
Arranges candidates over a point (or centroid of a polygon), or at a preset offset from the point....
@ Curved
Arranges candidates following the curvature of a line feature. Applies to line layers only.
@ 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'...
@ Horizontal
Arranges horizontal candidates scattered throughout a polygon feature. Applies to polygon layers only...
@ PerimeterCurved
Arranges candidates following the curvature of a polygon's boundary. Applies to polygon layers only.
@ BufferedGroups
Buffered transactional editing means that all editable layers in the buffered transaction group are t...
FieldDomainSplitPolicy
Split policy for field domains.
@ Duplicate
Duplicate original value.
BlendMode
Blending modes defining the available composition modes that can be used when painting.
GeometryType
The geometry types are used to group Qgis::WkbType in a coarse way.
@ Generated
A generated relation is a child of a polymorphic relation.
@ Normal
A normal relation.
static const float DEFAULT_MAPTOPIXEL_THRESHOLD
Default threshold between map coordinates and device coordinates for map2pixel simplification.
RenderUnit
Rendering size units.
VertexMarkerType
Editing vertex markers, used for showing vertices during a edit operation.
@ SemiTransparentCircle
Semi-transparent circle marker.
VectorEditResult
Flags which control feature selection behavior.
@ Success
Edit operation was successful.
@ InvalidLayer
Edit failed due to invalid layer.
WkbType
The WKB type describes the number of dimensions a geometry has.
@ AllowOverlapIfRequired
Avoids overlapping labels when possible, but permit overlaps if labels for features cannot otherwise ...
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.
Abstract base class for objects which generate elevation profiles.
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(Qgis::AttributeActionType 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.
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...
@ ForceReadOnly
Open layer in a read-only mode (since QGIS 3.28)
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.
bool useEstimatedMetadata() const
Returns true if estimated metadata should be used for the connection.
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 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.
void updateFields(QgsFields &flds) const
Adds fields with the expressions buffered in this object to a QgsFields object.
void addExpression(const QString &exp, const QgsField &fld)
Add an expression to the buffer.
QList< QgsExpressionFieldBuffer::ExpressionField > expressions() const
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.
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)
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(Qgis::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.
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...
static QgsFeatureRenderer * loadSld(const QDomNode &node, Qgis::GeometryType geomType, QString &errorMessage)
Create a new renderer according to the information contained in the UserStyle element of a SLD style ...
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.
Qgis::FieldDomainSplitPolicy splitPolicy() const
Returns the field's split policy, which indicates how field values should be handled during a split o...
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.
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...
void setOverlapHandling(Qgis::LabelOverlapHandling handling)
Sets the technique used to handle overlapping labels.
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.
Base class for storage of map layer elevation properties.
static QString typeToString(Qgis::LayerType 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.
bool renameStyle(const QString &name, const QString &newName)
Rename a stored style to a different name.
Stores style information (renderer, opacity, labeling, diagrams etc.) applicable to a map layer.
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 ...
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...
virtual QgsMapLayer * clone() const =0
Returns a new instance equivalent to this one except for the id which is still unique.
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,...
@ FlagForceReadOnly
Force open as read only.
@ 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.
QgsMapLayerStyleManager * styleManager() const
Gets access to the layer's style manager.
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.
void setMapTipTemplate(const QString &mapTipTemplate)
The mapTip is a pretty, html representation for feature information.
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 Qgis::BlendMode getBlendModeEnum(QPainter::CompositionMode blendMode)
Returns a BlendMode corresponding to a QPainter::CompositionMode.
static QPainter::CompositionMode getCompositionMode(Qgis::BlendMode blendMode)
Returns a QPainter::CompositionMode corresponding to a BlendMode.
Contains settings for how a map layer will be labeled.
double yOffset
Vertical offset of label.
const QgsLabelPlacementSettings & placementSettings() const
Returns the label placement settings.
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.
double xOffset
Horizontal offset of label.
Qgis::LabelPlacement placement
Label placement mode.
double angleOffset
Label rotation, in degrees clockwise.
double maxCurvedCharAngleOut
Maximum angle between outside curved label characters (valid range -20.0 to -95.0)
Qgis::RenderUnit offsetUnits
Units for offsets of label.
bool isExpression
true if this label is made from a expression string, e.g., FieldName || 'mm'
const QgsLabelLineSettings & lineSettings() const
Returns the label line settings, which contain settings related to how the label engine places and fo...
Qgis::UpsideDownLabelHandling 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.
A class to represent a 2D point.
Point geometry type, with support for z-dimension and m-values.
Encapsulates properties and constraints relating to fetching elevation profiles from different source...
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
bool commitChanges(QStringList &commitErrors, bool stopEditing=true, QgsVectorLayer *vectorLayer=nullptr)
Attempts to commit to the underlying data provider any buffered changes made since the last to call t...
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.
bool rollBack(QStringList &rollbackErrors, bool stopEditing=true, QgsVectorLayer *vectorLayer=nullptr)
Stops a current editing operation on vectorLayer and discards any uncommitted edits.
QgsPathResolver pathResolver() const
Returns path resolver object with considering whether the project uses absolute or relative paths and...
bool startEditing(QgsVectorLayer *vectorLayer=nullptr)
Makes the layer editable.
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 absoluteToRelativeUri(const QString &providerKey, const QString &uri, const QgsReadWriteContext &context) const
Converts absolute path(s) to relative path(s) in the given provider-specific 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.
QString loadStoredStyle(const QString &providerKey, const QString &uri, QString &styleName, QString &errCause)
Loads a layer style from the provider storage, reporting its name.
QString relativeToAbsoluteUri(const QString &providerKey, const QString &uri, const QgsReadWriteContext &context) const
Converts relative path(s) to absolute path(s) in the given provider-specific URI.
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.
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.
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.
A boolean settings entry.
static QgsSettingsTreeNode * sTreeQgis
This class is a composition of two QSettings instances:
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 double rendererFrameRate(const QgsFeatureRenderer *renderer)
Calculates the frame rate (in frames per second) at which the given renderer must be redrawn.
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)
static Qgis::RenderUnit decodeSldUom(const QString &str, double *scaleFactor=nullptr)
Decodes a SLD unit of measure string to a render unit.
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 setSizeUnit(Qgis::RenderUnit unit)
Sets the units used for the buffer size.
void setEnabled(bool enabled)
Sets whether the text buffer will be drawn.
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 setSizeUnit(Qgis::RenderUnit unit)
Sets the units for the size of rendered text.
void setBuffer(const QgsTextBufferSettings &bufferSettings)
Sets the text's buffer settings.
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.
static bool isNull(const QVariant &variant)
Returns true if the specified variant should be considered a NULL value.
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....
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.
Qgis::WkbType wkbType() const override=0
Returns the geometry type which is returned by this layer.
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.
bool commitChanges(QStringList &commitErrors, bool stopEditing=true)
Attempts to commit any changes to disk.
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 deleteFeatures(const QgsFeatureIds &fid)
Deletes a set of features from the layer (but does not commit it)
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.
QgsVectorLayerEditBufferGroup * editBufferGroup() const
Returns the parent edit buffer group for this edit buffer, or nullptr if not part of a group.
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.
Vector layer specific subclass of QgsMapLayerElevationProperties.
void setDefaultsFromLayer(QgsMapLayer *layer) override
Sets default properties based on sensible choices for the given map layer.
QgsVectorLayerElevationProperties * clone() const override
Creates a clone of the properties.
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 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.
const QgsVectorJoinList & vectorJoins() const
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 QgsAbstractProfileGenerator for vector layers.
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.
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 bool deleteSelectedFeatures(int *deletedCount=nullptr, QgsVectorLayer::DeleteContext *context=nullptr)
Deletes the selected features.
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.
virtual void saveStyleToDatabase(const QString &name, const QString &description, bool useAsDefault, const QString &uiFileContent, QString &msgError, QgsMapLayer::StyleCategories categories=QgsMapLayer::AllStyleCategories)
Saves named and sld style of the layer to the style table in the db.
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...
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 the layer's temporal properties.
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.
bool hasMapTips() const FINAL
Returns true if the layer contains map tips.
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.
static const QgsSettingsEntryEnumFlag< QgsVectorSimplifyMethod::SimplifyHints > * settingsSimplifyDrawingHints
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.
const QgsDiagramLayerSettings * diagramLayerSettings() const
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.
QgsAbstractProfileGenerator * createProfileGenerator(const QgsProfileRequest &request) override
Given a profile request, returns a new profile generator ready for generating elevation profiles.
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.
Q_INVOKABLE Qgis::GeometryOperationResult splitFeatures(const QgsPointSequence &splitLine, bool topologicalEditing=false)
Splits features cut by the given line.
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)
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.
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.
Q_INVOKABLE void selectByExpression(const QString &expression, Qgis::SelectBehavior behavior=Qgis::SelectBehavior::SetSelection, QgsExpressionContext *context=nullptr)
Selects matching features using an expression.
static const QgsSettingsEntryDouble * settingsSimplifyMaxScale
~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.
const QgsAbstractVectorLayerLabeling * labeling() const
Access to const labeling configuration.
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).
static const QgsSettingsEntryBool * settingsSimplifyLocal
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).
QgsMapLayerElevationProperties * elevationProperties() override
Returns the layer's elevation properties.
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.
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.
Q_INVOKABLE Qgis::WkbType wkbType() const FINAL
Returns the WKBType or WKBUnknown in case of error.
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.
QgsFeatureRenderer * renderer()
Returns the feature renderer used for rendering the features in the layer in 2D map views.
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 setWeakRelations(const QList< QgsWeakRelation > &relations)
Sets the layer's weak relations.
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.
QgsActionManager * actions()
Returns all layer actions defined on this layer.
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.
QgsFeatureSource::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.
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.
Q_INVOKABLE Qgis::GeometryType geometryType() const
Returns point, line or polygon.
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.
const QgsVectorSimplifyMethod & simplifyMethod() const
Returns the simplification settings for fast rendering of features.
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.
void beforeRollBack()
Emitted before changes are rolled back.
QgsAttributeList primaryKeyAttributes() const
Returns the list of attributes which make up the layer's primary keys.
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...
static const QgsSettingsEntryEnumFlag< QgsVectorSimplifyMethod::SimplifyAlgorithm > * settingsSimplifyAlgorithm
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.
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.
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.
const QgsDiagramRenderer * diagramRenderer() const
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...
static const QgsSettingsEntryDouble * settingsSimplifyDrawingTol
QSet< QVariant > uniqueValues(int fieldIndex, int limit=-1) const FINAL
Calculates a list of unique values contained within an attribute in the layer.
void setFieldSplitPolicy(int index, Qgis::FieldDomainSplitPolicy policy)
Sets a split policy for the field with the specified index.
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 (or the "child" / "right" layer in the relationship)
@ Referenced
The layer is referenced (or the "parent" / "left" left in the relationship)
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 QString geometryDisplayString(Qgis::GeometryType type) SIP_HOLDGIL
Returns a display string for a geometry type.
static Qgis::GeometryType geometryType(Qgis::WkbType type) SIP_HOLDGIL
Returns the geometry type for a WKB type, e.g., both MultiPolygon and CurvePolygon would have a Polyg...
static QString displayString(Qgis::WkbType 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)
@ UnknownCount
Provider returned an unknown feature count.
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.
T qgsEnumKeyToValue(const QString &key, const T &defaultValue, bool tryValueAsKey=true, bool *returnOk=nullptr)
Returns the value corresponding to the given key of an enum.
QString qgsEnumValueToKey(const T &value, bool *returnOk=nullptr)
Returns the value for the given key of an enum.
QString qgsFlagValueToKeys(const T &value, bool *returnOk=nullptr)
Returns the value for the given keys of a flag.
T qgsFlagKeysToValue(const QString &keys, const T &defaultValue, bool tryValueAsKey=true, bool *returnOk=nullptr)
Returns the value corresponding to the given keys of a flag.
QMap< QString, QString > QgsStringMap
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
#define QGIS_PROTECT_QOBJECT_THREAD_ACCESS_NON_FATAL
#define QGIS_PROTECT_QOBJECT_THREAD_ACCESS
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.
bool skipCrsValidation
Controls whether the layer is allowed to have an invalid/unknown CRS.
bool forceReadOnly
Controls whether the layer is forced to be load as Read Only.
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.
Qgis::WkbType fallbackWkbType
Fallback geometry type.
bool loadAllStoredStyles
Controls whether the stored styles will be all loaded.