23#include "moc_qgslayertree.cpp"
25using namespace Qt::StringLiterals;
34 , mCustomLayerOrder( other.mCustomLayerOrder )
35 , mHasCustomLayerOrder( other.mHasCustomLayerOrder )
40void QgsLayerTree::init()
48 return _qgis_listQPointerToRaw( mCustomLayerOrder );
55 if ( newOrder == mCustomLayerOrder )
58 mCustomLayerOrder = newOrder;
61 if ( mHasCustomLayerOrder )
67 QList<QgsMapLayer *> layers;
80 layers.append( layer );
88 if ( mHasCustomLayerOrder )
100 return mHasCustomLayerOrder;
121 auto tree = std::make_unique< QgsLayerTree >();
123 tree->readCommonXml( element );
125 tree->readChildrenFromXml( element, context );
132 QDomDocument doc = parentElement.ownerDocument();
133 QDomElement elem = doc.createElement( u
"layer-tree-group"_s );
138 node->writeXml( elem, context );
140 QDomElement customOrderElem = doc.createElement( u
"custom-order"_s );
141 customOrderElem.setAttribute( u
"enabled"_s, mHasCustomLayerOrder ? 1 : 0 );
142 elem.appendChild( customOrderElem );
144 for (
QgsMapLayer *layer : std::as_const( mCustomLayerOrder ) )
150 QDomElement layerElem = doc.createElement( u
"item"_s );
151 layerElem.appendChild( doc.createTextNode( layer->id() ) );
152 customOrderElem.appendChild( layerElem );
155 elem.appendChild( customOrderElem );
157 parentElement.appendChild( elem );
172void QgsLayerTree::nodeAddedChildren(
QgsLayerTreeNode *node,
int indexFrom,
int indexTo )
177 QList<QgsMapLayer *> layers;
180 for (
int i = indexFrom; i <= indexTo; ++i )
190 for ( QgsLayerTreeLayer *nodeL : nodeLayers )
191 layers << nodeL->layer();
195 for ( QgsMapLayer *layer : std::as_const( layers ) )
197 if ( !mCustomLayerOrder.contains( layer ) && layer )
198 mCustomLayerOrder.append( layer );
205void QgsLayerTree::nodeRemovedChildren()
208 auto layer = layers.begin();
210 while ( layer != layers.end() )
213 layer = layers.erase( layer );
224 const bool emitSignal = _qgis_listRawToQPointer( layers ) == mCustomLayerOrder;
233void QgsLayerTree::addMissingLayers()
235 bool changed =
false;
237 const QList< QgsLayerTreeLayer * > layers =
findLayers();
238 for (
const auto layer : layers )
240 if ( !mCustomLayerOrder.contains( layer->layer() ) &&
241 layer->layer() && layer->layer()->isSpatial() )
243 mCustomLayerOrder.append( layer->layer() );
251 if ( mHasCustomLayerOrder )
260 QDomElement customOrderElem = elem.firstChildElement( u
"custom-order"_s );
261 if ( !customOrderElem.isNull() )
265 QDomElement itemElem = customOrderElem.firstChildElement( u
"item"_s );
266 while ( !itemElem.isNull() )
268 order.append( itemElem.text() );
269 itemElem = itemElem.nextSiblingElement( u
"item"_s );
Layer tree group node serves as a container for layers and further groups.
QList< QgsMapLayer * > layerOrderRespectingGroupLayers() const
Returns an ordered list of map layers in the group, ignoring any layers which are child layers of Qgs...
QList< QgsLayerTreeNode * > layerAndCustomNodeOrderRespectingGroupLayers() const
Returns an ordered list of map layers and custom nodes in the group, ignoring any layers which are ch...
void removeAllChildren()
Remove all child nodes.
QList< QgsLayerTreeLayer * > findLayers() const
Find all layer nodes.
QgsLayerTreeLayer * findLayer(QgsMapLayer *layer) const
Find layer node representing the map layer.
Layer tree node points to a map layer.
QgsMapLayer * layer() const
Returns the map layer associated with this node.
Base class for nodes in a layer tree.
void removedChildren(QgsLayerTreeNode *node, int indexFrom, int indexTo)
Emitted when one or more nodes has been removed from a node within the tree.
QList< QgsLayerTreeNode * > children()
Gets list of children of the node. Children are owned by the parent.
QgsLayerTreeNode(NodeType t, bool checked=true)
Constructor.
void writeCommonXml(QDomElement &element)
Write common XML elements.
void addedChildren(QgsLayerTreeNode *node, int indexFrom, int indexTo)
Emitted when one or more nodes have been added to a node within the tree.
QList< QgsLayerTreeNode * > mChildren
list of children - node is responsible for their deletion
Namespace with helper functions for layer tree operations.
bool hasCustomLayerOrder() const
Determines if the layer order should be derived from the layer tree or if a custom override order sha...
void customLayerOrderChanged()
Emitted when the custom layer order has changed.
void readLayerOrderFromXml(const QDomElement &doc)
Load the layer order from an XML element.
static QgsLayerTreeLayer * toLayer(QgsLayerTreeNode *node)
Cast node to a layer.
void writeXml(QDomElement &parentElement, const QgsReadWriteContext &context) override
Write layer tree to XML.
QList< QgsMapLayer * > layerOrder() const
The order in which layers will be rendered on the canvas.
QgsLayerTree()
Create a new empty layer tree.
static std::unique_ptr< QgsLayerTree > readXml(const QDomElement &element, const QgsReadWriteContext &context)
Load the layer tree from an XML element.
void hasCustomLayerOrderChanged(bool hasCustomLayerOrder)
Emitted when the hasCustomLayerOrder flag changes.
void clear()
Clear any information from this layer tree.
static bool isLayer(const QgsLayerTreeNode *node)
Check whether the node is a valid layer node.
void setHasCustomLayerOrder(bool hasCustomLayerOrder)
Determines if the layer order should be derived from the layer tree or if a custom override order sha...
static bool isGroup(QgsLayerTreeNode *node)
Check whether the node is a valid group node.
void setCustomLayerOrder(const QList< QgsMapLayer * > &customLayerOrder)
The order in which layers will be rendered on the canvas.
static QgsLayerTreeGroup * toGroup(QgsLayerTreeNode *node)
Cast node to a group.
void layerOrderChanged()
Emitted when the layer order has changed.
QList< QgsMapLayer * > customLayerOrder() const
The order in which layers will be rendered on the canvas.
QList< QgsLayerTreeNode * > layerAndCustomNodeOrder() const
The order in which layers and custom nodes will be rendered on the canvas.
QgsLayerTree * clone() const override
Create a copy of the node. Returns new instance.
Base class for all map layer types.
virtual bool isSpatial() const
Returns true if the layer is considered a spatial layer, ie it has some form of geometry associated w...
A container for the context for various read/write operations on objects.
QList< QgsWeakMapLayerPointer > QgsWeakMapLayerPointerList
A list of weak pointers to QgsMapLayers.