105#include <QPainterPath>
107#include <QProgressDialog>
108#include <QRegularExpression>
110#include <QStringBuilder>
112#include <QUndoCommand>
118#include "moc_qgsvectorlayer.cpp"
120using namespace Qt::StringLiterals;
131#ifdef TESTPROVIDERLIB
136 const QString &uri,
const QString &qmlStyle,
const QString &sldStyle,
const QString &styleName,
const QString &styleDescription,
const QString &uiFileContent,
bool useAsDefault, QString &errCause
139typedef QString
loadStyle_t(
const QString &uri, QString &errCause );
141typedef int listStyles_t(
const QString &uri, QStringList &ids, QStringList &names, QStringList &descriptions, QString &errCause );
143typedef QString
getStyleById_t(
const QString &uri, QString styleID, QString &errCause );
153 , mAuxiliaryLayer( nullptr )
154 , mAuxiliaryLayerKey( QString() )
156 , mRefreshRendererTimer( new QTimer( this ) )
167 mGeometryOptions = std::make_unique<QgsGeometryOptions>();
171 mStoredExpressionManager->setParent(
this );
174 mJoinBuffer->setParent(
this );
179 if ( !vectorLayerPath.isEmpty() && !
mProviderKey.isEmpty() )
190 mDataSourceReadOnly =
true;
192 setDataSource( vectorLayerPath, baseName, providerKey, providerOptions, providerFlags );
195 for (
const QgsField &field : std::as_const( mFields ) )
197 if ( !mAttributeAliasMap.contains( field.name() ) )
198 mAttributeAliasMap.insert( field.name(), QString() );
203 mTemporalProperties->setDefaultsFromDataProviderTemporalCapabilities( mDataProvider->temporalCapabilities() );
204 if ( !mTemporalProperties->isActive() )
208 mTemporalProperties->guessDefaultsFromFields( mFields );
211 mElevationProperties->setDefaultsFromLayer(
this );
229 connect( mRefreshRendererTimer, &QTimer::timeout,
this, [
this] {
triggerRepaint(
true ); } );
238 delete mDataProvider;
241 delete mExpressionFieldBuffer;
243 delete mDiagramLayerSettings;
244 delete mDiagramRenderer;
249 delete mConditionalStyles;
250 delete mStoredExpressionManager;
252 if ( mFeatureCounter )
253 mFeatureCounter->cancel();
255 qDeleteAll( mRendererGenerators );
269 dataSource = mDataProvider->dataSourceUri();
270 options.transformContext = mDataProvider->transformContext();
283 layer->mXmlExtent2D = mXmlExtent2D;
284 layer->mLazyExtent2D = mLazyExtent2D;
285 layer->mValidExtent2D = mValidExtent2D;
286 layer->mXmlExtent3D = mXmlExtent3D;
287 layer->mLazyExtent3D = mLazyExtent3D;
288 layer->mValidExtent3D = mValidExtent3D;
290 QList<QgsVectorLayerJoinInfo> joins =
vectorJoins();
291 const auto constJoins = joins;
312 for (
const QgsAction &action : constActions )
349 auto constraintIt = constraints.constBegin();
350 for ( ; constraintIt != constraints.constEnd(); ++constraintIt )
366 layer->mElevationProperties = mElevationProperties->
clone();
367 layer->mElevationProperties->setParent( layer );
369 layer->mSelectionProperties = mSelectionProperties->
clone();
370 layer->mSelectionProperties->setParent( layer );
381 return mDataProvider->storageType();
393 return mDataProvider->capabilitiesString();
402 return mDataProvider && mDataProvider->isSqlQuery();
418 return mDataProvider->dataComment();
444 mDataProvider->reloadData();
463 p.setPen( QColor( 50, 100, 120, 200 ) );
464 p.setBrush( QColor( 200, 200, 210, 120 ) );
465 p.drawEllipse( x - m, y - m, m * 2 + 1, m * 2 + 1 );
469 p.setPen( QColor( 255, 0, 0 ) );
470 p.drawLine( x - m, y + m, x + m, y - m );
471 p.drawLine( x - m, y - m, x + m, y + m );
483 mSelectedFeatureIds.insert( fid );
484 mPreviousSelectedFeatureIds.clear();
493 mSelectedFeatureIds.unite( featureIds );
494 mPreviousSelectedFeatureIds.clear();
503 mSelectedFeatureIds.remove( fid );
504 mPreviousSelectedFeatureIds.clear();
513 mSelectedFeatureIds.subtract( featureIds );
514 mPreviousSelectedFeatureIds.clear();
536 newSelection << feat.
id();
549 std::optional< QgsExpressionContext > defaultContext;
553 context = &defaultContext.value();
580 newSelection << feat.
id();
599 bool matches = exp.
evaluate( context ).toBool();
603 newSelection << feat.
id();
607 newSelection << feat.
id();
631 newSelection = idsToSelect;
635 newSelection = mSelectedFeatureIds + idsToSelect;
639 newSelection = mSelectedFeatureIds - idsToSelect;
643 newSelection = mSelectedFeatureIds.intersect( idsToSelect );
647 QgsFeatureIds deselectedFeatures = mSelectedFeatureIds - newSelection;
648 mSelectedFeatureIds = newSelection;
649 mPreviousSelectedFeatureIds.clear();
659 if ( !intersectingIds.isEmpty() )
661 QgsDebugMsgLevel( u
"Trying to select and deselect the same item at the same time. Unsure what to do. Selecting dubious items."_s, 3 );
664 mSelectedFeatureIds -= deselectIds;
665 mSelectedFeatureIds += selectIds;
666 mPreviousSelectedFeatureIds.clear();
676 ids.subtract( mSelectedFeatureIds );
703 if ( mSelectedFeatureIds.contains( fet.
id() ) )
705 deselectIds << fet.
id();
709 selectIds << fet.
id();
720 if ( mSelectedFeatureIds.isEmpty() )
725 mPreviousSelectedFeatureIds = previous;
732 if ( mPreviousSelectedFeatureIds.isEmpty() || !mSelectedFeatureIds.empty() )
743 return mDataProvider;
751 return mDataProvider;
759 return mSelectionProperties;
766 return mTemporalProperties;
773 return mElevationProperties;
789 if (
isValid() && mDataProvider && mDataProvider->encoding() != encoding )
791 mDataProvider->setEncoding( encoding );
800 delete mDiagramRenderer;
801 mDiagramRenderer = r;
825 if ( !
isValid() || !
isSpatial() || mSelectedFeatureIds.isEmpty() || !mDataProvider )
852 if ( mSelectedFeatureIds.contains( fet.
id() ) )
863 if ( retval.
width() == 0.0 || retval.
height() == 0.0 )
871 retval.
set( -1.0, -1.0, 1.0, 1.0 );
883 return mLabelsEnabled &&
static_cast< bool >( mLabeling );
890 mLabelsEnabled = enabled;
898 if ( !mDiagramRenderer || !mDiagramLayerSettings )
901 QList<QgsDiagramSettings> settingList = mDiagramRenderer->diagramSettings();
902 if ( !settingList.isEmpty() )
904 return settingList.at( 0 ).enabled;
913 if ( !mSymbolFeatureCounted )
916 return mSymbolFeatureCountMap.value( legendKey, -1 );
923 if ( !mSymbolFeatureCounted )
926 return mSymbolFeatureIdMap.value( legendKey,
QgsFeatureIds() );
932 if ( ( mSymbolFeatureCounted || mFeatureCounter ) && !( storeSymbolFids && mSymbolFeatureIdMap.isEmpty() ) )
933 return mFeatureCounter;
935 mSymbolFeatureCountMap.clear();
936 mSymbolFeatureIdMap.clear();
941 return mFeatureCounter;
943 if ( !mDataProvider )
946 return mFeatureCounter;
951 return mFeatureCounter;
954 if ( !mFeatureCounter || ( storeSymbolFids && mSymbolFeatureIdMap.isEmpty() ) )
957 connect( mFeatureCounter, &
QgsTask::taskCompleted,
this, &QgsVectorLayer::onFeatureCounterCompleted, Qt::UniqueConnection );
958 connect( mFeatureCounter, &
QgsTask::taskTerminated,
this, &QgsVectorLayer::onFeatureCounterTerminated, Qt::UniqueConnection );
962 return mFeatureCounter;
970 if ( force || !mReadExtentFromXml || ( mReadExtentFromXml && mXmlExtent2D.isNull() && mXmlExtent3D.isNull() ) )
972 mValidExtent2D =
false;
973 mValidExtent3D =
false;
982 mValidExtent2D =
true;
990 mValidExtent3D =
true;
997 if ( !mDefaultValueOnUpdateFields.isEmpty() )
1002 int size = mFields.
size();
1003 for (
int idx : std::as_const( mDefaultValueOnUpdateFields ) )
1005 if ( idx < 0 || idx >= size )
1025 mLazyExtent2D =
false;
1032 updateExtent( mDataProvider->extent() );
1033 mValidExtent2D =
true;
1034 mLazyExtent2D =
false;
1038 if ( !mValidExtent2D && mLazyExtent2D && mReadExtentFromXml && !mXmlExtent2D.isNull() )
1040 updateExtent( mXmlExtent2D );
1041 mValidExtent2D =
true;
1042 mLazyExtent2D =
false;
1045 if ( !mValidExtent2D && mLazyExtent2D && mDataProvider && mDataProvider->isValid() )
1048 updateExtent( mDataProvider->extent() );
1049 mValidExtent2D =
true;
1050 mLazyExtent2D =
false;
1053 QgsDebugMsgLevel( u
"2D Extent of layer: %1"_s.arg( mExtent2D.toString() ), 3 );
1057 if ( mValidExtent2D )
1060 if ( !
isValid() || !mDataProvider )
1062 QgsDebugMsgLevel( u
"invoked with invalid layer or null mDataProvider"_s, 3 );
1067 || ( !mDataProvider->transaction() && ( mEditBuffer->deletedFeatureIds().isEmpty() && mEditBuffer->changedGeometries().isEmpty() ) )
1070 mDataProvider->updateExtents();
1074 if ( mDataProvider->featureCount() != 0 )
1080 if ( mEditBuffer && !mDataProvider->transaction() )
1082 const auto addedFeatures = mEditBuffer->addedFeatures();
1083 for ( QgsFeatureMap::const_iterator it = addedFeatures.constBegin(); it != addedFeatures.constEnd(); ++it )
1085 if ( it->hasGeometry() )
1108 if ( rect.xMinimum() > rect.xMaximum() && rect.yMinimum() > rect.yMaximum() )
1114 updateExtent( rect );
1115 mValidExtent2D =
true;
1128 if ( mDataProvider && mDataProvider->elevationProperties() && !mDataProvider->elevationProperties()->containsElevationData() )
1144 updateExtent( mDataProvider->extent3D() );
1145 mValidExtent3D =
true;
1146 mLazyExtent3D =
false;
1150 if ( !mValidExtent3D && mLazyExtent3D && mReadExtentFromXml && !mXmlExtent3D.isNull() )
1152 updateExtent( mXmlExtent3D );
1153 mValidExtent3D =
true;
1154 mLazyExtent3D =
false;
1157 if ( !mValidExtent3D && mLazyExtent3D && mDataProvider && mDataProvider->isValid() )
1160 updateExtent( mDataProvider->extent3D() );
1161 mValidExtent3D =
true;
1162 mLazyExtent3D =
false;
1165 QgsDebugMsgLevel( u
"3D Extent of layer: %1"_s.arg( mExtent3D.toString() ), 3 );
1169 if ( mValidExtent3D )
1172 if ( !
isValid() || !mDataProvider )
1174 QgsDebugMsgLevel( u
"invoked with invalid layer or null mDataProvider"_s, 3 );
1179 || ( !mDataProvider->transaction() && ( mEditBuffer->deletedFeatureIds().isEmpty() && mEditBuffer->changedGeometries().isEmpty() ) )
1182 mDataProvider->updateExtents();
1186 if ( mDataProvider->featureCount() != 0 )
1188 const QgsBox3D ext = mDataProvider->extent3D();
1189 extent.combineWith( ext );
1192 if ( mEditBuffer && !mDataProvider->transaction() )
1194 const auto addedFeatures = mEditBuffer->addedFeatures();
1195 for ( QgsFeatureMap::const_iterator it = addedFeatures.constBegin(); it != addedFeatures.constEnd(); ++it )
1197 if ( it->hasGeometry() )
1199 const QgsBox3D bbox = it->geometry().boundingBox3D();
1200 extent.combineWith( bbox );
1215 extent.combineWith( bb );
1227 mValidExtent3D =
true;
1253 if ( !
isValid() || !mDataProvider )
1255 QgsDebugMsgLevel( u
"invoked with invalid layer or null mDataProvider"_s, 3 );
1258 return mDataProvider->subsetString();
1265 if ( !
isValid() || !mDataProvider )
1267 QgsDebugMsgLevel( u
"invoked with invalid layer or null mDataProvider or while editing"_s, 3 );
1271 else if ( mEditBuffer )
1277 if ( subset == mDataProvider->subsetString() )
1280 bool res = mDataProvider->setSubsetString( subset );
1305 && ( mSimplifyMethod.simplifyHints() & simplifyHint )
1308 double maximumSimplificationScale = mSimplifyMethod.maximumScale();
1311 return !( maximumSimplificationScale > 1 && renderContext.
rendererScale() <= maximumSimplificationScale );
1320 return mConditionalStyles;
1328 if ( !
isValid() || !mDataProvider )
1340 if ( feature.isValid() )
1341 return feature.geometry();
1350 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1354 if ( mGeometryOptions->isActive() )
1357 mGeometryOptions->apply( geom );
1361 bool success = mEditBuffer->addFeature( feature );
1363 if ( success && mJoinBuffer->containsJoins() )
1365 success = mJoinBuffer->addFeature( feature );
1375 if ( !mEditBuffer || !mDataProvider )
1381 if ( currentFeature.
isValid() )
1383 bool hasChanged =
false;
1384 bool hasError =
false;
1396 QgsDebugMsgLevel( u
"geometry of feature %1 could not be changed."_s.arg( updatedFeature.
id() ), 3 );
1403 for (
int attr = 0; attr < fa.count(); ++attr )
1413 QgsDebugMsgLevel( u
"attribute %1 of feature %2 could not be changed."_s.arg( attr ).arg( updatedFeature.
id() ), 3 );
1418 if ( hasChanged && !mDefaultValueOnUpdateFields.isEmpty() && !skipDefaultValues )
1419 updateDefaultValues( updatedFeature.
id(), updatedFeature );
1425 QgsDebugMsgLevel( u
"feature %1 could not be retrieved"_s.arg( updatedFeature.
id() ), 3 );
1435 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1439 bool result = utils.
insertVertex( x, y, atFeatureId, beforeVertex );
1450 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1454 bool result = utils.
insertVertex( point, atFeatureId, beforeVertex );
1465 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1469 bool result = utils.
moveVertex( x, y, atFeatureId, atVertex );
1480 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1484 bool result = utils.
moveVertex( p, atFeatureId, atVertex );
1495 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1522 int count = mSelectedFeatureIds.size();
1535 *deletedCount = deleted;
1538 return deleted == count;
1541static const QgsPointSequence vectorPointXY2pointSequence(
const QVector<QgsPointXY> &points )
1544 pts.reserve( points.size() );
1545 QVector<QgsPointXY>::const_iterator it = points.constBegin();
1546 while ( it != points.constEnd() )
1557 return addRing( vectorPointXY2pointSequence( ring ), featureId );
1564 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1571 if ( !mSelectedFeatureIds.isEmpty() )
1573 result = utils.
addRing( ring, mSelectedFeatureIds, featureId );
1589 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1610 if ( !mSelectedFeatureIds.isEmpty() )
1612 result = utils.
addRing(
static_cast< QgsCurve *
>( ring->
clone() ), mSelectedFeatureIds, featureId );
1630 pts.reserve( points.size() );
1631 for ( QList<QgsPointXY>::const_iterator it = points.constBegin(); it != points.constEnd(); ++it )
1642 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1647 if ( mSelectedFeatureIds.empty() )
1652 else if ( mSelectedFeatureIds.size() > 1 )
1670 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1675 if ( mSelectedFeatureIds.empty() )
1680 else if ( mSelectedFeatureIds.size() > 1 )
1699 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1714 return splitParts( vectorPointXY2pointSequence( splitLine ), topologicalEditing );
1721 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1725 return utils.
splitParts( splitLine, topologicalEditing );
1732 return splitFeatures( vectorPointXY2pointSequence( splitLine ), topologicalEditing );
1741 bool preserveCircular =
false;
1742 return splitFeatures( &splitLineString, topologyTestPoints, preserveCircular, topologicalEditing );
1749 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1753 return utils.
splitFeatures( curve, topologyTestPoints, preserveCircular, topologicalEditing );
1760 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1778 if ( !
isValid() || !mEditBuffer || !mDataProvider )
1789 if ( !
mValid || !mEditBuffer || !mDataProvider )
1814 if ( !
isValid() || !mDataProvider )
1831 mDataProvider->enterUpdateMode();
1848 if ( mDataProvider )
1864 if ( !mRenderer->accept( visitor ) )
1868 if ( !mLabeling->accept( visitor ) )
1880 const QList<QgsAction>
actions = mActions->actions();
1883 if ( action.command().isEmpty() )
1888 switch ( action.type() )
1915 switch ( mEditFormConfig.initCodeSource() )
1919 initCode = u
"# Calling function ’%1’\n\n%2"_s.arg( mEditFormConfig.initFunction(), mEditFormConfig.initCode() );
1926 if ( inputFile && inputFile->open( QFile::ReadOnly ) )
1929 QTextStream inf( inputFile );
1930 initCode = inf.readAll();
1932 initCode = u
"# Calling function ’%1’\n# From file %2\n\n"_s.arg( mEditFormConfig.initFunction(), mEditFormConfig.initFilePath() ) + initCode;
1939 initCode = u
"# Calling function ’%1’\n# From environment\n\n"_s.arg( mEditFormConfig.initFunction() );
1949 if ( !initCode.isEmpty() )
1968 QDomNode pkeyNode = layer_node.namedItem( u
"provider"_s );
1970 if ( pkeyNode.isNull() )
1976 QDomElement pkeyElt = pkeyNode.toElement();
1995 const QDomElement elem = layer_node.toElement();
2009 if ( elem.hasAttribute( u
"wkbType"_s ) )
2013 QDomElement pkeyElem = pkeyNode.toElement();
2014 if ( !pkeyElem.isNull() )
2016 QString encodingString = pkeyElem.attribute( u
"encoding"_s );
2017 if ( mDataProvider && !encodingString.isEmpty() )
2019 mDataProvider->setEncoding( encodingString );
2024 mJoinBuffer->readXml( layer_node );
2029 mSetLegendFromStyle =
false;
2039 QDomNode depsNode = layer_node.namedItem( u
"dataDependencies"_s );
2040 QDomNodeList depsNodes = depsNode.childNodes();
2041 QSet<QgsMapLayerDependency> sources;
2042 for (
int i = 0; i < depsNodes.count(); i++ )
2044 QString
source = depsNodes.at( i ).toElement().attribute( u
"id"_s );
2049 if ( !mSetLegendFromStyle )
2055 mReadExtentFromXml =
true;
2057 if ( mReadExtentFromXml )
2059 const QDomNode extentNode = layer_node.namedItem( u
"extent"_s );
2060 if ( !extentNode.isNull() )
2064 const QDomNode extent3DNode = layer_node.namedItem( u
"extent3D"_s );
2065 if ( !extent3DNode.isNull() )
2072 const QDomNode asNode = layer_node.namedItem( u
"auxiliaryLayer"_s );
2073 const QDomElement asElem = asNode.toElement();
2074 if ( !asElem.isNull() )
2076 mAuxiliaryLayerKey = asElem.attribute( u
"key"_s );
2080 mServerProperties->readXml( layer_node );
2095 setDataProvider( provider, options,
flags );
2105 bool loadDefaultStyleFlag =
false;
2108 loadDefaultStyleFlag =
true;
2114 std::unique_ptr< QgsScopedRuntimeProfile > profile;
2116 profile = std::make_unique< QgsScopedRuntimeProfile >( tr(
"Load layer style" ), u
"projectload"_s );
2118 bool defaultLoadedFlag =
false;
2126 mSetLegendFromStyle =
false;
2131 if ( !defaultLoadedFlag && loadDefaultStyleFlag )
2139 std::unique_ptr< QgsFeatureRenderer > defaultRenderer( mDataProvider->createRenderer() );
2140 if ( defaultRenderer )
2142 defaultLoadedFlag =
true;
2148 if ( !defaultLoadedFlag )
2154 if ( !mSetLegendFromStyle )
2159 std::unique_ptr< QgsAbstractVectorLayerLabeling > defaultLabeling( mDataProvider->createLabeling() );
2160 if ( defaultLabeling )
2167 styleChangedSignalBlocker.release();
2184 QStringList ids, names, descriptions;
2185 QString errorMessage;
2187 const int relatedStylesCount {
listStylesInDatabase( ids, names, descriptions, errorMessage ) };
2188 Q_ASSERT( ids.count() == names.count() );
2189 const QString currentStyleName { mStyleManager->currentStyle() };
2190 for (
int i = 0; i < relatedStylesCount; ++i )
2192 if ( names.at( i ) == currentStyleName )
2196 errorMessage.clear();
2198 if ( !styleXml.isEmpty() && errorMessage.isEmpty() )
2204 QgsDebugMsgLevel( u
"Error retrieving style %1 from DB: %2"_s.arg( ids.at( i ), errorMessage ), 2 );
2214 std::unique_ptr< QgsFeatureRenderer > defaultRenderer( mDataProvider->createRenderer() );
2215 if ( defaultRenderer )
2231 delete mDataProvider;
2238 if ( provider.compare(
"postgres"_L1 ) == 0 )
2240 const QString checkUnicityKey { u
"checkPrimaryKeyUnicity"_s };
2242 if ( !uri.hasParam( checkUnicityKey ) )
2244 uri.setParam( checkUnicityKey, mReadExtentFromXml ?
"0" :
"1" );
2249 std::unique_ptr< QgsScopedRuntimeProfile > profile;
2251 profile = std::make_unique< QgsScopedRuntimeProfile >( tr(
"Create %1 provider" ).arg( provider ), u
"projectload"_s );
2256 mDataProvider = qobject_cast< QgsVectorDataProvider * >(
mPreloadedProvider.release() );
2263 if ( !mDataProvider )
2270 mDataProvider->setParent(
this );
2275 setValid( mDataProvider->isValid() );
2283 profile->switchTask( tr(
"Read layer metadata" ) );
2288 QgsLayerMetadata newMetadata = mDataProvider->layerMetadata();
2290 newMetadata.
combine( &mMetadata );
2300 mWkbType = mDataProvider->wkbType();
2304 const QgsFields providerFields = mDataProvider->fields();
2305 for (
const QgsField &field : providerFields )
2308 if ( !field.editorWidgetSetup().isNull() && mFieldWidgetSetups.value( field.name() ).isNull() )
2310 mFieldWidgetSetups[field.name()] = field.editorWidgetSetup();
2312 if ( !field.alias().isEmpty() && mAttributeAliasMap.value( field.name() ).isEmpty() )
2314 mAttributeAliasMap[field.name()] = field.alias();
2316 if ( !mAttributeSplitPolicy.contains( field.name() ) )
2318 mAttributeSplitPolicy[field.name()] = field.splitPolicy();
2320 if ( !mAttributeDuplicatePolicy.contains( field.name() ) )
2322 mAttributeDuplicatePolicy[field.name()] = field.duplicatePolicy();
2324 if ( !mAttributeMergePolicy.contains( field.name() ) )
2326 mAttributeMergePolicy[field.name()] = field.mergePolicy();
2331 profile->switchTask( tr(
"Read layer fields" ) );
2337 mDataSource = mDataProvider->dataSourceUri(
false );
2342 const thread_local QRegularExpression reg( R
"lit("[^"]+"\."([^"] + )"( \([^)]+\))?)lit" );
2343 const QRegularExpressionMatch match = reg.match(
name() );
2344 if ( match.hasMatch() )
2346 QStringList stuff = match.capturedTexts();
2347 QString lName = stuff[1];
2351 QMap<QString, QgsMapLayer *>::const_iterator it;
2352 for ( it = layers.constBegin(); it != layers.constEnd() && ( *it )->name() != lName; ++it )
2355 if ( it != layers.constEnd() && stuff.size() > 2 )
2357 lName +=
'.' + stuff[2].mid( 2, stuff[2].length() - 3 );
2360 if ( !lName.isEmpty() )
2370 else if ( provider ==
"ogr"_L1 )
2377 else if ( provider ==
"memory"_L1 )
2382 else if ( provider ==
"hana"_L1 )
2385 mDataSource = mDataProvider->dataSourceUri(
false );
2402 QDomElement mapLayerNode = layer_node.toElement();
2404 if ( mapLayerNode.isNull() || (
"maplayer" != mapLayerNode.nodeName() ) )
2417 if ( mDataProvider )
2419 QDomElement provider = document.createElement( u
"provider"_s );
2420 provider.setAttribute( u
"encoding"_s, mDataProvider->encoding() );
2421 QDomText providerText = document.createTextNode(
providerType() );
2422 provider.appendChild( providerText );
2423 layer_node.appendChild( provider );
2427 mJoinBuffer->writeXml( layer_node, document );
2430 QDomElement dependenciesElement = document.createElement( u
"layerDependencies"_s );
2436 QDomElement depElem = document.createElement( u
"layer"_s );
2437 depElem.setAttribute( u
"id"_s, dep.layerId() );
2438 dependenciesElement.appendChild( depElem );
2440 layer_node.appendChild( dependenciesElement );
2443 QDomElement dataDependenciesElement = document.createElement( u
"dataDependencies"_s );
2448 QDomElement depElem = document.createElement( u
"layer"_s );
2449 depElem.setAttribute( u
"id"_s, dep.layerId() );
2450 dataDependenciesElement.appendChild( depElem );
2452 layer_node.appendChild( dataDependenciesElement );
2455 mExpressionFieldBuffer->writeXml( layer_node, document );
2460 QDomElement asElem = document.createElement( u
"auxiliaryLayer"_s );
2461 if ( mAuxiliaryLayer )
2463 const QString pkField = mAuxiliaryLayer->joinInfo().targetFieldName();
2464 asElem.setAttribute( u
"key"_s, pkField );
2466 layer_node.appendChild( asElem );
2470 return writeSymbology( layer_node, document, errorMsg, context );
2499 mJoinBuffer->resolveReferences(
project );
2507 if ( categories.testFlag(
Fields ) )
2509 if ( !mExpressionFieldBuffer )
2511 mExpressionFieldBuffer->readXml( layerNode );
2521 QDomNodeList referencedLayersNodeList = layerNode.toElement().elementsByTagName( u
"referencedLayers"_s );
2522 if ( referencedLayersNodeList.size() > 0 )
2524 const QDomNodeList relationNodes { referencedLayersNodeList.at( 0 ).childNodes() };
2525 for (
int i = 0; i < relationNodes.length(); ++i )
2527 const QDomElement relationElement = relationNodes.at( i ).toElement();
2534 QDomNodeList referencingLayersNodeList = layerNode.toElement().elementsByTagName( u
"referencingLayers"_s );
2535 if ( referencingLayersNodeList.size() > 0 )
2537 const QDomNodeList relationNodes { referencingLayersNodeList.at( 0 ).childNodes() };
2538 for (
int i = 0; i < relationNodes.length(); ++i )
2540 const QDomElement relationElement = relationNodes.at( i ).toElement();
2546 QDomElement layerElement = layerNode.toElement();
2550 readStyle( layerNode, errorMessage, context, categories );
2552 if ( categories.testFlag(
MapTips ) )
2554 QDomElement mapTipElem = layerNode.namedItem( u
"mapTip"_s ).toElement();
2560 mDisplayExpression = layerNode.namedItem( u
"previewExpression"_s ).toElement().text();
2563 QString
displayField = layerNode.namedItem( u
"displayfield"_s ).toElement().text();
2567 if ( mMapTipTemplate.isEmpty() && categories.testFlag(
MapTips ) )
2577 if ( categories.testFlag(
Actions ) )
2578 mActions->readXml( layerNode, context );
2580 if ( categories.testFlag(
Fields ) )
2585 QDomNode aliasesNode = layerNode.namedItem( u
"aliases"_s );
2586 if ( !aliasesNode.isNull() )
2588 QDomElement aliasElem;
2590 QDomNodeList aliasNodeList = aliasesNode.toElement().elementsByTagName( u
"alias"_s );
2591 for (
int i = 0; i < aliasNodeList.size(); ++i )
2593 aliasElem = aliasNodeList.at( i ).toElement();
2596 if ( aliasElem.hasAttribute( u
"field"_s ) )
2598 field = aliasElem.attribute( u
"field"_s );
2602 int index = aliasElem.attribute( u
"index"_s ).toInt();
2604 if ( index >= 0 && index <
fields().count() )
2610 if ( !aliasElem.attribute( u
"name"_s ).isEmpty() )
2613 alias = context.
projectTranslator()->
translate( u
"project:layers:%1:fieldaliases"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text() ), aliasElem.attribute( u
"name"_s ) );
2614 QgsDebugMsgLevel(
"context" + u
"project:layers:%1:fieldaliases"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text() ) +
" source " + aliasElem.attribute( u
"name"_s ), 3 );
2619 alias = context.
projectTranslator()->
translate( u
"project:layers:%1:fieldaliases"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text() ), field );
2620 QgsDebugMsgLevel(
"context" + u
"project:layers:%1:fieldaliases"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text() ) +
" source " + field, 3 );
2622 if ( alias == aliasElem.attribute( u
"field"_s ) )
2626 QgsDebugMsgLevel(
"field " + field +
" origalias " + aliasElem.attribute( u
"name"_s ) +
" trans " + alias, 3 );
2627 mAttributeAliasMap.insert( field, alias );
2634 const QDomNode splitPoliciesNode = layerNode.namedItem( u
"splitPolicies"_s );
2635 if ( !splitPoliciesNode.isNull() )
2637 const QDomNodeList splitPolicyNodeList = splitPoliciesNode.toElement().elementsByTagName( u
"policy"_s );
2638 for (
int i = 0; i < splitPolicyNodeList.size(); ++i )
2640 const QDomElement splitPolicyElem = splitPolicyNodeList.at( i ).toElement();
2641 const QString field = splitPolicyElem.attribute( u
"field"_s );
2643 mAttributeSplitPolicy.insert( field, policy );
2648 mAttributeDuplicatePolicy.clear();
2649 const QDomNode duplicatePoliciesNode = layerNode.namedItem( u
"duplicatePolicies"_s );
2650 if ( !duplicatePoliciesNode.isNull() )
2652 const QDomNodeList duplicatePolicyNodeList = duplicatePoliciesNode.toElement().elementsByTagName( u
"policy"_s );
2653 for (
int i = 0; i < duplicatePolicyNodeList.size(); ++i )
2655 const QDomElement duplicatePolicyElem = duplicatePolicyNodeList.at( i ).toElement();
2656 const QString field = duplicatePolicyElem.attribute( u
"field"_s );
2658 mAttributeDuplicatePolicy.insert( field, policy );
2662 const QDomNode mergePoliciesNode = layerNode.namedItem( u
"mergePolicies"_s );
2663 if ( !mergePoliciesNode.isNull() )
2665 const QDomNodeList mergePolicyNodeList = mergePoliciesNode.toElement().elementsByTagName( u
"policy"_s );
2666 for (
int i = 0; i < mergePolicyNodeList.size(); ++i )
2668 const QDomElement mergePolicyElem = mergePolicyNodeList.at( i ).toElement();
2669 const QString field = mergePolicyElem.attribute( u
"field"_s );
2671 mAttributeMergePolicy.insert( field, policy );
2676 mDefaultExpressionMap.clear();
2677 QDomNode defaultsNode = layerNode.namedItem( u
"defaults"_s );
2678 if ( !defaultsNode.isNull() )
2680 QDomNodeList defaultNodeList = defaultsNode.toElement().elementsByTagName( u
"default"_s );
2681 for (
int i = 0; i < defaultNodeList.size(); ++i )
2683 QDomElement defaultElem = defaultNodeList.at( i ).toElement();
2685 QString field = defaultElem.attribute( u
"field"_s, QString() );
2686 QString expression = defaultElem.attribute( u
"expression"_s, QString() );
2687 bool applyOnUpdate = defaultElem.attribute( u
"applyOnUpdate"_s, u
"0"_s ) ==
"1"_L1;
2688 if ( field.isEmpty() || expression.isEmpty() )
2691 mDefaultExpressionMap.insert( field,
QgsDefaultValue( expression, applyOnUpdate ) );
2696 mFieldConstraints.clear();
2697 mFieldConstraintStrength.clear();
2698 QDomNode constraintsNode = layerNode.namedItem( u
"constraints"_s );
2699 if ( !constraintsNode.isNull() )
2701 QDomNodeList constraintNodeList = constraintsNode.toElement().elementsByTagName( u
"constraint"_s );
2702 for (
int i = 0; i < constraintNodeList.size(); ++i )
2704 QDomElement constraintElem = constraintNodeList.at( i ).toElement();
2706 QString field = constraintElem.attribute( u
"field"_s, QString() );
2707 int constraints = constraintElem.attribute( u
"constraints"_s, u
"0"_s ).toInt();
2708 if ( field.isEmpty() || constraints == 0 )
2713 int uniqueStrength = constraintElem.attribute( u
"unique_strength"_s, u
"1"_s ).toInt();
2714 int notNullStrength = constraintElem.attribute( u
"notnull_strength"_s, u
"1"_s ).toInt();
2715 int expStrength = constraintElem.attribute( u
"exp_strength"_s, u
"1"_s ).toInt();
2722 mFieldConstraintExpressions.clear();
2723 QDomNode constraintExpressionsNode = layerNode.namedItem( u
"constraintExpressions"_s );
2724 if ( !constraintExpressionsNode.isNull() )
2726 QDomNodeList constraintNodeList = constraintExpressionsNode.toElement().elementsByTagName( u
"constraint"_s );
2727 for (
int i = 0; i < constraintNodeList.size(); ++i )
2729 QDomElement constraintElem = constraintNodeList.at( i ).toElement();
2731 QString field = constraintElem.attribute( u
"field"_s, QString() );
2732 QString exp = constraintElem.attribute( u
"exp"_s, QString() );
2734 = context.
projectTranslator()->
translate( u
"project:layers:%1:constraintdescriptions"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text() ), constraintElem.attribute( u
"desc"_s, QString() ) );
2735 QgsDebugMsgLevel(
"context" + u
"project:layers:%1:constraintdescriptions"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text() ) +
" source " + constraintElem.attribute( u
"desc"_s, QString() ), 3 );
2736 if ( field.isEmpty() || exp.isEmpty() )
2739 mFieldConstraintExpressions.insert( field, qMakePair( exp, desc ) );
2747 if ( categories.testFlag(
Fields ) || categories.testFlag(
Forms ) )
2751 QDomElement widgetsElem = layerNode.namedItem( u
"fieldConfiguration"_s ).toElement();
2752 QDomNodeList fieldConfigurationElementList = widgetsElem.elementsByTagName( u
"field"_s );
2753 for (
int i = 0; i < fieldConfigurationElementList.size(); ++i )
2755 const QDomElement fieldConfigElement = fieldConfigurationElementList.at( i ).toElement();
2756 const QDomElement fieldWidgetElement = fieldConfigElement.elementsByTagName( u
"editWidget"_s ).at( 0 ).toElement();
2758 QString fieldName = fieldConfigElement.attribute( u
"name"_s );
2760 if ( categories.testFlag(
Fields ) )
2764 if ( categories.testFlag(
Forms ) )
2766 const QString widgetType = fieldWidgetElement.attribute( u
"type"_s );
2767 const QDomElement cfgElem = fieldConfigElement.elementsByTagName( u
"config"_s ).at( 0 ).toElement();
2768 const QDomElement optionsElem = cfgElem.childNodes().at( 0 ).toElement();
2771 if ( widgetType ==
"ValueRelation"_L1 )
2773 optionsMap[u
"Value"_s]
2774 = context.
projectTranslator()->
translate( u
"project:layers:%1:fields:%2:valuerelationvalue"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text(), fieldName ), optionsMap[u
"Value"_s].toString() );
2775 optionsMap[u
"Description"_s]
2777 ->
translate( u
"project:layers:%1:fields:%2:valuerelationdescription"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text(), fieldName ), optionsMap[u
"Description"_s].toString() );
2779 if ( widgetType ==
"ValueMap"_L1 )
2781 if ( optionsMap[u
"map"_s].canConvert<QList<QVariant>>() )
2783 QList<QVariant> translatedValueList;
2784 const QList<QVariant> valueList = optionsMap[u
"map"_s].toList();
2785 for (
int i = 0, row = 0; i < valueList.count(); i++, row++ )
2787 QMap<QString, QVariant> translatedValueMap;
2788 QString translatedKey
2790 ->
translate( u
"project:layers:%1:fields:%2:valuemapdescriptions"_s.arg( layerNode.namedItem( u
"id"_s ).toElement().text(), fieldName ), valueList[i].toMap().constBegin().key() );
2791 translatedValueMap.insert( translatedKey, valueList[i].toMap().constBegin().value() );
2792 translatedValueList.append( translatedValueMap );
2794 optionsMap.insert( u
"map"_s, translatedValueList );
2798 mFieldWidgetSetups[fieldName] = setup;
2805 if ( categories.testFlag(
Fields ) )
2807 const QList<QPair<QString, Qgis::FieldConfigurationFlag>>
2809 for (
const auto &config : legacyConfig )
2811 QDomNode excludeNode = layerNode.namedItem( config.first );
2812 if ( !excludeNode.isNull() )
2814 QDomNodeList attributeNodeList = excludeNode.toElement().elementsByTagName( u
"attribute"_s );
2815 for (
int i = 0; i < attributeNodeList.size(); ++i )
2817 QString fieldName = attributeNodeList.at( i ).toElement().text();
2818 if ( !mFieldConfigurationFlags.contains( fieldName ) )
2819 mFieldConfigurationFlags[fieldName] = config.second;
2821 mFieldConfigurationFlags[fieldName].setFlag( config.second,
true );
2828 mGeometryOptions->readXml( layerNode.namedItem( u
"geometryOptions"_s ) );
2830 if ( categories.testFlag(
Forms ) )
2831 mEditFormConfig.readXml( layerNode, context );
2835 mAttributeTableConfig.readXml( layerNode );
2836 mConditionalStyles->readXml( layerNode, context );
2837 mStoredExpressionManager->readXml( layerNode );
2843 QDomElement mapLayerNode = layerNode.toElement();
2844 if ( categories.testFlag(
LayerConfiguration ) && mapLayerNode.attribute( u
"readOnly"_s, u
"0"_s ).toInt() == 1 )
2849 if ( categories.testFlag(
Legend ) )
2853 const QDomElement legendElem = layerNode.firstChildElement( u
"legend"_s );
2854 if ( !legendElem.isNull() )
2857 legend->readXml( legendElem, context );
2859 mSetLegendFromStyle =
true;
2888 if ( !rendererElement.isNull() )
2906 if ( mSelectionProperties )
2907 mSelectionProperties->readXml( node.toElement(), context );
2911 if ( categories.testFlag(
Labeling ) )
2915 QDomElement labelingElement = node.firstChildElement( u
"labeling"_s );
2917 if ( labelingElement.isNull() || ( labelingElement.attribute( u
"type"_s ) ==
"simple"_L1 && labelingElement.firstChildElement( u
"settings"_s ).isNull() ) )
2925 labeling = readLabelingFromCustomProperties();
2933 if ( node.toElement().hasAttribute( u
"labelsEnabled"_s ) )
2934 mLabelsEnabled = node.toElement().attribute( u
"labelsEnabled"_s ).toInt();
2936 mLabelsEnabled =
true;
2942 QDomNode blendModeNode = node.namedItem( u
"blendMode"_s );
2943 if ( !blendModeNode.isNull() )
2945 QDomElement e = blendModeNode.toElement();
2950 QDomNode featureBlendModeNode = node.namedItem( u
"featureBlendMode"_s );
2951 if ( !featureBlendModeNode.isNull() )
2953 QDomElement e = featureBlendModeNode.toElement();
2961 QDomNode layerTransparencyNode = node.namedItem( u
"layerTransparency"_s );
2962 if ( !layerTransparencyNode.isNull() )
2964 QDomElement e = layerTransparencyNode.toElement();
2965 setOpacity( 1.0 - e.text().toInt() / 100.0 );
2967 QDomNode layerOpacityNode = node.namedItem( u
"layerOpacity"_s );
2968 if ( !layerOpacityNode.isNull() )
2970 QDomElement e = layerOpacityNode.toElement();
2974 const bool hasScaleBasedVisibiliy { node.attributes().namedItem( u
"hasScaleBasedVisibilityFlag"_s ).nodeValue() ==
'1' };
2977 const double maxScale { node.attributes().namedItem( u
"maxScale"_s ).nodeValue().toDouble( &ok ) };
2982 const double minScale { node.attributes().namedItem( u
"minScale"_s ).nodeValue().toDouble( &ok ) };
2988 QDomElement e = node.toElement();
2993 mSimplifyMethod.setThreshold( e.attribute( u
"simplifyDrawingTol"_s, u
"1"_s ).toFloat() );
2994 mSimplifyMethod.setForceLocalOptimization( e.attribute( u
"simplifyLocal"_s, u
"1"_s ).toInt() );
2995 mSimplifyMethod.setMaximumScale( e.attribute( u
"simplifyMaxScale"_s, u
"1"_s ).toFloat() );
2998 mRenderer->setReferenceScale( e.attribute( u
"symbologyReferenceScale"_s, u
"-1"_s ).toDouble() );
3002 if ( categories.testFlag(
Diagrams ) )
3006 delete mDiagramRenderer;
3007 mDiagramRenderer =
nullptr;
3008 QDomElement singleCatDiagramElem = node.firstChildElement( u
"SingleCategoryDiagramRenderer"_s );
3009 if ( !singleCatDiagramElem.isNull() )
3012 mDiagramRenderer->readXml( singleCatDiagramElem, context );
3014 QDomElement linearDiagramElem = node.firstChildElement( u
"LinearlyInterpolatedDiagramRenderer"_s );
3015 if ( !linearDiagramElem.isNull() )
3017 if ( linearDiagramElem.hasAttribute( u
"classificationAttribute"_s ) )
3020 int idx = linearDiagramElem.attribute( u
"classificationAttribute"_s ).toInt();
3021 if ( idx >= 0 && idx < mFields.count() )
3022 linearDiagramElem.setAttribute( u
"classificationField"_s, mFields.at( idx ).name() );
3026 mDiagramRenderer->readXml( linearDiagramElem, context );
3028 QDomElement stackedDiagramElem = node.firstChildElement( u
"StackedDiagramRenderer"_s );
3029 if ( !stackedDiagramElem.isNull() )
3032 mDiagramRenderer->readXml( stackedDiagramElem, context );
3035 if ( mDiagramRenderer )
3037 QDomElement diagramSettingsElem = node.firstChildElement( u
"DiagramLayerSettings"_s );
3038 if ( !diagramSettingsElem.isNull() )
3040 bool oldXPos = diagramSettingsElem.hasAttribute( u
"xPosColumn"_s );
3041 bool oldYPos = diagramSettingsElem.hasAttribute( u
"yPosColumn"_s );
3042 bool oldShow = diagramSettingsElem.hasAttribute( u
"showColumn"_s );
3043 if ( oldXPos || oldYPos || oldShow )
3049 int xPosColumn = diagramSettingsElem.attribute( u
"xPosColumn"_s ).toInt();
3050 if ( xPosColumn >= 0 && xPosColumn < mFields.count() )
3055 int yPosColumn = diagramSettingsElem.attribute( u
"yPosColumn"_s ).toInt();
3056 if ( yPosColumn >= 0 && yPosColumn < mFields.count() )
3061 int showColumn = diagramSettingsElem.attribute( u
"showColumn"_s ).toInt();
3062 if ( showColumn >= 0 && showColumn < mFields.count() )
3065 QDomElement propertiesElem = diagramSettingsElem.ownerDocument().createElement( u
"properties"_s );
3071 ddp.
writeXml( propertiesElem, defs );
3072 diagramSettingsElem.appendChild( propertiesElem );
3075 delete mDiagramLayerSettings;
3077 mDiagramLayerSettings->readXml( diagramSettingsElem );
3083 styleChangedSignalBlocker.release();
3094 QDomElement layerElement = node.toElement();
3097 ( void )
writeStyle( node, doc, errorMessage, context, categories );
3100 mGeometryOptions->writeXml( node );
3105 if ( !legendElement.isNull() )
3106 node.appendChild( legendElement );
3115 QDomElement referencedLayersElement = doc.createElement( u
"referencedLayers"_s );
3116 node.appendChild( referencedLayersElement );
3118 const QList<QgsRelation>
referencingRelations { p->relationManager()->referencingRelations(
this ) };
3121 switch ( rel.type() )
3132 QDomElement referencingLayersElement = doc.createElement( u
"referencingLayers"_s );
3133 node.appendChild( referencingLayersElement );
3135 const QList<QgsRelation> referencedRelations { p->relationManager()->referencedRelations(
this ) };
3136 for (
const QgsRelation &rel : referencedRelations )
3138 switch ( rel.type() )
3151 if ( categories.testFlag(
Fields ) || categories.testFlag(
Forms ) )
3153 QDomElement fieldConfigurationElement;
3155 fieldConfigurationElement = doc.createElement( u
"fieldConfiguration"_s );
3156 node.appendChild( fieldConfigurationElement );
3158 for (
const QgsField &field : std::as_const( mFields ) )
3160 QDomElement fieldElement = doc.createElement( u
"field"_s );
3161 fieldElement.setAttribute( u
"name"_s, field.name() );
3162 fieldConfigurationElement.appendChild( fieldElement );
3164 if ( categories.testFlag(
Fields ) )
3166 fieldElement.setAttribute( u
"configurationFlags"_s,
qgsFlagValueToKeys( field.configurationFlags() ) );
3169 if ( categories.testFlag(
Forms ) )
3174 QDomElement editWidgetElement = doc.createElement( u
"editWidget"_s );
3175 fieldElement.appendChild( editWidgetElement );
3176 editWidgetElement.setAttribute( u
"type"_s, field.editorWidgetSetup().type() );
3177 QDomElement editWidgetConfigElement = doc.createElement( u
"config"_s );
3180 editWidgetElement.appendChild( editWidgetConfigElement );
3186 if ( categories.testFlag(
Fields ) )
3189 QDomElement aliasElem = doc.createElement( u
"aliases"_s );
3190 for (
const QgsField &field : std::as_const( mFields ) )
3192 QDomElement aliasEntryElem = doc.createElement( u
"alias"_s );
3193 aliasEntryElem.setAttribute( u
"field"_s, field.name() );
3194 aliasEntryElem.setAttribute( u
"index"_s, mFields.indexFromName( field.name() ) );
3195 aliasEntryElem.setAttribute( u
"name"_s, field.alias() );
3196 aliasElem.appendChild( aliasEntryElem );
3198 node.appendChild( aliasElem );
3202 QDomElement splitPoliciesElement = doc.createElement( u
"splitPolicies"_s );
3203 bool hasNonDefaultSplitPolicies =
false;
3204 for (
const QgsField &field : std::as_const( mFields ) )
3208 QDomElement splitPolicyElem = doc.createElement( u
"policy"_s );
3209 splitPolicyElem.setAttribute( u
"field"_s, field.name() );
3210 splitPolicyElem.setAttribute( u
"policy"_s,
qgsEnumValueToKey( field.splitPolicy() ) );
3211 splitPoliciesElement.appendChild( splitPolicyElem );
3212 hasNonDefaultSplitPolicies =
true;
3215 if ( hasNonDefaultSplitPolicies )
3216 node.appendChild( splitPoliciesElement );
3221 QDomElement duplicatePoliciesElement = doc.createElement( u
"duplicatePolicies"_s );
3222 bool hasNonDefaultDuplicatePolicies =
false;
3223 for (
const QgsField &field : std::as_const( mFields ) )
3227 QDomElement duplicatePolicyElem = doc.createElement( u
"policy"_s );
3228 duplicatePolicyElem.setAttribute( u
"field"_s, field.name() );
3229 duplicatePolicyElem.setAttribute( u
"policy"_s,
qgsEnumValueToKey( field.duplicatePolicy() ) );
3230 duplicatePoliciesElement.appendChild( duplicatePolicyElem );
3231 hasNonDefaultDuplicatePolicies =
true;
3234 if ( hasNonDefaultDuplicatePolicies )
3235 node.appendChild( duplicatePoliciesElement );
3240 QDomElement mergePoliciesElement = doc.createElement( u
"mergePolicies"_s );
3241 bool hasNonDefaultMergePolicies =
false;
3242 for (
const QgsField &field : std::as_const( mFields ) )
3246 QDomElement mergePolicyElem = doc.createElement( u
"policy"_s );
3247 mergePolicyElem.setAttribute( u
"field"_s, field.name() );
3248 mergePolicyElem.setAttribute( u
"policy"_s,
qgsEnumValueToKey( field.mergePolicy() ) );
3249 mergePoliciesElement.appendChild( mergePolicyElem );
3250 hasNonDefaultMergePolicies =
true;
3253 if ( hasNonDefaultMergePolicies )
3254 node.appendChild( mergePoliciesElement );
3258 QDomElement defaultsElem = doc.createElement( u
"defaults"_s );
3259 for (
const QgsField &field : std::as_const( mFields ) )
3261 QDomElement defaultElem = doc.createElement( u
"default"_s );
3262 defaultElem.setAttribute( u
"field"_s, field.name() );
3263 defaultElem.setAttribute( u
"expression"_s, field.defaultValueDefinition().expression() );
3264 defaultElem.setAttribute( u
"applyOnUpdate"_s, field.defaultValueDefinition().applyOnUpdate() ? u
"1"_s : u
"0"_s );
3265 defaultsElem.appendChild( defaultElem );
3267 node.appendChild( defaultsElem );
3270 QDomElement constraintsElem = doc.createElement( u
"constraints"_s );
3271 for (
const QgsField &field : std::as_const( mFields ) )
3273 QDomElement constraintElem = doc.createElement( u
"constraint"_s );
3274 constraintElem.setAttribute( u
"field"_s, field.name() );
3275 constraintElem.setAttribute( u
"constraints"_s, field.constraints().constraints() );
3280 constraintsElem.appendChild( constraintElem );
3282 node.appendChild( constraintsElem );
3285 QDomElement constraintExpressionsElem = doc.createElement( u
"constraintExpressions"_s );
3286 for (
const QgsField &field : std::as_const( mFields ) )
3288 QDomElement constraintExpressionElem = doc.createElement( u
"constraint"_s );
3289 constraintExpressionElem.setAttribute( u
"field"_s, field.name() );
3290 constraintExpressionElem.setAttribute( u
"exp"_s, field.constraints().constraintExpression() );
3291 constraintExpressionElem.setAttribute( u
"desc"_s, field.constraints().constraintDescription() );
3292 constraintExpressionsElem.appendChild( constraintExpressionElem );
3294 node.appendChild( constraintExpressionsElem );
3297 if ( !mExpressionFieldBuffer )
3305 mExpressionFieldBuffer->writeXml( node, doc );
3310 if ( categories.testFlag(
Actions ) )
3311 mActions->writeXml( node );
3315 mAttributeTableConfig.writeXml( node );
3316 mConditionalStyles->writeXml( node, doc, context );
3317 mStoredExpressionManager->writeXml( node );
3320 if ( categories.testFlag(
Forms ) )
3321 mEditFormConfig.writeXml( node, context );
3325 node.toElement().setAttribute( u
"readOnly"_s, mReadOnly );
3330 QDomElement prevExpElem = doc.createElement( u
"previewExpression"_s );
3331 QDomText prevExpText = doc.createTextNode( mDisplayExpression );
3332 prevExpElem.appendChild( prevExpText );
3333 node.appendChild( prevExpElem );
3337 if ( categories.testFlag(
MapTips ) )
3339 QDomElement mapTipElem = doc.createElement( u
"mapTip"_s );
3341 QDomText mapTipText = doc.createTextNode( mMapTipTemplate );
3342 mapTipElem.appendChild( mapTipText );
3343 node.toElement().appendChild( mapTipElem );
3353 QDomElement mapLayerNode = node.toElement();
3366 QDomElement rendererElement = mRenderer->save( doc, context );
3367 node.appendChild( rendererElement );
3369 if ( mSelectionProperties )
3371 mSelectionProperties->writeXml( mapLayerNode, doc, context );
3375 if ( categories.testFlag(
Labeling ) )
3379 QDomElement labelingElement = mLabeling->save( doc, context );
3380 node.appendChild( labelingElement );
3382 mapLayerNode.setAttribute( u
"labelsEnabled"_s, mLabelsEnabled ? u
"1"_s : u
"0"_s );
3388 mapLayerNode.setAttribute( u
"simplifyDrawingHints"_s, QString::number(
static_cast< int >( mSimplifyMethod.simplifyHints() ) ) );
3389 mapLayerNode.setAttribute( u
"simplifyAlgorithm"_s, QString::number(
static_cast< int >( mSimplifyMethod.simplifyAlgorithm() ) ) );
3390 mapLayerNode.setAttribute( u
"simplifyDrawingTol"_s, QString::number( mSimplifyMethod.threshold() ) );
3391 mapLayerNode.setAttribute( u
"simplifyLocal"_s, mSimplifyMethod.forceLocalOptimization() ? 1 : 0 );
3392 mapLayerNode.setAttribute( u
"simplifyMaxScale"_s, QString::number( mSimplifyMethod.maximumScale() ) );
3404 QDomElement blendModeElem = doc.createElement( u
"blendMode"_s );
3406 blendModeElem.appendChild( blendModeText );
3407 node.appendChild( blendModeElem );
3410 QDomElement featureBlendModeElem = doc.createElement( u
"featureBlendMode"_s );
3412 featureBlendModeElem.appendChild( featureBlendModeText );
3413 node.appendChild( featureBlendModeElem );
3419 QDomElement layerOpacityElem = doc.createElement( u
"layerOpacity"_s );
3420 QDomText layerOpacityText = doc.createTextNode( QString::number(
opacity() ) );
3421 layerOpacityElem.appendChild( layerOpacityText );
3422 node.appendChild( layerOpacityElem );
3424 mapLayerNode.setAttribute( u
"maxScale"_s,
maximumScale() );
3425 mapLayerNode.setAttribute( u
"minScale"_s,
minimumScale() );
3427 mapLayerNode.setAttribute( u
"symbologyReferenceScale"_s, mRenderer ? mRenderer->referenceScale() : -1 );
3430 if ( categories.testFlag(
Diagrams ) && mDiagramRenderer )
3432 mDiagramRenderer->writeXml( mapLayerNode, doc, context );
3433 if ( mDiagramLayerSettings )
3434 mDiagramLayerSettings->writeXml( mapLayerNode, doc );
3445 QDomElement nameElem = node.firstChildElement( u
"Name"_s );
3446 if ( nameElem.isNull() )
3448 errorMessage = u
"Warning: Name element not found within NamedLayer while it's required."_s;
3464 readSldLabeling( node );
3466 styleChangedSignalBlocker.release();
3476 context.setExtraProperties( props );
3495 QDomElement nameNode = doc.createElement( u
"se:Name"_s );
3496 nameNode.appendChild( doc.createTextNode(
name() ) );
3497 node.appendChild( nameNode );
3499 QDomElement userStyleElem = doc.createElement( u
"UserStyle"_s );
3500 node.appendChild( userStyleElem );
3502 QDomElement nameElem = doc.createElement( u
"se:Name"_s );
3503 nameElem.appendChild( doc.createTextNode(
name() ) );
3505 userStyleElem.appendChild( nameElem );
3507 QDomElement featureTypeStyleElem = doc.createElement( u
"se:FeatureTypeStyle"_s );
3508 userStyleElem.appendChild( featureTypeStyleElem );
3510 mRenderer->toSld( doc, featureTypeStyleElem, context );
3513 mLabeling->toSld( featureTypeStyleElem, context );
3523 if ( !mEditBuffer || !mDataProvider )
3528 if ( mGeometryOptions->isActive() )
3529 mGeometryOptions->apply( geom );
3533 bool result = mEditBuffer->changeGeometry( fid, geom );
3538 if ( !skipDefaultValue && !mDefaultValueOnUpdateFields.isEmpty() )
3539 updateDefaultValues( fid );
3549 bool result =
false;
3551 switch (
fields().fieldOrigin( field ) )
3554 result = mJoinBuffer->changeAttributeValue( fid, field, newValue, oldValue );
3563 if ( mEditBuffer && mDataProvider )
3564 result = mEditBuffer->changeAttributeValue( fid, field, newValue, oldValue );
3572 if ( result && !skipDefaultValues && !mDefaultValueOnUpdateFields.isEmpty() )
3590 for (
auto it = newValues.constBegin(); it != newValues.constEnd(); ++it )
3592 const int field = it.key();
3593 const QVariant newValue = it.value();
3596 if ( oldValues.contains( field ) )
3597 oldValue = oldValues[field];
3599 switch (
fields().fieldOrigin( field ) )
3602 newValuesJoin[field] = newValue;
3603 oldValuesJoin[field] = oldValue;
3610 newValuesNotJoin[field] = newValue;
3611 oldValuesNotJoin[field] = oldValue;
3620 if ( !newValuesJoin.isEmpty() && mJoinBuffer )
3622 result = mJoinBuffer->changeAttributeValues( fid, newValuesJoin, oldValuesJoin );
3625 if ( !newValuesNotJoin.isEmpty() )
3627 if ( mEditBuffer && mDataProvider )
3628 result &= mEditBuffer->changeAttributeValues( fid, newValuesNotJoin, oldValues );
3633 if ( result && !skipDefaultValues && !mDefaultValueOnUpdateFields.isEmpty() )
3645 if ( !mEditBuffer || !mDataProvider )
3648 return mEditBuffer->addAttribute( field );
3655 if ( attIndex < 0 || attIndex >=
fields().count() )
3659 mFields[attIndex].setAlias( QString() );
3660 if ( mAttributeAliasMap.contains(
name ) )
3662 mAttributeAliasMap.remove(
name );
3664 mEditFormConfig.setFields( mFields );
3673 if ( index < 0 || index >=
fields().count() )
3676 switch ( mFields.fieldOrigin( index ) )
3680 if ( mExpressionFieldBuffer )
3682 int oi = mFields.fieldOriginIndex( index );
3683 mExpressionFieldBuffer->renameExpression( oi, newName );
3696 if ( !mEditBuffer || !mDataProvider )
3699 return mEditBuffer->renameAttribute( index, newName );
3713 if ( attIndex < 0 || attIndex >=
fields().count() )
3718 mAttributeAliasMap.insert(
name, aliasString );
3719 mFields[attIndex].setAlias( aliasString );
3720 mEditFormConfig.setFields( mFields );
3728 if ( index < 0 || index >=
fields().count() )
3738 if ( index >= 0 && index < mFields.count() )
3739 return mFields.at( index ).displayName();
3748 return mAttributeAliasMap;
3755 if ( index < 0 || index >=
fields().count() )
3760 mAttributeSplitPolicy.insert(
name, policy );
3761 mFields[index].setSplitPolicy( policy );
3762 mEditFormConfig.setFields( mFields );
3770 if ( index < 0 || index >=
fields().count() )
3775 mAttributeDuplicatePolicy.insert(
name, policy );
3776 mFields[index].setDuplicatePolicy( policy );
3777 mEditFormConfig.setFields( mFields );
3785 if ( index < 0 || index >=
fields().count() )
3790 mAttributeMergePolicy.insert(
name, policy );
3791 mFields[index].setMergePolicy( policy );
3792 mEditFormConfig.setFields( mFields );
3800 QSet<QString> excludeList;
3801 QMap< QString, Qgis::FieldConfigurationFlags >::const_iterator flagsIt = mFieldConfigurationFlags.constBegin();
3802 for ( ; flagsIt != mFieldConfigurationFlags.constEnd(); ++flagsIt )
3806 excludeList << flagsIt.key();
3816 QMap< QString, Qgis::FieldConfigurationFlags >::iterator flagsIt = mFieldConfigurationFlags.begin();
3817 for ( ; flagsIt != mFieldConfigurationFlags.end(); ++flagsIt )
3828 QSet<QString> excludeList;
3829 QMap< QString, Qgis::FieldConfigurationFlags >::const_iterator flagsIt = mFieldConfigurationFlags.constBegin();
3830 for ( ; flagsIt != mFieldConfigurationFlags.constEnd(); ++flagsIt )
3834 excludeList << flagsIt.key();
3844 QMap< QString, Qgis::FieldConfigurationFlags >::iterator flagsIt = mFieldConfigurationFlags.begin();
3845 for ( ; flagsIt != mFieldConfigurationFlags.end(); ++flagsIt )
3856 if ( index < 0 || index >=
fields().count() )
3865 if ( !mEditBuffer || !mDataProvider )
3868 return mEditBuffer->deleteAttribute( index );
3875 bool deleted =
false;
3878 QList<int> attrList = qgis::setToList( qgis::listToSet( attrs ) );
3880 std::sort( attrList.begin(), attrList.end(), std::greater<int>() );
3882 for (
int attr : std::as_const( attrList ) )
3900 if ( context && context->
cascade )
3903 const bool hasRelationsOrJoins = !relations.empty() || mJoinBuffer->
containsJoins();
3904 if ( hasRelationsOrJoins )
3909 if ( handledFeatureIds.contains( fid ) )
3917 handledFeatureIds << fid;
3926 for (
const QgsRelation &relation : relations )
3929 switch ( relation.strength() )
3934 QgsFeatureIterator relatedFeaturesIt = relation.getRelatedFeatures(
getFeature( fid ) );
3936 QgsFeature childFeature;
3937 while ( relatedFeaturesIt.
nextFeature( childFeature ) )
3939 childFeatureIds.insert( childFeature.
id() );
3941 if ( childFeatureIds.count() > 0 )
3943 relation.referencingLayer()->startEditing();
3944 relation.referencingLayer()->deleteFeatures( childFeatureIds, context );
3956 if ( mJoinBuffer->containsJoins() )
3957 mJoinBuffer->deleteFeature( fid, context );
3959 bool res = mEditBuffer->deleteFeature( fid );
3971 return deleteFeatureCascade( fid, context );
3980 if ( ( context && context->
cascade ) || mJoinBuffer->containsJoins() )
3984 res = deleteFeatureCascade( fid, context ) && res;
3988 res = mEditBuffer && mEditBuffer->deleteFeatures( fids );
3993 mSelectedFeatureIds.subtract( fids );
4013 if ( !mDataProvider )
4014 return pkAttributesList;
4017 for (
int i = 0; i < mFields.count(); ++i )
4020 pkAttributesList << i;
4023 return pkAttributesList;
4030 if ( !mDataProvider )
4032 return mDataProvider->featureCount() + ( mEditBuffer && !mDataProvider->transaction() ? mEditBuffer->addedFeatures().size() - mEditBuffer->deletedFeatureIds().size() : 0 );
4039 const QgsFeatureIds deletedFeatures( mEditBuffer && !mDataProvider->transaction() ? mEditBuffer->deletedFeatureIds() :
QgsFeatureIds() );
4040 const QgsFeatureMap addedFeatures( mEditBuffer && !mDataProvider->transaction() ? mEditBuffer->addedFeatures() :
QgsFeatureMap() );
4042 if ( mEditBuffer && !deletedFeatures.empty() )
4044 if ( addedFeatures.size() > deletedFeatures.size() )
4050 if ( ( !mEditBuffer || addedFeatures.empty() ) && mDataProvider && mDataProvider->empty() )
4063 mCommitErrors.clear();
4065 if ( !mDataProvider )
4067 mCommitErrors << tr(
"ERROR: no provider" );
4073 mCommitErrors << tr(
"ERROR: layer not editable" );
4079 if ( !mAllowCommit )
4082 mCommitChangesActive =
true;
4084 bool success =
false;
4085 if ( mEditBuffer->editBufferGroup() )
4086 success = mEditBuffer->editBufferGroup()->commitChanges( mCommitErrors, stopEditing );
4088 success = mEditBuffer->commitChanges( mCommitErrors );
4090 mCommitChangesActive =
false;
4092 if ( !mDeletedFids.empty() )
4095 mDeletedFids.clear();
4116 mDataProvider->updateExtents();
4120 mDataProvider->leaveUpdateMode();
4126 if ( mFields.names() != mDataProvider->fields().names() )
4140 return mCommitErrors;
4155 if ( !mDataProvider )
4157 mCommitErrors << tr(
"ERROR: no provider" );
4161 bool rollbackExtent = !mDataProvider->transaction() && ( !mEditBuffer->deletedFeatureIds().isEmpty() || !mEditBuffer->addedFeatures().isEmpty() || !mEditBuffer->changedGeometries().isEmpty() );
4165 mEditBuffer->rollBack();
4181 mEditBuffer =
nullptr;
4186 if ( rollbackExtent )
4189 mDataProvider->leaveUpdateMode();
4199 return mSelectedFeatureIds.size();
4207 return mSelectedFeatureIds;
4215 features.reserve( mSelectedFeatureIds.count() );
4222 features.push_back( f );
4232 if ( mSelectedFeatureIds.isEmpty() )
4238 if ( mSelectedFeatureIds.count() == 1 )
4239 request.
setFilterFid( *mSelectedFeatureIds.constBegin() );
4250 if ( !mEditBuffer || !mDataProvider )
4253 if ( mGeometryOptions->isActive() )
4255 for (
auto feature = features.begin(); feature != features.end(); ++feature )
4258 mGeometryOptions->apply( geom );
4263 bool res = mEditBuffer->addFeatures( features );
4266 if ( res && mJoinBuffer->containsJoins() )
4267 res = mJoinBuffer->addFeatures( features );
4285 if ( exp.isField() )
4308 if ( !mDisplayExpression.isEmpty() || mFields.isEmpty() )
4310 return mDisplayExpression;
4315 if ( !candidateName.isEmpty() )
4338 return ( mEditBuffer && mDataProvider );
4350bool QgsVectorLayer::isReadOnly()
const
4354 return mDataSourceReadOnly || mReadOnly;
4362 if ( readonly && mEditBuffer )
4366 if ( !readonly && mDataSourceReadOnly )
4369 mReadOnly = readonly;
4378 if ( !mDataProvider )
4381 if ( mDataSourceReadOnly )
4392 return mEditBuffer && mEditBuffer->isModified();
4399 bool auxiliaryField =
false;
4403 return auxiliaryField;
4410 auxiliaryField =
true;
4413 return auxiliaryField;
4429 if ( r != mRenderer )
4433 mSymbolFeatureCounted =
false;
4434 mSymbolFeatureCountMap.clear();
4435 mSymbolFeatureIdMap.clear();
4440 if ( refreshRate <= 0 )
4442 mRefreshRendererTimer->stop();
4443 mRefreshRendererTimer->setInterval( 0 );
4447 mRefreshRendererTimer->setInterval( 1000 / refreshRate );
4448 mRefreshRendererTimer->start();
4463 mRendererGenerators << generator;
4471 for (
int i = mRendererGenerators.count() - 1; i >= 0; --i )
4473 if ( mRendererGenerators.at( i )->id() ==
id )
4475 delete mRendererGenerators.at( i );
4476 mRendererGenerators.removeAt( i );
4486 QList< const QgsFeatureRendererGenerator * > res;
4496 if ( !mDataProvider )
4500 if ( mDataProvider->transaction() )
4502 QString ignoredError;
4503 mDataProvider->transaction()->createSavepoint( ignoredError );
4506 mEditCommandActive =
true;
4514 if ( !mDataProvider )
4519 mEditCommandActive =
false;
4520 if ( !mDeletedFids.isEmpty() )
4524 mSelectedFeatureIds.subtract( mDeletedFids );
4527 mDeletedFids.clear();
4536 if ( !mDataProvider )
4547 auto command = std::make_unique< QUndoCommand >();
4548 command->setObsolete(
true );
4551 mEditCommandActive =
false;
4552 mDeletedFids.clear();
4560 return mJoinBuffer->addJoin( joinInfo );
4567 return mJoinBuffer->removeJoin( joinLayerId );
4574 return mJoinBuffer->vectorJoins();
4582 mExpressionFieldBuffer->addExpression( exp, fld );
4584 int idx = mFields.indexFromName( fld.
name() );
4594 int oi = mFields.fieldOriginIndex( index );
4595 mExpressionFieldBuffer->removeExpression( oi );
4607 int oi = mFields.fieldOriginIndex( index );
4608 if ( oi < 0 || oi >= mExpressionFieldBuffer->expressions().size() )
4611 return mExpressionFieldBuffer->expressions().at( oi ).cachedExpression.expression();
4618 int oi = mFields.fieldOriginIndex( index );
4619 mExpressionFieldBuffer->updateExpression( oi, exp );
4627 if ( !mDataProvider )
4632 mFields = mDataProvider->fields();
4636 mEditBuffer->updateFields( mFields );
4639 if ( mJoinBuffer->containsJoins() )
4640 mJoinBuffer->updateFields( mFields );
4642 if ( mExpressionFieldBuffer )
4643 mExpressionFieldBuffer->updateFields( mFields );
4646 for (
auto aliasIt = mAttributeAliasMap.constBegin(); aliasIt != mAttributeAliasMap.constEnd(); ++aliasIt )
4648 int index = mFields.lookupField( aliasIt.key() );
4652 mFields[index].setAlias( aliasIt.value() );
4655 for (
auto splitPolicyIt = mAttributeSplitPolicy.constBegin(); splitPolicyIt != mAttributeSplitPolicy.constEnd(); ++splitPolicyIt )
4657 int index = mFields.lookupField( splitPolicyIt.key() );
4661 mFields[index].setSplitPolicy( splitPolicyIt.value() );
4664 for (
auto duplicatePolicyIt = mAttributeDuplicatePolicy.constBegin(); duplicatePolicyIt != mAttributeDuplicatePolicy.constEnd(); ++duplicatePolicyIt )
4666 int index = mFields.lookupField( duplicatePolicyIt.key() );
4670 mFields[index].setDuplicatePolicy( duplicatePolicyIt.value() );
4673 for (
auto mergePolicyIt = mAttributeMergePolicy.constBegin(); mergePolicyIt != mAttributeMergePolicy.constEnd(); ++mergePolicyIt )
4675 int index = mFields.lookupField( mergePolicyIt.key() );
4679 mFields[index].setMergePolicy( mergePolicyIt.value() );
4683 QMap< QString, Qgis::FieldConfigurationFlags >::const_iterator flagsIt = mFieldConfigurationFlags.
constBegin();
4684 for ( ; flagsIt != mFieldConfigurationFlags.constEnd(); ++flagsIt )
4686 int index = mFields.lookupField( flagsIt.key() );
4690 mFields[index].setConfigurationFlags( flagsIt.value() );
4694 mDefaultValueOnUpdateFields.clear();
4695 QMap< QString, QgsDefaultValue >::const_iterator defaultIt = mDefaultExpressionMap.constBegin();
4696 for ( ; defaultIt != mDefaultExpressionMap.constEnd(); ++defaultIt )
4698 int index = mFields.lookupField( defaultIt.key() );
4702 mFields[index].setDefaultValueDefinition( defaultIt.value() );
4703 if ( defaultIt.value().applyOnUpdate() )
4704 mDefaultValueOnUpdateFields.insert( index );
4707 QMap< QString, QgsFieldConstraints::Constraints >::const_iterator constraintIt = mFieldConstraints.constBegin();
4708 for ( ; constraintIt != mFieldConstraints.constEnd(); ++constraintIt )
4710 int index = mFields.lookupField( constraintIt.key() );
4723 mFields[index].setConstraints( constraints );
4726 QMap< QString, QPair< QString, QString > >::const_iterator constraintExpIt = mFieldConstraintExpressions.constBegin();
4727 for ( ; constraintExpIt != mFieldConstraintExpressions.constEnd(); ++constraintExpIt )
4729 int index = mFields.lookupField( constraintExpIt.key() );
4740 mFields[index].setConstraints( constraints );
4744 for ( ; constraintStrengthIt != mFieldConstraintStrength.constEnd(); ++constraintStrengthIt )
4746 int index = mFields.lookupField( constraintStrengthIt.key().first );
4756 constraints.
setConstraintStrength( constraintStrengthIt.key().second, constraintStrengthIt.value() );
4757 mFields[index].setConstraints( constraints );
4760 auto fieldWidgetIterator = mFieldWidgetSetups.constBegin();
4761 for ( ; fieldWidgetIterator != mFieldWidgetSetups.constEnd(); ++fieldWidgetIterator )
4763 int index = mFields.indexOf( fieldWidgetIterator.key() );
4767 mFields[index].setEditorWidgetSetup( fieldWidgetIterator.value() );
4770 if ( oldFields != mFields )
4773 mEditFormConfig.setFields( mFields );
4781 if ( index < 0 || index >= mFields.count() || !mDataProvider )
4784 QString expression = mFields.at( index ).defaultValueDefinition().expression();
4785 if ( expression.isEmpty() )
4786 return mDataProvider->defaultValue( index );
4789 std::unique_ptr< QgsExpressionContext > tempContext;
4794 evalContext = tempContext.get();
4829 if ( index < 0 || index >= mFields.count() )
4834 mDefaultExpressionMap.insert( mFields.at( index ).name(), definition );
4838 mDefaultExpressionMap.remove( mFields.at( index ).name() );
4847 if ( index < 0 || index >= mFields.count() )
4850 return mFields.at( index ).defaultValueDefinition();
4858 if ( !mDataProvider )
4871 uniqueValues = mDataProvider->uniqueValues( index, limit );
4873 if ( mEditBuffer && !mDataProvider->transaction() )
4877 for (
const QVariant &v : constUniqueValues )
4879 vals << v.toString();
4883 QMapIterator< QgsFeatureId, QgsFeature > addedIt( added );
4884 while ( addedIt.hasNext() && ( limit < 0 ||
uniqueValues.count() < limit ) )
4887 QVariant v = addedIt.value().attribute( index );
4890 QString vs = v.toString();
4891 if ( !vals.contains( vs ) )
4899 QMapIterator< QgsFeatureId, QgsAttributeMap > it( mEditBuffer->changedAttributeValues() );
4900 while ( it.hasNext() && ( limit < 0 ||
uniqueValues.count() < limit ) )
4903 QVariant v = it.value().value( index );
4906 QString vs = v.toString();
4907 if ( !vals.contains( vs ) )
4921 if ( mDataProvider->transaction()
4922 || ( mEditBuffer->deletedFeatureIds().isEmpty() && mEditBuffer->addedFeatures().isEmpty() && !mEditBuffer->deletedAttributeIds().contains( index ) && mEditBuffer->changedAttributeValues().isEmpty() ) )
4924 uniqueValues = mDataProvider->uniqueValues( index, limit );
4938 QVariant currentValue;
4939 QHash<QString, QVariant> val;
4943 val.insert( currentValue.toString(), currentValue );
4944 if ( limit >= 0 && val.size() >= limit )
4950 return qgis::listToSet( val.values() );
4954 Q_ASSERT_X(
false,
"QgsVectorLayer::uniqueValues()",
"Unknown source of the field!" );
4962 QStringList results;
4963 if ( !mDataProvider )
4976 results = mDataProvider->uniqueStringsMatching( index, substring, limit, feedback );
4978 if ( mEditBuffer && !mDataProvider->transaction() )
4981 QMapIterator< QgsFeatureId, QgsFeature > addedIt( added );
4982 while ( addedIt.hasNext() && ( limit < 0 || results.count() < limit ) && ( !feedback || !feedback->
isCanceled() ) )
4985 QVariant v = addedIt.value().attribute( index );
4988 QString vs = v.toString();
4989 if ( vs.contains( substring, Qt::CaseInsensitive ) && !results.contains( vs ) )
4996 QMapIterator< QgsFeatureId, QgsAttributeMap > it( mEditBuffer->changedAttributeValues() );
4997 while ( it.hasNext() && ( limit < 0 || results.count() < limit ) && ( !feedback || !feedback->
isCanceled() ) )
5000 QVariant v = it.value().value( index );
5003 QString vs = v.toString();
5004 if ( vs.contains( substring, Qt::CaseInsensitive ) && !results.contains( vs ) )
5017 if ( mDataProvider->transaction()
5018 || ( mEditBuffer->deletedFeatureIds().isEmpty() && mEditBuffer->addedFeatures().isEmpty() && !mEditBuffer->deletedAttributeIds().contains( index ) && mEditBuffer->changedAttributeValues().isEmpty() ) )
5020 return mDataProvider->uniqueStringsMatching( index, substring, limit, feedback );
5033 QString fieldName = mFields.at( index ).name();
5038 QString currentValue;
5041 currentValue = f.
attribute( index ).toString();
5042 if ( !results.contains( currentValue ) )
5043 results << currentValue;
5045 if ( ( limit >= 0 && results.size() >= limit ) || ( feedback && feedback->
isCanceled() ) )
5055 Q_ASSERT_X(
false,
"QgsVectorLayer::uniqueStringsMatching()",
"Unknown source of the field!" );
5064 minimumOrMaximumValue( index, &minimum,
nullptr );
5073 minimumOrMaximumValue( index,
nullptr, &maximum );
5081 minimumOrMaximumValue( index, &minimum, &maximum );
5084void QgsVectorLayer::minimumOrMaximumValue(
int index, QVariant *minimum, QVariant *maximum )
const
5089 *minimum = QVariant();
5091 *maximum = QVariant();
5093 if ( !mDataProvider )
5110 *minimum = mDataProvider->minimumValue( index );
5112 *maximum = mDataProvider->maximumValue( index );
5113 if ( mEditBuffer && !mDataProvider->transaction() )
5116 QMapIterator< QgsFeatureId, QgsFeature > addedIt( added );
5117 while ( addedIt.hasNext() )
5120 const QVariant v = addedIt.value().attribute( index );
5127 QMapIterator< QgsFeatureId, QgsAttributeMap > it( mEditBuffer->changedAttributeValues() );
5128 while ( it.hasNext() )
5131 const QVariant v = it.value().value( index );
5144 if ( mDataProvider->transaction()
5145 || ( mEditBuffer->deletedFeatureIds().isEmpty() && mEditBuffer->addedFeatures().isEmpty() && !mEditBuffer->deletedAttributeIds().contains( index ) && mEditBuffer->changedAttributeValues().isEmpty() ) )
5148 *minimum = mDataProvider->minimumValue( index );
5150 *maximum = mDataProvider->maximumValue( index );
5166 bool firstValue =
true;
5169 const QVariant currentValue = f.
attribute( index );
5176 *minimum = currentValue;
5178 *maximum = currentValue;
5183 if ( minimum && currentValue.isValid() &&
qgsVariantLessThan( currentValue, *minimum ) )
5184 *minimum = currentValue;
5186 *maximum = currentValue;
5193 Q_ASSERT_X(
false,
"QgsVectorLayer::minimumOrMaximumValue()",
"Unknown source of the field!" );
5196void QgsVectorLayer::createEditBuffer()
5203 if ( mDataProvider->transaction() )
5207 connect( mDataProvider->transaction(), &
QgsTransaction::dirtied,
this, &QgsVectorLayer::onDirtyTransaction, Qt::UniqueConnection );
5231void QgsVectorLayer::clearEditBuffer()
5236 mEditBuffer =
nullptr;
5241 const QString &fieldOrExpression,
5258 if ( !mDataProvider )
5261 *
error = tr(
"Layer is invalid" );
5267 if ( attrIndex >= 0 )
5274 bool providerOk =
false;
5275 QVariant val = mDataProvider->aggregate(
aggregate, attrIndex, parameters, context, providerOk, fids );
5289 c.setFidsFilter( *fids );
5290 c.setParameters( parameters );
5291 bool aggregateOk =
false;
5292 const QVariant result =
c.calculate(
aggregate, fieldOrExpression, context, &aggregateOk, feedback );
5295 if ( !aggregateOk &&
error )
5318 return mFeatureBlendMode;
5321void QgsVectorLayer::readSldLabeling(
const QDomNode &node )
5328 QDomElement element = node.toElement();
5329 if ( element.isNull() )
5332 QDomElement userStyleElem = element.firstChildElement( u
"UserStyle"_s );
5333 if ( userStyleElem.isNull() )
5339 QDomElement featTypeStyleElem = userStyleElem.firstChildElement( u
"FeatureTypeStyle"_s );
5340 if ( featTypeStyleElem.isNull() )
5347 QDomElement mergedFeatTypeStyle = featTypeStyleElem.cloneNode(
false ).toElement();
5352 bool needRuleBasedLabeling =
false;
5355 while ( !featTypeStyleElem.isNull() )
5357 QDomElement ruleElem = featTypeStyleElem.firstChildElement( u
"Rule"_s );
5358 while ( !ruleElem.isNull() )
5362 bool hasTextSymbolizer =
false;
5363 bool hasRuleBased =
false;
5364 QDomElement ruleChildElem = ruleElem.firstChildElement();
5365 while ( !ruleChildElem.isNull() )
5368 if ( ruleChildElem.localName() ==
"Filter"_L1 || ruleChildElem.localName() ==
"MinScaleDenominator"_L1 || ruleChildElem.localName() ==
"MaxScaleDenominator"_L1 )
5370 hasRuleBased =
true;
5373 else if ( ruleChildElem.localName() ==
"TextSymbolizer"_L1 )
5376 hasTextSymbolizer =
true;
5379 ruleChildElem = ruleChildElem.nextSiblingElement();
5382 if ( hasTextSymbolizer )
5387 mergedFeatTypeStyle.appendChild( ruleElem.cloneNode().toElement() );
5391 QgsDebugMsgLevel( u
"Info: Filter or Min/MaxScaleDenominator element found: need a RuleBasedLabeling"_s, 4 );
5392 needRuleBasedLabeling =
true;
5397 if ( ruleCount > 1 )
5399 QgsDebugMsgLevel( u
"Info: More Rule elements found: need a RuleBasedLabeling"_s, 4 );
5400 needRuleBasedLabeling =
true;
5404 if ( ruleCount == 0 )
5406 needRuleBasedLabeling =
false;
5409 ruleElem = ruleElem.nextSiblingElement( u
"Rule"_s );
5411 featTypeStyleElem = featTypeStyleElem.nextSiblingElement( u
"FeatureTypeStyle"_s );
5414 if ( ruleCount == 0 )
5420 QDomElement ruleElem = mergedFeatTypeStyle.firstChildElement( u
"Rule"_s );
5422 if ( needRuleBasedLabeling )
5425 QgsRuleBasedLabeling::Rule *rootRule =
new QgsRuleBasedLabeling::Rule(
nullptr );
5426 while ( !ruleElem.isNull() )
5428 QString label, description, filterExp;
5429 int scaleMinDenom = 0, scaleMaxDenom = 0;
5430 QgsPalLayerSettings settings;
5433 QDomElement childElem = ruleElem.firstChildElement();
5434 while ( !childElem.isNull() )
5436 if ( childElem.localName() ==
"Name"_L1 )
5440 if ( label.isEmpty() )
5441 label = childElem.firstChild().nodeValue();
5443 else if ( childElem.localName() ==
"Description"_L1 )
5446 QDomElement titleElem = childElem.firstChildElement( u
"Title"_s );
5447 if ( !titleElem.isNull() )
5449 label = titleElem.firstChild().nodeValue();
5452 QDomElement abstractElem = childElem.firstChildElement( u
"Abstract"_s );
5453 if ( !abstractElem.isNull() )
5455 description = abstractElem.firstChild().nodeValue();
5458 else if ( childElem.localName() ==
"Abstract"_L1 )
5461 description = childElem.firstChild().nodeValue();
5463 else if ( childElem.localName() ==
"Title"_L1 )
5466 label = childElem.firstChild().nodeValue();
5468 else if ( childElem.localName() ==
"Filter"_L1 )
5484 else if ( childElem.localName() ==
"MinScaleDenominator"_L1 )
5487 int v = childElem.firstChild().nodeValue().toInt( &ok );
5491 else if ( childElem.localName() ==
"MaxScaleDenominator"_L1 )
5494 int v = childElem.firstChild().nodeValue().toInt( &ok );
5498 else if ( childElem.localName() ==
"TextSymbolizer"_L1 )
5500 readSldTextSymbolizer( childElem, settings );
5503 childElem = childElem.nextSiblingElement();
5506 QgsRuleBasedLabeling::Rule *ruleLabeling =
new QgsRuleBasedLabeling::Rule(
new QgsPalLayerSettings( settings ), scaleMinDenom, scaleMaxDenom, filterExp, label );
5509 ruleElem = ruleElem.nextSiblingElement();
5512 setLabeling(
new QgsRuleBasedLabeling( rootRule ) );
5519 QDomElement textSymbolizerElem = ruleElem.firstChildElement( u
"TextSymbolizer"_s );
5520 QgsPalLayerSettings s;
5521 if ( readSldTextSymbolizer( textSymbolizerElem, s ) )
5523 setLabeling(
new QgsVectorLayerSimpleLabeling( s ) );
5529bool QgsVectorLayer::readSldTextSymbolizer(
const QDomNode &node,
QgsPalLayerSettings &settings )
const
5533 if ( node.localName() !=
"TextSymbolizer"_L1 )
5535 QgsDebugMsgLevel( u
"Not a TextSymbolizer element: %1"_s.arg( node.localName() ), 3 );
5538 QDomElement textSymbolizerElem = node.toElement();
5540 QDomElement labelElem = textSymbolizerElem.firstChildElement( u
"Label"_s );
5541 if ( !labelElem.isNull() )
5543 QDomElement propertyNameElem = labelElem.firstChildElement( u
"PropertyName"_s );
5544 if ( !propertyNameElem.isNull() )
5549 QString labelAttribute = propertyNameElem.text();
5553 int fieldIndex = mFields.lookupField( labelAttribute );
5554 if ( fieldIndex == -1 )
5557 QgsExpression exp( labelAttribute );
5558 if ( !exp.hasEvalError() )
5564 QgsDebugMsgLevel( u
"SLD label attribute error: %1"_s.arg( exp.evalErrorString() ), 3 );
5581 if ( textSymbolizerElem.hasAttribute( u
"uom"_s ) )
5586 QString fontFamily = u
"Sans-Serif"_s;
5587 double fontPointSize = 10;
5589 int fontWeight = -1;
5590 bool fontItalic =
false;
5591 bool fontUnderline =
false;
5594 QDomElement fontElem = textSymbolizerElem.firstChildElement( u
"Font"_s );
5595 if ( !fontElem.isNull() )
5598 for ( QgsStringMap::iterator it = fontSvgParams.begin(); it != fontSvgParams.end(); ++it )
5600 QgsDebugMsgLevel( u
"found fontSvgParams %1: %2"_s.arg( it.key(), it.value() ), 4 );
5602 if ( it.key() ==
"font-family"_L1 )
5604 fontFamily = it.value();
5606 else if ( it.key() ==
"font-style"_L1 )
5608 fontItalic = ( it.value() ==
"italic"_L1 ) || ( it.value() ==
"Italic"_L1 );
5610 else if ( it.key() ==
"font-size"_L1 )
5613 double fontSize = it.value().toDouble( &ok );
5616 fontPointSize = fontSize;
5617 fontUnitSize = sldUnitSize;
5620 else if ( it.key() ==
"font-weight"_L1 )
5622 if ( ( it.value() ==
"bold"_L1 ) || ( it.value() ==
"Bold"_L1 ) )
5623 fontWeight = QFont::Bold;
5625 else if ( it.key() ==
"font-underline"_L1 )
5627 fontUnderline = ( it.value() ==
"underline"_L1 ) || ( it.value() ==
"Underline"_L1 );
5632 QgsTextFormat format;
5633 QFont font( fontFamily, 1, fontWeight, fontItalic );
5634 font.setUnderline( fontUnderline );
5636 format.
setSize( fontPointSize );
5640 QDomElement fillElem = textSymbolizerElem.firstChildElement( u
"Fill"_s );
5642 Qt::BrushStyle textBrush = Qt::SolidPattern;
5644 if ( textColor.isValid() )
5646 QgsDebugMsgLevel( u
"Info: textColor %1."_s.arg( QVariant( textColor ).toString() ), 4 );
5650 QgsTextBufferSettings bufferSettings;
5653 QDomElement haloElem = textSymbolizerElem.firstChildElement( u
"Halo"_s );
5654 if ( !haloElem.isNull() )
5659 QDomElement radiusElem = haloElem.firstChildElement( u
"Radius"_s );
5660 if ( !radiusElem.isNull() )
5663 double bufferSize = radiusElem.text().toDouble( &ok );
5666 bufferSettings.
setSize( bufferSize );
5671 QDomElement haloFillElem = haloElem.firstChildElement( u
"Fill"_s );
5673 Qt::BrushStyle bufferBrush = Qt::SolidPattern;
5675 if ( bufferColor.isValid() )
5677 QgsDebugMsgLevel( u
"Info: bufferColor %1."_s.arg( QVariant( bufferColor ).toString() ), 4 );
5678 bufferSettings.
setColor( bufferColor );
5683 QDomElement labelPlacementElem = textSymbolizerElem.firstChildElement( u
"LabelPlacement"_s );
5684 if ( !labelPlacementElem.isNull() )
5687 QDomElement pointPlacementElem = labelPlacementElem.firstChildElement( u
"PointPlacement"_s );
5688 if ( !pointPlacementElem.isNull() )
5696 QDomElement displacementElem = pointPlacementElem.firstChildElement( u
"Displacement"_s );
5697 if ( !displacementElem.isNull() )
5699 QDomElement displacementXElem = displacementElem.firstChildElement( u
"DisplacementX"_s );
5700 if ( !displacementXElem.isNull() )
5703 double xOffset = displacementXElem.text().toDouble( &ok );
5710 QDomElement displacementYElem = displacementElem.firstChildElement( u
"DisplacementY"_s );
5711 if ( !displacementYElem.isNull() )
5714 double yOffset = displacementYElem.text().toDouble( &ok );
5722 QDomElement anchorPointElem = pointPlacementElem.firstChildElement( u
"AnchorPoint"_s );
5723 if ( !anchorPointElem.isNull() )
5725 QDomElement anchorPointXElem = anchorPointElem.firstChildElement( u
"AnchorPointX"_s );
5726 if ( !anchorPointXElem.isNull() )
5729 double xOffset = anchorPointXElem.text().toDouble( &ok );
5736 QDomElement anchorPointYElem = anchorPointElem.firstChildElement( u
"AnchorPointY"_s );
5737 if ( !anchorPointYElem.isNull() )
5740 double yOffset = anchorPointYElem.text().toDouble( &ok );
5749 QDomElement rotationElem = pointPlacementElem.firstChildElement( u
"Rotation"_s );
5750 if ( !rotationElem.isNull() )
5753 double rotation = rotationElem.text().toDouble( &ok );
5763 QDomElement linePlacementElem = labelPlacementElem.firstChildElement( u
"LinePlacement"_s );
5764 if ( !linePlacementElem.isNull() )
5773 QDomElement vendorOptionElem = textSymbolizerElem.firstChildElement( u
"VendorOption"_s );
5774 while ( !vendorOptionElem.isNull() && vendorOptionElem.localName() ==
"VendorOption"_L1 )
5776 QString optionName = vendorOptionElem.attribute( u
"name"_s );
5777 QString optionValue;
5778 if ( vendorOptionElem.firstChild().nodeType() == QDomNode::TextNode )
5780 optionValue = vendorOptionElem.firstChild().nodeValue();
5784 if ( vendorOptionElem.firstChild().nodeType() == QDomNode::ElementNode && vendorOptionElem.firstChild().localName() ==
"Literal"_L1 )
5787 optionValue = vendorOptionElem.firstChild().firstChild().nodeValue();
5791 QgsDebugError( u
"unexpected child of %1 named %2"_s.arg( vendorOptionElem.localName(), optionName ) );
5795 if ( !optionName.isEmpty() && !optionValue.isEmpty() )
5797 vendorOptions[optionName] = optionValue;
5800 vendorOptionElem = vendorOptionElem.nextSiblingElement();
5802 if ( !vendorOptions.isEmpty() )
5804 for ( QgsStringMap::iterator it = vendorOptions.begin(); it != vendorOptions.end(); ++it )
5806 if ( it.key() ==
"underlineText"_L1 && it.value() ==
"true"_L1 )
5808 font.setUnderline(
true );
5811 else if ( it.key() ==
"strikethroughText"_L1 && it.value() ==
"true"_L1 )
5813 font.setStrikeOut(
true );
5816 else if ( it.key() ==
"maxDisplacement"_L1 )
5820 else if ( it.key() ==
"followLine"_L1 && it.value() ==
"true"_L1 )
5831 else if ( it.key() ==
"maxAngleDelta"_L1 )
5834 double angle = it.value().toDouble( &ok );
5842 else if ( it.key() ==
"conflictResolution"_L1 && it.value() ==
"false"_L1 )
5846 else if ( it.key() ==
"forceLeftToRight"_L1 && it.value() ==
"false"_L1 )
5850 else if ( it.key() ==
"group"_L1 && it.value() ==
"yes"_L1 )
5854 else if ( it.key() ==
"labelAllGroup"_L1 && it.value() ==
"true"_L1 )
5870 return mEditFormConfig;
5881 mEditFormConfig.onRelationsLoaded();
5891 if ( config.isEmpty() )
5927 if ( !mDiagramLayerSettings )
5929 *mDiagramLayerSettings = s;
5937 QString myMetadata = u
"<html><head></head>\n<body>\n"_s;
5942 myMetadata += u
"<h1>"_s + tr(
"Information from provider" ) + u
"</h1>\n<hr>\n"_s;
5943 myMetadata +=
"<table class=\"list-view\">\n"_L1;
5948 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Storage" ) + u
"</td><td>"_s +
storageType() + u
"</td></tr>\n"_s;
5954 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Comment" ) + u
"</td><td>"_s +
dataComment() + u
"</td></tr>\n"_s;
5960 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Encoding" ) + u
"</td><td>"_s + provider->encoding() + u
"</td></tr>\n"_s;
5961 myMetadata += provider->htmlMetadata();
5975 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Geometry type" ) + u
"</td><td>"_s + typeString + u
"</td></tr>\n"_s;
5981 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Geometry column" ) + u
"</td><td>"_s + provider->geometryColumnName() + u
"</td></tr>\n"_s;
5988 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Extent" ) + u
"</td><td>"_s + extentAsStr + u
"</td></tr>\n"_s;
5992 QLocale locale = QLocale();
5993 locale.setNumberOptions( locale.numberOptions() &= ~QLocale::NumberOption::OmitGroupSeparator );
5994 myMetadata += u
"<tr><td class=\"highlight\">"_s
5995 + tr(
"Feature count" )
5998 + u
"</td></tr>\n"_s;
6001 myMetadata +=
"</table>\n<br><br>"_L1;
6010 myMetadata += u
"<h1>"_s + tr(
"Identification" ) + u
"</h1>\n<hr>\n"_s;
6011 myMetadata += htmlFormatter.identificationSectionHtml();
6012 myMetadata +=
"<br><br>\n"_L1;
6015 myMetadata += u
"<h1>"_s + tr(
"Extent" ) + u
"</h1>\n<hr>\n"_s;
6016 myMetadata += htmlFormatter.extentSectionHtml(
isSpatial() );
6017 myMetadata +=
"<br><br>\n"_L1;
6020 myMetadata += u
"<h1>"_s + tr(
"Access" ) + u
"</h1>\n<hr>\n"_s;
6021 myMetadata += htmlFormatter.accessSectionHtml();
6022 myMetadata +=
"<br><br>\n"_L1;
6025 myMetadata += u
"<h1>"_s + tr(
"Fields" ) + u
"</h1>\n<hr>\n<table class=\"list-view\">\n"_s;
6029 if ( !pkAttrList.isEmpty() )
6031 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Primary key attributes" ) + u
"</td><td>"_s;
6032 const auto constPkAttrList = pkAttrList;
6033 for (
int idx : constPkAttrList )
6037 myMetadata +=
"</td></tr>\n"_L1;
6043 myMetadata += u
"<tr><td class=\"highlight\">"_s + tr(
"Count" ) + u
"</td><td>"_s + QString::number( myFields.
size() ) + u
"</td></tr>\n"_s;
6045 myMetadata +=
"</table>\n<br><table width=\"100%\" class=\"tabular-view\">\n"_L1;
6046 myMetadata +=
"<tr><th>"_L1 + tr(
"Field" ) +
"</th><th>"_L1 + tr(
"Type" ) +
"</th><th>"_L1 + tr(
"Length" ) +
"</th><th>"_L1 + tr(
"Precision" ) +
"</th><th>"_L1 + tr(
"Comment" ) +
"</th></tr>\n"_L1;
6048 for (
int i = 0; i < myFields.
size(); ++i )
6053 rowClass = u
"class=\"odd-row\""_s;
6054 myMetadata +=
"<tr "_L1
6061 + QString::number( myField.
length() )
6063 + QString::number( myField.
precision() )
6066 +
"</td></tr>\n"_L1;
6070 myMetadata +=
"</table>\n<br><br>"_L1;
6073 myMetadata += u
"<h1>"_s + tr(
"Contacts" ) + u
"</h1>\n<hr>\n"_s;
6074 myMetadata += htmlFormatter.contactsSectionHtml();
6075 myMetadata +=
"<br><br>\n"_L1;
6078 myMetadata += u
"<h1>"_s + tr(
"Links" ) + u
"</h1>\n<hr>\n"_s;
6079 myMetadata += htmlFormatter.linksSectionHtml();
6080 myMetadata +=
"<br><br>\n"_L1;
6083 myMetadata += u
"<h1>"_s + tr(
"History" ) + u
"</h1>\n<hr>\n"_s;
6084 myMetadata += htmlFormatter.historySectionHtml();
6085 myMetadata +=
"<br><br>\n"_L1;
6089 myMetadata +=
"\n</body>\n</html>\n"_L1;
6093void QgsVectorLayer::invalidateSymbolCountedFlag()
6097 mSymbolFeatureCounted =
false;
6100void QgsVectorLayer::onFeatureCounterCompleted()
6105 mFeatureCounter =
nullptr;
6108void QgsVectorLayer::onFeatureCounterTerminated()
6112 mFeatureCounter =
nullptr;
6115void QgsVectorLayer::onJoinedFieldsChanged()
6132void QgsVectorLayer::onFeatureDeleted(
QgsFeatureId fid )
6138 if ( mEditCommandActive || mCommitChangesActive )
6140 mDeletedFids << fid;
6144 mSelectedFeatureIds.remove( fid );
6151void QgsVectorLayer::onRelationsLoaded()
6155 mEditFormConfig.onRelationsLoaded();
6158void QgsVectorLayer::onSymbolsCounted()
6162 if ( mFeatureCounter )
6164 mSymbolFeatureCounted =
true;
6165 mSymbolFeatureCountMap = mFeatureCounter->symbolFeatureCountMap();
6166 mSymbolFeatureIdMap = mFeatureCounter->symbolFeatureIdMap();
6176 return p->relationManager()->referencingRelations(
this, idx );
6185 return mWeakRelations;
6192 mWeakRelations = relations;
6201 QString joinKey = mAuxiliaryLayerKey;
6202 if ( !key.isEmpty() )
6205 if ( storage.
isValid() && !joinKey.isEmpty() )
6230 mAuxiliaryLayerKey.clear();
6232 if ( mAuxiliaryLayer )
6245 mAuxiliaryLayer.reset( alayer );
6246 if ( mAuxiliaryLayer )
6247 mAuxiliaryLayer->setParent(
this );
6255 return mAuxiliaryLayer.get();
6262 return mAuxiliaryLayer.get();
6269 if ( mDataProvider )
6274void QgsVectorLayer::emitDataChanged()
6278 if ( mDataChangedFired )
6285 if (
QgsVectorLayer *layerWeDependUpon = qobject_cast<QgsVectorLayer *>( sender() ); layerWeDependUpon && layerWeDependUpon->mCommitChangesActive )
6290 mDataChangedFired =
true;
6292 mDataChangedFired =
false;
6299 QSet<QgsMapLayerDependency> deps;
6300 const auto constODeps = oDeps;
6307 QSet<QgsMapLayerDependency> toAdd = deps -
dependencies();
6327 if ( mDataProvider )
6351 if ( !toAdd.isEmpty() )
6361 if ( fieldIndex < 0 || fieldIndex >= mFields.count() || !mDataProvider )
6369 constraints |= mDataProvider->fieldConstraints( mFields.fieldOriginIndex( fieldIndex ) );
6379 QMap< QgsFieldConstraints::Constraint, QgsFieldConstraints::ConstraintStrength > m;
6381 if ( fieldIndex < 0 || fieldIndex >= mFields.count() )
6384 QString
name = mFields.at( fieldIndex ).name();
6387 for ( ; conIt != mFieldConstraintStrength.constEnd(); ++conIt )
6389 if ( conIt.key().first ==
name )
6391 m[conIt.key().second] = mFieldConstraintStrength.value( conIt.key() );
6402 if ( index < 0 || index >= mFields.count() )
6405 QString
name = mFields.at( index ).name();
6409 constraints |= constraint;
6410 mFieldConstraints.insert(
name, constraints );
6412 mFieldConstraintStrength.insert( qMakePair(
name, constraint ), strength );
6421 if ( index < 0 || index >= mFields.count() )
6424 QString
name = mFields.at( index ).name();
6428 constraints &= ~constraint;
6429 mFieldConstraints.insert(
name, constraints );
6431 mFieldConstraintStrength.remove( qMakePair(
name, constraint ) );
6440 if ( index < 0 || index >= mFields.count() )
6443 return mFields.at( index ).constraints().constraintExpression();
6450 if ( index < 0 || index >= mFields.count() )
6453 return mFields.at( index ).constraints().constraintDescription();
6460 if ( index < 0 || index >= mFields.count() )
6463 if ( expression.isEmpty() )
6465 mFieldConstraintExpressions.remove( mFields.at( index ).name() );
6469 mFieldConstraintExpressions.insert( mFields.at( index ).name(), qMakePair( expression, description ) );
6478 if ( index < 0 || index >= mFields.count() )
6481 mFieldConfigurationFlags.insert( mFields.at( index ).name(),
flags );
6489 if ( index < 0 || index >= mFields.count() )
6492 flags.setFlag( flag, active );
6500 if ( index < 0 || index >= mFields.count() )
6503 return mFields.at( index ).configurationFlags();
6510 if ( index < 0 || index >= mFields.count() )
6514 mFieldWidgetSetups.remove( mFields.at( index ).name() );
6516 mFieldWidgetSetups.insert( mFields.at( index ).name(), setup );
6524 if ( index < 0 || index >= mFields.count() )
6527 return mFields.at( index ).editorWidgetSetup();
6537 if (
customProperty( u
"labeling/enabled"_s, QVariant(
false ) ).toBool() )
6541 settings.readFromLayerCustomProperties(
this );
6548 for (
const QString &key : constCustomPropertyKeys )
6550 if ( key.startsWith(
"labeling/"_L1 ) )
6562 return mAllowCommit;
6580 return mGeometryOptions.get();
6594 return mReadExtentFromXml;
6597void QgsVectorLayer::onDirtyTransaction(
const QString &sql,
const QString &name )
6602 if ( tr && mEditBuffer )
6604 qobject_cast<QgsVectorLayerEditPassthrough *>( mEditBuffer )->update( tr, sql,
name );
6610 QList<QgsVectorLayer *> layers;
6611 QMap<QgsVectorLayer *, QgsFeatureIds>::const_iterator i;
6614 if ( includeAuxiliaryLayers || !qobject_cast< QgsAuxiliaryLayer * >( i.key() ) )
6615 layers.append( i.key() );
Provides global constants and enumerations for use throughout the application.
@ Action
Expression functions.
@ FormInitCode
Map layers' action.
@ SelectAtId
Fast access to features using their ID.
@ CreateRenderer
Provider can create feature renderers using backend-specific formatting information....
@ CreateLabeling
Provider can set labeling settings using backend-specific formatting information. Since QGIS 3....
@ ReadLayerMetadata
Provider can read layer metadata from data store. Since QGIS 3.0. See QgsDataProvider::layerMetadata(...
@ DeleteFeatures
Allows deletion of features.
QFlags< VectorRenderingSimplificationFlag > VectorRenderingSimplificationFlags
Simplification flags for vector feature rendering.
@ 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.
SpatialIndexPresence
Enumeration of spatial index presence states.
@ Unknown
Spatial index presence cannot be determined, index may or may not exist.
VectorRenderingSimplificationFlag
Simplification flags for vector feature rendering.
@ NoSimplification
No simplification can be applied.
@ 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.
QFlags< VectorLayerTypeFlag > VectorLayerTypeFlags
Vector layer type flags.
VectorSimplificationAlgorithm
Simplification algorithms for vector features.
@ Distance
The simplification uses the distance between points to remove duplicate points.
@ File
Load the Python code from an external file.
@ Environment
Use the Python code available in the Python environment.
@ NoSource
Do not use Python code at all.
@ Dialog
Use the Python code provided in the dialog.
@ ExactIntersect
Use exact geometry intersection (slower) instead of bounding boxes.
@ SubsetOfAttributes
Fetch only a subset of attributes (setSubsetOfAttributes sets this flag).
@ NoGeometry
Geometry is not required. It may still be returned if e.g. required for a filter condition.
@ FastExtent3D
Provider's 3D extent retrieval via QgsDataProvider::extent3D() is always guaranteed to be trivial/fas...
@ FastExtent2D
Provider's 2D extent retrieval via QgsDataProvider::extent() is always guaranteed to be trivial/fast ...
@ BufferedGroups
Buffered transactional editing means that all editable layers in the buffered transaction group are t...
@ OpenUrl
Open URL action.
@ SubmitUrlMultipart
POST data to an URL using "multipart/form-data".
@ Windows
Windows specific.
@ SubmitUrlEncoded
POST data to an URL, using "application/x-www-form-urlencoded" or "application/json" if the body is v...
FieldDomainMergePolicy
Merge policy for field domains.
@ UnsetField
Clears the field value so that the data provider backend will populate using any backend triggers or ...
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.
FieldDuplicatePolicy
Duplicate policy for fields.
@ Duplicate
Duplicate original value.
static const float DEFAULT_MAPTOPIXEL_THRESHOLD
Default threshold between map coordinates and device coordinates for map2pixel simplification.
QFlags< DataProviderReadFlag > DataProviderReadFlags
Flags which control data provider construction.
FeatureAvailability
Possible return value for QgsFeatureSource::hasFeatures() to determine if a source is empty.
@ FeaturesMaybeAvailable
There may be features available in this source.
@ FeaturesAvailable
There is at least one feature available in this source.
@ NoFeaturesAvailable
There are certainly no features available in this source.
@ Provider
Field originates from the underlying data provider of the vector layer.
@ Edit
Field has been temporarily added in editing mode.
@ Unknown
The field origin has not been specified.
@ Expression
Field is calculated from an expression.
@ Join
Field originates from a joined layer.
RenderUnit
Rendering size units.
@ Points
Points (e.g., for font sizes).
@ LoadDefaultStyle
Reset the layer's style to the default for the datasource.
@ ForceReadOnly
Open layer in a read-only mode.
Aggregate
Available aggregates to calculate.
VertexMarkerType
Editing vertex markers, used for showing vertices during a edit operation.
@ SemiTransparentCircle
Semi-transparent circle marker.
VectorEditResult
Specifies the result of a vector layer edit operation.
@ Success
Edit operation was successful.
@ InvalidLayer
Edit failed due to invalid layer.
WkbType
The WKB type describes the number of dimensions a geometry has.
FieldConfigurationFlag
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.
@ NoFlag
No flag is defined.
@ HideFromWms
Field is not available if layer is served as WMS from QGIS server.
@ AllowOverlapIfRequired
Avoids overlapping labels when possible, but permit overlaps if labels for features cannot otherwise ...
QFlags< FieldConfigurationFlag > FieldConfigurationFlags
Configuration flags for fields These flags are meant to be user-configurable and are not describing a...
@ AlwaysAllowUpsideDown
Show upside down for all labels, including dynamic ones.
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...
static QgsAbstractVectorLayerLabeling * create(const QDomElement &element, const QgsReadWriteContext &context)
Try to create instance of an implementation based on the XML data.
Storage and management of actions associated with a layer.
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.
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 ...
static QgsNetworkContentFetcherRegistry * networkContentFetcherRegistry()
Returns the application's network content registry used for fetching temporary files during QGIS sess...
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.
A container for configuration of the attribute table.
void update(const QgsFields &fields)
Update the configuration with the given fields.
Allows managing the auxiliary storage for a vector layer.
QgsVectorLayerJoinInfo joinInfo() const
Returns information to use for joining with primary key and so on.
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.
A 3-dimensional box composed of x, y, z coordinates.
QString toString(int precision=16) const
Returns a string representation of form xmin,ymin,zmin : xmax,ymax,zmax Coordinates will be truncated...
bool isEmpty() const
Returns true if the box is empty.
Holds conditional style information for a layer.
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
Returns true if the curve is closed.
QgsCurve * clone() const override=0
Clones the geometry by performing a deep copy.
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 dataSourceUri(bool expandAuthConfig=false) const
Gets the data source specification.
Stores the component parts of a data source URI (e.g.
bool useEstimatedMetadata() const
Returns true if estimated metadata should be used for the connection.
Provides a container for managing client side default values for fields.
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.
@ PositionY
Y-coordinate data defined diagram position.
@ Show
Whether to show the diagram.
Evaluates and returns the diagram settings relating to a diagram for a specific feature.
A embedded script entity for QgsObjectEntityVisitorInterface.
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 writeXml(QDomNode &layer_node, QDomDocument &document) const
Saves expressions to xml under the layer node.
An expression node which takes its value from a feature's field.
QString name() const
The name of the column.
Handles 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)
Fetch next feature and stores in f, returns true on success.
bool close()
Call to end the iteration.
An interface for objects which generate feature renderers for vector layers.
Abstract base class for all 2D vector feature renderers.
static QgsFeatureRenderer * defaultRenderer(Qgis::GeometryType geomType)
Returns a new renderer - used by default in vector layers.
static QgsFeatureRenderer * load(QDomElement &symbologyElem, const QgsReadWriteContext &context)
create a renderer from XML element
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 ...
Wraps a request for features to a vector layer (or directly its vector data provider).
QgsFeatureRequest & setFlags(Qgis::FeatureRequestFlags flags)
Sets flags that affect how features will be fetched.
QgsFeatureRequest & setFilterFids(const QgsFeatureIds &fids)
Sets the feature IDs that should 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.
QgsFeatureRequest & setExpressionContext(const QgsExpressionContext &context)
Sets the expression context used to evaluate filter expressions.
QgsFeatureRequest & setFilterFid(QgsFeatureId fid)
Sets the feature ID that should be fetched.
virtual QgsFeatureIds allFeatureIds() const
Returns a list of all feature IDs for features present in the source.
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
Q_INVOKABLE 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.
Q_INVOKABLE 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
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.
ConstraintOrigin constraintOrigin(Constraint constraint) const
Returns the origin of a field constraint, or ConstraintOriginNotSet if the constraint is not present ...
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().
void setConstraint(Constraint constraint, ConstraintOrigin origin=ConstraintOriginLayer)
Sets a constraint on the field.
QFlags< Constraint > Constraints
Encapsulate a field in an attribute table or data source.
QString typeName() const
Gets the field type.
QString displayNameWithAlias() const
Returns the name to use when displaying this field and adds the alias in parenthesis if it is defined...
Container of fields for a vector layer.
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).
Q_INVOKABLE int lookupField(const QString &fieldName) const
Looks up field's index from the field name.
const_iterator constBegin() const noexcept
Returns a const STL-style iterator pointing to the first item in the list.
Contains options to automatically adjust geometries to constraints on a layer.
A geometry is the spatial representation of a feature.
bool isExactlyEqual(const QgsGeometry &geometry, Qgis::GeometryBackend backend=Qgis::GeometryBackend::QGIS) const
Compares the geometry with another geometry using the specified backend.
QgsBox3D boundingBox3D() const
Returns the 3D bounding box of the 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.
Alters the size of rendered diagrams using linear scaling.
static void warning(const QString &msg)
Goes to qWarning.
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 QDomElement writeXml(QDomDocument &doc, const QgsReadWriteContext &context) const
Writes configuration to a DOM element, to be used later with readXml().
static QgsMapLayerLegend * defaultVectorLegend(QgsVectorLayer *vl)
Create new legend implementation for vector layer.
Base class for utility classes that encapsulate information necessary for rendering of map layers.
Base class for storage of map layer selection properties.
Stores style information (renderer, opacity, labeling, diagrams etc.) applicable to a map layer.
Base class for storage of map layer temporal properties.
void readStyleManager(const QDomNode &layerNode)
Read style manager's configuration (if any). To be called by subclasses.
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.
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 Q_INVOKABLE 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.
virtual void setExtent3D(const QgsBox3D &box)
Sets the extent.
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.
static Qgis::DataProviderReadFlags providerReadFlags(const QDomNode &layerNode, QgsMapLayer::ReadFlags layerReadFlags)
Returns provider read flag deduced from layer read flags layerReadFlags and a dom node layerNode that...
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 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.
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 setDataSource(const QString &dataSource, const QString &baseName=QString(), const QString &provider=QString(), bool loadDefaultStyleFlag=false)
Updates the data source of the layer.
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
QgsMapLayer(Qgis::LayerType type=Qgis::LayerType::Vector, const QString &name=QString(), const QString &source=QString())
Constructor for QgsMapLayer.
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.
QString publicSource(bool hidePassword=false) const
Gets a version of the internal layer definition that has sensitive bits removed (for example,...
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.
QFlags< StyleCategory > StyleCategories
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.
std::unique_ptr< QgsDataProvider > mPreloadedProvider
Optionally used when loading a project, it is released when the layer is effectively created.
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.
QgsMapLayer::LayerFlags flags
bool hasScaleBasedVisibility() const
Returns whether scale based visibility is enabled for the layer.
virtual QString getStyleFromDatabase(const QString &styleId, QString &msgError)
Returns the named style corresponding to style id provided.
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 QgsBox3D extent3D() const
Returns the 3D extent of the layer.
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.
void setMapTipsEnabled(bool enabled)
Enable or disable map tips for this layer.
@ FlagReadExtentFromXml
Read extent from xml and skip get extent from provider.
@ 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.
double minimumScale() const
Returns the minimum map scale (i.e.
void repaintRequested(bool deferredUpdate=false)
By emitting this signal the layer tells that either appearance or content have been changed and any v...
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.
void layerModified()
Emitted when modifications has been done on layer.
void setProviderType(const QString &providerType)
Sets the providerType (provider key).
QString customPropertyHtmlMetadata() const
Returns an HTML fragment containing custom property information, for use in the htmlMetadata() method...
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, const char *file=__builtin_FILE(), const char *function=__builtin_FUNCTION(), int line=__builtin_LINE(), Qgis::StringFormat format=Qgis::StringFormat::PlainText)
Adds a message to the log instance (and creates it if necessary).
QFile * localFile(const QString &filePathOrUrl)
Returns a QFile from a local file or to a temporary file previously fetched by the registry.
An interface for classes which can visit various object entity (e.g.
virtual bool visitEmbeddedScript(const QgsEmbeddedScriptEntity &entity, const QgsObjectVisitorContext &context)
Called when the visitor will visit an embedded script entity.
A QgsObjectEntityVisitorInterface context object.
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 Qgis::BlendMode corresponding to a QPainter::CompositionMode.
static QPainter::CompositionMode getCompositionMode(Qgis::BlendMode blendMode)
Returns a QPainter::CompositionMode corresponding to a Qgis::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.
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
Translates a string using the Qt QTranslator mechanism.
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.
bool rollBack(QStringList &rollbackErrors, bool stopEditing=true, QgsVectorLayer *vectorLayer=nullptr)
Stops a current editing operation on vectorLayer and discards any uncommitted edits.
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 an 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.
static QgsProviderRegistry * instance(const QString &pluginPath=QString())
Means of accessing canonical single instance.
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.
Allows entering a context category and takes care of leaving this category on deletion of the class.
A container for the context for various read/write operations on objects.
QgsReadWriteContextCategoryPopper enterCategory(const QString &category, const QString &details=QString()) const
Push a category to the stack.
const QgsProjectTranslator * projectTranslator() const
Returns the project translator.
QgsCoordinateTransformContext transformContext() const
Returns data provider coordinate transform context.
const QgsPathResolver & pathResolver() const
Returns path resolver for conversion between relative and absolute paths.
A rectangle specified with double values.
Q_INVOKABLE QString toString(int precision=16) const
Returns a string representation of form xmin,ymin : xmax,ymax Coordinates will be rounded to the spec...
void set(const QgsPointXY &p1, const QgsPointXY &p2, bool normalize=true)
Sets the rectangle from two QgsPoints.
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.
void setNull()
Mark a rectangle as being null (holding no spatial information).
QList< QgsRelation > referencedRelations(const QgsVectorLayer *layer=nullptr) const
Gets all relations where this layer is the referenced part (i.e.
void relationsLoaded()
Emitted when the relations were loaded after reading a project.
Represents a relationship between two vector layers.
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.
void appendChild(QgsRuleBasedLabeling::Rule *rule)
add child rule, take ownership, sets this as parent
A boolean settings entry.
A template class for enum and flag settings entry.
static QgsSettingsTreeNode * sTreeQgis
Stores settings for use within QGIS.
Renders the diagrams for all features with the same settings.
Holds SLD export options and other information related to SLD export of a QGIS layer style.
void setExtraProperties(const QVariantMap &properties)
Sets the open ended set of properties that can drive/inform the SLD encoding.
QVariantMap extraProperties() const
Returns the open ended set of properties that can drive/inform the SLD encoding.
Renders diagrams using mixed diagram render types.
Manages stored expressions regarding creation, modification and storing in the project.
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....
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.
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.
static QString threadDescription(QThread *thread)
Returns a descriptive identifier for a thread.
Allows creation of a multi-layer database-side transaction.
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, bool silenceNullWarnings=false)
Returns true if the specified variant should be considered a NULL value.
Base class for vector data providers.
static const int EditingCapabilities
Bitmask of all provider's editing capabilities.
virtual QString geometryColumnName() const
Returns the name of the column storing geometry, if applicable.
void raiseError(const QString &msg) const
Signals an error in this provider.
virtual void handlePostCloneOperations(QgsVectorDataProvider *source)
Handles any post-clone operations required after this vector data provider was cloned from the source...
virtual QgsTransaction * transaction() const
Returns the transaction this data provider is included in, if any.
void committedAttributesDeleted(const QString &layerId, const QgsAttributeList &deletedAttributes)
Emitted after attribute deletion has been committed to the layer.
void committedAttributeValuesChanges(const QString &layerId, const QgsChangedAttributesMap &changedAttributesValues)
Emitted after feature attribute value changes have been committed to the layer.
void geometryChanged(QgsFeatureId fid, const QgsGeometry &geom)
Emitted when a feature's geometry is changed.
void committedAttributesAdded(const QString &layerId, const QList< QgsField > &addedAttributes)
Emitted after attribute addition has been committed to the layer.
void committedFeaturesAdded(const QString &layerId, const QgsFeatureList &addedFeatures)
Emitted after feature addition has been committed to the layer.
void featureDeleted(QgsFeatureId fid)
Emitted when a feature was deleted from the buffer.
void attributeAdded(int idx)
Emitted when an attribute was added to the buffer.
void committedGeometriesChanges(const QString &layerId, const QgsGeometryMap &changedGeometries)
Emitted after feature geometry changes have been committed to the layer.
void attributeValueChanged(QgsFeatureId fid, int idx, const QVariant &value)
Emitted when a feature's attribute value has been changed.
void attributeDeleted(int idx)
Emitted when an attribute was deleted from the buffer.
void featureAdded(QgsFeatureId fid)
Emitted when a feature has been added to the buffer.
void layerModified()
Emitted when modifications has been done on layer.
void committedFeaturesRemoved(const QString &layerId, const QgsFeatureIds &deletedFeatureIds)
Emitted after feature removal has been committed to the layer.
Contains utility functions for editing vector layers.
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.
QgsVectorLayerElevationProperties * clone() const override
Creates a clone of the properties.
Counts the features in a QgsVectorLayer in task.
A feature iterator which iterates over features from a QgsVectorLayer.
Manages joined fields for a vector layer.
bool containsJoins() const
Quick way to test if there is any join at all.
void joinedFieldsChanged()
Emitted whenever the list of joined fields changes (e.g.
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.
Implementation of layer selection properties for vector layers.
QgsVectorLayerSelectionProperties * clone() const override
Creates a clone of the properties.
Basic implementation of the labeling interface.
Implementation of map layer temporal properties for vector layers.
Contains settings which reflect the context in which vector layer tool operations should be considere...
QgsExpressionContext * expressionContext() const
Returns the optional expression context used by the vector layer tools.
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...
static QgsFeatureIds filterValidFeatureIds(const QgsVectorLayer *layer, const QgsFeatureIds &featureIds)
Filters a set of feature IDs to only include those that exist in the layer.
Represents a vector layer which manages a vector based dataset.
void setLabeling(QgsAbstractVectorLayerLabeling *labeling)
Sets labeling configuration.
Q_INVOKABLE QString attributeDisplayName(int index) const
Convenience function that returns the attribute alias if defined or the field name else.
bool writeSymbology(QDomNode &node, QDomDocument &doc, QString &errorMessage, const QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories=QgsMapLayer::AllStyleCategories) const final
Write the style for the layer into the document provided.
QSet< QgsMapLayerDependency > dependencies() const final
Gets the list of dependencies.
int addExpressionField(const QString &exp, const QgsField &fld)
Add a new field which is calculated by the expression specified.
Q_INVOKABLE void selectByRect(const QgsRectangle &rect, Qgis::SelectBehavior behavior=Qgis::SelectBehavior::SetSelection)
Selects features found within the search rectangle (in layer's coordinates).
void committedFeaturesAdded(const QString &layerId, const QgsFeatureList &addedFeatures)
Emitted when features are added to the provider if not in transaction mode.
Q_DECL_DEPRECATED Qgis::GeometryOperationResult addPart(const QList< QgsPointXY > &ring)
Adds a new part polygon to a multipart feature.
static const QgsSettingsEntryEnumFlag< Qgis::VectorRenderingSimplificationFlags > * settingsSimplifyDrawingHints
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 isModified() const override
Returns true if the provider has been modified since the last commit.
bool isEditable() const final
Returns true if the provider is in editing mode.
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 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.
Q_INVOKABLE QVariant minimumValue(int index) const final
Returns the minimum value for an attribute column or an invalid variant in case of error.
void beforeRemovingExpressionField(int idx)
Will be emitted, when an expression field is going to be deleted from this vector layer.
Q_INVOKABLE bool deleteFeatures(const QgsFeatureIds &fids, QgsVectorLayer::DeleteContext *context=nullptr)
Deletes a set of features from the layer (but does not commit it).
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.
void setFieldConfigurationFlags(int index, Qgis::FieldConfigurationFlags flags)
Sets the configuration flags of the field at given index.
Q_INVOKABLE QVariant maximumValue(int index) const final
Returns the maximum value for an attribute column or an invalid variant in case of error.
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.
QgsVectorLayer(const QString &path=QString(), const QString &baseName=QString(), const QString &providerLib="ogr", const QgsVectorLayer::LayerOptions &options=QgsVectorLayer::LayerOptions())
Constructor - creates a vector layer.
QgsMapLayerTemporalProperties * temporalProperties() override
Returns the layer's temporal properties.
QgsExpressionContext createExpressionContext() const final
This method needs to be reimplemented in all classes which implement this interface and return an exp...
Q_INVOKABLE bool changeAttributeValue(QgsFeatureId fid, int field, const QVariant &newValue, const QVariant &oldValue=QVariant(), bool skipDefaultValues=false, QgsVectorLayerToolsContext *context=nullptr)
Changes an attribute value for a feature (but does not immediately commit the changes).
Q_DECL_DEPRECATED Qgis::GeometryOperationResult splitFeatures(const QVector< QgsPointXY > &splitLine, bool topologicalEditing=false)
Splits features cut by the given line.
QgsDefaultValue defaultValueDefinition(int index) const
Returns the definition of the expression used when calculating the default value for a field.
QgsVectorLayerFeatureCounter * countSymbolFeatures(bool storeSymbolFids=false)
Count features for symbols.
QPainter::CompositionMode featureBlendMode() const
Returns the current blending mode for features.
QString constraintExpression(int index) const
Returns the constraint expression for for a specified field index, if set.
Q_INVOKABLE bool addAttribute(const QgsField &field)
Add an attribute field (but does not commit it) returns true if the field was added.
void attributeAdded(int idx)
Will be emitted, when a new attribute has been added to this vector layer.
QString capabilitiesString() const
Capabilities for this layer, comma separated and translated.
void deselect(QgsFeatureId featureId)
Deselects feature by its ID.
void allowCommitChanged()
Emitted whenever the allowCommit() 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,...
QgsBox3D extent3D() const final
Returns the 3D extent of the layer.
const QgsDiagramLayerSettings * diagramLayerSettings() const
void setFieldConstraint(int index, QgsFieldConstraints::Constraint constraint, QgsFieldConstraints::ConstraintStrength strength=QgsFieldConstraints::ConstraintStrengthHard)
Sets a constraint for a specified field index.
Q_INVOKABLE void invertSelectionInRectangle(const QgsRectangle &rect)
Inverts selection of features found within the search rectangle (in layer's coordinates).
bool loadAuxiliaryLayer(const QgsAuxiliaryStorage &storage, const QString &key=QString())
Loads the auxiliary layer for this vector layer.
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...
QgsAbstractProfileGenerator * createProfileGenerator(const QgsProfileRequest &request) override
Given a profile request, returns a new profile generator ready for generating elevation profiles.
bool readSymbology(const QDomNode &layerNode, QString &errorMessage, QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories=QgsMapLayer::AllStyleCategories) final
Read the symbology for the current layer from the DOM node supplied.
Q_INVOKABLE QgsRectangle boundingBoxOfSelected() const
Returns the bounding box of the selected features. If there is no selection, QgsRectangle(0,...
bool isSpatial() const final
Returns true if this is a geometry layer and false in case of NoGeometry (table only) or UnknownGeome...
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.
void removeFeatureRendererGenerator(const QString &id)
Removes the feature renderer with matching id from the layer.
Q_INVOKABLE bool deleteFeature(QgsFeatureId fid, QgsVectorLayer::DeleteContext *context=nullptr)
Deletes a feature from the layer (but does not commit it).
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.
QVariant aggregate(Qgis::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.
QgsRectangle sourceExtent() const final
Returns the extent of all geometries from the source.
QgsFieldConstraints::Constraints fieldConstraints(int fieldIndex) const
Returns any constraints which are present for a specified field index.
static const QgsSettingsEntryEnumFlag< Qgis::VectorSimplificationAlgorithm > * settingsSimplifyAlgorithm
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.
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.
bool setDependencies(const QSet< QgsMapLayerDependency > &layers) final
Sets the list of dependencies.
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 setFieldMergePolicy(int index, Qgis::FieldDomainMergePolicy policy)
Sets a merge policy for the field with the specified index.
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
void reload() final
Synchronises with changes in the datasource.
long long featureCount() const final
Returns feature count including changes which have not yet been committed If you need only the count ...
~QgsVectorLayer() override
QgsRectangle extent() const final
Returns the extent of the layer.
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.
bool hasMapTips() const final
Returns true if the layer contains map tips.
Q_INVOKABLE Qgis::WkbType wkbType() const final
Returns the WKBType or WKBUnknown in case of error.
void setExtent(const QgsRectangle &rect) final
Sets the extent.
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.
QgsBox3D sourceExtent3D() const final
Returns the 3D extent of all geometries from the source.
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.
Qgis::FeatureAvailability hasFeatures() const final
Determines if this vector layer has features.
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.
bool writeStyle(QDomNode &node, QDomDocument &doc, QString &errorMessage, const QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories=QgsMapLayer::AllStyleCategories) const final
Write just the symbology information for the layer into the document.
void setProviderEncoding(const QString &encoding)
Sets the text encoding of the data provider.
Q_DECL_DEPRECATED 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 Q_INVOKABLE bool deleteAttribute(int attr)
Deletes an attribute field (but does not commit it).
static const QgsSettingsEntryBool * settingsSimplifyLocal
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...
bool simplifyDrawingCanbeApplied(const QgsRenderContext &renderContext, Qgis::VectorRenderingSimplificationFlag simplifyHint) const
Returns whether the VectorLayer can apply the specified simplification hint.
QString htmlMetadata() const final
Obtain a formatted HTML string containing assorted metadata for this layer.
QgsMapLayerElevationProperties * elevationProperties() override
Returns the layer's elevation properties.
bool removeJoin(const QString &joinLayerId)
Removes a vector layer join.
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.
QStringList commitErrors() const
Returns a list containing any error messages generated when attempting to commit changes to the layer...
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...
QString storageType() const
Returns the permanent storage type for this layer as a friendly name.
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...
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
QgsExpressionContextScope * createExpressionContextScope() const final
This method needs to be reimplemented in all classes which implement this interface and return an exp...
QgsGeometryOptions * geometryOptions() const
Configuration and logic to apply automatically on any edit happening on this layer.
QgsStringMap attributeAliases() const
Returns a map of field name to attribute alias.
Q_INVOKABLE int translateFeature(QgsFeatureId featureId, double dx, double dy)
Translates feature by dx, dy.
virtual void updateExtents(bool force=false)
Update the extents for the layer.
void attributeDeleted(int idx)
Will be emitted, when an attribute has been deleted from this vector layer.
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.
Qgis::FieldConfigurationFlags fieldConfigurationFlags(int index) const
Returns the configuration flags of the field at given index.
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.
QgsFeatureIterator getSelectedFeatures(QgsFeatureRequest request=QgsFeatureRequest()) const
Returns an iterator of the selected features.
void setEditorWidgetSetup(int index, const QgsEditorWidgetSetup &setup)
Sets the editor widget setup for the field at the specified index.
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.
QString sourceName() const final
Returns a friendly display name for the source.
bool readStyle(const QDomNode &node, QString &errorMessage, QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories=QgsMapLayer::AllStyleCategories) final
Read the style for the current layer from the DOM node supplied.
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...
void setFieldConfigurationFlag(int index, Qgis::FieldConfigurationFlag flag, bool active)
Sets the given configuration flag for the field at given index to be active or not.
void setFieldDuplicatePolicy(int index, Qgis::FieldDuplicatePolicy policy)
Sets a duplicate policy for the field with the specified index.
bool setReadOnly(bool readonly=true)
Makes layer read-only (editing disabled) or not.
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 resolveReferences(QgsProject *project) final
Resolves references to other layers (kept as layer IDs after reading XML) into layer objects.
void reselect()
Reselects the previous set of selected features.
void select(QgsFeatureId featureId)
Selects feature by its ID.
QgsEditorWidgetSetup editorWidgetSetup(int index) const
Returns the editor widget setup for the field at the specified index.
bool readSld(const QDomNode &node, QString &errorMessage) final
QgsMapLayerRenderer * createMapRenderer(QgsRenderContext &rendererContext) final
Returns new instance of QgsMapLayerRenderer that will be used for rendering of given context.
QgsFeatureIterator getFeatures(const QgsFeatureRequest &request=QgsFeatureRequest()) const final
Queries the layer for features specified in request.
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.
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.
QgsCoordinateReferenceSystem sourceCrs() const final
Returns the coordinate reference system for features in the source.
void readOnlyChanged()
Emitted when the read only state of this layer is changed.
void removeExpressionField(int index)
Removes an expression field.
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.
Q_INVOKABLE void selectByIds(const QgsFeatureIds &ids, Qgis::SelectBehavior behavior=Qgis::SelectBehavior::SetSelection, bool validateIds=false)
Selects matching features using a list of feature IDs.
Q_INVOKABLE 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.
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.
void afterRollBack()
Emitted after changes are rolled back.
bool writeXml(QDomNode &layer_node, QDomDocument &doc, const QgsReadWriteContext &context) const final
Writes vector layer specific state to project file Dom node.
void setDiagramLayerSettings(const QgsDiagramLayerSettings &s)
bool readXml(const QDomNode &layer_node, QgsReadWriteContext &context) final
Reads vector layer specific state from project file Dom node.
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.
Q_INVOKABLE 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.
Q_INVOKABLE 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 setExtent3D(const QgsBox3D &rect) final
Sets the extent.
const QList< QgsVectorLayerJoinInfo > vectorJoins() const
Q_INVOKABLE 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.
void beforeRollBack()
Emitted before changes are rolled back.
QgsAttributeList primaryKeyAttributes() const
Returns the list of attributes which make up the layer's primary keys.
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.
bool addFeatures(QgsFeatureList &features, QgsFeatureSink::Flags flags=QgsFeatureSink::Flags()) final
Adds a list of features to the sink.
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.
Q_INVOKABLE QSet< QVariant > uniqueValues(int fieldIndex, int limit=-1) const final
Calculates a list of unique values contained within an attribute in 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.
bool addFeature(QgsFeature &feature, QgsFeatureSink::Flags flags=QgsFeatureSink::Flags()) final
Adds a single feature to the sink.
void beforeModifiedCheck() const
Emitted when the layer is checked for modifications. Use for last-minute additions.
Q_INVOKABLE QgsFeature getFeature(QgsFeatureId fid) const
Queries the layer for the feature with the given id.
Q_INVOKABLE void invertSelection()
Selects not selected features and deselects selected ones.
const QgsDiagramRenderer * diagramRenderer() const
Q_INVOKABLE bool changeAttributeValues(QgsFeatureId fid, const QgsAttributeMap &newValues, const QgsAttributeMap &oldValues=QgsAttributeMap(), bool skipDefaultValues=false, QgsVectorLayerToolsContext *context=nullptr)
Changes attributes' values for a feature (but does not immediately commit the changes).
QgsMapLayerSelectionProperties * selectionProperties() override
Returns the layer's selection properties.
QgsVectorDataProvider * dataProvider() final
Returns the layer's data provider, it may be nullptr.
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
Qgis::SpatialIndexPresence hasSpatialIndex() const override
void setFieldSplitPolicy(int index, Qgis::FieldDomainSplitPolicy policy)
Sets a split policy for the field with the specified index.
@ 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 Qgis::GeometryType geometryType(Qgis::WkbType type)
Returns the geometry type for a WKB type, e.g., both MultiPolygon and CurvePolygon would have a Polyg...
static Q_INVOKABLE QString displayString(Qgis::WkbType type)
Returns a non-translated display string type for a WKB type, e.g., the geometry name used in WKT geom...
static Q_INVOKABLE QString geometryDisplayString(Qgis::GeometryType type)
Returns a display string for a geometry type.
static QDomElement writeVariant(const QVariant &value, QDomDocument &doc)
Write a QVariant to a QDomElement.
static QgsBox3D readBox3D(const QDomElement &element)
Decodes a DOM element to a 3D box.
static QVariant readVariant(const QDomElement &element)
Read a QVariant from a QDomElement.
static 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
#define QgsDebugMsgLevel(str, level)
#define QgsDebugError(str)
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)
QList< int > QgsAttributeList
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.