30#include "moc_qgspointclusterrendererwidget.cpp"
32using namespace Qt::StringLiterals;
53 setupBlankUi( layer->name() );
57 connect( mRendererComboBox,
static_cast<void ( QComboBox::* )(
int )
>( &QComboBox::currentIndexChanged ),
this, &QgsPointClusterRendererWidget::mRendererComboBox_currentIndexChanged );
58 connect( mDistanceSpinBox,
static_cast<void ( QDoubleSpinBox::* )(
double )
>( &QDoubleSpinBox::valueChanged ),
this, &QgsPointClusterRendererWidget::mDistanceSpinBox_valueChanged );
60 connect( mRendererSettingsButton, &QPushButton::clicked,
this, &QgsPointClusterRendererWidget::mRendererSettingsButton_clicked );
61 this->layout()->setContentsMargins( 0, 0, 0, 0 );
73 mRenderer = std::make_unique<QgsPointClusterRenderer>();
75 renderer->copyRendererData( mRenderer.get() );
78 blockAllSignals(
true );
82 QStringList::const_iterator it = rendererList.constBegin();
83 for ( ; it != rendererList.constEnd(); ++it )
85 if ( *it !=
"pointDisplacement"_L1 && *it !=
"pointCluster"_L1 && *it !=
"heatmapRenderer"_L1 )
92 mDistanceSpinBox->setValue( mRenderer->tolerance() );
93 mDistanceUnitWidget->setUnit( mRenderer->toleranceUnit() );
94 mDistanceUnitWidget->setMapUnitScale( mRenderer->toleranceMapUnitScale() );
95 mCenterSymbolToolButton->setSymbol( mRenderer->clusterSymbol()->clone() );
97 blockAllSignals(
false );
100 if ( mRenderer->embeddedRenderer() )
102 const QString rendererName = mRenderer->embeddedRenderer()->type();
103 const int rendererIndex = mRendererComboBox->findData( rendererName );
104 if ( rendererIndex != -1 )
106 mRendererComboBox->setCurrentIndex( rendererIndex );
107 mRendererComboBox_currentIndexChanged( rendererIndex );
111 connect( mCenterSymbolToolButton, &
QgsSymbolButton::changed,
this, &QgsPointClusterRendererWidget::centerSymbolChanged );
112 mCenterSymbolToolButton->setDialogTitle( tr(
"Cluster symbol" ) );
113 mCenterSymbolToolButton->setLayer(
mLayer );
114 mCenterSymbolToolButton->registerExpressionContextGenerator(
this );
121 return mRenderer.get();
127 if ( mDistanceUnitWidget )
128 mDistanceUnitWidget->setMapCanvas(
context.mapCanvas() );
129 if ( mCenterSymbolToolButton )
131 mCenterSymbolToolButton->setMapCanvas(
context.mapCanvas() );
132 mCenterSymbolToolButton->setMessageBar(
context.messageBar() );
136void QgsPointClusterRendererWidget::mRendererComboBox_currentIndexChanged(
int index )
138 const QString rendererId = mRendererComboBox->itemData( index ).toString();
143 const std::unique_ptr<QgsFeatureRenderer> oldRenderer( mRenderer->embeddedRenderer()->clone() );
145 mRenderer->setEmbeddedRenderer( tempRenderWidget->
renderer()->
clone() );
146 delete tempRenderWidget;
151void QgsPointClusterRendererWidget::mRendererSettingsButton_clicked()
162 QgsExpressionContextScope scope;
165 QList<QgsExpressionContextScope> scopes =
mContext.additionalExpressionContextScopes();
168 context.setAdditionalExpressionContextScopes( scopes );
177void QgsPointClusterRendererWidget::mDistanceSpinBox_valueChanged(
double d )
181 mRenderer->setTolerance( d );
186void QgsPointClusterRendererWidget::mDistanceUnitWidget_changed()
190 mRenderer->setToleranceUnit( mDistanceUnitWidget->unit() );
191 mRenderer->setToleranceMapUnitScale( mDistanceUnitWidget->getMapUnitScale() );
196void QgsPointClusterRendererWidget::blockAllSignals(
bool block )
198 mRendererComboBox->blockSignals( block );
199 mCenterSymbolToolButton->blockSignals( block );
200 mDistanceSpinBox->blockSignals( block );
201 mDistanceUnitWidget->blockSignals( block );
207 if (
auto *lExpressionContext =
mContext.expressionContext() )
214 QList<QgsExpressionContextScope> scopes =
mContext.additionalExpressionContextScopes();
216 const auto constScopes = scopes;
225void QgsPointClusterRendererWidget::centerSymbolChanged()
227 mRenderer->setClusterSymbol( mCenterSymbolToolButton->clonedSymbol<
QgsMarkerSymbol>() );
231void QgsPointClusterRendererWidget::updateRendererFromWidget()
241void QgsPointClusterRendererWidget::setupBlankUi(
const QString &layerName )
243 QGridLayout *layout =
new QGridLayout(
this );
244 QLabel *label =
new QLabel( tr(
"The point cluster renderer only applies to (single) point layers. \n'%1' is not a (single) point layer and cannot be displayed by the point cluster renderer." ).arg( layerName ),
this );
245 layout->addWidget( label );
@ Millimeters
Millimeters.
@ Points
Points (e.g., for font sizes).
@ MetersInMapUnits
Meters value as Map units.
static QgsRendererRegistry * rendererRegistry()
Returns the application's renderer registry, used for managing vector layer renderers.
Single scope for storing variables and functions for use within a QgsExpressionContext.
void addVariable(const QgsExpressionContextScope::StaticVariable &variable)
Adds a variable into the context scope.
Expression contexts are used to encapsulate the parameters around which a QgsExpression should be eva...
static const QString EXPR_CLUSTER_SIZE
Inbuilt variable name for cluster size variable.
static const QString EXPR_CLUSTER_COLOR
Inbuilt variable name for cluster color variable.
Abstract base class for all 2D vector feature renderers.
virtual QgsFeatureRenderer * clone() const =0
Create a deep copy of this renderer.
A marker symbol type, for rendering Point and MultiPoint geometries.
static QgsPointClusterRenderer * convertFromRenderer(const QgsFeatureRenderer *renderer)
Creates a QgsPointClusterRenderer from an existing renderer.
QStringList renderersList(QgsRendererAbstractMetadata::LayerTypes layerTypes=QgsRendererAbstractMetadata::All) const
Returns a list of available renderers.
QgsRendererAbstractMetadata * rendererMetadata(const QString &rendererName)
Returns the metadata for a specified renderer.
A database of saved style entities, including symbols, color ramps, text formats and others.
Contains settings which reflect the context in which a symbol (or renderer) widget is shown,...
Represents a vector layer which manages a vector based dataset.
Q_INVOKABLE Qgis::WkbType wkbType() const final
Returns the WKBType or WKBUnknown in case of error.
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...
Single variable definition for use within a QgsExpressionContextScope.