QGIS/python/core/layertree/qgslayertreelayer.sip
2014-07-04 21:40:22 +02:00

60 lines
1.7 KiB
Plaintext

/**
* Layer tree node points to a map layer.
*
* When using with existing QgsMapLayer instance, it is expected that the layer
* has been registered in QgsMapLayerRegistry earlier.
*
* The node can exist also without a valid instance of a layer (just ID). That
* means the referenced layer does not need to be loaded in order to use it
* in layer tree. In such case, the node will start listening to map layer
* registry updates in expectation that the layer (identified by its ID) will
* be loaded later.
*
* A map layer is supposed to be present in one layer tree just once. It is
* however possible that temporarily a layer exists in one tree more than just
* once, e.g. while reordering items with drag and drop.
*
* @note added in 2.4
*/
class QgsLayerTreeLayer : QgsLayerTreeNode
{
%TypeHeaderCode
#include <qgslayertreelayer.h>
%End
public:
explicit QgsLayerTreeLayer( QgsMapLayer* layer );
explicit QgsLayerTreeLayer( QString layerId, QString name = QString() );
QString layerId() const;
QgsMapLayer* layer() const;
QString layerName() const;
void setLayerName( const QString& n );
Qt::CheckState isVisible() const;
void setVisible( Qt::CheckState visible );
//! @note added in 2.5
bool childrenCheckable() const;
//! @note added in 2.5
void setChildrenCheckable( bool checkable );
static QgsLayerTreeLayer* readXML( QDomElement& element ) /Factory/;
virtual void writeXML( QDomElement& parentElement );
virtual QString dump() const;
virtual QgsLayerTreeNode* clone() const /Factory/;
signals:
//! emitted when a previously unavailable layer got loaded
void layerLoaded();
private:
QgsLayerTreeLayer( const QgsLayerTreeLayer& other );
};