QGIS API Documentation 3.39.0-Master (d0dedde5474)
Loading...
Searching...
No Matches
qgsdataprovider.h
Go to the documentation of this file.
1/***************************************************************************
2 qgsdataprovider.h - DataProvider Interface class
3 --------------------------------------
4 Date : 09-Sep-2003
5 Copyright : (C) 2003 by Gary E.Sherman
6 email : sherman at mrcc.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 QQGSDATAPROVIDER_H
17#define QQGSDATAPROVIDER_H
18
19#include "qgis_core.h"
20#include <QDateTime>
21#include <QObject>
22#include <QString>
23#include <QStringList>
24#include <QMutex>
25
26#include "qgsdatasourceuri.h"
28#include "qgslayermetadata.h"
29#include "qgserror.h"
31
32class QgsRectangle;
35
36
41class CORE_EXPORT QgsDataProvider : public QObject
42{
43
44#ifdef SIP_RUN
46 if ( qobject_cast<QgsVectorDataProvider *>( sipCpp ) )
47 {
48 sipType = sipType_QgsVectorDataProvider;
49 }
50 else if ( qobject_cast<QgsRasterDataProvider *>( sipCpp ) )
51 {
52 sipType = sipType_QgsRasterDataProvider;
53 }
54 else if ( qobject_cast<QgsMeshDataProvider *>( sipCpp ) )
55 {
56 sipType = sipType_QgsMeshDataProvider;
57 }
58 else if ( qobject_cast<QgsPointCloudDataProvider *>( sipCpp ) )
59 {
60 sipType = sipType_QgsPointCloudDataProvider;
61 }
62 else
63 {
64 sipType = 0;
65 }
67#endif
68 Q_OBJECT
69
70 public:
71
80 {
82 CustomData = 3000
83 };
84
101
107 QgsDataProvider( const QString &uri = QString(),
110
117
123 virtual void setDataSourceUri( const QString &uri )
124 {
125 mDataSourceURI = uri;
126 }
127
137 virtual QString dataSourceUri( bool expandAuthConfig = false ) const
138 {
139 if ( expandAuthConfig && mDataSourceURI.contains( QLatin1String( "authcfg" ) ) )
140 {
141 const QgsDataSourceUri uri( mDataSourceURI );
142 return uri.uri( expandAuthConfig );
143 }
144 else
145 {
146 return mDataSourceURI;
147 }
148 }
149
157 virtual QString dataComment() const { return QString(); };
158
164 virtual QString htmlMetadata() const;
165
170 void setUri( const QgsDataSourceUri &uri )
171 {
172 mDataSourceURI = uri.uri( true );
173 }
174
180 void setUri( const QString &uri )
181 {
182 mDataSourceURI = uri;
183 }
184
190 {
191 return QgsDataSourceUri( mDataSourceURI );
192 }
193
199 virtual Qgis::DataProviderFlags flags() const;
200
208 virtual QgsDataProviderTemporalCapabilities *temporalCapabilities();
209
217 virtual const QgsDataProviderTemporalCapabilities *temporalCapabilities() const SIP_SKIP;
218
226 virtual QgsDataProviderElevationProperties *elevationProperties();
227
235 virtual const QgsDataProviderElevationProperties *elevationProperties() const SIP_SKIP;
236
245 virtual QgsRectangle extent() const = 0;
246
257 virtual QgsBox3D extent3D() const
258 {
259 return extent().toBox3d( std::numeric_limits<double>::quiet_NaN(), std::numeric_limits<double>::quiet_NaN() );
260 }
261
266 virtual bool isValid() const = 0;
267
271 virtual void updateExtents()
272 {
273 // NOP by default
274 }
275
276
283 virtual bool setSubsetString( const QString &subset, bool updateFeatureCount = true )
284 {
285 // NOP by default
286 Q_UNUSED( subset )
287 Q_UNUSED( updateFeatureCount )
288 return false;
289 }
290
291
295 virtual bool supportsSubsetString() const { return false; }
296
303 virtual QString subsetString() const
304 {
305 return QString();
306 }
307
308
317 virtual QStringList subLayers() const
318 {
319 return QStringList(); // Empty
320 }
321
329 virtual QStringList subLayerStyles() const
330 {
331 return QStringList(); // Empty
332 }
333
334
338 virtual uint subLayerCount() const
339 {
340 return 0;
341 }
342
343
349 virtual void setLayerOrder( const QStringList &layers )
350 {
351 //prevent unused var warnings
352 if ( layers.count() < 1 )
353 {
354 return;
355 }
356 // NOOP
357 }
358
359
363 virtual void setSubLayerVisibility( const QString &name, bool vis )
364 {
365 //prevent unused var warnings
366 if ( name.isEmpty() || !vis )
367 {
368 return;
369 }
370 // NOOP
371 }
372
373
374 // TODO? Instead of being pure virtual, might be better to generalize this
375 // behavior and presume that none of the sub-classes are going to do
376 // anything strange with regards to their name or description?
377
386 virtual QString name() const = 0;
387
388
394 virtual QString description() const = 0;
395
396
405 virtual QString fileVectorFilters() const
406 {
407 return QString();
408 }
409
410
419 virtual QString fileRasterFilters() const
420 {
421 return QString();
422 }
423
424 // TODO QGIS 4 -> Make `reloadData()` non virtual. This should be implemented in `reloadProviderData()`.
425
433 virtual void reloadData();
434
436 virtual QDateTime timestamp() const { return mTimestamp; }
437
439 virtual QDateTime dataTimestamp() const { return QDateTime(); }
440
446 virtual QgsError error() const { return mError; }
447
451 virtual void invalidateConnections( const QString &connection ) { Q_UNUSED( connection ) }
452
474 virtual bool enterUpdateMode() { return true; }
475
492 virtual bool leaveUpdateMode() { return true; }
493
499 void setProviderProperty( ProviderProperty property, const QVariant &value );
500
506 void setProviderProperty( int property, const QVariant &value ); // SIP_SKIP
507
513 QVariant providerProperty( ProviderProperty property, const QVariant &defaultValue = QVariant() ) const;
514
520 QVariant providerProperty( int property, const QVariant &defaultValue ) const; // SIP_SKIP
521
531 virtual void setListening( bool isListening );
532
533#ifndef SIP_RUN
534
540 {
542 double lastRenderingTimeMs = -1;
543
545 double maxRenderingTimeMs = MAXIMUM_LAYER_PREVIEW_TIME_MS;
546 };
547#endif
548
560 virtual bool renderInPreview( const QgsDataProvider::PreviewContext &context ); // SIP_SKIP
561
569 virtual QgsLayerMetadata layerMetadata() const { return QgsLayerMetadata(); }
570
578 virtual bool writeLayerMetadata( const QgsLayerMetadata &metadata ) { Q_UNUSED( metadata ) return false; }
579
587 QgsCoordinateTransformContext transformContext() const SIP_SKIP;
588
599 virtual void setTransformContext( const QgsCoordinateTransformContext &transformContext ) SIP_SKIP;
600
607 static QString sublayerSeparator();
608
614 virtual Qgis::ProviderStyleStorageCapabilities styleStorageCapabilities() const;
615
616 signals:
617
624 void fullExtentCalculated();
625
638 void dataChanged();
639
646 void notify( const QString &msg );
647
648
649 protected:
650
654 QDateTime mTimestamp;
655
657 QgsError mError;
658
660 void appendError( const QgsErrorMessage &message ) { mError.append( message ); }
661
663 void setError( const QgsError &error ) { mError = error;}
664
667
668 private:
669
674 QString mDataSourceURI;
675
677
678 QMap< int, QVariant > mProviderProperties;
679
683 mutable QMutex mOptionsMutex;
684
689 virtual void reloadProviderData() {}
690
691 friend class TestQgsProject;
692};
693
694#endif
The Qgis class provides global constants for use throughout the application.
Definition qgis.h:54
QFlags< DataProviderFlag > DataProviderFlags
Data provider flags.
Definition qgis.h:2126
QFlags< DataProviderReadFlag > DataProviderReadFlags
Flags which control data provider construction.
Definition qgis.h:450
A 3-dimensional box composed of x, y, z coordinates.
Definition qgsbox3d.h:43
This class represents a coordinate reference system (CRS).
Contains information about the context in which a coordinate transform is executed.
Base class for handling elevation related properties for a data provider.
Base class for handling properties relating to a data provider's temporal capabilities.
Abstract base class for spatial data provider implementations.
virtual void invalidateConnections(const QString &connection)
Invalidate connections corresponding to specified name.
virtual bool leaveUpdateMode()
Leave update mode.
void setUri(const QgsDataSourceUri &uri)
Set the data source specification.
virtual void setLayerOrder(const QStringList &layers)
Reorder the list of layer names to be rendered by this provider (in order from bottom to top)
virtual QString name() const =0
Returns a provider name.
void setError(const QgsError &error)
Sets error message.
virtual QDateTime timestamp() const
Time stamp of data source in the moment when data/metadata were loaded by provider.
virtual QgsCoordinateReferenceSystem crs() const =0
Returns the coordinate system for the data source.
virtual QString dataComment() const
Returns a short comment for the data that this provider is providing access to (e....
void setUri(const QString &uri)
Set the data source specification.
ProviderProperty
Properties are used to pass custom configuration options into data providers.
@ EvaluateDefaultValues
Evaluate default values on provider side when calling QgsVectorDataProvider::defaultValue( int index ...
virtual QString subsetString() const
Returns the subset definition string (typically sql) currently in use by the layer and used by the pr...
virtual QgsLayerMetadata layerMetadata() const
Returns layer metadata collected from the provider's source.
virtual bool isValid() const =0
Returns true if this is a valid layer.
virtual void setDataSourceUri(const QString &uri)
Set the data source specification.
virtual QString fileRasterFilters() const
Returns raster file filter string.
virtual QgsError error() const
Gets current status error.
virtual QDateTime dataTimestamp() const
Current time stamp of data source.
virtual bool supportsSubsetString() const
Returns true if the provider supports setting of subset strings.
virtual QString dataSourceUri(bool expandAuthConfig=false) const
Gets the data source specification.
virtual QString description() const =0
Returns description.
QgsDataSourceUri uri() const
Gets the data source specification.
virtual QString fileVectorFilters() const
Returns vector file filter string.
virtual QStringList subLayerStyles() const
Sub-layer styles for each sub-layer handled by this provider, in order from bottom to top.
Qgis::DataProviderReadFlags mReadFlags
Read flags. It's up to the subclass to respect these when needed.
virtual void updateExtents()
Update the extents of the layer.
virtual bool setSubsetString(const QString &subset, bool updateFeatureCount=true)
Set the subset string used to create a subset of features in the layer.
virtual uint subLayerCount() const
Returns the number of layers for the current data source.
virtual QStringList subLayers() const
Sub-layers handled by this provider, in order from bottom to top.
virtual bool writeLayerMetadata(const QgsLayerMetadata &metadata)
Writes layer metadata to the underlying provider source.
virtual bool enterUpdateMode()
Enter update mode.
virtual void setSubLayerVisibility(const QString &name, bool vis)
Set the visibility of the given sublayer name.
Class for storing the component parts of a RDBMS data source URI (e.g.
QString uri(bool expandAuthConfig=true) const
Returns the complete URI as a string.
QgsErrorMessage represents single error message.
Definition qgserror.h:33
A container for error messages.
Definition qgserror.h:81
void append(const QString &message, const QString &tag)
Append new error message.
Definition qgserror.cpp:39
A structured metadata store for a map layer.
A rectangle specified with double values.
#define SIP_CONVERT_TO_SUBCLASS_CODE(code)
Definition qgis_sip.h:191
#define SIP_SKIP
Definition qgis_sip.h:126
#define SIP_END
Definition qgis_sip.h:208
Stores settings related to the context in which a preview job runs.
Setting options for creating vector data providers.
QgsCoordinateTransformContext transformContext
Coordinate transform context.