54#include "moc_qgsmeshlayer.cpp"
57 const QString &baseName,
58 const QString &providerKey,
71 flags |= Qgis::DataProviderReadFlag::LoadDefaultStyle;
73 QgsMeshLayer::setDataSourcePrivate( meshLayerPath, baseName, providerKey, providerOptions,
flags );
86void QgsMeshLayer::createSimplifiedMeshes()
90 if ( mSimplificationSettings.
isEnabled() && !hasSimplifiedMeshes() )
92 const double reductionFactor = mSimplificationSettings.
reductionFactor();
94 QVector<QgsTriangularMesh *> simplifyMeshes =
95 mTriangularMeshes[0]->simplifyMesh( reductionFactor );
97 for (
int i = 0; i < simplifyMeshes.count() ; ++i )
99 mTriangularMeshes.emplace_back( simplifyMeshes[i] );
104bool QgsMeshLayer::hasSimplifiedMeshes()
const
109 return ( mTriangularMeshes.size() > 1 );
115 delete mDataProvider;
122 return mDataProvider;
129 return mDataProvider;
139 options.transformContext = mDataProvider->transformContext();
144 layer->mElevationProperties = mElevationProperties->
clone();
145 layer->mElevationProperties->setParent( layer );
153 for (
const QString &extraDataset : mExtraDatasetUri )
168 return mMeshEditor->extent();
171 return mDataProvider->extent();
184 if ( !mDataProvider )
201 for (
const int index : groupsList )
202 assignDefaultStyleToDatasetGroup( index );
206 if ( !groupsList.isEmpty() )
209 mRendererSettings.setActiveScalarDatasetGroup( 0 );
212 if ( meta.
maximum() == std::numeric_limits<double>::quiet_NaN() &&
213 meta.
minimum() == std::numeric_limits<double>::quiet_NaN() )
222 mRendererSettings.setNativeMeshSettings( meshSettings );
224 for (
const int i : groupsList )
226 assignDefaultStyleToDatasetGroup( i );
245 applyClassificationOnScalarSettings( meta, scalarSettings );
247 mRendererSettings.setScalarSettings( i, scalarSettings );
250 if ( !groupsList.isEmpty() )
261 const int index = mDatasetGroupStore->indexFromGroupName(
name );
270 mDatasetGroupStore->removeDatasetGroup( index );
272 if ( mExtraDatasetUri.contains( groupMetadata.
uri() ) )
274 mExtraDatasetUri.removeOne( groupMetadata.
uri() );
289 if ( mDatasetGroupStore->addPersistentDatasets( path ) )
291 mExtraDatasetUri.append( path );
293 if ( !isTemporalBefore && temporalCapabilities->hasTemporalCapabilities() )
295 mTemporalProperties->setDefaultsFromDataProviderTemporalCapabilities(
296 temporalCapabilities );
300 QDateTime referenceTime = defaultReferenceTime;
301 if ( !defaultReferenceTime.isValid() )
302 referenceTime = QDateTime( QDate::currentDate(), QTime( 0, 0, 0 ), Qt::UTC );
306 mTemporalProperties->setIsActive(
true );
319 if ( mDatasetGroupStore->addDatasetGroup( std::unique_ptr< QgsMeshDatasetGroup >( datasetGroup ) ) )
331 return mDatasetGroupStore->saveDatasetGroup( path, datasetGroupIndex, driver );
338 return mNativeMesh.get();
345 return mNativeMesh.get();
352 for (
const std::unique_ptr<QgsTriangularMesh> &lod : mTriangularMeshes )
354 if ( lod && lod->averageTriangleSize() > minimumTriangleSize )
358 if ( !mTriangularMeshes.empty() )
359 return mTriangularMeshes.back().get();
368 return mTriangularMeshes.size();
375 if ( mTriangularMeshes.empty() )
378 return mTriangularMeshes.front().get();
380 if ( lodIndex >=
int( mTriangularMeshes.size() ) )
381 return mTriangularMeshes.back().get();
383 return mTriangularMeshes.at( lodIndex ).get();
398 if ( mTriangularMeshes.empty() )
401 mTriangularMeshes.emplace_back( baseMesh );
404 if ( mTriangularMeshes[0].get()->update( mNativeMesh.get(), transform ) )
405 mTriangularMeshes.resize( 1 );
407 createSimplifiedMeshes();
414 return mRendererCache.get();
421 return mRendererSettings;
428 const int oldActiveScalar = mRendererSettings.activeScalarDatasetGroup();
429 const int oldActiveVector = mRendererSettings.activeVectorDatasetGroup();
430 mRendererSettings = settings;
432 if ( oldActiveScalar != mRendererSettings.activeScalarDatasetGroup() )
435 if ( oldActiveVector != mRendererSettings.activeVectorDatasetGroup() )
450 return mTimeSettings;
457 mTimeSettings = settings;
466 return QgsMeshLayerUtils::formatTime( hours, mTemporalProperties->referenceTime(), mTimeSettings );
468 return QgsMeshLayerUtils::formatTime( hours, QDateTime(), mTimeSettings );
475 return mDatasetGroupStore->datasetGroupCount();
482 return mDatasetGroupStore->extraDatasetGroupCount();
489 return mDatasetGroupStore->datasetGroupIndexes();
496 return mDatasetGroupStore->enabledDatasetGroupIndexes();
503 return mDatasetGroupStore->datasetGroupMetadata( index );
510 return mDatasetGroupStore->datasetCount( index.
group() );
517 return mDatasetGroupStore->datasetMetadata( index );
524 return mDatasetGroupStore->datasetValue( index, valueIndex );
531 return mDatasetGroupStore->datasetValues( index, valueIndex, count );
538 return mDatasetGroupStore->dataset3dValues( index, faceIndex, count );
545 return mDatasetGroupStore->areFacesActive( index, faceIndex, count );
552 return mDatasetGroupStore->isFaceActive( index, faceIndex );
566 const QgsRectangle searchRectangle( point.
x() - searchRadius, point.
y() - searchRadius, point.
x() + searchRadius, point.
y() + searchRadius );
570 if ( faceIndex >= 0 )
587 const int v1 = face[0], v2 = face[1], v3 = face[2];
592 const double x = QgsMeshLayerUtils::interpolateFromVerticesData( p1, p2, p3, val1.
x(), val2.
x(), val3.
x(), point );
593 double y = std::numeric_limits<double>::quiet_NaN();
596 y = QgsMeshLayerUtils::interpolateFromVerticesData( p1, p2, p3, val1.
y(), val2.
y(), val3.
y(), point );
611 value = block2d.
value( 0 );
641 if ( faceIndex >= 0 )
657 const int selectedIndex = closestEdge( point, searchRadius, projectedPoint );
659 if ( selectedIndex >= 0 )
673 const int v1 = edge.first, v2 = edge.second;
677 const double edgeLength = p1.
distance( p2 );
678 const double dist1 = p1.
distance( projectedPoint.
x(), projectedPoint.
y() );
679 value = QgsMeshLayerUtils::interpolateFromVerticesData( dist1 / edgeLength, val1, val2 );
703 if ( ! mTemporalProperties->isActive() )
706 const QDateTime layerReferenceTime = mTemporalProperties->referenceTime();
707 QDateTime utcTime = timeRange.
begin();
708 if ( utcTime.timeSpec() != Qt::UTC )
709 utcTime.setTimeSpec( Qt::UTC );
710 const qint64 startTime = layerReferenceTime.msecsTo( utcTime );
712 return mDatasetGroupStore->datasetIndexAtTime( startTime, datasetGroupIndex, mTemporalProperties->matchingMethod() );
719 return mDatasetGroupStore->datasetIndexAtTime( relativeTime.
seconds() * 1000, datasetGroupIndex, mTemporalProperties->matchingMethod() );
726 qint64 usedRelativeTime1 = startRelativeTime.
seconds() * 1000;
727 qint64 usedRelativeTime2 = endRelativeTime.
seconds() * 1000;
730 if ( mTemporalProperties->referenceTime().isValid() &&
732 mDataProvider->isValid() &&
733 mTemporalProperties->referenceTime() != mDataProvider->temporalCapabilities()->referenceTime() )
735 usedRelativeTime1 = usedRelativeTime1 + mTemporalProperties->referenceTime().msecsTo( mDataProvider->temporalCapabilities()->referenceTime() );
736 usedRelativeTime2 = usedRelativeTime2 + mTemporalProperties->referenceTime().msecsTo( mDataProvider->temporalCapabilities()->referenceTime() );
739 return mDatasetGroupStore->datasetIndexInTimeInterval( usedRelativeTime1, usedRelativeTime2, datasetGroupIndex );
746 if ( meta.
extraOptions().contains( QStringLiteral(
"classification" ) ) )
750 const QStringList classes = meta.
extraOptions()[QStringLiteral(
"classification" )].split( QStringLiteral(
";;" ) );
753 if ( meta.
extraOptions().contains( QStringLiteral(
"units" ) ) )
754 units = meta.
extraOptions()[ QStringLiteral(
"units" )];
756 QVector<QVector<double>> bounds;
757 for (
const QString &classe : classes )
759 const QStringList boundsStr = classe.split(
',' );
760 QVector<double> bound;
761 for (
const QString &boundStr : boundsStr )
762 bound.append( boundStr.toDouble() );
763 bounds.append( bound );
766 if ( ( bounds.count() == 1 && bounds.first().count() > 2 ) ||
767 ( bounds.count() > 1 ) )
769 const QVector<double> firstClass = bounds.first();
770 const QVector<double> lastClass = bounds.last();
771 const double minValue = firstClass.count() > 1 ? ( firstClass.first() + firstClass.last() ) / 2 : firstClass.first();
772 const double maxValue = lastClass.count() > 1 ? ( lastClass.first() + lastClass.last() ) / 2 : lastClass.first();
773 const double diff = maxValue - minValue;
774 QList<QgsColorRampShader::ColorRampItem> colorRampItemlist;
775 for (
int i = 0; i < bounds.count(); ++i )
777 const QVector<double> &boundClass = bounds.at( i );
778 QgsColorRampShader::ColorRampItem item;
780 if ( !boundClass.isEmpty() )
782 const double scalarValue = ( boundClass.first() + boundClass.last() ) / 2;
783 item.
color = colorRamp->
color( ( scalarValue - minValue ) / diff );
784 if ( i != 0 && i < bounds.count() - 1 )
786 item.
label = QString( (
"%1 - %2 %3" ) ).
787 arg( QString::number( boundClass.first() ) ).
788 arg( QString::number( boundClass.last() ) ).
792 colorRampItemlist.append( item );
795 if ( firstClass.count() == 1 )
796 colorRampItemlist.first().label = QObject::tr(
"below %1 %2" ).
797 arg( QString::number( firstClass.first() ) ).
801 colorRampItemlist.first().label = QString( (
"%1 - %2 %3" ) ).
802 arg( QString::number( firstClass.first() ) ).
803 arg( QString::number( firstClass.last() ) ).
807 if ( lastClass.count() == 1 )
808 colorRampItemlist.last().label = QObject::tr(
"above %1 %2" ).
809 arg( QString::number( lastClass.first() ) ).
813 colorRampItemlist.last().label = QString( (
"%1 - %2 %3" ) ).
814 arg( QString::number( lastClass.first() ) ).
815 arg( QString::number( lastClass.last() ) ).
836 if ( mTemporalProperties->isActive() )
837 return datasetIndexAtTime( timeRange, group >= 0 ? group : mRendererSettings.activeScalarDatasetGroup() );
839 return QgsMeshDatasetIndex( group >= 0 ? group : mRendererSettings.activeScalarDatasetGroup(), mStaticScalarDatasetIndex );
846 if ( mTemporalProperties->isActive() )
847 return datasetIndexAtTime( timeRange, group >= 0 ? group : mRendererSettings.activeVectorDatasetGroup() );
849 return QgsMeshDatasetIndex( group >= 0 ? group : mRendererSettings.activeVectorDatasetGroup(), mStaticVectorDatasetIndex );
852void QgsMeshLayer::fillNativeMesh()
856 Q_ASSERT( !mNativeMesh );
858 mNativeMesh = std::make_unique<QgsMesh>( );
866void QgsMeshLayer::onDatasetGroupsAdded(
const QList<int> &datasetGroupIndexes )
871 for (
int datasetGroupIndex : datasetGroupIndexes )
873 if ( !mRendererSettings.hasSettings( datasetGroupIndex ) )
874 assignDefaultStyleToDatasetGroup( datasetGroupIndex );
881void QgsMeshLayer::onMeshEdited()
885 mRendererCache = std::make_unique<QgsMeshLayerRendererCache>( );
895 return mDatasetGroupStore->datasetGroupTreeItem();
902 mDatasetGroupStore->setDatasetGroupTreeItem( rootItem );
903 updateActiveDatasetGroups();
910 return QgsMeshDatasetIndex( group >= 0 ? group : mRendererSettings.activeVectorDatasetGroup(), mStaticVectorDatasetIndex );
918 mTemporalProperties->setReferenceTime( referenceTime, lDataProvider->temporalCapabilities() );
920 mTemporalProperties->setReferenceTime( referenceTime,
nullptr );
927 mTemporalProperties->setMatchingMethod( matchingMethod );
930int QgsMeshLayer::closestEdge(
const QgsPointXY &point,
double searchRadius,
QgsPointXY &projectedPoint )
const
934 const QgsRectangle searchRectangle( point.
x() - searchRadius, point.
y() - searchRadius, point.
x() + searchRadius, point.
y() + searchRadius );
938 int selectedIndex = -1;
943 double sqrMaxDistFromPoint = pow( searchRadius, 2 );
944 for (
const int edgeIndex : edgeIndexes )
950 const double sqrDist = point.
sqrDistToSegment( vertex1.
x(), vertex1.
y(), vertex2.
x(), vertex2.
y(), projPoint, 0 );
951 if ( sqrDist < sqrMaxDistFromPoint )
953 selectedIndex = edgeIndex;
954 projectedPoint = projPoint;
955 sqrMaxDistFromPoint = sqrDist;
960 return selectedIndex;
963int QgsMeshLayer::closestVertex(
const QgsPointXY &point,
double searchRadius,
QgsPointXY &projectedPoint )
const
968 int selectedIndex = -1;
969 projectedPoint = QgsPointXY();
971 return selectedIndex;
973 const QgsRectangle rectangle( point.
x() - searchRadius, point.
y() - searchRadius, point.
x() + searchRadius, point.
y() + searchRadius );
974 double maxDistance = searchRadius;
976 const QList<int> edgeIndexes = mesh->edgeIndexesForRectangle( rectangle );
977 for (
const int edgeIndex : edgeIndexes )
979 const QgsMeshEdge &edge = mesh->edges().at( edgeIndex );
982 const double dist1 = point.
distance( vertex1 );
983 const double dist2 = point.
distance( vertex2 );
984 if ( dist1 < maxDistance )
987 projectedPoint = vertex1;
988 selectedIndex = edge.first;
990 if ( dist2 < maxDistance )
993 projectedPoint = vertex2;
994 selectedIndex = edge.second;
999 const QList<int> faceIndexes = mesh->faceIndexesForRectangle( rectangle );
1000 for (
const int faceIndex : faceIndexes )
1002 const QgsMeshFace &face = mesh->triangles().at( faceIndex );
1003 for (
int i = 0; i < 3; ++i )
1006 const double dist = point.
distance( vertex );
1007 if ( dist < maxDistance )
1010 projectedPoint = vertex;
1011 selectedIndex = face.at( i );
1016 return selectedIndex;
1019int QgsMeshLayer::closestFace(
const QgsPointXY &point,
double searchRadius,
QgsPointXY &projectedPoint )
const
1024 int selectedIndex = -1;
1025 projectedPoint = QgsPointXY();
1027 return selectedIndex;
1029 const QgsRectangle rectangle( point.
x() - searchRadius, point.
y() - searchRadius, point.
x() + searchRadius, point.
y() + searchRadius );
1030 double maxDistance = std::numeric_limits<double>::max();
1032 const QList<int> faceIndexes = mesh->faceIndexesForRectangle( rectangle );
1033 for (
const int faceIndex : faceIndexes )
1035 const int nativefaceIndex = mesh->trianglesToNativeFaces().at( faceIndex );
1036 if ( nativefaceIndex < 0 && nativefaceIndex >= mesh->faceCentroids().count() )
1038 const QgsPointXY centroid = mesh->faceCentroids()[nativefaceIndex];
1039 const double dist = point.
distance( centroid );
1040 if ( dist < maxDistance )
1043 projectedPoint = centroid;
1044 selectedIndex = nativefaceIndex;
1048 return selectedIndex;
1055 mDatasetGroupStore->resetDatasetGroupTreeItem();
1056 updateActiveDatasetGroups();
1063 if ( !mDataProvider )
1065 const int groupCount = mDataProvider->datasetGroupCount();
1066 for (
int i = 0; i < groupCount; ++i )
1068 const qint64 timeStep = mDataProvider->temporalCapabilities()->firstTimeStepDuration( i );
1080 const qint64 time = mDatasetGroupStore->datasetRelativeTime( index );
1092 return mDatasetGroupStore->datasetRelativeTime( index );
1104 message = QObject::tr(
"Face %1 invalid" ).arg( error.
elementIndex );
1107 message = QObject::tr(
"Too many vertices for face %1" ).arg( error.
elementIndex );
1110 message = QObject::tr(
"Face %1 is flat" ).arg( error.
elementIndex );
1113 message = QObject::tr(
"Vertex %1 is a unique shared vertex" ).arg( error.
elementIndex );
1116 message = QObject::tr(
"Vertex %1 is invalid" ).arg( error.
elementIndex );
1119 message = QObject::tr(
"Face %1 is manifold" ).arg( error.
elementIndex );
1150 mSimplificationSettings.setEnabled(
false );
1158 mRendererCache.reset();
1159 error = mMeshEditor->initializeWithErrorsFix();
1162 error = mMeshEditor->initialize();
1166 mMeshEditor->deleteLater();
1167 mMeshEditor =
nullptr;
1175 mDataProvider->close();
1178 mExtraDatasetUri.clear();
1179 mDatasetGroupStore = std::make_unique<QgsMeshDatasetGroupStore>(
this );
1181 mDatasetGroupStore->addDatasetGroup( mMeshEditor->createZValueDatasetGroup() );
1198 QString detailsError;
1199 if ( !mMeshEditor->checkConsistency(
error ) )
1202 detailsError = tr(
"Unknown inconsistent mesh error" );
1207 detailsError = detailsErrorMessage(
error );
1210 if ( !detailsError.isEmpty() )
1219 if ( !mDataProvider )
1222 const bool res = mDataProvider->saveMeshFrame( *mNativeMesh.get() );
1224 if ( continueEditing )
1226 mMeshEditor->initialize();
1231 mMeshEditor->deleteLater();
1232 mMeshEditor =
nullptr;
1235 mDataProvider->reloadData();
1236 mDataProvider->populateMesh( mNativeMesh.get() );
1237 mDatasetGroupStore = std::make_unique<QgsMeshDatasetGroupStore>(
this );
1238 mDatasetGroupStore->setPersistentProvider( mDataProvider, QStringList() );
1249 if ( !mDataProvider )
1252 mTriangularMeshes.clear();
1253 mDataProvider->reloadData();
1254 mDataProvider->populateMesh( mNativeMesh.get() );
1256 mRendererCache = std::make_unique<QgsMeshLayerRendererCache>( );
1259 if ( continueEditing )
1266 mMeshEditor->deleteLater();
1267 mMeshEditor =
nullptr;
1270 mDatasetGroupStore = std::make_unique<QgsMeshDatasetGroupStore>(
this );
1271 mDatasetGroupStore->setPersistentProvider( mDataProvider, QStringList() );
1285 mMeshEditor->stopEditing();
1286 mTriangularMeshes.at( 0 )->update( mNativeMesh.get(), transform );
1287 mRendererCache = std::make_unique<QgsMeshLayerRendererCache>( );
1297 if ( !mMeshEditor->reindex( renumber ) )
1300 mTriangularMeshes.clear();
1302 mTriangularMeshes.at( 0 )->update( mNativeMesh.get(), transform );
1303 mRendererCache = std::make_unique<QgsMeshLayerRendererCache>( );
1304 mMeshEditor->resetTriangularMesh( mTriangularMeshes.at( 0 ).get() );
1321 return mMeshEditor->isModified();
1347 return mMeshEditor->validVerticesCount();
1348 else if ( mDataProvider )
1349 return mDataProvider->vertexCount();
1358 return mMeshEditor->validFacesCount();
1359 else if ( mDataProvider )
1360 return mDataProvider->faceCount();
1369 return mNativeMesh->edgeCount();
1370 else if ( mDataProvider )
1371 return mDataProvider->edgeCount();
1375void QgsMeshLayer::updateActiveDatasetGroups()
1381 if ( !mDatasetGroupStore->datasetGroupTreeItem() )
1391 if ( !activeScalarItem && treeItem->childCount() > 0 && oldActiveScalar != -1 )
1392 activeScalarItem = treeItem->
child( 0 );
1394 if ( activeScalarItem && !activeScalarItem->
isEnabled() )
1396 for (
int i = 0; i < treeItem->childCount(); ++i )
1398 activeScalarItem = treeItem->
child( i );
1402 activeScalarItem =
nullptr;
1406 if ( activeScalarItem )
1411 QgsMeshDatasetGroupTreeItem *activeVectorItem =
1412 treeItem->childFromDatasetGroupIndex( oldActiveVector );
1414 if ( !( activeVectorItem && activeVectorItem->
isEnabled() ) )
1427 QString activeScalarName;
1428 QString activeVectorName;
1429 QgsMeshRendererSettings consistentSettings = settings;
1433 for (
auto it = nameToIndex.constBegin(); it != nameToIndex.constEnd(); ++it )
1435 int index = it.value();
1436 const QString
name = it.key() ;
1437 int globalIndex = mDatasetGroupStore->indexFromGroupName(
name );
1438 if ( globalIndex >= 0 )
1440 QgsMeshRendererScalarSettings scalarSettings = settings.
scalarSettings( index );
1442 if ( settings.
hasVectorSettings( it.value() ) && mDatasetGroupStore->datasetGroupMetadata( globalIndex ).isVector() )
1444 QgsMeshRendererVectorSettings vectorSettings = settings.
vectorSettings( index );
1455 if ( index == activeScalar )
1456 activeScalarName =
name;
1457 if ( index == activeVector )
1458 activeVectorName =
name;
1462 for (
int globalIndex : globalIndexes )
1464 const QString
name = mDatasetGroupStore->groupName( globalIndex );
1465 if ( !nameToIndex.contains(
name ) )
1467 consistentSettings.
setScalarSettings( globalIndex, mRendererSettings.scalarSettings( globalIndex ) );
1468 if ( mDatasetGroupStore->datasetGroupMetadata( globalIndex ).isVector() )
1470 consistentSettings.
setVectorSettings( globalIndex, mRendererSettings.vectorSettings( globalIndex ) );
1475 if ( !activeScalarName.isEmpty() )
1477 if ( !activeVectorName.isEmpty() )
1480 return consistentSettings;
1491 if ( !
mDataSource.isEmpty() && !provider.isEmpty() )
1492 setDataProvider( provider, options,
flags );
1500 closestElement( elementType, point, searchRadius, projectedPoint );
1501 return projectedPoint;
1508 switch ( elementType )
1511 return closestVertex( point, searchRadius, projectedPoint );
1513 return closestEdge( point, searchRadius, projectedPoint );
1515 return closestFace( point, searchRadius, projectedPoint );
1538 context.
lastScope()->
setVariable( QStringLiteral(
"_native_mesh" ), QVariant::fromValue( *mNativeMesh ) );
1540 expression.
prepare( &context );
1542 for (
int i = 0; i < mNativeMesh->vertexCount(); ++i )
1546 if ( expression.
evaluate( &context ).toBool() )
1571 context.
lastScope()->
setVariable( QStringLiteral(
"_native_mesh" ), QVariant::fromValue( *mNativeMesh ) );
1573 expression.
prepare( &context );
1575 for (
int i = 0; i < mNativeMesh->faceCount(); ++i )
1579 if ( expression.
evaluate( &context ).toBool() )
1590 return QgsMeshDatasetIndex( group >= 0 ? group : mRendererSettings.activeScalarDatasetGroup(), mStaticScalarDatasetIndex );
1597 const int oldActiveVector = mRendererSettings.activeVectorDatasetGroup();
1602 if ( oldActiveVector != mRendererSettings.activeVectorDatasetGroup() )
1610 const int oldActiveScalar = mRendererSettings.activeScalarDatasetGroup();
1615 if ( oldActiveScalar != mRendererSettings.activeScalarDatasetGroup() )
1623 return mSimplificationSettings;
1630 mSimplificationSettings = simplifySettings;
1641 props[
"color1"] =
"13,8,135,255";
1642 props[
"color2"] =
"240,249,33,255";
1644 "0.0196078;27,6,141,255:0.0392157;38,5,145,255:0.0588235;47,5,150,255:0.0784314;56,4,154,255:0.0980392;65,4,157,255:"
1645 "0.117647;73,3,160,255:0.137255;81,2,163,255:0.156863;89,1,165,255:0.176471;97,0,167,255:0.196078;105,0,168,255:"
1646 "0.215686;113,0,168,255:0.235294;120,1,168,255:0.254902;128,4,168,255:0.27451;135,7,166,255:0.294118;142,12,164,255:"
1647 "0.313725;149,17,161,255:0.333333;156,23,158,255:0.352941;162,29,154,255:0.372549;168,34,150,255:0.392157;174,40,146,255:"
1648 "0.411765;180,46,141,255:0.431373;186,51,136,255:0.45098;191,57,132,255:0.470588;196,62,127,255:0.490196;201,68,122,255:"
1649 "0.509804;205,74,118,255:0.529412;210,79,113,255:0.54902;214,85,109,255:0.568627;218,91,105,255:0.588235;222,97,100,255:"
1650 "0.607843;226,102,96,255:0.627451;230,108,92,255:0.647059;233,114,87,255:0.666667;237,121,83,255:0.686275;240,127,79,255:"
1651 "0.705882;243,133,75,255:0.72549;245,140,70,255:0.745098;247,147,66,255:0.764706;249,154,62,255:0.784314;251,161,57,255:"
1652 "0.803922;252,168,53,255:0.823529;253,175,49,255:0.843137;254,183,45,255:0.862745;254,190,42,255:0.882353;253,198,39,255:"
1653 "0.901961;252,206,37,255:0.921569;251,215,36,255:0.941176;248,223,37,255:0.960784;246,232,38,255:0.980392;243,240,39,255";
1657void QgsMeshLayer::assignDefaultStyleToDatasetGroup(
int groupIndex )
1662 const double groupMin =
metadata.minimum();
1663 const double groupMax =
metadata.maximum();
1665 QgsColorRampShader fcn( groupMin, groupMax, _createDefaultColorRamp() );
1666 fcn.classifyColorRamp( 5, -1, QgsRectangle(),
nullptr );
1668 QgsMeshRendererScalarSettings scalarSettings;
1671 QgsInterpolatedLineWidth edgeStrokeWidth;
1674 const QgsInterpolatedLineColor edgeStrokeColor( fcn );
1675 const QgsInterpolatedLineRenderer edgeStrokePen;
1677 mRendererSettings.setScalarSettings( groupIndex, scalarSettings );
1681 QgsMeshRendererVectorSettings vectorSettings;
1683 mRendererSettings.setVectorSettings( groupIndex, vectorSettings );
1695 createSimplifiedMeshes();
1698 if ( !mRendererCache )
1699 mRendererCache = std::make_unique<QgsMeshLayerRendererCache>( );
1715 if (
extent.isNull() || !this->extent().intersects(
extent ) )
1725 QVector<double> scalarDatasetValues;
1735 if ( !datasetIndex.
isValid() )
1741 const int count = QgsMeshLayerUtils::datasetValuesCount( mNativeMesh.get(), scalarDataType );
1751 scalarDatasetValues = QgsMeshLayerUtils::calculateMagnitudes( vals );
1755 scalarDatasetValues = QVector<double>( count, std::numeric_limits<double>::quiet_NaN() );
1760 if ( intersectedFacesIndices.isEmpty() )
1765 min = std::numeric_limits<double>::max();
1766 max = -std::numeric_limits<double>::max();
1770 for (
int intersectedFaceIndex : intersectedFacesIndices )
1777 min = std::min( min, value );
1778 max = std::max( max, value );
1784 for (
int vertexIndex : face )
1786 value = scalarDatasetValues.at( vertexIndex );
1787 min = std::min( min, value );
1788 max = std::max( max, value );
1803void QgsMeshLayer::checkSymbologyConsistency()
1807 const QList<int> groupIndexes = mDatasetGroupStore->datasetGroupIndexes();
1811 if ( !groupIndexes.empty() )
1817 if ( !groupIndexes.contains( mRendererSettings.activeVectorDatasetGroup() ) &&
1818 mRendererSettings.activeVectorDatasetGroup() != -1 )
1820 mRendererSettings.setActiveVectorDatasetGroup( -1 );
1829 Q_UNUSED( errorMessage )
1832 const QDomElement elem = node.toElement();
1837 const QDomElement elemRendererSettings = elem.firstChildElement(
"mesh-renderer-settings" );
1838 if ( !elemRendererSettings.isNull() )
1841 QMap<QString, int> groupNameToGlobalIndex;
1842 QDomElement nameToIndexElem = elem.firstChildElement(
"name-to-global-index" );
1843 while ( !nameToIndexElem.isNull() )
1845 const QString
name = nameToIndexElem.attribute( QStringLiteral(
"name" ) );
1846 int globalIndex = nameToIndexElem.attribute( QStringLiteral(
"global-index" ) ).toInt();
1847 groupNameToGlobalIndex.insert(
name, globalIndex );
1848 nameToIndexElem = nameToIndexElem.nextSiblingElement( QStringLiteral(
"name-to-global-index" ) );
1851 mRendererSettings = accordSymbologyWithGroupName(
rendererSettings, groupNameToGlobalIndex );
1853 checkSymbologyConsistency();
1855 const QDomElement elemSimplifySettings = elem.firstChildElement(
"mesh-simplify-settings" );
1856 if ( !elemSimplifySettings.isNull() )
1857 mSimplificationSettings.readXml( elemSimplifySettings, context );
1860 const QDomNode blendModeNode = node.namedItem( QStringLiteral(
"blendMode" ) );
1861 if ( !blendModeNode.isNull() )
1863 const QDomElement e = blendModeNode.toElement();
1868 if ( categories.testFlag(
Labeling ) )
1872 QDomElement labelingElement = node.firstChildElement( QStringLiteral(
"labeling" ) );
1873 if ( !labelingElement.isNull() )
1876 mLabelsEnabled = node.toElement().attribute( QStringLiteral(
"labelsEnabled" ), QStringLiteral(
"0" ) ).toInt();
1884 const QDomNode layerOpacityNode = node.namedItem( QStringLiteral(
"layerOpacity" ) );
1885 if ( !layerOpacityNode.isNull() )
1887 const QDomElement e = layerOpacityNode.toElement();
1892 if ( categories.testFlag(
Legend ) )
1896 const QDomElement legendElem = node.firstChildElement( QStringLiteral(
"legend" ) );
1899 l->readXml( legendElem, context );
1911 Q_UNUSED( errorMessage )
1914 QDomElement elem = node.toElement();
1918 const QDomElement elemRendererSettings = mRendererSettings.writeXml( doc, context );
1919 elem.appendChild( elemRendererSettings );
1923 for (
int index : groupIndexes )
1925 QDomElement elemNameToIndex = doc.createElement( QStringLiteral(
"name-to-global-index" ) );
1926 elemNameToIndex.setAttribute( QStringLiteral(
"name" ), mDatasetGroupStore->groupName( index ) );
1927 elemNameToIndex.setAttribute( QStringLiteral(
"global-index" ), index );
1928 elem.appendChild( elemNameToIndex );
1931 const QDomElement elemSimplifySettings = mSimplificationSettings.writeXml( doc, context );
1932 elem.appendChild( elemSimplifySettings );
1935 QDomElement blendModeElement = doc.createElement( QStringLiteral(
"blendMode" ) );
1937 blendModeElement.appendChild( blendModeText );
1938 node.appendChild( blendModeElement );
1940 if ( categories.testFlag(
Labeling ) )
1944 QDomElement labelingElement = mLabeling->save( doc, context );
1945 elem.appendChild( labelingElement );
1947 elem.setAttribute( QStringLiteral(
"labelsEnabled" ), mLabelsEnabled ? QStringLiteral(
"1" ) : QStringLiteral(
"0" ) );
1953 QDomElement layerOpacityElem = doc.createElement( QStringLiteral(
"layerOpacity" ) );
1954 const QDomText layerOpacityText = doc.createTextNode( QString::number(
opacity() ) );
1955 layerOpacityElem.appendChild( layerOpacityText );
1956 node.appendChild( layerOpacityElem );
1962 if ( !legendElement.isNull() )
1963 node.appendChild( legendElement );
1973 return writeSymbology( node, doc, errorMessage, context, categories );
1980 return readSymbology( node, errorMessage, context, categories );
2004 const QDomNode pkeyNode = layer_node.namedItem( QStringLiteral(
"provider" ) );
2006 if ( pkeyNode.isNull() )
2012 const QDomElement pkeyElt = pkeyNode.toElement();
2024 const QDomElement elemExtraDatasets = layer_node.firstChildElement( QStringLiteral(
"extra-datasets" ) );
2025 if ( !elemExtraDatasets.isNull() )
2027 QDomElement elemUri = elemExtraDatasets.firstChildElement( QStringLiteral(
"uri" ) );
2028 while ( !elemUri.isNull() )
2031 mExtraDatasetUri.append( uri );
2032 elemUri = elemUri.nextSiblingElement( QStringLiteral(
"uri" ) );
2036 if ( pkeyNode.toElement().hasAttribute( QStringLiteral(
"time-unit" ) ) )
2037 mTemporalUnit =
static_cast<Qgis::TemporalUnit>( pkeyNode.toElement().attribute( QStringLiteral(
"time-unit" ) ).toInt() );
2040 const QDomElement elemDatasetGroupsStore = layer_node.firstChildElement( QStringLiteral(
"mesh-dataset-groups-store" ) );
2041 if ( elemDatasetGroupsStore.isNull() )
2044 mDatasetGroupStore->readXml( elemDatasetGroupsStore, context );
2051 if ( !mTemporalProperties->timeExtent().begin().isValid() || mTemporalProperties->alwaysLoadReferenceTimeFromSource() )
2055 const QDomElement elemStaticDataset = layer_node.firstChildElement( QStringLiteral(
"static-active-dataset" ) );
2056 if ( elemStaticDataset.hasAttribute( QStringLiteral(
"scalar" ) ) )
2058 mStaticScalarDatasetIndex = elemStaticDataset.attribute( QStringLiteral(
"scalar" ) ).toInt();
2060 if ( elemStaticDataset.hasAttribute( QStringLiteral(
"vector" ) ) )
2062 mStaticVectorDatasetIndex = elemStaticDataset.attribute( QStringLiteral(
"vector" ) ).toInt();
2073 QDomElement mapLayerNode = layer_node.toElement();
2075 if ( mapLayerNode.isNull() || ( QLatin1String(
"maplayer" ) != mapLayerNode.nodeName() ) )
2084 if ( mDataProvider )
2086 QDomElement provider = document.createElement( QStringLiteral(
"provider" ) );
2087 const QDomText providerText = document.createTextNode(
providerType() );
2088 provider.appendChild( providerText );
2089 layer_node.appendChild( provider );
2090 provider.setAttribute( QStringLiteral(
"time-unit" ),
static_cast< int >( mDataProvider->temporalCapabilities()->temporalUnit() ) );
2092 const QStringList extraDatasetUris = mDataProvider->extraDatasets();
2093 QDomElement elemExtraDatasets = document.createElement( QStringLiteral(
"extra-datasets" ) );
2094 for (
const QString &uri : extraDatasetUris )
2097 QDomElement elemUri = document.createElement( QStringLiteral(
"uri" ) );
2098 elemUri.appendChild( document.createTextNode( path ) );
2099 elemExtraDatasets.appendChild( elemUri );
2101 layer_node.appendChild( elemExtraDatasets );
2104 QDomElement elemStaticDataset = document.createElement( QStringLiteral(
"static-active-dataset" ) );
2105 elemStaticDataset.setAttribute( QStringLiteral(
"scalar" ), mStaticScalarDatasetIndex );
2106 elemStaticDataset.setAttribute( QStringLiteral(
"vector" ), mStaticVectorDatasetIndex );
2107 layer_node.appendChild( elemStaticDataset );
2111 layer_node.appendChild( mDatasetGroupStore->writeXml( document, context ) );
2115 return writeSymbology( layer_node, document, errorMsg, context );
2122 if ( !mMeshEditor && mDataProvider && mDataProvider->isValid() )
2124 mDataProvider->reloadData();
2125 mDatasetGroupStore->setPersistentProvider( mDataProvider, QStringList() );
2129 mNativeMesh = std::make_unique<QgsMesh>( );
2133 if ( mTemporalProperties->alwaysLoadReferenceTimeFromSource() )
2134 mTemporalProperties->setDefaultsFromDataProviderTemporalCapabilities( mDataProvider->temporalCapabilities() );
2137 mTriangularMeshes.clear();
2140 mRendererCache = std::make_unique<QgsMeshLayerRendererCache>( );
2142 checkSymbologyConsistency();
2152 if ( mDataProvider )
2153 return mDataProvider->subLayers();
2155 return QStringList();
2163 QString myMetadata = QStringLiteral(
"<html>\n<body>\n" );
2168 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"Information from provider" ) + QStringLiteral(
"</h1>\n<hr>\n" );
2169 myMetadata += QLatin1String(
"<table class=\"list-view\">\n" );
2172 myMetadata += QStringLiteral(
"<tr><td class=\"highlight\">" ) + tr(
"Extent" ) + QStringLiteral(
"</td><td>" ) +
extent().
toString() + QStringLiteral(
"</td></tr>\n" );
2175 QLocale locale = QLocale();
2176 locale.setNumberOptions( locale.numberOptions() &= ~QLocale::NumberOption::OmitGroupSeparator );
2180 myMetadata += QStringLiteral(
"<tr><td class=\"highlight\">" )
2181 + tr(
"Vertex count" ) + QStringLiteral(
"</td><td>" )
2183 + QStringLiteral(
"</td></tr>\n" );
2184 myMetadata += QStringLiteral(
"<tr><td class=\"highlight\">" )
2185 + tr(
"Face count" ) + QStringLiteral(
"</td><td>" )
2186 + ( locale.toString(
static_cast<qlonglong
>(
meshFaceCount() ) ) )
2187 + QStringLiteral(
"</td></tr>\n" );
2188 myMetadata += QStringLiteral(
"<tr><td class=\"highlight\">" )
2189 + tr(
"Edge count" ) + QStringLiteral(
"</td><td>" )
2190 + ( locale.toString(
static_cast<qlonglong
>(
meshEdgeCount() ) ) )
2191 + QStringLiteral(
"</td></tr>\n" );
2192 myMetadata += QStringLiteral(
"<tr><td class=\"highlight\">" )
2193 + tr(
"Dataset groups count" ) + QStringLiteral(
"</td><td>" )
2195 + QStringLiteral(
"</td></tr>\n" );
2196 myMetadata += provider->htmlMetadata();
2200 myMetadata += QLatin1String(
"</table>\n<br><br>" );
2206 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"Identification" ) + QStringLiteral(
"</h1>\n<hr>\n" );
2207 myMetadata += htmlFormatter.identificationSectionHtml( );
2208 myMetadata += QLatin1String(
"<br><br>\n" );
2211 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"Extent" ) + QStringLiteral(
"</h1>\n<hr>\n" );
2212 myMetadata += htmlFormatter.extentSectionHtml(
isSpatial() );
2213 myMetadata += QLatin1String(
"<br><br>\n" );
2216 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"Access" ) + QStringLiteral(
"</h1>\n<hr>\n" );
2217 myMetadata += htmlFormatter.accessSectionHtml( );
2218 myMetadata += QLatin1String(
"<br><br>\n" );
2221 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"Contacts" ) + QStringLiteral(
"</h1>\n<hr>\n" );
2222 myMetadata += htmlFormatter.contactsSectionHtml( );
2223 myMetadata += QLatin1String(
"<br><br>\n" );
2226 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"Links" ) + QStringLiteral(
"</h1>\n<hr>\n" );
2227 myMetadata += htmlFormatter.linksSectionHtml( );
2228 myMetadata += QLatin1String(
"<br><br>\n" );
2231 myMetadata += QStringLiteral(
"<h1>" ) + tr(
"History" ) + QStringLiteral(
"</h1>\n<hr>\n" );
2232 myMetadata += htmlFormatter.historySectionHtml( );
2233 myMetadata += QLatin1String(
"<br><br>\n" );
2237 myMetadata += QLatin1String(
"\n</body>\n</html>\n" );
2252 mDatasetGroupStore->setPersistentProvider(
nullptr, QStringList() );
2254 delete mDataProvider;
2260 mDataProvider = qobject_cast< QgsMeshDataProvider * >(
mPreloadedProvider.release() );
2264 std::unique_ptr< QgsScopedRuntimeProfile > profile;
2266 profile = std::make_unique< QgsScopedRuntimeProfile >( tr(
"Create %1 provider" ).arg( provider ), QStringLiteral(
"projectload" ) );
2271 if ( !mDataProvider )
2273 QgsDebugMsgLevel( QStringLiteral(
"Unable to get mesh data provider" ), 2 );
2277 mDataProvider->setParent(
this );
2278 QgsDebugMsgLevel( QStringLiteral(
"Instantiated the mesh data provider plugin" ), 2 );
2280 setValid( mDataProvider->isValid() );
2287 if ( !mTemporalProperties->isValid() )
2289 mTemporalProperties->setDefaultsFromDataProviderTemporalCapabilities(
dataProvider()->temporalCapabilities() );
2292 mDataProvider->setTemporalUnit( mTemporalUnit );
2294 mDatasetGroupStore->setPersistentProvider( mDataProvider, mExtraDatasetUri );
2296 setCrs( mDataProvider->crs() );
2298 if ( provider == QLatin1String(
"mesh_memory" ) )
2305 for (
int i = 0; i < mDataProvider->datasetGroupCount(); ++i )
2307 int globalIndex = mDatasetGroupStore->globalDatasetGroupIndexInSource( mDataProvider, i );
2308 if ( globalIndex != -1 &&
2310 assignDefaultStyleToDatasetGroup( globalIndex );
2325 return mTemporalProperties;
2332 return mElevationProperties;
2339 return mLabelsEnabled &&
static_cast< bool >( mLabeling );
2346 mLabelsEnabled = enabled;
2363 if ( ! mDataProvider )
2365 QgsDebugMsgLevel( QStringLiteral(
"Unable to get mesh data provider" ), 2 );
2369 if ( mDataProvider->dataSourceUri().contains( path ) )
2372 return !mExtraDatasetUri.contains( path );
Provides global constants and enumerations for use throughout the application.
@ Exact
Assigns the color of the exact matching value in the color ramp item list.
@ Critical
Critical/error message.
@ TooManyVerticesInFace
A face has more vertices than the maximum number supported per face.
@ InvalidFace
An error occurs due to an invalid face (for example, vertex indexes are unordered).
@ UniqueSharedVertex
A least two faces share only one vertices.
@ ManifoldFace
ManifoldFace.
@ InvalidVertex
An error occurs due to an invalid vertex (for example, vertex index is out of range the available ver...
@ FlatFace
A flat face is present.
BlendMode
Blending modes defining the available composition modes that can be used when painting.
TemporalUnit
Temporal units.
@ Milliseconds
Milliseconds.
QFlags< DataProviderReadFlag > DataProviderReadFlags
Flags which control data provider construction.
@ EqualInterval
Uses equal interval.
@ Mesh
Mesh layer. Added in QGIS 3.2.
@ LoadDefaultStyle
Reset the layer's style to the default for the datasource.
QgsVertexIterator vertices() const
Returns a read-only, Java-style iterator for traversal of vertices of all the geometry,...
Abstract base class - its implementations define different approaches to the labeling of a mesh layer...
static QgsAbstractMeshLayerLabeling * create(const QDomElement &element, const QgsReadWriteContext &context)
Try to create instance of an implementation based on the XML data.
Abstract base class for objects which generate elevation profiles.
static QgsRuntimeProfiler * profiler()
Returns the application runtime profiler.
A ramp shader will color a raster pixel based on a list of values ranges in a ramp.
void setClassificationMode(Qgis::ShaderClassificationMethod classificationMode)
Sets the classification mode.
QgsColorRamp * sourceColorRamp() const
Returns the source color ramp.
void setColorRampType(Qgis::ShaderInterpolationMethod colorRampType)
Sets the color ramp interpolation method.
void setColorRampItemList(const QList< QgsColorRampShader::ColorRampItem > &list)
Sets a custom color map.
Abstract base class for color ramps.
virtual QColor color(double value) const =0
Returns the color corresponding to a specified value.
Contains information about the context in which a coordinate transform is executed.
Base class for handling properties relating to a data provider's temporal capabilities.
bool hasTemporalCapabilities() const
Returns true if the provider has temporal capabilities available.
void dataChanged()
Emitted whenever a change is made to the data provider which may have caused changes in the provider'...
virtual bool isValid() const =0
Returns true if this is a valid layer.
void setVariable(const QString &name, const QVariant &value, bool isStatic=false)
Convenience method for setting a variable in the context scope by name name and value.
static QgsExpressionContextScope * meshExpressionScope(QgsMesh::ElementType elementType)
Creates a new scope which contains functions relating to mesh layer element elementType.
Expression contexts are used to encapsulate the parameters around which a QgsExpression should be eva...
QgsExpressionContextScope * lastScope()
Returns the last scope added to the context.
void appendScope(QgsExpressionContextScope *scope)
Appends a scope to the end of the context.
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.
QVariant evaluate()
Evaluate the feature and return the result.
static QgsColorRamp * create(const QVariantMap &properties=QVariantMap())
Creates a new QgsColorRamp from a map of properties.
void setMaximumValue(double maximumValue)
Sets the maximum value used to defined the variable width.
void setMinimumValue(double minimumValue)
Sets the minimum value used to defined the variable width.
A representation of the interval between two datetime values.
double seconds() const
Returns the interval duration in seconds.
Base class for storage of map layer elevation properties.
static QString typeToString(Qgis::LayerType type)
Converts a map layer type to a string value.
An abstract interface for implementations of legends for one map layer.
static QgsMapLayerLegend * defaultMeshLegend(QgsMeshLayer *ml)
Create new legend implementation for mesh layer.
virtual QDomElement writeXml(QDomDocument &doc, const QgsReadWriteContext &context) const
Writes configuration to a DOM element, to be used later with readXml().
Base class for utility classes that encapsulate information necessary for rendering of map layers.
Base class for storage of map layer temporal properties.
virtual void setDefaultsFromDataProviderTemporalCapabilities(const QgsDataProviderTemporalCapabilities *capabilities)=0
Sets the layers temporal settings to appropriate defaults based on a provider's temporal capabilities...
virtual bool isSpatial() const
Returns true if the layer is considered a spatial layer, ie it has some form of geometry associated w...
QgsMapLayerLegend * legend() const
Can be nullptr.
void editingStopped()
Emitted when edited changes have been successfully written to the data provider.
QString source() const
Returns the source for the layer.
QString providerType() const
Returns the provider type (provider key) for this layer.
void setBlendMode(QPainter::CompositionMode blendMode)
Set the blending mode used for rendering a layer.
void trigger3DUpdate()
Will advise any 3D maps that this layer requires to be updated in the scene.
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.
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...
QString mLayerName
Name of the layer - used for display.
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.
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....
QFlags< StyleCategory > StyleCategories
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...
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 dataSourceChanged()
Emitted whenever the layer's data source has been changed.
QgsMapLayer::LayerFlags flags
void emitStyleChanged()
Triggers an emission of the styleChanged() signal.
void dataChanged()
Data of layer changed.
virtual QgsMapLayer * clone() const =0
Returns a new instance equivalent to this one except for the id which is still unique.
QString mDataSource
Data source description string, varies by layer type.
@ FlagDontResolveLayers
Don't resolve layer paths or create data providers for layers.
void setValid(bool valid)
Sets whether layer is valid or not.
void readCommonStyle(const QDomElement &layerElement, const QgsReadWriteContext &context, StyleCategories categories=AllStyleCategories)
Read style data common to all layer types.
QgsMapLayer::ReadFlags mReadFlags
Read flags. It's up to the subclass to respect these when restoring state from XML.
void setLegend(QgsMapLayerLegend *legend)
Assign a legend controller to the map layer.
@ Rendering
Rendering: scale visibility, simplify method, opacity.
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.
void invalidateWgs84Extent()
Invalidates the WGS84 extent.
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.
Abstract class for interpolating 3d stacked mesh data to 2d data.
QgsMeshDataBlock calculate(const QgsMesh3DDataBlock &block3d, QgsFeedback *feedback=nullptr) const
Calculated 2d block values from 3d stacked mesh values.
A block of 3d stacked mesh data related N faces defined on base mesh frame.
A block of integers/doubles from a mesh dataset.
QgsMeshDatasetValue value(int index) const
Returns a value represented by the index For active flag the behavior is undefined.
bool isValid() const
Whether the block is valid.
MatchingTemporalDatasetMethod
Method for selection of temporal mesh dataset from a range time.
Base class for providing data for QgsMeshLayer.
QgsMeshDataProviderTemporalCapabilities * temporalCapabilities() override
Returns the provider's temporal capabilities.
virtual void populateMesh(QgsMesh *mesh) const =0
Populates the mesh vertices, edges and faces.
Registers and accesses all the dataset groups related to a mesh layer.
void datasetGroupsAdded(QList< int > indexes)
Emitted after dataset groups are added.
Tree item for display of the mesh dataset groups.
int datasetGroupIndex() const
Returns the dataset group index.
QgsMeshDatasetGroupTreeItem * childFromDatasetGroupIndex(int index)
Returns the child with dataset group index Searches as depper as needed on the child hierarchy.
bool isEnabled() const
Returns true if the item is enabled, i.e.
QgsMeshDatasetGroupTreeItem * child(int row) const
Returns a child.
Abstract class that represents a dataset group.
An index that identifies the dataset group (e.g.
bool isValid() const
Returns whether index is valid, ie at least groups is set.
int group() const
Returns a group index.
Represents a single mesh dataset value.
double y() const
Returns y value.
double x() const
Returns x value.
Represents an error which occurred during mesh editing.
Qgis::MeshEditingErrorType errorType
Handles edit operations on a mesh layer.
void meshEdited()
Emitted when the mesh is edited.
Mesh layer specific subclass of QgsMapLayerElevationProperties.
QgsMeshLayerElevationProperties * clone() const override
Creates a clone of the properties.
Implementation of QgsAbstractProfileGenerator for mesh layers.
Implementation of threaded rendering for mesh layers.
Implementation of map layer temporal properties for mesh layers.
int closestElement(QgsMesh::ElementType elementType, const QgsPointXY &point, double searchRadius, QgsPointXY &projectedPoint) const
Returns the index of the snapped point on the mesh element closest to point intersecting with the sea...
QList< int > selectVerticesByExpression(QgsExpression expression)
Returns a list of vertex indexes that meet the condition defined by expression with the context expre...
void setMeshSimplificationSettings(const QgsMeshSimplificationSettings &meshSimplificationSettings)
Sets mesh simplification settings.
int datasetCount(const QgsMeshDatasetIndex &index) const
Returns the dataset count in the dataset groups.
QList< int > datasetGroupsIndexes() const
Returns the list of indexes of dataset groups handled by the layer.
void stopFrameEditing(const QgsCoordinateTransform &transform)
Stops editing of the mesh, re-indexes the faces and vertices, rebuilds the triangular mesh and its sp...
QgsRectangle extent() const override
Returns the extent of the layer.
void setStaticVectorDatasetIndex(const QgsMeshDatasetIndex &staticVectorDatasetIndex)
Sets the static vector dataset index that is rendered if the temporal properties is not active.
void setStaticScalarDatasetIndex(const QgsMeshDatasetIndex &staticScalarDatasetIndex)
Sets the static scalar dataset index that is rendered if the temporal properties is not active.
bool contains(const QgsMesh::ElementType &type) const
Returns whether the mesh contains at mesh elements of given type.
QgsMeshRendererSettings rendererSettings() const
Returns renderer settings.
QgsMeshDatasetIndex activeScalarDatasetIndex(QgsRenderContext &rendererContext)
Returns current active scalar dataset index for current renderer context.
QgsMeshDatasetIndex activeVectorDatasetAtTime(const QgsDateTimeRange &timeRange, int group=-1) const
Returns dataset index from active vector group depending on the time range If the temporal properties...
QList< QgsMeshDatasetIndex > datasetIndexInRelativeTimeInterval(const QgsInterval &startRelativeTime, const QgsInterval &endRelativeTime, int datasetGroupIndex) const
Returns a list of dataset indexes from datasets group that are in a interval time from the layer refe...
void activeScalarDatasetGroupChanged(int index)
Emitted when active scalar group dataset is changed.
int datasetGroupCount() const
Returns the dataset groups count handle by the layer.
void updateTriangularMesh(const QgsCoordinateTransform &transform=QgsCoordinateTransform())
Gets native mesh and updates (creates if it doesn't exist) the base triangular mesh.
bool addDatasets(const QString &path, const QDateTime &defaultReferenceTime=QDateTime())
Adds datasets to the mesh from file with path.
bool isModified() const override
Returns whether the mesh frame has been modified since the last save.
void activeVectorDatasetGroupChanged(int index)
Emitted when active vector group dataset is changed.
void reload() override
Synchronises with changes in the datasource.
QgsPointXY snapOnElement(QgsMesh::ElementType elementType, const QgsPointXY &point, double searchRadius)
Returns the position of the snapped point on the mesh element closest to point intersecting with the ...
bool readXml(const QDomNode &layer_node, QgsReadWriteContext &context) override
Called by readLayerXML(), used by children to read state specific to them from project files.
QStringList subLayers() const override
Returns the sublayers of this layer.
QgsMeshEditor * meshEditor()
Returns a pointer to the mesh editor own by the mesh layer.
const QgsAbstractMeshLayerLabeling * labeling() const
Access to const labeling configuration.
void setDatasetGroupTreeRootItem(QgsMeshDatasetGroupTreeItem *rootItem)
Sets the root items of the dataset group tree item.
QgsMeshDatasetValue dataset1dValue(const QgsMeshDatasetIndex &index, const QgsPointXY &point, double searchRadius) const
Returns the value of 1D mesh dataset defined on edge that are in the search area defined by point ans...
QgsMeshDatasetIndex staticVectorDatasetIndex(int group=-1) const
Returns the static vector dataset index that is rendered if the temporal properties is not active.
QgsMesh * nativeMesh()
Returns native mesh (nullptr before rendering or calling to updateMesh).
bool minimumMaximumActiveScalarDataset(const QgsRectangle &extent, const QgsMeshDatasetIndex &datasetIndex, double &min, double &max)
Extracts minimum and maximum value for active scalar dataset on mesh faces.
QgsTriangularMesh * triangularMeshByLodIndex(int lodIndex) const
Returns triangular corresponding to the index of level of details.
QString htmlMetadata() const override
Obtain a formatted HTML string containing assorted metadata for this layer.
int meshFaceCount() const
Returns the faces count of the mesh frame.
QList< int > selectFacesByExpression(QgsExpression expression)
Returns a list of faces indexes that meet the condition defined by expression with the context expres...
void setRendererSettings(const QgsMeshRendererSettings &settings, const bool repaint=true)
Sets new renderer settings.
QgsMapLayerElevationProperties * elevationProperties() override
Returns the layer's elevation properties.
QgsMeshLayer * clone() const override
Returns a new instance equivalent to this one except for the id which is still unique.
void timeSettingsChanged()
Emitted when time format is changed.
QList< int > enabledDatasetGroupsIndexes() const
Returns the list of indexes of enables dataset groups handled by the layer.
void resetDatasetGroupTreeItem()
Reset the dataset group tree item to default from provider.
int triangularMeshLevelOfDetailCount() const
Returns the count of levels of detail of the mesh simplification.
bool rollBackFrameEditing(const QgsCoordinateTransform &transform, bool continueEditing=true)
Rolls Back editing of the mesh frame.
QString encodedSource(const QString &source, const QgsReadWriteContext &context) const override
Called by writeLayerXML(), used by derived classes to encode provider's specific data source to proje...
QgsMeshDatasetIndex datasetIndexAtRelativeTime(const QgsInterval &relativeTime, int datasetGroupIndex) const
Returns dataset index from datasets group depending on the relative time from the layer reference tim...
bool writeXml(QDomNode &layer_node, QDomDocument &doc, const QgsReadWriteContext &context) const override
Called by writeLayerXML(), used by children to write state specific to them to project files.
bool commitFrameEditing(const QgsCoordinateTransform &transform, bool continueEditing=true)
Commits editing of the mesh frame, Rebuilds the triangular mesh and its spatial index with transform,...
QgsAbstractProfileGenerator * createProfileGenerator(const QgsProfileRequest &request) override
Given a profile request, returns a new profile generator ready for generating elevation profiles.
QgsMeshDataBlock datasetValues(const QgsMeshDatasetIndex &index, int valueIndex, int count) const
Returns N vector/scalar values from the index from the dataset.
bool writeStyle(QDomNode &node, QDomDocument &doc, QString &errorMessage, const QgsReadWriteContext &context, StyleCategories categories=AllStyleCategories) const override
Write just the symbology information for the layer into the document.
void setLabeling(QgsAbstractMeshLayerLabeling *labeling)
Sets labeling configuration.
void setTransformContext(const QgsCoordinateTransformContext &transformContext) override
Sets the coordinate transform context to transformContext.
int meshEdgeCount() const
Returns the edges count of the mesh frame.
QgsMeshSimplificationSettings meshSimplificationSettings() const
Returns mesh simplification settings.
QgsMapLayerRenderer * createMapRenderer(QgsRenderContext &rendererContext) override
Returns new instance of QgsMapLayerRenderer that will be used for rendering of given context.
bool isEditable() const override
Returns true if the layer can be edited.
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...
QgsMeshDataBlock areFacesActive(const QgsMeshDatasetIndex &index, int faceIndex, int count) const
Returns whether the faces are active for particular dataset.
void setLabelsEnabled(bool enabled)
Sets whether labels should be enabled for the layer.
bool isFaceActive(const QgsMeshDatasetIndex &index, int faceIndex) const
Returns N vector/scalar values from the face index from the dataset for 3d stacked meshes.
QgsMeshDatasetMetadata datasetMetadata(const QgsMeshDatasetIndex &index) const
Returns the dataset metadata.
bool saveDataset(const QString &path, int datasetGroupIndex, QString driver)
Saves datasets group on file with the specified driver.
bool supportsEditing() const override
Returns whether the layer supports editing or not.
QgsMeshDataProvider * dataProvider() override
Returns the layer's data provider, it may be nullptr.
QgsInterval firstValidTimeStep() const
Returns the first valid time step of the dataset groups, invalid QgInterval if no time step is presen...
QgsInterval datasetRelativeTime(const QgsMeshDatasetIndex &index)
Returns the relative time of the dataset from the reference time of its group.
QgsMeshDatasetIndex datasetIndexAtTime(const QgsDateTimeRange &timeRange, int datasetGroupIndex) const
Returns dataset index from datasets group depending on the time range.
Q_DECL_DEPRECATED bool startFrameEditing(const QgsCoordinateTransform &transform)
Starts editing of the mesh frame.
bool reindex(const QgsCoordinateTransform &transform, bool renumber)
Re-indexes the faces and vertices, and renumber the indexes if renumber is true.
QgsMeshDatasetValue datasetValue(const QgsMeshDatasetIndex &index, int valueIndex) const
Returns vector/scalar value associated with the index from the dataset To read multiple continuous va...
QgsMeshTimeSettings timeSettings() const
Returns time format settings.
QgsMapLayerTemporalProperties * temporalProperties() override
Returns the layer's temporal properties.
bool writeSymbology(QDomNode &node, QDomDocument &doc, QString &errorMessage, const QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories=QgsMapLayer::AllStyleCategories) const override
Write the style for the layer into the document provided.
int meshVertexCount() const
Returns the vertices count of the mesh frame.
bool labelsEnabled() const
Returns whether the layer contains labels which are enabled and should be drawn.
void setReferenceTime(const QDateTime &referenceTime)
Sets the reference time of the layer.
bool readStyle(const QDomNode &node, QString &errorMessage, QgsReadWriteContext &context, StyleCategories categories=AllStyleCategories) override
Read the style for the current layer from the DOM node supplied.
int extraDatasetGroupCount() const
Returns the extra dataset groups count handle by the layer.
bool datasetsPathUnique(const QString &path)
Checks whether that datasets path is already added to this mesh layer.
qint64 datasetRelativeTimeInMilliseconds(const QgsMeshDatasetIndex &index)
Returns the relative time (in milliseconds) of the dataset from the reference time of its group.
QgsMeshDatasetIndex activeScalarDatasetAtTime(const QgsDateTimeRange &timeRange, int group=-1) const
Returns dataset index from active scalar group depending on the time range.
QgsTriangularMesh * triangularMesh(double minimumTriangleSize=0) const
Returns triangular mesh (nullptr before rendering or calling to updateMesh).
QgsMeshDatasetIndex staticScalarDatasetIndex(int group=-1) const
Returns the static scalar dataset index that is rendered if the temporal properties is not active.
void setTemporalMatchingMethod(const QgsMeshDataProviderTemporalCapabilities::MatchingTemporalDatasetMethod &matchingMethod)
Sets the method used to match the temporal dataset from a requested time, see activeVectorDatasetAtTi...
bool removeDatasets(const QString &name)
Removes datasets from the mesh with given name.
QgsMeshDatasetGroupTreeItem * datasetGroupTreeRootItem() const
Returns the root items of the dataset group tree item.
QgsMesh3DDataBlock dataset3dValues(const QgsMeshDatasetIndex &index, int faceIndex, int count) const
Returns N vector/scalar values from the face index from the dataset for 3d stacked meshes.
QgsMesh3DDataBlock dataset3dValue(const QgsMeshDatasetIndex &index, const QgsPointXY &point) const
Returns the 3d values of stacked 3d mesh defined by the given point.
bool readSymbology(const QDomNode &node, QString &errorMessage, QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories=QgsMapLayer::AllStyleCategories) override
Read the symbology for the current layer from the DOM node supplied.
QString decodedSource(const QString &source, const QString &provider, const QgsReadWriteContext &context) const override
Called by readLayerXML(), used by derived classes to decode provider's specific data source from proj...
void reloaded()
Emitted when the mesh layer is reloaded, see reload().
QString formatTime(double hours)
Returns (date) time in hours formatted to human readable form.
QgsMeshDatasetGroupMetadata datasetGroupMetadata(const QgsMeshDatasetIndex &index) const
Returns the dataset groups metadata.
QgsMeshLayerRendererCache * rendererCache()
Returns native mesh (nullptr before rendering).
void setTimeSettings(const QgsMeshTimeSettings &settings)
Sets time format settings.
QgsMeshLayer(const QString &path=QString(), const QString &baseName=QString(), const QString &providerLib=QStringLiteral("mesh_memory"), const QgsMeshLayer::LayerOptions &options=QgsMeshLayer::LayerOptions())
Constructor - creates a mesh layer.
Represents a mesh renderer settings for mesh objects.
void setEnabled(bool enabled)
Sets whether mesh structure rendering is enabled.
Represents a mesh renderer settings for scalar datasets.
void setClassificationMinimumMaximum(double minimum, double maximum)
Sets min/max values used for creation of the color ramp shader.
void setColorRampShader(const QgsColorRampShader &shader)
Sets color ramp shader function.
QgsColorRampShader colorRampShader() const
Returns color ramp shader function.
@ NoResampling
Does not use resampling.
@ NeighbourAverage
Does a simple average of values defined for all surrounding faces/vertices.
void setEdgeStrokeWidth(const QgsInterpolatedLineWidth &strokeWidth)
Sets the stroke width used to render edges scalar dataset.
void setDataResamplingMethod(const DataResamplingMethod &dataResamplingMethod)
Sets data interpolation method.
Represents all mesh renderer settings.
void setActiveVectorDatasetGroup(int activeVectorDatasetGroup)
Sets the active vector dataset group.
QgsMeshRendererScalarSettings scalarSettings(int groupIndex) const
Returns renderer settings.
int activeVectorDatasetGroup() const
Returns the active vector dataset group.
bool hasVectorSettings(int groupIndex) const
Returns whether groupIndex has existing vector settings.
bool removeVectorSettings(int groupIndex)
Removes vector settings for groupIndex.
int activeScalarDatasetGroup() const
Returns the active scalar dataset group.
QgsMeshRendererVectorSettings vectorSettings(int groupIndex) const
Returns renderer settings.
void setActiveScalarDatasetGroup(int activeScalarDatasetGroup)
Sets the active scalar dataset group.
void setVectorSettings(int groupIndex, const QgsMeshRendererVectorSettings &settings)
Sets new renderer settings.
bool removeScalarSettings(int groupIndex)
Removes scalar settings with groupIndex.
void setScalarSettings(int groupIndex, const QgsMeshRendererScalarSettings &settings)
Sets new renderer settings.
void setColorRampShader(const QgsColorRampShader &colorRampShader)
Returns the color ramp shader used to render vector datasets.
Represents an overview renderer settings.
double reductionFactor() const
Returns the reduction factor used to build simplified mesh.
bool isEnabled() const
Returns if the overview is active.
Represents a mesh time settings for mesh datasets.
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())
Adds a message to the log instance (and creates it if necessary).
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.
QString writePath(const QString &filename) const
Prepare a filename to save it to the project file.
QString readPath(const QString &filename) const
Turn filename read from the project file to an absolute path.
double distance(double x, double y) const
Returns the distance between this point and a specified x, y coordinate.
double sqrDistToSegment(double x1, double y1, double x2, double y2, QgsPointXY &minDistPoint, double epsilon=Qgis::DEFAULT_SEGMENT_EPSILON) const
Returns the minimum distance between this point and a segment.
Point geometry type, with support for z-dimension and m-values.
double distance(double x, double y) const
Returns the Cartesian 2D distance between this point and a specified x, y coordinate.
Encapsulates properties and constraints relating to fetching elevation profiles from different source...
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.
virtual void setMaximumValue(double value)
Sets the maximum value for the raster shader.
virtual void setMinimumValue(double value)
Sets the minimum value for the raster shader.
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 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 truncated to the sp...
void setNull()
Mark a rectangle as being null (holding no spatial information).
Contains information about the context of a rendering operation.
QgsCoordinateTransform coordinateTransform() const
Returns the current coordinate transform for the context.
QgsColorRamp * colorRamp(const QString &name) const
Returns a new copy of the specified color ramp.
static QgsStyle * defaultStyle(bool initialize=true)
Returns the default application-wide style.
void setIsActive(bool active)
Sets whether the temporal property is active.
const QgsDateTimeRange & temporalRange() const
Returns the datetime range for the object.
bool isTemporal() const
Returns true if the object's temporal range is enabled, and the object will be filtered when renderin...
T begin() const
Returns the beginning of the range.
static QgsMeshEditingError checkTopology(const QgsMesh &mesh, int maxVerticesPerFace)
Checks the topology of the mesh mesh, if error occurs, this mesh can't be edited.
A triangular/derived mesh with vertices in map coordinates.
const QVector< QgsMeshFace > & triangles() const
Returns triangles.
QList< int > edgeIndexesForRectangle(const QgsRectangle &rectangle) const
Finds indexes of edges intersecting given bounding box It uses spatial indexing.
const QVector< QgsMeshVertex > & vertices() const
Returns vertices in map coordinate system.
const QVector< QgsMeshEdge > & edges() const
Returns edges.
bool contains(const QgsMesh::ElementType &type) const
Returns whether the mesh contains mesh elements of given type.
const QVector< int > & trianglesToNativeFaces() const
Returns mapping between triangles and original faces.
QList< int > faceIndexesForRectangle(const QgsRectangle &rectangle) const
Finds indexes of triangles intersecting given bounding box It uses spatial indexing.
int faceIndexForPoint_v2(const QgsPointXY &point) const
Finds index of triangle at given point It uses spatial indexing and don't use geos to be faster.
#define QgsDebugMsgLevel(str, level)
#define INVALID_MESHLAYER_TIME
QVector< int > QgsMeshFace
List of vertex indexes.
QPair< int, int > QgsMeshEdge
Edge is a straight line seqment between 2 points.
QgsPoint QgsMeshVertex
xyz coords of vertex
QgsTemporalRange< QDateTime > QgsDateTimeRange
QgsRange which stores a range of date times.
#define QGIS_PROTECT_QOBJECT_THREAD_ACCESS
Setting options for creating vector data providers.
Setting options for loading mesh layers.
QgsCoordinateTransformContext transformContext
Coordinate transform context.
bool loadDefaultStyle
Set to true if the default layer style should be loaded.
bool skipCrsValidation
Controls whether the layer is allowed to have an invalid/unknown CRS.
Mesh - vertices, edges and faces.
ElementType
Defines type of mesh elements.