QGIS API Documentation 3.41.0-Master (3440c17df1d)
|
This class is a base class for nodes in a layer tree. More...
#include <qgslayertreenode.h>
Public Types | |
enum | NodeType { NodeGroup , NodeLayer } |
Enumeration of possible tree node types. More... | |
Signals | |
void | addedChildren (QgsLayerTreeNode *node, int indexFrom, int indexTo) |
Emitted when one or more nodes have been added to a node within the tree. | |
void | customPropertyChanged (QgsLayerTreeNode *node, const QString &key) |
Emitted when a custom property of a node within the tree has been changed or removed. | |
void | expandedChanged (QgsLayerTreeNode *node, bool expanded) |
Emitted when the collapsed/expanded state of a node within the tree has been changed. | |
void | nameChanged (QgsLayerTreeNode *node, QString name) |
Emitted when the name of the node is changed. | |
void | removedChildren (QgsLayerTreeNode *node, int indexFrom, int indexTo) |
Emitted when one or more nodes has been removed from a node within the tree. | |
void | visibilityChanged (QgsLayerTreeNode *node) |
Emitted when check state of a node within the tree has been changed. | |
void | willAddChildren (QgsLayerTreeNode *node, int indexFrom, int indexTo) |
Emitted when one or more nodes will be added to a node within the tree. | |
void | willRemoveChildren (QgsLayerTreeNode *node, int indexFrom, int indexTo) |
Emitted when one or more nodes will be removed from a node within the tree. | |
Public Member Functions | |
~QgsLayerTreeNode () override | |
QList< QgsLayerTreeNode * > | abandonChildren () |
Removes the children, disconnect all the forwarded and external signals and sets their parent to nullptr . | |
QList< QgsMapLayer * > | checkedLayers () const |
Returns a list of any checked layers which belong to this node or its children. | |
QList< QgsLayerTreeNode * > | children () |
Gets list of children of the node. Children are owned by the parent. | |
QList< QgsLayerTreeNode * > | children () const |
Gets list of children of the node. Children are owned by the parent. | |
virtual QgsLayerTreeNode * | clone () const =0 |
Create a copy of the node. Returns new instance. | |
QStringList | customProperties () const |
Returns list of keys stored in custom properties. | |
QVariant | customProperty (const QString &key, const QVariant &defaultValue=QVariant()) const |
Read a custom property from layer. Properties are stored in a map and saved in project file. | |
int | depth () const |
Returns the depth of this node, i.e. | |
virtual QString | dump () const =0 |
Returns string with layer tree structure. For debug purposes only. | |
bool | isExpanded () const |
Returns whether the node should be shown as expanded or collapsed in GUI. | |
bool | isItemVisibilityCheckedRecursive () const |
Returns whether this node is checked and all its children. | |
bool | isItemVisibilityUncheckedRecursive () const |
Returns whether this node is unchecked and all its children. | |
bool | isVisible () const |
Returns whether a node is really visible (ie checked and all its ancestors checked as well) | |
bool | itemVisibilityChecked () const |
Returns whether a node is checked (independently of its ancestors or children) | |
virtual QString | name () const =0 |
Returns name of the node. | |
NodeType | nodeType () const |
Find out about type of the node. It is usually shorter to use convenience functions from QgsLayerTree namespace for that. | |
QgsLayerTreeNode * | parent () |
Gets pointer to the parent. If parent is nullptr , the node is a root node. | |
void | removeCustomProperty (const QString &key) |
Remove a custom property from layer. Properties are stored in a map and saved in project file. | |
virtual void | resolveReferences (const QgsProject *project, bool looseMatching=false)=0 |
Turn textual references to layers into map layer object from project. | |
void | setCustomProperty (const QString &key, const QVariant &value) |
Sets a custom property for the node. Properties are stored in a map and saved in project file. | |
void | setExpanded (bool expanded) |
Sets whether the node should be shown as expanded or collapsed in GUI. | |
void | setItemVisibilityChecked (bool checked) |
Check or uncheck a node (independently of its ancestors or children) | |
void | setItemVisibilityCheckedParentRecursive (bool checked) |
Check or uncheck a node and all its parents. | |
virtual void | setItemVisibilityCheckedRecursive (bool checked) |
Check or uncheck a node and all its children (taking into account exclusion rules) | |
virtual void | setName (const QString &name)=0 |
Set name of the node. | |
bool | takeChild (QgsLayerTreeNode *node) |
Remove a child from a node. | |
virtual void | writeXml (QDomElement &parentElement, const QgsReadWriteContext &context)=0 |
Write layer tree to XML. | |
Static Public Member Functions | |
static QgsLayerTreeNode * | readXml (QDomElement &element, const QgsProject *project) |
Read layer tree from XML. | |
static QgsLayerTreeNode * | readXml (QDomElement &element, const QgsReadWriteContext &context) |
Read layer tree from XML. | |
Protected Member Functions | |
QgsLayerTreeNode (const QgsLayerTreeNode &other) | |
QgsLayerTreeNode (NodeType t, bool checked=true) | |
Constructor. | |
void | insertChildrenPrivate (int index, const QList< QgsLayerTreeNode * > &nodes) |
Low-level insertion of children to the node. The children must not have any parent yet! | |
virtual void | makeOrphan () |
Sets parent to nullptr and disconnects all external and forwarded signals. | |
void | readCommonXml (QDomElement &element) |
Read common XML elements. | |
void | removeChildrenPrivate (int from, int count, bool destroy=true) |
Low-level removal of children from the node. | |
void | writeCommonXml (QDomElement &element) |
Write common XML elements. | |
Protected Attributes | |
bool | mChecked |
QList< QgsLayerTreeNode * > | mChildren |
list of children - node is responsible for their deletion | |
bool | mExpanded |
whether the node should be shown in GUI as expanded | |
NodeType | mNodeType |
type of the node - determines which subclass is used | |
QgsLayerTreeNode * | mParent = nullptr |
pointer to the parent node - nullptr in case of root node | |
QgsObjectCustomProperties | mProperties |
custom properties attached to the node | |
This class is a base class for nodes in a layer tree.
Layer tree is a hierarchical structure consisting of group and layer nodes:
Layer trees may be used for organization of layers, typically a layer tree is exposed to the user using QgsLayerTreeView widget which shows the tree and allows manipulation with the tree.
Ownership of nodes: every node is owned by its parent. Therefore once node is added to a layer tree, it is the responsibility of the parent to delete it when the node is not needed anymore. Deletion of root node of a tree will delete all nodes of the tree.
Signals: signals are propagated from children to parent. That means it is sufficient to connect to root node in order to get signals about updates in the whole layer tree. When adding or removing a node that contains further children (i.e. a whole subtree), the addition/removal signals are emitted only for the root node of the subtree that is being added or removed.
Custom properties: Every node may have some custom properties assigned to it. This mechanism allows third parties store additional data with the nodes. The properties are used within QGIS code (whether to show layer in overview, whether the node is embedded from another project etc), but may be also used by third party plugins. Custom properties are stored also in the project file. The storage is not efficient for large amount of data.
Custom properties that have already been used within QGIS:
Definition at line 76 of file qgslayertreenode.h.
Enumeration of possible tree node types.
Enumerator | |
---|---|
NodeGroup | Container of other groups and layers. |
NodeLayer | Leaf node pointing to a layer. |
Definition at line 101 of file qgslayertreenode.h.
|
override |
Definition at line 47 of file qgslayertreenode.cpp.
|
protected |
Constructor.
Definition at line 26 of file qgslayertreenode.cpp.
|
protected |
Definition at line 33 of file qgslayertreenode.cpp.
QList< QgsLayerTreeNode * > QgsLayerTreeNode::abandonChildren | ( | ) |
Removes the children, disconnect all the forwarded and external signals and sets their parent to nullptr
.
Definition at line 52 of file qgslayertreenode.cpp.
|
signal |
Emitted when one or more nodes have been added to a node within the tree.
QList< QgsMapLayer * > QgsLayerTreeNode::checkedLayers | ( | ) | const |
Returns a list of any checked layers which belong to this node or its children.
Definition at line 180 of file qgslayertreenode.cpp.
|
inline |
Gets list of children of the node. Children are owned by the parent.
Definition at line 122 of file qgslayertreenode.h.
|
inline |
Gets list of children of the node. Children are owned by the parent.
Definition at line 124 of file qgslayertreenode.h.
|
pure virtual |
Create a copy of the node. Returns new instance.
Implemented in QgsLayerTree, QgsLayerTreeGroup, and QgsLayerTreeLayer.
QStringList QgsLayerTreeNode::customProperties | ( | ) | const |
Returns list of keys stored in custom properties.
Definition at line 232 of file qgslayertreenode.cpp.
QVariant QgsLayerTreeNode::customProperty | ( | const QString & | key, |
const QVariant & | defaultValue = QVariant() |
||
) | const |
Read a custom property from layer. Properties are stored in a map and saved in project file.
Definition at line 218 of file qgslayertreenode.cpp.
|
signal |
Emitted when a custom property of a node within the tree has been changed or removed.
int QgsLayerTreeNode::depth | ( | ) | const |
Returns the depth of this node, i.e.
the number of its ancestors
Definition at line 187 of file qgslayertreenode.cpp.
|
pure virtual |
Returns string with layer tree structure. For debug purposes only.
Implemented in QgsLayerTreeGroup, and QgsLayerTreeLayer.
|
signal |
Emitted when the collapsed/expanded state of a node within the tree has been changed.
|
protected |
Low-level insertion of children to the node. The children must not have any parent yet!
Definition at line 248 of file qgslayertreenode.cpp.
bool QgsLayerTreeNode::isExpanded | ( | ) | const |
Returns whether the node should be shown as expanded or collapsed in GUI.
Definition at line 122 of file qgslayertreenode.cpp.
bool QgsLayerTreeNode::isItemVisibilityCheckedRecursive | ( | ) | const |
Returns whether this node is checked and all its children.
Definition at line 127 of file qgslayertreenode.cpp.
bool QgsLayerTreeNode::isItemVisibilityUncheckedRecursive | ( | ) | const |
Returns whether this node is unchecked and all its children.
Definition at line 141 of file qgslayertreenode.cpp.
bool QgsLayerTreeNode::isVisible | ( | ) | const |
Returns whether a node is really visible (ie checked and all its ancestors checked as well)
Definition at line 116 of file qgslayertreenode.cpp.
|
inline |
Returns whether a node is checked (independently of its ancestors or children)
Definition at line 182 of file qgslayertreenode.h.
|
protectedvirtual |
Sets parent to nullptr
and disconnects all external and forwarded signals.
Reimplemented in QgsLayerTreeGroup.
Definition at line 63 of file qgslayertreenode.cpp.
|
pure virtual |
Returns name of the node.
Implemented in QgsLayerTreeGroup, and QgsLayerTreeLayer.
|
signal |
Emitted when the name of the node is changed.
|
inline |
Find out about type of the node. It is usually shorter to use convenience functions from QgsLayerTree namespace for that.
Definition at line 118 of file qgslayertreenode.h.
|
inline |
Gets pointer to the parent. If parent is nullptr
, the node is a root node.
Definition at line 120 of file qgslayertreenode.h.
|
protected |
Read common XML elements.
Definition at line 237 of file qgslayertreenode.cpp.
|
static |
Read layer tree from XML.
Returns new instance. Also resolves textual references to layers from the project (calls resolveReferences() internally).
Definition at line 80 of file qgslayertreenode.cpp.
|
static |
Read layer tree from XML.
Returns new instance. Does not resolve textual references to layers. Call resolveReferences() afterwards to do it.
Definition at line 69 of file qgslayertreenode.cpp.
|
protected |
Low-level removal of children from the node.
Definition at line 293 of file qgslayertreenode.cpp.
void QgsLayerTreeNode::removeCustomProperty | ( | const QString & | key | ) |
Remove a custom property from layer. Properties are stored in a map and saved in project file.
Definition at line 223 of file qgslayertreenode.cpp.
|
signal |
Emitted when one or more nodes has been removed from a node within the tree.
|
pure virtual |
Turn textual references to layers into map layer object from project.
This method should be called after readXml() If looseMatching is true
then a looser match will be used, where a layer will match if the name, public source, and data provider match. This can be used to match legend customization from different projects where layers will have different layer IDs.
Implemented in QgsLayerTreeGroup, and QgsLayerTreeLayer.
void QgsLayerTreeNode::setCustomProperty | ( | const QString & | key, |
const QVariant & | value | ||
) |
Sets a custom property for the node. Properties are stored in a map and saved in project file.
Definition at line 209 of file qgslayertreenode.cpp.
void QgsLayerTreeNode::setExpanded | ( | bool | expanded | ) |
Sets whether the node should be shown as expanded or collapsed in GUI.
Definition at line 199 of file qgslayertreenode.cpp.
void QgsLayerTreeNode::setItemVisibilityChecked | ( | bool | checked | ) |
Check or uncheck a node (independently of its ancestors or children)
Definition at line 96 of file qgslayertreenode.cpp.
void QgsLayerTreeNode::setItemVisibilityCheckedParentRecursive | ( | bool | checked | ) |
Check or uncheck a node and all its parents.
Definition at line 109 of file qgslayertreenode.cpp.
|
virtual |
Check or uncheck a node and all its children (taking into account exclusion rules)
Reimplemented in QgsLayerTreeGroup.
Definition at line 104 of file qgslayertreenode.cpp.
|
pure virtual |
Set name of the node.
Emits nameChanged signal.
Implemented in QgsLayerTreeGroup, and QgsLayerTreeLayer.
bool QgsLayerTreeNode::takeChild | ( | QgsLayerTreeNode * | node | ) |
Remove a child from a node.
Definition at line 329 of file qgslayertreenode.cpp.
|
signal |
Emitted when check state of a node within the tree has been changed.
|
signal |
Emitted when one or more nodes will be added to a node within the tree.
|
signal |
Emitted when one or more nodes will be removed from a node within the tree.
|
protected |
Write common XML elements.
Definition at line 242 of file qgslayertreenode.cpp.
|
pure virtual |
Write layer tree to XML.
Implemented in QgsLayerTree, QgsLayerTreeGroup, and QgsLayerTreeLayer.
|
protected |
Definition at line 283 of file qgslayertreenode.h.
|
protected |
list of children - node is responsible for their deletion
Definition at line 287 of file qgslayertreenode.h.
|
protected |
whether the node should be shown in GUI as expanded
Definition at line 289 of file qgslayertreenode.h.
|
protected |
type of the node - determines which subclass is used
Definition at line 282 of file qgslayertreenode.h.
|
protected |
pointer to the parent node - nullptr
in case of root node
Definition at line 285 of file qgslayertreenode.h.
|
protected |
custom properties attached to the node
Definition at line 291 of file qgslayertreenode.h.