QGIS API Documentation 3.41.0-Master (cea29feecf2)
Loading...
Searching...
No Matches
qgsoptionswidgetfactory.h
Go to the documentation of this file.
1/***************************************************************************
2 qgsoptionswidgetfactory.h
3 -------------------------------
4 Date : March 2017
5 Copyright : (C) 2017 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 QGSOPTIONSWIDGETFACTORY_H
17#define QGSOPTIONSWIDGETFACTORY_H
18
19#include <QListWidgetItem>
20#include "qgis_gui.h"
21#include "qgis_sip.h"
23
29class GUI_EXPORT QgsOptionsPageWidget : public QWidget
30{
31 Q_OBJECT
32
33 public:
37 QgsOptionsPageWidget( QWidget *parent SIP_TRANSFERTHIS = nullptr )
38 : QWidget( parent )
39 {}
40
51 virtual QString helpKey() const { return QString(); }
52
57 QHash<QWidget *, QgsOptionsDialogHighlightWidget *> registeredHighlightWidgets() SIP_SKIP
58 {
59 return mHighlightWidgets;
60 }
61
71 virtual bool isValid() { return true; }
72
73 public slots:
74
79 virtual void apply() = 0;
80
85 virtual void cancel() { return; }
86
87 protected:
94 {
95 mHighlightWidgets.insert( highlightWidget->widget(), highlightWidget );
96 }
97
98 private:
99 QHash<QWidget *, QgsOptionsDialogHighlightWidget *> mHighlightWidgets;
100};
101
107// NOTE - this is a QObject so we can detect its destruction and avoid
108// QGIS crashing when a plugin crashes/exits without deregistering a factory
109class GUI_EXPORT QgsOptionsWidgetFactory : public QObject
110{
111 Q_OBJECT
112
113 public:
115
117 QgsOptionsWidgetFactory( const QString &title, const QIcon &icon, const QString &key = QString() )
118 : mTitle( title )
119 , mIcon( icon )
120 , mKey( key )
121 {}
122
128 virtual QIcon icon() const { return mIcon; }
129
134 void setIcon( const QIcon &icon ) { mIcon = icon; }
135
140 virtual QString title() const { return mTitle; }
141
146 void setTitle( const QString &title ) { mTitle = title; }
147
154 virtual QString key() const { return mKey; }
155
160 void setKey( const QString &key ) { mKey = key; }
161
174 virtual QString pagePositionHint() const { return QString(); }
175
185 virtual QStringList path() const { return QStringList(); }
186
192 virtual QgsOptionsPageWidget *createWidget( QWidget *parent = nullptr ) const = 0 SIP_FACTORY;
193
194 private:
195 QString mTitle;
196 QIcon mIcon;
197 QString mKey;
198};
199
200#endif // QGSOPTIONSWIDGETFACTORY_H
Container for a widget to be used to search text in the option dialog If the widget type is handled,...
Base class for widgets for pages included in the options dialog.
QgsOptionsPageWidget(QWidget *parent=nullptr)
Constructor for QgsOptionsPageWidget.
QHash< QWidget *, QgsOptionsDialogHighlightWidget * > registeredHighlightWidgets()
Returns the registered highlight widgets used to search and highlight text in options dialogs.
void registerHighlightWidget(QgsOptionsDialogHighlightWidget *highlightWidget)
Register a highlight widget to be used to search and highlight text in options dialogs.
virtual QString helpKey() const
Returns the optional help key for the options page.
virtual void cancel()
Called to cancel settings changed in the options page (e.g.
virtual bool isValid()
Validates the current state of the widget.
virtual void apply()=0
Called to permanently apply the settings shown in the options page (e.g.
A factory class for creating custom options pages.
void setKey(const QString &key)
Set the key for the interface.
void setTitle(const QString &title)
Set the title for the interface.
QgsOptionsWidgetFactory(const QString &title, const QIcon &icon, const QString &key=QString())
Constructor.
void setIcon(const QIcon &icon)
Set the icon to show in the interface for the factory object.
virtual QStringList path() const
Returns the path to place the widget page at, for options dialogs which are structured using a tree v...
virtual QgsOptionsPageWidget * createWidget(QWidget *parent=nullptr) const =0
Factory function to create the widget on demand as needed by the options dialog.
virtual QString key() const
The key of the panel (untranslated title).
virtual QIcon icon() const
The icon that will be shown in the UI for the panel.
virtual QString title() const
The title of the panel.
virtual QString pagePositionHint() const
Returns a tab name hinting at where this page should be inserted into the options properties tab list...
QgsOptionsWidgetFactory()=default
#define SIP_TRANSFERTHIS
Definition qgis_sip.h:53
#define SIP_SKIP
Definition qgis_sip.h:126
#define SIP_FACTORY
Definition qgis_sip.h:76