16#ifndef QGSPROCESSINGMESHDATASETWIDGET_H
17#define QGSPROCESSINGMESHDATASETWIDGET_H
19#include "ui_qgsprocessingmeshdatasettimewidget.h"
31class GUI_EXPORT QgsProcessingMeshDatasetGroupsWidget :
public QWidget
42 void setMeshLayer(
QgsMeshLayer *layer,
bool layerFromProject =
false );
43 void setValue(
const QVariant &value );
44 QVariant value()
const;
51 void selectCurrentActiveDatasetGroup();
57 QPointer<QLineEdit> mLineEdit;
58 QPointer<QToolButton> mToolButton;
59 QPointer<QAction> mActionCurrentActiveDatasetGroups;
60 QPointer<QAction> mActionAvailableDatasetGroups;
62 QMap<int, QString> mDatasetGroupsNames;
64 QStringList datasetGroupsNames();
65 void updateSummaryText();
67 friend class TestProcessingGui;
78 QString parameterType()
const override;
79 QgsAbstractProcessingParameterWidgetWrapper *createWidgetWrapper(
const QgsProcessingParameterDefinition *parameter,
Qgis::ProcessingMode type )
override;
80 QgsProcessingAbstractParameterDefinitionWidget *createParameterDefinitionWidget(
81 QgsProcessingContext &context,
const QgsProcessingParameterWidgetContext &widgetContext,
const QgsProcessingParameterDefinition *definition =
nullptr,
const QgsProcessingAlgorithm *
algorithm =
nullptr
83 void postInitialize(
const QList<QgsAbstractProcessingParameterWidgetWrapper *> &wrappers )
override;
86 void setMeshLayerWrapperValue(
const QgsAbstractProcessingParameterWidgetWrapper *wrapper );
89 QWidget *createWidget()
override;
90 void setWidgetValue(
const QVariant &value, QgsProcessingContext &context )
override;
91 QVariant widgetValue()
const override;
94 QgsProcessingMeshDatasetGroupsWidget *mWidget =
nullptr;
96 friend class TestProcessingGui;
104 QgsProcessingMeshDatasetGroupsParameterDefinitionWidget(
105 QgsProcessingContext &context,
106 const QgsProcessingParameterWidgetContext &widgetContext,
107 const QgsProcessingParameterDefinition *definition =
nullptr,
108 const QgsProcessingAlgorithm *
algorithm =
nullptr,
112 QgsProcessingParameterDefinition *createParameter(
const QString &name,
const QString &description,
Qgis::ProcessingParameterFlags flags )
const override;
115 QComboBox *mParentLayerComboBox =
nullptr;
118class GUI_EXPORT QgsProcessingMeshDatasetTimeWidget :
public QWidget,
private Ui::QgsProcessingMeshDatasetTimeWidgetBase
123 QgsProcessingMeshDatasetTimeWidget(
124 QWidget *parent =
nullptr,
const QgsProcessingParameterMeshDatasetTime *param =
nullptr,
const QgsProcessingParameterWidgetContext &context = QgsProcessingParameterWidgetContext()
132 void setMeshLayer( QgsMeshLayer *layer,
bool layerFromProject =
false );
133 void setDatasetGroupIndexes(
const QList<int> datasetGroupIndexes );
135 void setValue(
const QVariant &value );
136 QVariant value()
const;
145 const QgsProcessingParameterMeshDatasetTime *mParam =
nullptr;
147 QgsMapCanvas *mCanvas;
149 QLineEdit *mLineEdit =
nullptr;
150 QToolButton *mToolButton =
nullptr;
151 QgsMeshLayer *mMeshLayer =
nullptr;
152 QList<int> mDatasetGroupIndexes;
153 QDateTime mReferenceTime;
155 void populateTimeSteps();
156 bool hasTemporalDataset()
const;
158 void populateTimeStepsFromLayer();
160 void storeTimeStepsFromLayer( QgsMeshLayer *layer );
161 QMap<int, QList<qint64>> mDatasetTimeSteps;
166 friend class TestProcessingGui;
176 QString parameterType()
const override;
177 QgsAbstractProcessingParameterWidgetWrapper *createWidgetWrapper(
const QgsProcessingParameterDefinition *parameter,
Qgis::ProcessingMode type )
override;
178 void postInitialize(
const QList<QgsAbstractProcessingParameterWidgetWrapper *> &wrappers )
override;
179 QgsProcessingAbstractParameterDefinitionWidget *createParameterDefinitionWidget(
180 QgsProcessingContext &context,
const QgsProcessingParameterWidgetContext &widgetContext,
const QgsProcessingParameterDefinition *definition =
nullptr,
const QgsProcessingAlgorithm *
algorithm =
nullptr
184 void setMeshLayerWrapperValue(
const QgsAbstractProcessingParameterWidgetWrapper *wrapper );
187 void setDatasetGroupIndexesWrapperValue(
const QgsAbstractProcessingParameterWidgetWrapper *wrapper );
190 QWidget *createWidget()
override;
191 void setWidgetValue(
const QVariant &value, QgsProcessingContext &context )
override;
192 QVariant widgetValue()
const override;
195 QgsProcessingMeshDatasetTimeWidget *mWidget =
nullptr;
196 std::unique_ptr<QgsMeshLayer> mTemporarytMeshLayer;
197 friend class TestProcessingGui;
205 QgsProcessingMeshDatasetTimeParameterDefinitionWidget(
206 QgsProcessingContext &context,
207 const QgsProcessingParameterWidgetContext &widgetContext,
208 const QgsProcessingParameterDefinition *definition =
nullptr,
209 const QgsProcessingAlgorithm *
algorithm =
nullptr,
213 QgsProcessingParameterDefinition *createParameter(
const QString &name,
const QString &description,
Qgis::ProcessingParameterFlags flags )
const override;
216 QComboBox *mParentDatasetComboBox =
nullptr;
217 QString mMeshLayerParameterName;
ProcessingMode
Types of modes which Processing widgets can be created for.
@ Standard
Standard (single-run) algorithm mode.
QFlags< ProcessingParameterFlag > ProcessingParameterFlags
Flags which dictate the behavior of Processing parameters.
Represents a mesh layer supporting display of data on structured or unstructured meshes.
A parameter for processing algorithms that need a list of mesh dataset groups.
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 allowing algorithms to be written in pure substantial changes are required in order to port existing x Processing algorithms for QGIS x The most significant changes are outlined not GeoAlgorithm For algorithms which operate on features one by consider subclassing the QgsProcessingFeatureBasedAlgorithm class This class allows much of the boilerplate code for looping over features from a vector layer to be bypassed and instead requires implementation of a processFeature method Ensure that your algorithm(or algorithm 's parent class) implements the new pure virtual createInstance(self) call