QGIS API Documentation 3.99.0-Master (2fe06baccd8)
Loading...
Searching...
No Matches
qgsprocessingtoolboxmodel.h
Go to the documentation of this file.
1/***************************************************************************
2 qgsprocessingtoolboxmodel.h
3 ---------------------------
4 begin : May 2018
5 copyright : (C) 2018 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 QGSPROCESSINGTOOLBOXMODEL_H
17#define QGSPROCESSINGTOOLBOXMODEL_H
18
19#include "qgis.h"
20#include "qgis_gui.h"
22
23#include <QAbstractItemModel>
24#include <QPointer>
25#include <QSortFilterProxyModel>
26
27class QgsVectorLayer;
31class QgsProcessingToolboxModelGroupNode;
32class QgsProcessingRecentAlgorithmLog;
33class QgsProcessingFavoriteAlgorithmManager;
34
36
43class GUI_EXPORT QgsProcessingToolboxModelNode : public QObject
44{
45 Q_OBJECT
46
47#ifdef SIP_RUN
49 if ( sipCpp->inherits( "QgsProcessingToolboxModelNode" ) )
50 {
51 sipType = sipType_QgsProcessingToolboxModelNode;
52 QgsProcessingToolboxModelNode *node = qobject_cast<QgsProcessingToolboxModelNode *>( sipCpp );
53 if ( node->nodeType() == QgsProcessingToolboxModelNode::NodeType::Provider )
54 sipType = sipType_QgsProcessingToolboxModelProviderNode;
55 else if ( node->nodeType() == QgsProcessingToolboxModelNode::NodeType::Group )
56 sipType = sipType_QgsProcessingToolboxModelGroupNode;
57 else if ( node->nodeType() == QgsProcessingToolboxModelNode::NodeType::Algorithm )
58 sipType = sipType_QgsProcessingToolboxModelAlgorithmNode;
59 else if ( node->nodeType() == QgsProcessingToolboxModelNode::NodeType::Parameter )
60 sipType = sipType_QgsProcessingToolboxModelParameterNode;
61 else if ( node->nodeType() == QgsProcessingToolboxModelNode::NodeType::Recent )
62 sipType = sipType_QgsProcessingToolboxModelRecentNode;
63 else if ( node->nodeType() == QgsProcessingToolboxModelNode::NodeType::Favorite )
64 sipType = sipType_QgsProcessingToolboxModelFavoriteNode;
65 else if ( node->nodeType() == QgsProcessingToolboxModelNode::NodeType::ParameterGroup )
66 sipType = sipType_QgsProcessingToolboxModelParameterGroupNode;
67 }
68 else
69 sipType = 0;
71#endif
72
73 public:
74 // *INDENT-OFF*
75
77 enum class NodeType SIP_MONKEYPATCH_SCOPEENUM_UNNEST( QgsProcessingToolboxModelNode, NodeType ) : int
78 {
79 Provider SIP_MONKEYPATCH_COMPAT_NAME( NodeProvider ) = 0,
80 Group SIP_MONKEYPATCH_COMPAT_NAME( NodeGroup ),
81 Algorithm SIP_MONKEYPATCH_COMPAT_NAME( NodeAlgorithm ),
82 Recent SIP_MONKEYPATCH_COMPAT_NAME( NodeRecent ),
83 Parameter,
84 ParameterGroup,
85 Favorite,
86 };
87 Q_ENUM( NodeType )
88 // *INDENT-ON*
89
90 ~QgsProcessingToolboxModelNode() override;
91
95 virtual NodeType nodeType() const = 0;
96
100 QgsProcessingToolboxModelNode *parent() { return mParent; }
101
105 QList<QgsProcessingToolboxModelNode *> children() { return mChildren; }
106
111 QList<QgsProcessingToolboxModelNode *> children() const SIP_SKIP
112 {
113 return mChildren;
114 }
115
120 QgsProcessingToolboxModelNode *takeChild( QgsProcessingToolboxModelNode *node );
121
127 QgsProcessingToolboxModelGroupNode *getChildGroupNode( const QString &id );
128
133 void addChildNode( QgsProcessingToolboxModelNode *node SIP_TRANSFER );
134
138 void deleteChildren();
139
140 private:
141 QgsProcessingToolboxModelNode *mParent = nullptr;
142 QList<QgsProcessingToolboxModelNode *> mChildren;
143};
144
151class GUI_EXPORT QgsProcessingToolboxModelRecentNode : public QgsProcessingToolboxModelNode
152{
153 Q_OBJECT
154
155 public:
156 QgsProcessingToolboxModelRecentNode() = default;
157
158 NodeType nodeType() const override { return NodeType::Recent; }
159};
160
167class GUI_EXPORT QgsProcessingToolboxModelFavoriteNode : public QgsProcessingToolboxModelNode
168{
169 Q_OBJECT
170
171 public:
172 QgsProcessingToolboxModelFavoriteNode() = default;
173
174 NodeType nodeType() const override { return NodeType::Favorite; }
175};
176
183class GUI_EXPORT QgsProcessingToolboxModelParameterGroupNode : public QgsProcessingToolboxModelNode
184{
185 Q_OBJECT
186
187 public:
188 QgsProcessingToolboxModelParameterGroupNode() = default;
189
190 NodeType nodeType() const override { return NodeType::ParameterGroup; }
191};
192
199class GUI_EXPORT QgsProcessingToolboxModelProviderNode : public QgsProcessingToolboxModelNode
200{
201 Q_OBJECT
202
203 public:
208 QgsProcessingToolboxModelProviderNode( QgsProcessingProvider *provider );
209
210 NodeType nodeType() const override { return NodeType::Provider; }
211
215 QgsProcessingProvider *provider();
216
220 QString providerId() const { return mProviderId; }
221
222 private:
223 // NOTE: we store both the provider ID and a pointer to the provider here intentionally.
224 // We store the provider pointer to avoid having to lookup the provider from the registry
225 // every time the node is used (which kills performance in the filter proxy model), but
226 // we also store the provider id string in order to identify the provider that the node
227 // is linked to for cleanups after the provider is removed.
228 QString mProviderId;
229 QPointer<QgsProcessingProvider> mProvider;
230};
231
238class GUI_EXPORT QgsProcessingToolboxModelGroupNode : public QgsProcessingToolboxModelNode
239{
240 Q_OBJECT
241
242 public:
250 QgsProcessingToolboxModelGroupNode( const QString &id, const QString &name );
251
252 NodeType nodeType() const override { return NodeType::Group; }
253
257 QString id() const { return mId; }
258
262 QString name() const { return mName; }
263
264 private:
265 QString mId;
266 QString mName;
267};
268
275class GUI_EXPORT QgsProcessingToolboxModelAlgorithmNode : public QgsProcessingToolboxModelNode
276{
277 Q_OBJECT
278
279 public:
284 QgsProcessingToolboxModelAlgorithmNode( const QgsProcessingAlgorithm *algorithm );
285
286 NodeType nodeType() const override { return NodeType::Algorithm; }
287
291 const QgsProcessingAlgorithm *algorithm() const;
292
293 private:
294 const QgsProcessingAlgorithm *mAlgorithm = nullptr;
295};
296
297
304class GUI_EXPORT QgsProcessingToolboxModelParameterNode : public QgsProcessingToolboxModelNode
305{
306 Q_OBJECT
307
308 public:
313 QgsProcessingToolboxModelParameterNode( const QgsProcessingParameterType *paramType );
314
315 NodeType nodeType() const override { return NodeType::Parameter; }
316
320 const QgsProcessingParameterType *parameterType() const;
321
322 private:
323 const QgsProcessingParameterType *mParamType = nullptr;
324};
325
327
337class GUI_EXPORT QgsProcessingToolboxModel : public QAbstractItemModel
338{
339 Q_OBJECT
340
341 public:
342 // *INDENT-OFF*
343
351 {
352 NodeType SIP_MONKEYPATCH_COMPAT_NAME( RoleNodeType ) = Qt::UserRole,
353 AlgorithmFlags SIP_MONKEYPATCH_COMPAT_NAME( RoleAlgorithmFlags ),
354 AlgorithmId SIP_MONKEYPATCH_COMPAT_NAME( RoleAlgorithmId ),
355 AlgorithmName SIP_MONKEYPATCH_COMPAT_NAME( RoleAlgorithmName ),
356 AlgorithmShortDescription SIP_MONKEYPATCH_COMPAT_NAME( RoleAlgorithmShortDescription ),
357 AlgorithmTags SIP_MONKEYPATCH_COMPAT_NAME( RoleAlgorithmTags ),
358 ProviderFlags SIP_MONKEYPATCH_COMPAT_NAME( RoleProviderFlags ),
359 ParameterTypeId,
360 };
361 Q_ENUM( CustomRole )
362 // *INDENT-ON*
363
364
378 QgsProcessingToolboxModel( QObject *parent SIP_TRANSFERTHIS = nullptr, QgsProcessingRegistry *registry = nullptr, QgsProcessingRecentAlgorithmLog *recentLog = nullptr, QgsProcessingFavoriteAlgorithmManager *favoriteManager = nullptr );
379
380 Qt::ItemFlags flags( const QModelIndex &index ) const override;
381 QVariant data( const QModelIndex &index, int role = Qt::DisplayRole ) const override;
382 int rowCount( const QModelIndex &parent = QModelIndex() ) const override;
383 int columnCount( const QModelIndex & = QModelIndex() ) const override;
384 QModelIndex index( int row, int column, const QModelIndex &parent = QModelIndex() ) const override;
385 QModelIndex parent( const QModelIndex &index ) const override;
386 QMimeData *mimeData( const QModelIndexList &indexes ) const override;
387
392 QgsProcessingToolboxModelNode *index2node( const QModelIndex &index ) const;
393
398 QModelIndex node2index( QgsProcessingToolboxModelNode *node ) const;
399
407 QgsProcessingProvider *providerForIndex( const QModelIndex &index ) const;
408
416 QString providerIdForIndex( const QModelIndex &index ) const;
417
425 const QgsProcessingAlgorithm *algorithmForIndex( const QModelIndex &index ) const;
426
432 bool isAlgorithm( const QModelIndex &index ) const;
433
442 const QgsProcessingParameterType *parameterTypeForIndex( const QModelIndex &index ) const;
443
450 bool isParameter( const QModelIndex &index ) const;
451
456 QModelIndex indexForProvider( const QString &providerId ) const;
457
461 QModelIndex indexOfParentTreeNode( QgsProcessingToolboxModelNode *parentNode ) const;
462
463 signals:
464
469
474
475 private slots:
476
477 void rebuild();
478 void repopulateRecentAlgorithms( bool resetting = false );
479 void repopulateFavoriteAlgorithms( bool resetting = false );
480
481 private:
482 QPointer<QgsProcessingRegistry> mRegistry;
483 QPointer<QgsProcessingRecentAlgorithmLog> mRecentLog;
484 QPointer<QgsProcessingFavoriteAlgorithmManager> mFavoriteManager;
485
486 std::unique_ptr<QgsProcessingToolboxModelGroupNode> mRootNode;
487 QgsProcessingToolboxModelRecentNode *mRecentNode = nullptr;
488 QgsProcessingToolboxModelFavoriteNode *mFavoriteNode = nullptr;
489
490 void addProvider( QgsProcessingProvider *provider );
491
496 static bool isTopLevelProvider( const QString &providerId );
497
501 static QString toolTipForAlgorithm( const QgsProcessingAlgorithm *algorithm );
502};
503
504
514class GUI_EXPORT QgsProcessingToolboxProxyModel : public QSortFilterProxyModel
515{
516 Q_OBJECT
517
518 public:
519 // *INDENT-OFF*
520
523 {
524 Toolbox SIP_MONKEYPATCH_COMPAT_NAME( FilterToolbox ) = 1 << 1,
525 Modeler SIP_MONKEYPATCH_COMPAT_NAME( FilterModeler ) = 1 << 2,
526 InPlace SIP_MONKEYPATCH_COMPAT_NAME( FilterInPlace ) = 1 << 3,
527 ShowKnownIssues SIP_MONKEYPATCH_COMPAT_NAME( FilterShowKnownIssues ) = 1 << 4,
528 };
529 Q_ENUM( Filter )
530 Q_DECLARE_FLAGS( Filters, Filter )
531 Q_FLAG( Filters )
532 // *INDENT-ON*
533
548 explicit QgsProcessingToolboxProxyModel( QObject *parent SIP_TRANSFERTHIS = nullptr, QgsProcessingRegistry *registry = nullptr, QgsProcessingRecentAlgorithmLog *recentLog = nullptr, QgsProcessingFavoriteAlgorithmManager *favoriteManager = nullptr );
549
554
560
566
571 Filters filters() const { return mFilters; }
572
576 void setInPlaceLayer( QgsVectorLayer *layer );
577
587 void setFilterString( const QString &filter );
588
594 QString filterString() const { return mFilterString; }
595
596 bool filterAcceptsRow( int sourceRow, const QModelIndex &sourceParent ) const override;
597 bool lessThan( const QModelIndex &left, const QModelIndex &right ) const override;
598 QVariant data( const QModelIndex &index, int role = Qt::DisplayRole ) const override;
599
600 private:
601 QgsProcessingToolboxModel *mModel = nullptr;
602 Filters mFilters = Filters();
603 QString mFilterString;
604 QPointer<QgsVectorLayer> mInPlaceLayer;
605};
607
608#endif // QGSPROCESSINGTOOLBOXMODEL_H
Abstract base class for processing algorithms.
Makes metadata of processing parameters available.
Abstract base class for processing providers.
Registry for various processing components, including providers, algorithms and various parameters an...
A model for providers and algorithms shown within the Processing toolbox.
QgsProcessingToolboxModel(QObject *parent=nullptr, QgsProcessingRegistry *registry=nullptr, QgsProcessingRecentAlgorithmLog *recentLog=nullptr, QgsProcessingFavoriteAlgorithmManager *favoriteManager=nullptr)
Constructor for QgsProcessingToolboxModel, with the given parent object.
void recentAlgorithmAdded()
Emitted whenever recent algorithms are added to the model.
void favoriteAlgorithmAdded()
Emitted whenever favorite algorithms are added to the model.
Filters filters() const
Returns any filters that affect how toolbox content is filtered.
QString filterString() const
Returns the current filter string, if set.
void setFilters(QgsProcessingToolboxProxyModel::Filters filters)
Set filters that affect how toolbox content is filtered.
QgsProcessingToolboxProxyModel(QObject *parent=nullptr, QgsProcessingRegistry *registry=nullptr, QgsProcessingRecentAlgorithmLog *recentLog=nullptr, QgsProcessingFavoriteAlgorithmManager *favoriteManager=nullptr)
Constructor for QgsProcessingToolboxProxyModel, with the given parent object.
QgsProcessingToolboxModel * toolboxModel()
Returns the underlying source Processing toolbox model.
Filter
Available filter flags for filtering the model.
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_CONVERT_TO_SUBCLASS_CODE(code)
Definition qgis_sip.h:199
#define SIP_TRANSFERTHIS
Definition qgis_sip.h:53
#define SIP_ENUM_BASETYPE(type)
Definition qgis_sip.h:275
#define SIP_SKIP
Definition qgis_sip.h:134
#define SIP_MONKEYPATCH_SCOPEENUM_UNNEST(OUTSIDE_CLASS, FORMERNAME)
Definition qgis_sip.h:268
#define SIP_TRANSFER
Definition qgis_sip.h:36
#define SIP_END
Definition qgis_sip.h:216
#define SIP_MONKEYPATCH_COMPAT_NAME(FORMERNAME)
Definition qgis_sip.h:270
Q_DECLARE_OPERATORS_FOR_FLAGS(QgsProjectionSelectionWidget::CrsOptions)