17#include "moc_qgsmeshrenderervectorsettingswidget.cpp"
27 QVector<QgsDoubleSpinBox *> widgets;
28 widgets << mMinMagSpinBox << mMaxMagSpinBox
29 << mHeadWidthSpinBox << mHeadLengthSpinBox
30 << mMinimumShaftSpinBox << mMaximumShaftSpinBox
31 << mScaleShaftByFactorOfSpinBox << mShaftLengthSpinBox
32 << mWindBarbLengthSpinBox << mWindBarbMagnitudeMultiplierSpinBox;
35 for (
const auto &widget : std::as_const( widgets ) )
38 widget->setSpecialValueText( QString() );
39 widget->setValue( widget->minimum() );
42 mShaftLengthComboBox->setCurrentIndex( -1 );
47 mXSpacingSpinBox->setClearValue( 10.0 );
48 mYSpacingSpinBox->setClearValue( 10.0 );
49 mStreamlinesDensitySpinBox->setClearValue( 15.0 );
50 mTracesParticlesCountSpinBox->setClearValue( 1000 );
51 mTracesMaxLengthSpinBox->setClearValue( 100.0 );
53 mWindBarbLengthSpinBox->setClearValue( 10.0 );
54 mWindBarbMagnitudeMultiplierSpinBox->setValue( 1.0 );
55 mWindBarbMagnitudeMultiplierSpinBox->setClearValue( 1.0 );
58 connect( mColoringMethodComboBox, qOverload<int>( &QComboBox::currentIndexChanged ),
this, &QgsMeshRendererVectorSettingsWidget::onColoringMethodChanged );
60 connect( mColorRampShaderMinimumSpinBox, qOverload<double>( &QgsDoubleSpinBox::valueChanged ),
this, &QgsMeshRendererVectorSettingsWidget::onColorRampMinMaxChanged );
61 connect( mColorRampShaderMaximumSpinBox, qOverload<double>( &QgsDoubleSpinBox::valueChanged ),
this, &QgsMeshRendererVectorSettingsWidget::onColorRampMinMaxChanged );
67 connect( mShaftLengthComboBox, qOverload<int>( &QComboBox::currentIndexChanged ), mShaftOptionsStackedWidget, &QStackedWidget::setCurrentIndex );
71 connect( mColorRampShaderLoadButton, &QPushButton::clicked,
this, &QgsMeshRendererVectorSettingsWidget::loadColorRampShader );
73 onColoringMethodChanged();
75 for (
const auto &widget : std::as_const( widgets ) )
83 connect( mSymbologyVectorComboBox, qOverload<int>( &QComboBox::currentIndexChanged ),
this, &QgsMeshRendererVectorSettingsWidget::onSymbologyChanged );
84 onSymbologyChanged( 0 );
88 connect( mStreamlinesSeedingMethodComboBox, qOverload<int>( &QComboBox::currentIndexChanged ),
this, &QgsMeshRendererVectorSettingsWidget::onStreamLineSeedingMethodChanged );
89 onStreamLineSeedingMethodChanged( 0 );
99 mTracesTailLengthMapUnitWidget->setUnits(
109 mWindBarbLengthMapUnitWidget->setUnits(
117 connect( mWindBarbUnitsComboBox, qOverload<int>( &QComboBox::currentIndexChanged ),
this, &QgsMeshRendererVectorSettingsWidget::onWindBarbUnitsChanged );
118 onWindBarbUnitsChanged( 0 );
143 double val = filterValue( mMinMagSpinBox, -1 );
146 val = filterValue( mMaxMagSpinBox, -1 );
157 bool enabled = mDisplayVectorsOnGridGroupBox->isChecked();
166 val = filterValue( mMinimumShaftSpinBox, arrowSettings.
minShaftLength() );
169 val = filterValue( mMaximumShaftSpinBox, arrowSettings.
maxShaftLength() );
172 val = filterValue( mScaleShaftByFactorOfSpinBox, arrowSettings.
scaleFactor() );
186 streamlineSettings.
setSeedingDensity( mStreamlinesDensitySpinBox->value() / 100 );
199 windBarbSettings.
setShaftLength( mWindBarbLengthSpinBox->value() );
215 if ( mActiveDatasetGroup < 0 )
223 symbologyLabel->setVisible( hasFaces );
224 mSymbologyVectorComboBox->setVisible( hasFaces );
225 mSymbologyVectorComboBox->setCurrentIndex( hasFaces ?
settings.
symbology() : 0 );
233 mColoringMethodComboBox->setCurrentIndex( mColoringMethodComboBox->findData(
settings.
coloringMethod() ) );
253 mDisplayVectorsOnGridGroupBox->setVisible( hasFaces );
263 mScaleShaftByFactorOfSpinBox->setValue( arrowSettings.
scaleFactor() );
269 mStreamlinesSeedingMethodComboBox->setCurrentIndex( streamlinesSettings.
seedingMethod() );
270 mStreamlinesDensitySpinBox->setValue( streamlinesSettings.
seedingDensity() * 100 );
277 mTracesParticlesCountSpinBox->setValue( tracesSettings.
particlesCount() );
281 mWindBarbLengthSpinBox->setValue( windBarbSettings.
shaftLength() );
282 mWindBarbUnitsComboBox->setCurrentIndex(
static_cast<int>( windBarbSettings.
magnitudeUnits() ) );
287void QgsMeshRendererVectorSettingsWidget::onSymbologyChanged(
int currentIndex )
302 mDisplayVectorsOnGridGroupBox->setEnabled(
307void QgsMeshRendererVectorSettingsWidget::onStreamLineSeedingMethodChanged(
int currentIndex )
310 mStreamlinesDensityLabel->setEnabled( enabled );
311 mStreamlinesDensitySpinBox->setEnabled( enabled );
313 mDisplayVectorsOnGridGroupBox->setEnabled( !enabled );
316void QgsMeshRendererVectorSettingsWidget::onWindBarbUnitsChanged(
int currentIndex )
326void QgsMeshRendererVectorSettingsWidget::onColoringMethodChanged()
332 if ( mColorRampShaderWidget->shader().colorRampItemList().isEmpty() )
333 loadColorRampShader();
338void QgsMeshRendererVectorSettingsWidget::onColorRampMinMaxChanged()
340 mColorRampShaderWidget->setMinimumMaximumAndClassify(
341 filterValue( mColorRampShaderMinimumSpinBox, 0 ),
342 filterValue( mColorRampShaderMaximumSpinBox, 0 )
346void QgsMeshRendererVectorSettingsWidget::loadColorRampShader()
352 if ( currentVectorDataSetGroupIndex < 0 || !mMeshLayer->datasetGroupMetadata( currentVectorDataSetGroupIndex ).isVector() )
359 mColorRampShaderWidget->setMinimumMaximumAndClassify( min, max );
360 whileBlocking( mColorRampShaderMinimumSpinBox )->setValue( min );
361 whileBlocking( mColorRampShaderMaximumSpinBox )->setValue( max );
364double QgsMeshRendererVectorSettingsWidget::filterValue(
const QgsDoubleSpinBox *spinBox,
double errVal )
const
366 if ( spinBox->value() == spinBox->
clearValue() )
369 return spinBox->value();
@ Millimeters
Millimeters.
@ Points
Points (e.g., for font sizes)
@ MetersInMapUnits
Meters value as Map units.
The QgsSpinBox is a spin box with a clear button that will set the value to the defined clear value.
@ MinimumValue
Reset value to minimum()
ColoringMethod
Defines how the color is defined.
@ ColorRamp
Render with a color ramp.
@ SingleColor
Render with a single color.
bool contains(const QgsMesh::ElementType &type) const
Returns whether the mesh contains at mesh elements of given type.
Represents a mesh layer supporting display of data on structured or unstructured meshes.
QgsMeshRendererSettings rendererSettings() const
Returns renderer settings.
QgsMeshDataProvider * dataProvider() override
Returns the layer's data provider, it may be nullptr.
QgsMeshDatasetGroupMetadata datasetGroupMetadata(const QgsMeshDatasetIndex &index) const
Returns the dataset groups metadata.
Represents all mesh renderer settings.
int activeVectorDatasetGroup() const
Returns the active vector dataset group.
QgsMeshRendererVectorSettings vectorSettings(int groupIndex) const
Returns renderer settings.
Represents a mesh renderer settings for vector datasets displayed with arrows.
void setFixedShaftLength(double fixedShaftLength)
Sets fixed length (in millimeters)
void setMaxShaftLength(double maxShaftLength)
Sets maximum shaft length (in millimeters)
QgsMeshRendererVectorArrowSettings::ArrowScalingMethod shaftLengthMethod() const
Returns method used for drawing arrows.
void setMinShaftLength(double minShaftLength)
Sets mininimum shaft length (in millimeters)
double fixedShaftLength() const
Returns fixed arrow length (in millimeters)
void setArrowHeadWidthRatio(double arrowHeadWidthRatio)
Sets ratio of the head width of the arrow (range 0-1)
double scaleFactor() const
Returns scale factor.
double maxShaftLength() const
Returns maximum shaft length (in millimeters)
double arrowHeadWidthRatio() const
Returns ratio of the head width of the arrow (range 0-1)
void setArrowHeadLengthRatio(double arrowHeadLengthRatio)
Sets ratio of the head length of the arrow (range 0-1)
void setScaleFactor(double scaleFactor)
Sets scale factor.
void setShaftLengthMethod(ArrowScalingMethod shaftLengthMethod)
Sets method used for drawing arrows.
ArrowScalingMethod
Algorithm how to transform vector magnitude to length of arrow on the device in pixels.
double minShaftLength() const
Returns mininimum shaft length (in millimeters)
double arrowHeadLengthRatio() const
Returns ratio of the head length of the arrow (range 0-1)
Represents a renderer settings for vector datasets.
void setColorRampShader(const QgsColorRampShader &colorRampShader)
Returns the color ramp shader used to render vector datasets.
void setStreamLinesSettings(const QgsMeshRendererVectorStreamlineSettings &streamLinesSettings)
Sets settings for vector rendered with streamlines.
int userGridCellWidth() const
Returns width in pixels of user grid cell.
void setArrowsSettings(const QgsMeshRendererVectorArrowSettings &arrowSettings)
Sets settings for vector rendered with arrows.
void setUserGridCellWidth(int width)
Sets width of user grid cell (in pixels)
void setColor(const QColor &color)
Sets color used for drawing arrows.
QgsMeshRendererVectorTracesSettings tracesSettings() const
Returns settings for vector rendered with traces.
QColor color() const
Returns color used for drawing arrows.
int userGridCellHeight() const
Returns height in pixels of user grid cell.
void setOnUserDefinedGrid(bool enabled)
Toggles drawing of vectors on user defined grid.
double lineWidth() const
Returns line width of the arrow (in millimeters)
Symbology
Defines the symbology of vector rendering.
@ Traces
Displaying vector dataset with particle traces.
@ Arrows
Displaying vector dataset with arrows.
@ WindBarbs
Displaying vector dataset with wind barbs.
@ Streamlines
Displaying vector dataset with streamlines.
void setUserGridCellHeight(int height)
Sets height of user grid cell (in pixels)
Symbology symbology() const
Returns the displaying method used to render vector datasets.
double filterMax() const
Returns filter value for vector magnitudes.
QgsColorRampShader colorRampShader() const
Sets the color ramp shader used to render vector datasets.
void setSymbology(const Symbology &symbology)
Sets the displaying method used to render vector datasets.
void setFilterMin(double filterMin)
Sets filter value for vector magnitudes.
QgsMeshRendererVectorArrowSettings arrowSettings() const
Returns settings for vector rendered with arrows.
void setFilterMax(double filterMax)
Sets filter value for vector magnitudes.
void setTracesSettings(const QgsMeshRendererVectorTracesSettings &tracesSettings)
Sets settings for vector rendered with traces.
void setColoringMethod(const QgsInterpolatedLineColor::ColoringMethod &coloringMethod)
Sets the coloring method used to render vector datasets.
QgsInterpolatedLineColor::ColoringMethod coloringMethod() const
Returns the coloring method used to render vector datasets.
QgsMeshRendererVectorWindBarbSettings windBarbSettings() const
Returns settings for vector rendered with wind barbs.
void setLineWidth(double lineWidth)
Sets line width of the arrow in pixels (in millimeters)
bool isOnUserDefinedGrid() const
Returns whether vectors are drawn on user-defined grid.
double filterMin() const
Returns filter value for vector magnitudes.
void setWindBarbSettings(const QgsMeshRendererVectorWindBarbSettings &windBarbSettings)
Sets settings for vector rendered with wind barbs.
QgsMeshRendererVectorStreamlineSettings streamLinesSettings() const
Returns settings for vector rendered with streamlines.
Represents a streamline renderer settings for vector datasets displayed by streamlines.
void setSeedingDensity(double seedingDensity)
Sets the density used for seeding start points.
SeedingStartPointsMethod seedingMethod() const
Returns the method used for seeding start points of strealines.
void setSeedingMethod(const SeedingStartPointsMethod &seedingMethod)
Sets the method used for seeding start points of strealines.
SeedingStartPointsMethod
Method used to define start points that are used to draw streamlines.
@ Random
Seeds start points randomly on the mesh.
@ MeshGridded
Seeds start points on the vertices mesh or user regular grid.
double seedingDensity() const
Returns the density used for seeding start points.
Represents a trace renderer settings for vector datasets displayed by particle traces.
Qgis::RenderUnit maximumTailLengthUnit() const
Returns the maximum tail length unit.
void setMaximumTailLength(double maximumTailLength)
Sets the maximums tail length.
void setMaximumTailLengthUnit(Qgis::RenderUnit maximumTailLengthUnit)
Sets the maximum tail length unit.
double maximumTailLength() const
Returns the maximum tail length.
int particlesCount() const
Returns particles count.
void setParticlesCount(int value)
Sets particles count.
Represents a mesh renderer settings for vector datasets displayed with wind barbs.
void setShaftLengthUnits(Qgis::RenderUnit shaftLengthUnit)
Sets the units for the shaft length.
WindSpeedUnit magnitudeUnits() const
Returns the units that the data are in.
void setMagnitudeUnits(WindSpeedUnit units)
Sets the units that the data are in.
void setMagnitudeMultiplier(double magnitudeMultiplier)
Sets a multiplier for the magnitude to convert it to knots.
double shaftLength() const
Returns the shaft length (in millimeters)
void setShaftLength(double shaftLength)
Sets the shaft length (in millimeters)
WindSpeedUnit
Wind speed units. Wind barbs use knots so we use this enum for preset conversion values.
double magnitudeMultiplier() const
Returns the multiplier for the magnitude to convert it to knots, according to the units set with setM...
double maximumValue() const
Returns the minimum value for the raster shader.
double minimumValue() const
Returns the maximum value for the raster shader.
QgsSignalBlocker< Object > whileBlocking(Object *object)
Temporarily blocks signals from a QObject while calling a single method from the object.