2015-01-19 16:36:40 +10:00
|
|
|
/**
|
|
|
|
* @brief The QgsLayerDefinition class holds generic methods for loading/exporting QLR files.
|
|
|
|
*
|
|
|
|
* QLR files are an export of the layer xml including the style and datasource location. There is no link
|
|
|
|
* to the QLR file once loaded. Consider the QLR file a mini project file for layers and styles. QLR
|
|
|
|
* files also store the layer tree info for the exported layers, including group information.
|
|
|
|
*/
|
2015-03-24 12:01:18 +01:00
|
|
|
class QgsLayerDefinition
|
2015-01-19 09:22:10 +10:00
|
|
|
{
|
|
|
|
%TypeHeaderCode
|
|
|
|
#include <qgslayerdefinition.h>
|
|
|
|
%End
|
2015-03-24 12:01:18 +01:00
|
|
|
public:
|
2017-05-01 16:42:33 +02:00
|
|
|
static bool loadLayerDefinition( const QString &path, QgsProject *project, QgsLayerTreeGroup *rootGroup, QString &errorMessage /Out/ );
|
|
|
|
static bool loadLayerDefinition( QDomDocument doc, QgsProject *project, QgsLayerTreeGroup *rootGroup, QString &errorMessage /Out/, const QgsPathResolver &pathResolver );
|
|
|
|
static bool exportLayerDefinition( QString path, const QList<QgsLayerTreeNode*> &selectedTreeNodes, QString &errorMessage /Out/ );
|
|
|
|
static bool exportLayerDefinition( QDomDocument doc, const QList<QgsLayerTreeNode*> &selectedTreeNodes, QString &errorMessage /Out/, const QgsPathResolver &pathResolver );
|
2016-01-07 12:01:26 +01:00
|
|
|
|
2017-05-01 16:42:33 +02:00
|
|
|
static QDomDocument exportLayerDefinitionLayers( const QList<QgsMapLayer*> &layers, const QgsPathResolver &pathResolver );
|
|
|
|
static QList<QgsMapLayer*> loadLayerDefinitionLayers( QDomDocument &document, const QgsPathResolver &pathResolver ) /Factory/;
|
2017-01-27 17:36:36 +08:00
|
|
|
static QList<QgsMapLayer*> loadLayerDefinitionLayers( const QString &qlrfile ) /Factory/;
|
|
|
|
|
2016-01-07 12:01:26 +01:00
|
|
|
/**
|
|
|
|
* Class used to work with layer dependencies stored in a XML project or layer definition file
|
|
|
|
*/
|
|
|
|
class DependencySorter
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/** Constructor
|
|
|
|
* @param doc The XML document containing maplayer elements
|
|
|
|
*/
|
2017-05-01 16:42:33 +02:00
|
|
|
DependencySorter( const QDomDocument &doc );
|
2016-01-07 12:01:26 +01:00
|
|
|
|
2016-01-07 14:37:23 +01:00
|
|
|
/** Constructor
|
|
|
|
* @param fileName The filename where the XML document is stored
|
|
|
|
*/
|
2017-05-01 16:42:33 +02:00
|
|
|
DependencySorter( const QString &fileName );
|
2016-01-07 14:37:23 +01:00
|
|
|
|
2016-01-07 12:01:26 +01:00
|
|
|
/** Get the layer nodes in an order where they can be loaded incrementally without dependency break */
|
|
|
|
QVector<QDomNode> sortedLayerNodes() const;
|
|
|
|
|
2016-01-07 14:37:23 +01:00
|
|
|
/** Get the layer IDs in an order where they can be loaded incrementally without dependency break */
|
|
|
|
QStringList sortedLayerIds() const;
|
|
|
|
|
2016-01-07 12:01:26 +01:00
|
|
|
/** Whether some cyclic dependency has been detected */
|
|
|
|
bool hasCycle() const;
|
|
|
|
|
|
|
|
/** Whether some dependency is missing */
|
|
|
|
bool hasMissingDependency() const;
|
|
|
|
};
|
2015-01-19 09:22:10 +10:00
|
|
|
};
|
|
|
|
|