27 #include <QContextMenuEvent>    37   setHeaderHidden( 
true );
    39   setDragEnabled( 
true );
    40   setAcceptDrops( 
true );
    41   setDropIndicatorShown( 
true );
    42   setEditTriggers( EditKeyPressed );
    43   setExpandsOnDoubleClick( 
false ); 
    45   setSelectionMode( ExtendedSelection );
    46   setDefaultDropAction( Qt::MoveAction );
    50   setStyle( 
new QgsLayerTreeViewProxyStyle( 
this ) );
    63   if ( !qobject_cast<QgsLayerTreeModel *>( model ) )
    69   QTreeView::setModel( model );
   108     setCurrentIndex( QModelIndex() );
   125   QModelIndex idx = indexAt( event->pos() );
   126   if ( !idx.isValid() )
   127     setCurrentIndex( QModelIndex() );
   130   if ( menu && menu->actions().count() != 0 )
   131     menu->exec( mapToGlobal( event->pos() ) );
   148       int widgetsCount = layer->customProperty( QStringLiteral( 
"embeddedWidgets/count" ), 0 ).toInt();
   150       for ( 
int i = 0; i < widgetsCount; ++i )
   152         QString providerId = layer->customProperty( QStringLiteral( 
"embeddedWidgets/%1/id" ).arg( i ) ).toString();
   156           setIndexWidget( index, provider->createWidget( layer, i ) );
   166     QStringList expandedNodeKeys = parentNode->
customProperty( QStringLiteral( 
"expandedLegendNodes" ) ).toStringList();
   167     if ( expandedNodeKeys.isEmpty() )
   173       if ( expandedNodeKeys.contains( ruleKey ) )
   179   QList<QgsLayerTreeNode *> children = parentNode->
children();
   180   for ( 
int i = start; i <= end; ++i )
   199     node->setExpanded( isExpanded( index ) );
   204     QStringList lst = node->layerNode()->customProperty( QStringLiteral( 
"expandedLegendNodes" ) ).toStringList();
   205     bool expanded = isExpanded( index );
   206     bool isInList = lst.contains( ruleKey );
   207     if ( expanded && !isInList )
   209       lst.append( ruleKey );
   210       node->layerNode()->setCustomProperty( QStringLiteral( 
"expandedLegendNodes" ), lst );
   212     else if ( !expanded && isInList )
   214       lst.removeAll( ruleKey );
   215       node->layerNode()->setCustomProperty( QStringLiteral( 
"expandedLegendNodes" ), lst );
   223   QString layerCurrentID = layerCurrent ? layerCurrent->
id() : QString();
   228   QModelIndex nodeLayerIndex;
   244   if ( isExpanded( idx ) != expanded )
   245     setExpanded( idx, expanded );
   248 void QgsLayerTreeView::onCustomPropertyChanged( 
QgsLayerTreeNode *node, 
const QString &key )
   253   QSet<QString> expandedLegendNodes = node->
customProperty( QStringLiteral( 
"expandedLegendNodes" ) ).toStringList().toSet();
   259     if ( !key.isEmpty() )
   339   QList<QgsLayerTreeLayer *> layerNodes;
   350   QList<QgsMapLayer *> list;
   354       list << node->
layer();
   376 QStringList QgsLayerTreeView::viewOnlyCustomProperties()
   378   return QStringList() << QStringLiteral( 
"expandedLegendNodes" );
   400       if ( !parentKey.isEmpty() && !lst.contains( parentKey ) )
   442   if ( event->modifiers() & Qt::ControlModifier )
   446   QTreeView::mouseReleaseEvent( event );
   453   if ( event->modifiers() & Qt::ControlModifier )
   457   QTreeView::keyPressEvent( event );
   463   if ( event->keyboardModifiers() & Qt::AltModifier )
   467   QTreeView::dropEvent( event );
 Layer tree group node serves as a container for layers and further groups. 
 
static QgsLayerTreeLayer * toLayer(QgsLayerTreeNode *node)
Cast node to a layer. 
 
QList< QgsMapLayer * > selectedLayers() const
Gets list of selected layers. 
 
Base class for all map layer types. 
 
static bool isGroup(QgsLayerTreeNode *node)
Check whether the node is a valid group node. 
 
void setCurrentIndex(const QModelIndex ¤tIndex)
Sets index of the current item. May be used by view. Item marked as current is underlined. 
 
QList< QgsLayerTreeNode * > indexes2nodes(const QModelIndexList &list, bool skipInternal=false) const
Convert a list of indexes to a list of layer tree nodes. 
 
QgsLayerTreeViewMenuProvider * mMenuProvider
Context menu provider. Owned by the view. 
 
void removeIndicator(QgsLayerTreeNode *node, QgsLayerTreeViewIndicator *indicator)
Removes a previously added indicator to a layer tree node. 
 
void refreshLayerSymbology(const QString &layerId)
Force refresh of layer symbology. Normally not needed as the changes of layer's renderer are monitore...
 
void contextMenuEvent(QContextMenuEvent *event) override
 
static QgsLayerTreeGroup * toGroup(QgsLayerTreeNode *node)
Cast node to a group. 
 
QgsLayerTreeLayer * layerNode() const
Returns pointer to the parent layer node. 
 
void modelRowsInserted(const QModelIndex &index, int start, int end)
 
QgsMapLayer * currentLayer() const
Gets currently selected layer. May be null. 
 
QgsLayerTreeViewDefaultActions * defaultActions()
Gets access to the default actions that may be used with the tree view. 
 
bool isExpanded() const
Returns whether the node should be shown as expanded or collapsed in GUI. 
 
QModelIndex node2index(QgsLayerTreeNode *node) const
Returns index for a given node. If the node does not belong to the layer tree, the result is undefine...
 
void setFlags(QgsLayerTreeModel::Flags f)
Sets OR-ed combination of model flags. 
 
QList< QgsLayerTreeLayer * > selectedLayerNodes() const
Returns list of selected nodes filtered to just layer nodes. 
 
void mouseReleaseEvent(QMouseEvent *event) override
 
QString mCurrentLayerID
Keeps track of current layer ID (to check when to emit signal about change of current layer) ...
 
The QgsLayerTreeViewDefaultActions class serves as a factory of actions that can be used together wit...
 
The QgsLayerTreeModel class is model implementation for Qt item views framework. 
 
Rule key of the parent legend node - for legends with tree hierarchy (QString). Added in 2...
 
void updateExpandedStateToNode(const QModelIndex &index)
 
QString id() const
Returns the layer's unique ID, which is used to access this layer from QgsProject. 
 
QList< QgsLayerTreeNode * > children()
Gets list of children of the node. Children are owned by the parent. 
 
void expandedChanged(QgsLayerTreeNode *node, bool expanded)
Emitted when the collapsed/expanded state of a node within the tree has been changed. 
 
QModelIndex legendNode2index(QgsLayerTreeModelLegendNode *legendNode)
Returns index for a given legend node. 
 
Rule key of the node (QString) 
 
static QgsLayerTreeEmbeddedWidgetRegistry * layerTreeEmbeddedWidgetRegistry()
Returns the global layer tree embedded widget registry, used for registering widgets that may be embe...
 
void addIndicator(QgsLayerTreeNode *node, QgsLayerTreeViewIndicator *indicator)
Adds an indicator to the given layer tree node. 
 
static QgsLayerTreeModelLegendNode * index2legendNode(const QModelIndex &index)
Returns legend node for given index. 
 
QgsLayerTreeNode * parent()
Gets pointer to the parent. If parent is a null pointer, the node is a root node. ...
 
QgsLayerTreeGroup * currentGroupNode() const
Gets current group node. If a layer is current node, the function will return parent group...
 
QPoint mLastReleaseMousePos
Used by the item delegate for identification of which indicator has been clicked. ...
 
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...
 
QHash< QgsLayerTreeNode *, QList< QgsLayerTreeViewIndicator * > > mIndicators
Storage of indicators used with the tree view. 
 
static bool isLayer(const QgsLayerTreeNode *node)
Check whether the node is a valid layer node. 
 
This class is a base class for nodes in a layer tree. 
 
friend class QgsLayerTreeViewItemDelegate
 
void collapseAllNodes()
Enhancement of QTreeView::collapseAll() that also records expanded state in layer tree nodes...
 
void keyPressEvent(QKeyEvent *event) override
 
void currentLayerChanged(QgsMapLayer *layer)
Emitted when a current layer is changed. 
 
QgsLayerTreeModel * layerTreeModel() const
Gets access to the model casted to QgsLayerTreeModel. 
 
void refreshLayerLegend(QgsLayerTreeLayer *nodeLayer)
Force a refresh of legend nodes of a layer node. 
 
QgsLayerTreeViewDefaultActions * mDefaultActions
helper class with default actions. Lazily initialized. 
 
void setExpanded(bool expanded)
Sets whether the node should be shown as expanded or collapsed in GUI. 
 
QgsMapLayer * layer() const
 
Qt::ItemFlags flags(const QModelIndex &index) const override
 
void updateExpandedStateFromNode(QgsLayerTreeNode *node)
 
QList< QgsLayerTreeNode * > selectedNodes(bool skipInternal=false) const
Returns list of selected nodes. 
 
QgsLayerTreeNode * index2node(const QModelIndex &index) const
Returns layer tree node for given index. 
 
QgsLayerTree * rootGroup() const
Returns pointer to the root node of the layer tree. Always a non-null pointer. 
 
void onExpandedChanged(QgsLayerTreeNode *node, bool expanded)
 
Layer nodes may optionally include extra embedded widgets (if used in QgsLayerTreeView). Added in 2.16. 
 
QgsLayerTreeModelLegendNode * currentLegendNode() const
Gets current legend node. 
 
QgsLayerTreeViewMenuProvider * menuProvider() const
Returns pointer to the context menu provider. May be null. 
 
virtual QVariant data(int role) const =0
Returns data associated with the item. Must be implemented in derived class. 
 
void dropEvent(QDropEvent *event) override
 
QgsMapLayer * layerForIndex(const QModelIndex &index) const
 
The QgsLegendRendererItem class is abstract interface for legend items returned from QgsMapLayerLegen...
 
Check/uncheck action has consequences on children (or parents for leaf node) 
 
void setModel(QAbstractItemModel *model) override
Overridden setModel() from base class. Only QgsLayerTreeModel is an acceptable model. 
 
QList< QgsLayerTreeModelLegendNode * > layerLegendNodes(QgsLayerTreeLayer *nodeLayer, bool skipNodeEmbeddedInParent=false)
Returns filtered list of active legend nodes attached to a particular layer node (by default it retur...
 
void setCurrentLayer(QgsMapLayer *layer)
Sets currently selected layer. Null pointer will deselect any layer. 
 
QgsLayerTreeView(QWidget *parent=nullptr)
Constructor for QgsLayerTreeView. 
 
void setMenuProvider(QgsLayerTreeViewMenuProvider *menuProvider)
Sets provider for context menu. Takes ownership of the instance. 
 
~QgsLayerTreeView() override
 
QgsLayerTreeLayer * findLayer(QgsMapLayer *layer) const
Find layer node representing the map layer. 
 
void customPropertyChanged(QgsLayerTreeNode *node, const QString &key)
Emitted when a custom property of a node within the tree has been changed or removed. 
 
void expandAllNodes()
Enhancement of QTreeView::expandAll() that also records expanded state in layer tree nodes...
 
Indicator that can be used in a layer tree view to display icons next to items of the layer tree...
 
QList< QgsLayerTreeViewIndicator * > indicators(QgsLayerTreeNode *node) const
Returns list of indicators associated with a particular layer tree node. 
 
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...
 
Layer tree node points to a map layer. 
 
QgsLayerTreeNode * currentNode() const
Gets current node. May be null.