Class: QgsLayerTreeFilterProxyModel¶
A sort filter proxy model to easily reproduce the legend/layer tree in a tree view.
Layers are checkable by default. Symbology nodes will not be shown. Layers can be filtered by their type.
For more complex use-cases, the model can be re-implemented to allow a different interaction or to add more columns.
Added in version 3.14.
Class Hierarchy¶
Base classes¶
Methods
Returns the checked layers |
|
Rerturns the layer tree model |
|
Returns the map layer at a given index |
|
Returns |
|
Initialize the list of checked layers. |
|
Defines the type layers (vector, raster, etc) shown in the tree If the list is empty, all types are shown. |
|
Sets the layer tree model |
|
Determines if private layers are shown. |
|
Returns if private layers are shown. |
Virtual Methods
In PyQGIS, only methods marked as virtual
can be safely overridden in a Python subclass of QgsLayerTreeFilterProxyModel. See the FAQ for more details.
Returns if the layer is checked or not |
|
Sets the filter text to search for a layer in the tree |
|
This will set if the layer is checked or not |
- class qgis.core.QgsLayerTreeFilterProxyModel[source]¶
Bases:
QSortFilterProxyModel
- __init__(parent: QObject | None = None)
Constructor
- Parameters:
parent (Optional[QObject] = None)
- checkedLayers(self) List[QgsMapLayer] ¶
Returns the checked layers
- Return type:
List[QgsMapLayer]
- virtual isLayerChecked(self, layer: QgsMapLayer | None) bool [source]¶
Returns if the layer is checked or not
- Parameters:
layer (Optional[QgsMapLayer])
- Return type:
bool
- layerTreeModel(self) QgsLayerTreeModel | None [source]¶
Rerturns the layer tree model
- Return type:
Optional[QgsLayerTreeModel]
- mapLayer(self, idx: QModelIndex) QgsMapLayer | None [source]¶
Returns the map layer at a given index
- Parameters:
idx (QModelIndex)
- Return type:
Optional[QgsMapLayer]
- nodeShown(self, node: QgsLayerTreeNode | None) bool [source]¶
Returns
True
if the specifiednode
will be shown in the model.Added in version 3.40.
- Parameters:
node (Optional[QgsLayerTreeNode])
- Return type:
bool
- setCheckedLayers(self, layers: Iterable[QgsMapLayer])[source]¶
Initialize the list of checked layers.
Note
If the model is re-implemented, this method might become useless
- Parameters:
layers (Iterable[QgsMapLayer])
- virtual setFilterText(self, filterText: str | None = '')[source]¶
Sets the filter text to search for a layer in the tree
- Parameters:
filterText (Optional[str] = '')
- setFilters(self, filters: Qgis.LayerFilters | Qgis.LayerFilter)[source]¶
Defines the type layers (vector, raster, etc) shown in the tree If the list is empty, all types are shown.
- Parameters:
filters (Union[Qgis.LayerFilters, Qgis.LayerFilter])
- virtual setLayerChecked(self, layer: QgsMapLayer | None, checked: bool)[source]¶
This will set if the layer is checked or not
- Parameters:
layer (Optional[QgsMapLayer])
checked (bool)
- setLayerTreeModel(self, layerTreeModel: QgsLayerTreeModel | None)[source]¶
Sets the layer tree model
- Parameters:
layerTreeModel (Optional[QgsLayerTreeModel])