32#include "qgsmacnative.h"
33#elif defined (Q_OS_WIN)
35#include "qgswinnative.h"
39#elif defined (Q_OS_LINUX)
40#include "qgslinuxnative.h"
89 return instance()->mSettingsRegistryGui;
94 return instance()->mEditorWidgetRegistry;
99 return instance()->mRelationEditorRegistry;
104 return instance()->mShapeMapToolRegistry;
109 return instance()->mSourceSelectProviderRegistry;
114 return instance()->mSubsetStringEditorProviderRegistry;
119 return instance()->mProviderSourceWidgetProviderRegistry;
124 return instance()->mShortcutsManager;
129 return instance()->mLayerTreeEmbeddedWidgetRegistry;
134 return instance()->mMapLayerActionRegistry;
139 return instance()->mLayoutItemGuiRegistry;
144 return instance()->mAnnotationItemGuiRegistry;
149 return instance()->mProcessingGuiRegistry;
154 return instance()->mNumericFormatGuiRegistry;
159 return instance()->mCodeEditorColorSchemeRegistry;
164 return instance()->mProcessingFavoriteAlgorithmManager;
169 return instance()->mProcessingRecentAlgorithmLog;
174 return instance()->mDataItemGuiProviderRegistry;
179 return instance()->mProjectStorageGuiRegistry;
184 return instance()->mProviderGuiRegistry;
189 return instance()->mSensorGuiRegistry;
194 return instance()->mHistoryProviderRegistry;
199 return instance()->mSettingsEditorRegistry;
204 if ( widget->objectName().isEmpty() )
206 QgsDebugError( QStringLiteral(
"WARNING: No object name set. Best for it to be set objectName when using QgsGui::enableAutoGeometryRestore" ) );
213 return instance()->mWindowManager.get();
218 return instance()->mInputControllerManager;
223 instance()->mWindowManager.reset( manager );
240 delete mProcessingGuiRegistry;
241 delete mDataItemGuiProviderRegistry;
242 delete mProcessingFavoriteAlgorithmManager;
243 delete mProcessingRecentAlgorithmLog;
244 delete mLayoutItemGuiRegistry;
245 delete mAnnotationItemGuiRegistry;
246 delete mLayerTreeEmbeddedWidgetRegistry;
247 delete mEditorWidgetRegistry;
248 delete mMapLayerActionRegistry;
249 delete mSourceSelectProviderRegistry;
250 delete mHistoryProviderRegistry;
251 delete mShortcutsManager;
253 delete mNumericFormatGuiRegistry;
254 delete mWidgetStateHelper;
255 delete mProjectStorageGuiRegistry;
256 delete mProviderGuiRegistry;
257 delete mCodeEditorColorSchemeRegistry;
258 delete mSubsetStringEditorProviderRegistry;
259 delete mProviderSourceWidgetProviderRegistry;
260 delete mShapeMapToolRegistry;
261 delete mRelationEditorRegistry;
262 delete mInputControllerManager;
263 delete mSettingsRegistryGui;
264 delete mSensorGuiRegistry;
265 delete mSettingsEditorRegistry;
276 const int x = point.x() - screen->geometry().left();
277 const int y = point.y() - screen->geometry().top();
278 const QPixmap snappedPixmap = screen->grabWindow( 0, x, y, 1, 1 );
279 const QImage snappedImage = snappedPixmap.toImage();
280 return snappedImage.pixel( 0, 0 );
285 const QList< QScreen * > screens = QGuiApplication::screens();
286 for ( QScreen *screen : screens )
288 if ( screen->geometry().contains( point ) )
299 QgsMacNative *macNative =
new QgsMacNative();
302#elif defined (Q_OS_WIN)
304 mNative =
new QgsWinNative();
306 mNative =
new QgsNative();
308#elif defined(Q_OS_LINUX)
309 mNative =
new QgsLinuxNative();
311 mNative =
new QgsNative();
356 mProcessingFavoriteAlgorithmManager =
new QgsProcessingFavoriteAlgorithmManager();
357 mProcessingRecentAlgorithmLog =
new QgsProcessingRecentAlgorithmLog();
360 qRegisterMetaType< QgsHistoryEntry >(
"QgsHistoryEntry" );
379 tr(
"Python macros are currently disabled and will not be run" ),
386 QMessageBox msgBox( QMessageBox::Information, tr(
"Python Macros" ),
387 tr(
"Python macros are currently disabled. Do you allow this macro to run?" ) );
388 QAbstractButton *stopSessionButton = msgBox.addButton( tr(
"Disable for this Session" ), QMessageBox::DestructiveRole );
389 msgBox.addButton( tr(
"No" ), QMessageBox::NoRole );
390 QAbstractButton *yesButton = msgBox.addButton( tr(
"Yes" ), QMessageBox::YesRole );
393 QAbstractButton *clicked = msgBox.clickedButton();
394 if ( clicked == stopSessionButton )
398 return clicked == yesButton;
403 Q_ASSERT( messageBar );
406 QToolButton *btnEnableMacros =
new QToolButton();
407 btnEnableMacros->setText( tr(
"Enable Macros" ) );
408 btnEnableMacros->setStyleSheet( QStringLiteral(
"background-color: rgba(255, 255, 255, 0); color: black; text-decoration: underline;" ) );
409 btnEnableMacros->setCursor( Qt::PointingHandCursor );
410 btnEnableMacros->setSizePolicy( QSizePolicy::Maximum, QSizePolicy::Preferred );
413 tr(
"Security warning" ),
414 tr(
"Python macros cannot currently be run." ),
420 connect( btnEnableMacros, &QToolButton::clicked, messageBar, [ = ]()
438 static std::once_flag initialized;
439 std::call_once( initialized, [ = ]( )
447 if ( !abstractMetadata )
449 QgsDebugError( QStringLiteral(
"Failed to find callout entry in registry: %1" ).arg( name ) );
454 QgsDebugError( QStringLiteral(
"Failed to cast callout's metadata: " ) .arg( name ) );
462 _initCalloutWidgetFunction( QStringLiteral(
"simple" ), QgsSimpleLineCalloutWidget::create );
463 _initCalloutWidgetFunction( QStringLiteral(
"manhattan" ), QgsManhattanLineCalloutWidget::create );
464 _initCalloutWidgetFunction( QStringLiteral(
"curved" ), QgsCurvedLineCalloutWidget::create );
465 _initCalloutWidgetFunction( QStringLiteral(
"balloon" ), QgsBalloonCalloutWidget::create );
470void QgsGui::emitOptionsChanged()
@ Warning
Warning message.
PythonMacroMode
Authorisation to run Python Macros.
@ Always
Macros are always run.
@ NotForThisSession
Macros will not be run for this session.
@ Never
Macros are never run.
@ Ask
User is prompt before running.
@ SessionOnly
Only during this session.
Registry of available annotation item GUI behavior.
void addDefaultItems()
Populates the registry with default items.
static QString pluginPath()
Returns the path to the application plugin directory.
static const QgsSettingsEntryString * settingsLocaleUserLocale
Settings entry locale user locale.
static QgsCalloutRegistry * calloutRegistry()
Returns the application's callout registry, used for managing callout types.
static QString iconsPath()
Returns the path to the icons image directory.
Registry of available callout classes.
QgsCalloutAbstractMetadata * calloutMetadata(const QString &type) const
Returns the metadata for specified the specified callout type.
A registry of color schemes for use in QgsCodeEditor widgets.
This class keeps a list of data item GUI providers that may affect how QgsDataItems behave within the...
void initializeFromProviderGuiRegistry(QgsProviderGuiRegistry *providerGuiRegistry)
Initializes the registry.
QgsGui is a singleton class containing various registry and other global members related to GUI class...
static QgsMapToolShapeRegistry * mapToolShapeRegistry()
Returns the registry of shape map tools.
static QgsEditorWidgetRegistry * editorWidgetRegistry()
Returns the global editor widget registry, used for managing all known edit widget factories.
static QgsProviderSourceWidgetProviderRegistry * sourceWidgetProviderRegistry()
Returns the registry of provider source widget providers.
static QgsProcessingGuiRegistry * processingGuiRegistry()
Returns the global processing gui registry, used for registering the GUI behavior of processing algor...
static QgsShortcutsManager * shortcutsManager()
Returns the global shortcuts manager, used for managing a QAction and QShortcut sequences.
static void setWindowManager(QgsWindowManagerInterface *manager)
Sets the global window manager.
void optionsChanged()
This signal is emitted whenever the application options have been changed.
static QgsInputControllerManager * inputControllerManager()
Returns the global input controller manager.
static QgsProcessingFavoriteAlgorithmManager * processingFavoriteAlgorithmManager()
Returns the global Processing favorite algorithm manager, used for tracking favorite Processing algor...
static bool pythonMacroAllowed(void(*lambda)()=nullptr, QgsMessageBar *messageBar=nullptr)
Returns true if python macros are currently allowed to be run If the global option is to ask user,...
static QgsLayerTreeEmbeddedWidgetRegistry * layerTreeEmbeddedWidgetRegistry()
Returns the global layer tree embedded widget registry, used for registering widgets that may be embe...
static QScreen * findScreenAt(QPoint point)
Returns the screen at the given global point (pixel).
static QgsAnnotationItemGuiRegistry * annotationItemGuiRegistry()
Returns the global annotation item GUI registry, used for registering the GUI behavior of annotation ...
static QgsMapLayerActionRegistry * mapLayerActionRegistry()
Returns the global map layer action registry, used for registering map layer actions.
static QgsGui * instance()
Returns a pointer to the singleton instance.
static QgsProviderGuiRegistry * providerGuiRegistry()
Returns the registry of GUI-related components of data providers.
static QgsRelationWidgetRegistry * relationWidgetRegistry()
Returns the global relation widget registry, used for managing all known relation widget factories.
static QgsSensorGuiRegistry * sensorGuiRegistry()
Returns the registry of GUI-related components for sensors.
static void enableAutoGeometryRestore(QWidget *widget, const QString &key=QString())
Register the widget to allow its position to be automatically saved and restored when open and closed...
static QgsHistoryProviderRegistry * historyProviderRegistry()
Returns the global history provider registry, used for tracking history providers.
@ HigMenuTextIsTitleCase
Menu action texts should be title case.
@ HigDialogTitleIsTitleCase
Dialog titles should be title case.
static QgsNative * nativePlatformInterface()
Returns the global native interface, which offers abstraction to the host OS's underlying public inte...
static QgsWindowManagerInterface * windowManager()
Returns the global window manager, if set.
static QgsDataItemGuiProviderRegistry * dataItemGuiProviderRegistry()
Returns the global data item GUI provider registry, used for tracking providers which affect the brow...
static QgsProcessingRecentAlgorithmLog * processingRecentAlgorithmLog()
Returns the global processing recent algorithm log, used for tracking recently used processing algori...
QFlags< HigFlag > HigFlags
static QgsSubsetStringEditorProviderRegistry * subsetStringEditorProviderRegistry()
Returns the registry of subset string editors of data providers.
static QgsProjectStorageGuiRegistry * projectStorageGuiRegistry()
Returns the global GUI-related project storage registry.
static QgsGui::HigFlags higFlags()
Returns the platform's HIG flags.
static QgsLayoutItemGuiRegistry * layoutItemGuiRegistry()
Returns the global layout item GUI registry, used for registering the GUI behavior of layout items.
static void initCalloutWidgets()
Initializes callout widgets.
static QgsSettingsRegistryGui * settingsRegistryGui()
Returns the gui's settings registry, used for managing gui settings.
static QgsSourceSelectProviderRegistry * sourceSelectProviderRegistry()
Returns the global source select provider registry, used for managing all known source select widget ...
static QgsCodeEditorColorSchemeRegistry * codeEditorColorSchemeRegistry()
Returns the global code editor color scheme registry, used for registering the color schemes for QgsC...
static QgsNumericFormatGuiRegistry * numericFormatGuiRegistry()
Returns the global numeric format gui registry, used for registering the GUI widgets associated with ...
static QgsSettingsEditorWidgetRegistry * settingsEditorWidgetRegistry()
Returns the registry of settings editors.
static QColor sampleColor(QPoint point)
Samples the color on screen at the specified global point (pixel).
The QgsHistoryProviderRegistry is a registry for objects which track user history (i....
void addDefaultProviders()
Adds the default history providers to the registry.
Registry of available layout item GUI behavior.
This class tracks map layer actions.
Represents an item shown within a QgsMessageBar widget.
A bar for displaying non-blocking messages to the user.
bool popWidget(QgsMessageBarItem *item)
Remove the specified item from the bar, and display the next most recent one in the stack.
void pushMessage(const QString &text, Qgis::MessageLevel level=Qgis::MessageLevel::Info, int duration=-1)
A convenience method for pushing a message with the specified text to the bar.
void pushItem(QgsMessageBarItem *item)
Display a message item on the bar, after hiding the currently visible one and putting it in a stack.
The QgsProcessingGuiRegistry is a home for widgets for processing configuration widgets.
A registry / canonical manager of GUI parts of project storage backends.
void initializeFromProviderGuiRegistry(QgsProviderGuiRegistry *providerGuiRegistry)
Initializes the registry.
A registry / canonical manager of GUI parts of data providers.
Registry of available sensor GUI behavior.
bool populate()
Populates the registry with standard sensor types.
QgsSettingsRegistryGui is used for settings introspection and collects all QgsSettingsEntry instances...
This class is a composition of two QSettings instances:
void setEnumValue(const QString &key, const T &value, const Section section=NoSection)
Set the value of a setting based on an enum.
T enumValue(const QString &key, const T &defaultValue, const Section section=NoSection)
Returns the setting value for a setting based on an enum.
Shortcuts manager is a class that contains a list of QActions and QShortcuts that have been registere...
This class keeps a list of source select providers that may add items to the QgsDataSourceManagerDial...
void initializeFromProviderGuiRegistry(QgsProviderGuiRegistry *providerGuiRegistry)
Initializes the registry.
void addProvider(QgsSourceSelectProvider *provider)
Add a provider implementation. Takes ownership of the object.
This class keeps a list of subset string editor providers.
void initializeFromProviderGuiRegistry(QgsProviderGuiRegistry *providerGuiRegistry)
Initializes the registry.
QgsCalloutWidget *(* QgsCalloutWidgetFunc)(QgsMapLayer *)
#define QgsDebugError(str)