QGIS API Documentation 3.99.0-Master (a8f284845db)
Loading...
Searching...
No Matches
qgsprocessingfieldmapwidgetwrapper.h
Go to the documentation of this file.
1/***************************************************************************
2 qgsprocessingfieldmapwidgetwrapper.h
3 ---------------------
4 Date : June 2020
5 Copyright : (C) 2020 by Nyall Dawson
6 Email : nyall dot dawson at gmail dot com
7 ***************************************************************************
8 * *
9 * This program is free software; you can redistribute it and/or modify *
10 * it under the terms of the GNU General Public License as published by *
11 * the Free Software Foundation; either version 2 of the License, or *
12 * (at your option) any later version. *
13 * *
14 ***************************************************************************/
15
16#ifndef QGSPROCESSINGFIELDMAPWIDGETWRAPPER_H
17#define QGSPROCESSINGFIELDMAPWIDGETWRAPPER_H
18
19
20#include "ui_qgsprocessingfieldsmappingpanelbase.h"
21
24
25#define SIP_NO_FILE
26
27class QLineEdit;
28class QToolButton;
29
31
32
33class GUI_EXPORT QgsProcessingFieldMapPanelWidget : public QgsPanelWidget, private Ui::QgsProcessingFieldMapPanelBase
34{
35 Q_OBJECT
36
37 public:
38 QgsProcessingFieldMapPanelWidget( QWidget *parent = nullptr );
39
40 void setLayer( QgsVectorLayer *layer );
41 QgsVectorLayer *layer();
42 QVariant value() const;
43 void setValue( const QVariant &value );
44
49 void registerExpressionContextGenerator( const QgsExpressionContextGenerator *generator );
50
51 signals:
52
53 void changed();
54
55 private slots:
56 void loadFieldsFromLayer();
57 void addField();
58 void loadLayerFields();
59
60 private:
61 QgsFieldMappingModel *mModel = nullptr;
62
63 QgsVectorLayer *mLayer = nullptr;
64 bool mSkipConfirmDialog = false;
65
66 bool mBlockChangedSignal = false;
67 friend class TestProcessingGui;
68};
69
70
71class GUI_EXPORT QgsProcessingFieldMapParameterDefinitionWidget : public QgsProcessingAbstractParameterDefinitionWidget
72{
73 Q_OBJECT
74 public:
75 QgsProcessingFieldMapParameterDefinitionWidget( QgsProcessingContext &context, const QgsProcessingParameterWidgetContext &widgetContext, const QgsProcessingParameterDefinition *definition = nullptr, const QgsProcessingAlgorithm *algorithm = nullptr, QWidget *parent SIP_TRANSFERTHIS = nullptr );
76 QgsProcessingParameterDefinition *createParameter( const QString &name, const QString &description, Qgis::ProcessingParameterFlags flags ) const override;
77
78 private:
79 QComboBox *mParentLayerComboBox = nullptr;
80};
81
82
83class GUI_EXPORT QgsProcessingFieldMapWidgetWrapper : public QgsAbstractProcessingParameterWidgetWrapper, public QgsProcessingParameterWidgetFactoryInterface
84{
85 Q_OBJECT
86
87 public:
88 QgsProcessingFieldMapWidgetWrapper( const QgsProcessingParameterDefinition *parameter = nullptr, Qgis::ProcessingMode type = Qgis::ProcessingMode::Standard, QWidget *parent = nullptr );
89
90 // QgsProcessingParameterWidgetFactoryInterface
91 QString parameterType() const override;
92 QgsAbstractProcessingParameterWidgetWrapper *createWidgetWrapper( const QgsProcessingParameterDefinition *parameter, Qgis::ProcessingMode type ) override SIP_FACTORY;
93
94 // QgsProcessingParameterWidgetWrapper interface
95 QWidget *createWidget() override SIP_FACTORY;
96 QgsProcessingAbstractParameterDefinitionWidget *createParameterDefinitionWidget(
97 QgsProcessingContext &context,
98 const QgsProcessingParameterWidgetContext &widgetContext,
99 const QgsProcessingParameterDefinition *definition = nullptr,
100 const QgsProcessingAlgorithm *algorithm = nullptr
101 ) override;
102
103 void postInitialize( const QList<QgsAbstractProcessingParameterWidgetWrapper *> &wrappers ) override;
104 int stretch() const override;
105
106 public slots:
107 void setParentLayerWrapperValue( const QgsAbstractProcessingParameterWidgetWrapper *parentWrapper );
108
109 protected:
110 void setWidgetValue( const QVariant &value, QgsProcessingContext &context ) override;
111 QVariant widgetValue() const override;
112
113 QString modelerExpressionFormatString() const override;
114 const QgsVectorLayer *linkedVectorLayer() const override;
115
116 private:
117 QgsProcessingFieldMapPanelWidget *mPanel = nullptr;
118 std::unique_ptr<QgsVectorLayer> mParentLayer;
119
120 friend class TestProcessingGui;
121};
122
123
125
126#endif // QGSPROCESSINGFIELDMAPWIDGETWRAPPER_H
ProcessingMode
Types of modes which Processing widgets can be created for.
Definition qgis.h:3757
@ Standard
Standard (single-run) algorithm mode.
Definition qgis.h:3758
QFlags< ProcessingParameterFlag > ProcessingParameterFlags
Flags which dictate the behavior of Processing parameters.
Definition qgis.h:3863
A widget wrapper for Processing parameter value widgets.
Abstract interface for generating an expression context.
Holds mapping information for mapping from one set of QgsFields to another.
Base class for any widget that can be shown as an inline panel.
Abstract base class for widgets which allow users to specify the properties of a Processing parameter...
An interface for Processing widget wrapper factories.
Represents a vector layer which manages a vector based dataset.
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
#define SIP_TRANSFERTHIS
Definition qgis_sip.h:52
#define SIP_FACTORY
Definition qgis_sip.h:83