2017-06-08 15:37:13 +02:00
|
|
|
/************************************************************************
|
|
|
|
* This file has been generated automatically from *
|
|
|
|
* *
|
|
|
|
* src/gui/layertree/qgslayertreeview.h *
|
|
|
|
* *
|
|
|
|
* Do not edit manually ! Edit header and run scripts/sipify.pl again *
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2014-05-22 01:09:14 +07:00
|
|
|
class QgsLayerTreeView : QTreeView
|
|
|
|
{
|
2017-06-08 15:37:13 +02:00
|
|
|
%Docstring
|
|
|
|
The QgsLayerTreeView class extends QTreeView and provides some additional functionality
|
|
|
|
when working with a layer tree.
|
|
|
|
|
|
|
|
The view updates expanded state of layer tree nodes and also listens to changes
|
|
|
|
to expanded states in the layer tree.
|
|
|
|
|
|
|
|
The view keeps track of the current layer and emits a signal when the current layer has changed.
|
|
|
|
|
|
|
|
Allows the client to specify a context menu provider with custom actions. Also it comes
|
|
|
|
with a set of default actions that can be used when building context menu.
|
|
|
|
|
2017-12-05 20:04:14 -04:00
|
|
|
.. seealso:: :py:class:`QgsLayerTreeModel`
|
2017-06-08 15:37:13 +02:00
|
|
|
.. versionadded:: 2.4
|
|
|
|
%End
|
|
|
|
|
2014-05-22 01:09:14 +07:00
|
|
|
%TypeHeaderCode
|
2017-06-08 15:37:13 +02:00
|
|
|
#include "qgslayertreeview.h"
|
2014-05-22 01:09:14 +07:00
|
|
|
%End
|
2014-06-13 18:19:15 +07:00
|
|
|
%ConvertToSubClassCode
|
2017-06-08 15:37:13 +02:00
|
|
|
if ( sipCpp->inherits( "QgsLayerTreeView" ) )
|
|
|
|
sipType = sipType_QgsLayerTreeView;
|
|
|
|
else
|
|
|
|
sipType = 0;
|
2014-06-13 18:19:15 +07:00
|
|
|
%End
|
2014-06-03 17:45:56 +07:00
|
|
|
public:
|
|
|
|
explicit QgsLayerTreeView( QWidget *parent /TransferThis/ = 0 );
|
|
|
|
~QgsLayerTreeView();
|
|
|
|
|
2017-05-01 18:13:15 +02:00
|
|
|
virtual void setModel( QAbstractItemModel *model );
|
2017-06-08 15:37:13 +02:00
|
|
|
%Docstring
|
|
|
|
Overridden setModel() from base class. Only QgsLayerTreeModel is an acceptable model.
|
|
|
|
%End
|
2014-06-03 17:45:56 +07:00
|
|
|
|
2017-05-01 18:13:15 +02:00
|
|
|
QgsLayerTreeModel *layerTreeModel() const;
|
2017-06-08 15:37:13 +02:00
|
|
|
%Docstring
|
|
|
|
Get access to the model casted to QgsLayerTreeModel
|
|
|
|
:rtype: QgsLayerTreeModel
|
|
|
|
%End
|
2014-06-03 17:45:56 +07:00
|
|
|
|
2017-05-01 18:13:15 +02:00
|
|
|
QgsLayerTreeViewDefaultActions *defaultActions();
|
2017-06-08 15:37:13 +02:00
|
|
|
%Docstring
|
|
|
|
Get access to the default actions that may be used with the tree view
|
|
|
|
:rtype: QgsLayerTreeViewDefaultActions
|
|
|
|
%End
|
2014-06-03 17:45:56 +07:00
|
|
|
|
2017-05-01 18:13:15 +02:00
|
|
|
void setMenuProvider( QgsLayerTreeViewMenuProvider *menuProvider /Transfer/ );
|
2017-06-08 15:37:13 +02:00
|
|
|
%Docstring
|
|
|
|
Set provider for context menu. Takes ownership of the instance
|
|
|
|
%End
|
2017-05-01 18:13:15 +02:00
|
|
|
QgsLayerTreeViewMenuProvider *menuProvider() const;
|
2017-06-08 15:37:13 +02:00
|
|
|
%Docstring
|
|
|
|
Return pointer to the context menu provider. May be null
|
|
|
|
:rtype: QgsLayerTreeViewMenuProvider
|
|
|
|
%End
|
2014-06-03 17:45:56 +07:00
|
|
|
|
2017-05-01 18:13:15 +02:00
|
|
|
QgsMapLayer *currentLayer() const;
|
2017-06-08 15:37:13 +02:00
|
|
|
%Docstring
|
|
|
|
Get currently selected layer. May be null
|
|
|
|
:rtype: QgsMapLayer
|
|
|
|
%End
|
2017-05-01 18:13:15 +02:00
|
|
|
void setCurrentLayer( QgsMapLayer *layer );
|
2017-06-08 15:37:13 +02:00
|
|
|
%Docstring
|
|
|
|
Set currently selected layer. Null pointer will deselect any layer.
|
|
|
|
%End
|
2014-06-03 17:45:56 +07:00
|
|
|
|
2017-05-01 18:13:15 +02:00
|
|
|
QgsLayerTreeNode *currentNode() const;
|
2017-06-08 15:37:13 +02:00
|
|
|
%Docstring
|
|
|
|
Get current node. May be null
|
|
|
|
:rtype: QgsLayerTreeNode
|
|
|
|
%End
|
2017-05-01 18:13:15 +02:00
|
|
|
QgsLayerTreeGroup *currentGroupNode() const;
|
2017-06-08 15:37:13 +02:00
|
|
|
%Docstring
|
|
|
|
Get current group node. If a layer is current node, the function will return parent group. May be null.
|
|
|
|
:rtype: QgsLayerTreeGroup
|
|
|
|
%End
|
2014-06-03 17:45:56 +07:00
|
|
|
|
2017-05-01 18:13:15 +02:00
|
|
|
QgsLayerTreeModelLegendNode *currentLegendNode() const;
|
2017-06-08 15:37:13 +02:00
|
|
|
%Docstring
|
|
|
|
Get current legend node. May be null if current node is not a legend node.
|
|
|
|
.. versionadded:: 2.14
|
|
|
|
:rtype: QgsLayerTreeModelLegendNode
|
|
|
|
%End
|
2015-12-09 16:07:39 +11:00
|
|
|
|
2017-06-08 15:37:13 +02:00
|
|
|
QList<QgsLayerTreeNode *> selectedNodes( bool skipInternal = false ) const;
|
|
|
|
%Docstring
|
2017-10-05 11:51:04 +10:00
|
|
|
Return list of selected nodes
|
|
|
|
\param skipInternal If true, will ignore nodes which have an ancestor in the selection
|
2017-06-08 15:37:13 +02:00
|
|
|
:rtype: list of QgsLayerTreeNode
|
|
|
|
%End
|
|
|
|
QList<QgsLayerTreeLayer *> selectedLayerNodes() const;
|
|
|
|
%Docstring
|
|
|
|
Return list of selected nodes filtered to just layer nodes
|
|
|
|
:rtype: list of QgsLayerTreeLayer
|
|
|
|
%End
|
2014-06-03 17:45:56 +07:00
|
|
|
|
2017-06-08 15:37:13 +02:00
|
|
|
QList<QgsMapLayer *> selectedLayers() const;
|
|
|
|
%Docstring
|
|
|
|
Get list of selected layers
|
|
|
|
:rtype: list of QgsMapLayer
|
|
|
|
%End
|
2014-06-03 17:45:56 +07:00
|
|
|
|
|
|
|
public slots:
|
2017-05-01 18:13:15 +02:00
|
|
|
void refreshLayerSymbology( const QString &layerId );
|
2017-06-08 15:37:13 +02:00
|
|
|
%Docstring
|
|
|
|
Force refresh of layer symbology. Normally not needed as the changes of layer's renderer are monitored by the model
|
|
|
|
%End
|
2014-06-03 17:45:56 +07:00
|
|
|
|
2016-10-14 11:17:36 +08:00
|
|
|
void expandAllNodes();
|
2017-06-08 15:37:13 +02:00
|
|
|
%Docstring
|
2017-10-05 11:51:04 +10:00
|
|
|
Enhancement of QTreeView.expandAll() that also records expanded state in layer tree nodes
|
2017-06-08 15:37:13 +02:00
|
|
|
.. versionadded:: 2.18
|
|
|
|
%End
|
2016-10-14 11:17:36 +08:00
|
|
|
|
|
|
|
void collapseAllNodes();
|
2017-06-08 15:37:13 +02:00
|
|
|
%Docstring
|
2017-10-05 11:51:04 +10:00
|
|
|
Enhancement of QTreeView.collapseAll() that also records expanded state in layer tree nodes
|
2017-06-08 15:37:13 +02:00
|
|
|
.. versionadded:: 2.18
|
|
|
|
%End
|
2016-10-14 11:17:36 +08:00
|
|
|
|
2014-06-03 17:45:56 +07:00
|
|
|
signals:
|
2017-05-01 18:13:15 +02:00
|
|
|
void currentLayerChanged( QgsMapLayer *layer );
|
2017-06-08 15:37:13 +02:00
|
|
|
%Docstring
|
|
|
|
Emitted when a current layer is changed
|
|
|
|
%End
|
2014-06-03 17:45:56 +07:00
|
|
|
|
2015-02-03 02:21:52 +01:00
|
|
|
protected:
|
2017-06-08 15:37:13 +02:00
|
|
|
virtual void contextMenuEvent( QContextMenuEvent *event );
|
|
|
|
|
2015-02-03 02:21:52 +01:00
|
|
|
|
2017-05-01 18:13:15 +02:00
|
|
|
void updateExpandedStateFromNode( QgsLayerTreeNode *node );
|
2015-02-03 02:21:52 +01:00
|
|
|
|
2017-05-01 18:13:15 +02:00
|
|
|
QgsMapLayer *layerForIndex( const QModelIndex &index ) const;
|
2017-06-08 15:37:13 +02:00
|
|
|
%Docstring
|
|
|
|
:rtype: QgsMapLayer
|
|
|
|
%End
|
|
|
|
|
|
|
|
virtual void mouseReleaseEvent( QMouseEvent *event );
|
|
|
|
|
|
|
|
virtual void keyPressEvent( QKeyEvent *event );
|
|
|
|
|
2016-01-04 22:51:18 +11:00
|
|
|
|
2017-07-07 08:54:00 +10:00
|
|
|
virtual void dropEvent( QDropEvent *event );
|
|
|
|
|
|
|
|
|
|
|
|
|
2016-01-04 22:51:18 +11:00
|
|
|
protected slots:
|
|
|
|
|
2017-05-01 18:13:15 +02:00
|
|
|
void modelRowsInserted( const QModelIndex &index, int start, int end );
|
2016-01-04 22:51:18 +11:00
|
|
|
void modelRowsRemoved();
|
|
|
|
|
2017-05-01 18:13:15 +02:00
|
|
|
void updateExpandedStateToNode( const QModelIndex &index );
|
2016-01-04 22:51:18 +11:00
|
|
|
|
|
|
|
void onCurrentChanged();
|
2017-05-01 18:13:15 +02:00
|
|
|
void onExpandedChanged( QgsLayerTreeNode *node, bool expanded );
|
2016-01-04 22:51:18 +11:00
|
|
|
void onModelReset();
|
2017-06-08 15:37:13 +02:00
|
|
|
|
|
|
|
protected:
|
2014-06-03 17:45:56 +07:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class QgsLayerTreeViewMenuProvider
|
|
|
|
{
|
2017-06-08 15:37:13 +02:00
|
|
|
%Docstring
|
|
|
|
Implementation of this interface can be implemented to allow QgsLayerTreeView
|
|
|
|
instance to provide custom context menus (opened upon right-click).
|
|
|
|
|
2017-12-05 20:04:14 -04:00
|
|
|
.. seealso:: :py:class:`QgsLayerTreeView`
|
2017-06-08 15:37:13 +02:00
|
|
|
.. versionadded:: 2.4
|
2014-06-03 17:45:56 +07:00
|
|
|
%End
|
|
|
|
|
2017-06-08 15:37:13 +02:00
|
|
|
%TypeHeaderCode
|
|
|
|
#include "qgslayertreeview.h"
|
|
|
|
%End
|
2014-06-03 17:45:56 +07:00
|
|
|
public:
|
|
|
|
virtual ~QgsLayerTreeViewMenuProvider();
|
|
|
|
|
2017-05-01 18:13:15 +02:00
|
|
|
virtual QMenu *createContextMenu() = 0 /Factory/;
|
2017-06-08 15:37:13 +02:00
|
|
|
%Docstring
|
|
|
|
Return a newly created menu instance (or null pointer on error)
|
|
|
|
:rtype: QMenu
|
|
|
|
%End
|
2014-05-22 01:09:14 +07:00
|
|
|
};
|
2017-06-08 15:37:13 +02:00
|
|
|
|
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
* This file has been generated automatically from *
|
|
|
|
* *
|
|
|
|
* src/gui/layertree/qgslayertreeview.h *
|
|
|
|
* *
|
|
|
|
* Do not edit manually ! Edit header and run scripts/sipify.pl again *
|
|
|
|
************************************************************************/
|