mirror of
				https://github.com/qgis/QGIS.git
				synced 2025-10-25 00:05:24 -04:00 
			
		
		
		
	reverting 3fb0f66 (followup #45348) Using --no-public-is-protected (default on Windows) also works on Linux and fixes #45331 too
		
			
				
	
	
		
			414 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			414 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| /************************************************************************
 | |
|  * This file has been generated automatically from                      *
 | |
|  *                                                                      *
 | |
|  * src/core/annotations/qgsannotation.h                                 *
 | |
|  *                                                                      *
 | |
|  * Do not edit manually ! Edit header and run scripts/sipify.pl again   *
 | |
|  ************************************************************************/
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| class QgsAnnotation : QObject
 | |
| {
 | |
| %Docstring(signature="appended")
 | |
| 
 | |
| Abstract base class for annotation items which are drawn over a map.
 | |
| 
 | |
| :py:class:`QgsAnnotation` is an abstract base class for map annotation items. These annotations can be
 | |
| drawn within a map, and have either a fixed map position (retrieved using :py:func:`~mapPosition`)
 | |
| or are placed relative to the map's frame (retrieved using :py:func:`~relativePosition`).
 | |
| Annotations with a fixed map position also have a corresponding
 | |
| :py:class:`QgsCoordinateReferenceSystem`, which can be determined by calling :py:func:`~mapPositionCrs`.
 | |
| 
 | |
| Derived classes should implement their custom painting routines within
 | |
| a :py:func:`~renderAnnotation` override.
 | |
| 
 | |
| .. versionadded:: 3.0
 | |
| %End
 | |
| 
 | |
| %TypeHeaderCode
 | |
| #include "qgsannotation.h"
 | |
| %End
 | |
| %ConvertToSubClassCode
 | |
|     if ( dynamic_cast< QgsTextAnnotation * >( sipCpp ) )
 | |
|       sipType = sipType_QgsTextAnnotation;
 | |
|     else if ( dynamic_cast< QgsSvgAnnotation * >( sipCpp ) )
 | |
|       sipType = sipType_QgsSvgAnnotation;
 | |
|     else if ( dynamic_cast< QgsHtmlAnnotation * >( sipCpp ) )
 | |
|       sipType = sipType_QgsHtmlAnnotation;
 | |
|     else
 | |
|       sipType = NULL;
 | |
| %End
 | |
|   public:
 | |
| 
 | |
|     QgsAnnotation( QObject *parent /TransferThis/ = 0 );
 | |
| %Docstring
 | |
| Constructor for QgsAnnotation.
 | |
| %End
 | |
| 
 | |
|     ~QgsAnnotation();
 | |
| 
 | |
|     virtual QgsAnnotation *clone() const = 0 /Factory/;
 | |
| %Docstring
 | |
| Clones the annotation, returning a new copy of the annotation
 | |
| reflecting the annotation's current state.
 | |
| %End
 | |
| 
 | |
|     bool isVisible() const;
 | |
| %Docstring
 | |
| Returns ``True`` if the annotation is visible and should be rendered.
 | |
| 
 | |
| .. seealso:: :py:func:`setVisible`
 | |
| %End
 | |
| 
 | |
|     void setVisible( bool visible );
 | |
| %Docstring
 | |
| Sets whether the annotation is visible and should be rendered.
 | |
| 
 | |
| .. seealso:: :py:func:`isVisible`
 | |
| %End
 | |
| 
 | |
|     bool hasFixedMapPosition() const;
 | |
| %Docstring
 | |
| Returns ``True`` if the annotation is attached to a fixed map position, or
 | |
| ``False`` if the annotation uses a position relative to the current map
 | |
| extent.
 | |
| 
 | |
| .. seealso:: :py:func:`setHasFixedMapPosition`
 | |
| 
 | |
| .. seealso:: :py:func:`mapPosition`
 | |
| 
 | |
| .. seealso:: :py:func:`relativePosition`
 | |
| %End
 | |
| 
 | |
|     void setHasFixedMapPosition( bool fixed );
 | |
| %Docstring
 | |
| Sets whether the annotation is attached to a fixed map position, or
 | |
| uses a position relative to the current map extent.
 | |
| 
 | |
| .. seealso:: :py:func:`hasFixedMapPosition`
 | |
| %End
 | |
| 
 | |
|     QgsPointXY mapPosition() const;
 | |
| %Docstring
 | |
| Returns the map position of the annotation, if it is attached to a fixed map
 | |
| position.
 | |
| 
 | |
| .. seealso:: :py:func:`setMapPosition`
 | |
| 
 | |
| .. seealso:: :py:func:`hasFixedMapPosition`
 | |
| 
 | |
| .. seealso:: :py:func:`mapPositionCrs`
 | |
| %End
 | |
| 
 | |
|     void setMapPosition( const QgsPointXY &position );
 | |
| %Docstring
 | |
| Sets the map position of the annotation, if it is attached to a fixed map
 | |
| position.
 | |
| 
 | |
| .. seealso:: :py:func:`mapPosition`
 | |
| %End
 | |
| 
 | |
|     QgsCoordinateReferenceSystem mapPositionCrs() const;
 | |
| %Docstring
 | |
| Returns the CRS of the map position, or an invalid CRS if the annotation does
 | |
| not have a fixed map position.
 | |
| 
 | |
| .. seealso:: :py:func:`setMapPositionCrs`
 | |
| %End
 | |
| 
 | |
|     void setMapPositionCrs( const QgsCoordinateReferenceSystem &crs );
 | |
| %Docstring
 | |
| Sets the CRS of the map position.
 | |
| 
 | |
| .. seealso:: :py:func:`mapPositionCrs`
 | |
| %End
 | |
| 
 | |
|     QPointF relativePosition() const;
 | |
| %Docstring
 | |
| Returns the relative position of the annotation, if it is not attached to a fixed map
 | |
| position. The coordinates in the return point should be between 0 and 1, and represent
 | |
| the relative percentage for the position compared to the map width and height.
 | |
| 
 | |
| .. seealso:: :py:func:`setRelativePosition`
 | |
| %End
 | |
| 
 | |
|     void setRelativePosition( QPointF position );
 | |
| %Docstring
 | |
| Sets the relative position of the annotation, if it is not attached to a fixed map
 | |
| position. The coordinates in the return point should be between 0 and 1, and represent
 | |
| the relative percentage for the position compared to the map width and height.
 | |
| 
 | |
| .. seealso:: :py:func:`relativePosition`
 | |
| %End
 | |
| 
 | |
|  void setFrameOffsetFromReferencePoint( QPointF offset ) /Deprecated/;
 | |
| %Docstring
 | |
| Sets the annotation's frame's offset (in pixels) from the :py:func:`~QgsAnnotation.mapPosition` reference point.
 | |
| 
 | |
| .. seealso:: :py:func:`frameOffsetFromReferencePoint`
 | |
| 
 | |
| .. deprecated::
 | |
|    use :py:func:`~QgsAnnotation.setFrameOffsetFromReferencePointMm` instead
 | |
| %End
 | |
| 
 | |
|  QPointF frameOffsetFromReferencePoint() const /Deprecated/;
 | |
| %Docstring
 | |
| Returns the annotation's frame's offset (in pixels) from the :py:func:`~QgsAnnotation.mapPosition` reference point.
 | |
| 
 | |
| .. seealso:: :py:func:`setFrameOffsetFromReferencePoint`
 | |
| 
 | |
| .. deprecated::
 | |
|    use :py:func:`~QgsAnnotation.frameOffsetFromReferencePointMm` instead
 | |
| %End
 | |
| 
 | |
|     void setFrameOffsetFromReferencePointMm( QPointF offset );
 | |
| %Docstring
 | |
| Sets the annotation's frame's offset (in millimeters) from the :py:func:`~QgsAnnotation.mapPosition` reference point.
 | |
| 
 | |
| .. seealso:: :py:func:`frameOffsetFromReferencePointMm`
 | |
| 
 | |
| .. versionadded:: 3.4.8
 | |
| %End
 | |
| 
 | |
|     QPointF frameOffsetFromReferencePointMm() const;
 | |
| %Docstring
 | |
| Returns the annotation's frame's offset (in millimeters) from the :py:func:`~QgsAnnotation.mapPosition` reference point.
 | |
| 
 | |
| .. seealso:: :py:func:`setFrameOffsetFromReferencePointMm`
 | |
| 
 | |
| .. versionadded:: 3.4.8
 | |
| %End
 | |
| 
 | |
|  void setFrameSize( QSizeF size ) /Deprecated/;
 | |
| %Docstring
 | |
| Sets the size (in pixels) of the annotation's frame (the main area in which
 | |
| the annotation's content is drawn).
 | |
| 
 | |
| .. seealso:: :py:func:`frameSize`
 | |
| 
 | |
| .. deprecated::
 | |
|    use :py:func:`~QgsAnnotation.setFrameSizeMm` instead
 | |
| %End
 | |
| 
 | |
|  QSizeF frameSize() const /Deprecated/;
 | |
| %Docstring
 | |
| Returns the size (in pixels) of the annotation's frame (the main area in which
 | |
| the annotation's content is drawn).
 | |
| 
 | |
| .. seealso:: :py:func:`setFrameSize`
 | |
| 
 | |
| .. deprecated::
 | |
|    use :py:func:`~QgsAnnotation.frameSizeMm` instead
 | |
| %End
 | |
| 
 | |
|     void setFrameSizeMm( QSizeF size );
 | |
| %Docstring
 | |
| Sets the size (in millimeters) of the annotation's frame (the main area in which
 | |
| the annotation's content is drawn).
 | |
| 
 | |
| .. seealso:: :py:func:`frameSizeMm`
 | |
| 
 | |
| .. versionadded:: 3.4.8
 | |
| %End
 | |
| 
 | |
|     QSizeF frameSizeMm() const;
 | |
| %Docstring
 | |
| Returns the size (in millimeters) of the annotation's frame (the main area in which
 | |
| the annotation's content is drawn).
 | |
| 
 | |
| .. seealso:: :py:func:`setFrameSizeMm`
 | |
| 
 | |
| .. versionadded:: 3.4.8
 | |
| %End
 | |
| 
 | |
|     void setContentsMargin( const QgsMargins &margins );
 | |
| %Docstring
 | |
| Sets the margins (in millimeters) between the outside of the frame and the annotation
 | |
| content.
 | |
| 
 | |
| .. seealso:: :py:func:`contentsMargin`
 | |
| %End
 | |
| 
 | |
|     QgsMargins contentsMargin() const;
 | |
| %Docstring
 | |
| Returns the margins (in millimeters) between the outside of the frame and the annotation
 | |
| content.
 | |
| 
 | |
| .. seealso:: :py:func:`setContentsMargin`
 | |
| %End
 | |
| 
 | |
|     void setFillSymbol( QgsFillSymbol *symbol /Transfer/ );
 | |
| %Docstring
 | |
| Sets the fill symbol used for rendering the annotation frame. Ownership
 | |
| of the symbol is transferred to the annotation.
 | |
| 
 | |
| .. seealso:: :py:func:`fillSymbol`
 | |
| %End
 | |
| 
 | |
|     QgsFillSymbol *fillSymbol() const;
 | |
| %Docstring
 | |
| Returns the symbol that is used for rendering the annotation frame.
 | |
| 
 | |
| .. seealso:: :py:func:`setFillSymbol`
 | |
| %End
 | |
| 
 | |
|     void render( QgsRenderContext &context ) const;
 | |
| %Docstring
 | |
| Renders the annotation to a target render context.
 | |
| %End
 | |
| 
 | |
|     virtual void writeXml( QDomElement &elem, QDomDocument &doc, const QgsReadWriteContext &context ) const = 0;
 | |
| %Docstring
 | |
| Writes the annotation state to a DOM element. Derived classes should
 | |
| call _writeXml() within their implementation of this method.
 | |
| 
 | |
| .. seealso:: :py:func:`readXml`
 | |
| 
 | |
| .. seealso:: _writeXml
 | |
| %End
 | |
| 
 | |
|     virtual void readXml( const QDomElement &itemElem, const QgsReadWriteContext &context ) = 0;
 | |
| %Docstring
 | |
| Restores the annotation's state from a DOM element. Derived classes should
 | |
| call _readXml() within their implementation of this method.
 | |
| 
 | |
| .. seealso:: :py:func:`writeXml`
 | |
| 
 | |
| .. seealso:: _readXml
 | |
| %End
 | |
| 
 | |
|     void setMarkerSymbol( QgsMarkerSymbol *symbol /Transfer/ );
 | |
| %Docstring
 | |
| Sets the symbol that is drawn at the annotation's map position. Ownership
 | |
| of the symbol is transferred to the annotation.
 | |
| 
 | |
| .. seealso:: :py:func:`markerSymbol`
 | |
| %End
 | |
| 
 | |
|     QgsMarkerSymbol *markerSymbol() const;
 | |
| %Docstring
 | |
| Returns the symbol that is drawn at the annotation's map position.
 | |
| 
 | |
| .. seealso:: :py:func:`setMarkerSymbol`
 | |
| %End
 | |
| 
 | |
|     QgsMapLayer *mapLayer() const;
 | |
| %Docstring
 | |
| Returns the map layer associated with the annotation. Annotations can be
 | |
| associated with a map layer if their visibility should be synchronized
 | |
| with the layer's visibility.
 | |
| 
 | |
| .. seealso:: :py:func:`setMapLayer`
 | |
| %End
 | |
| 
 | |
|     void setMapLayer( QgsMapLayer *layer );
 | |
| %Docstring
 | |
| Sets the map layer associated with the annotation. Annotations can be
 | |
| associated with a map layer if their visibility should be synchronized
 | |
| with the layer's visibility.
 | |
| 
 | |
| .. seealso:: :py:func:`mapLayer`
 | |
| %End
 | |
| 
 | |
|     QgsFeature associatedFeature() const;
 | |
| %Docstring
 | |
| Returns the feature associated with the annotation, or an invalid
 | |
| feature if none has been set.
 | |
| 
 | |
| .. seealso:: :py:func:`setAssociatedFeature`
 | |
| %End
 | |
| 
 | |
|     virtual void setAssociatedFeature( const QgsFeature &feature );
 | |
| %Docstring
 | |
| Sets the feature associated with the annotation.
 | |
| 
 | |
| .. seealso:: :py:func:`associatedFeature`
 | |
| %End
 | |
| 
 | |
|     virtual bool accept( QgsStyleEntityVisitorInterface *visitor ) const;
 | |
| %Docstring
 | |
| Accepts the specified style entity ``visitor``, causing it to visit all style entities associated
 | |
| within the annotation.
 | |
| 
 | |
| Returns ``True`` if the visitor should continue visiting other objects, or ``False`` if visiting
 | |
| should be canceled.
 | |
| 
 | |
| .. versionadded:: 3.10
 | |
| %End
 | |
| 
 | |
|   signals:
 | |
| 
 | |
|     void appearanceChanged();
 | |
| %Docstring
 | |
| Emitted whenever the annotation's appearance changes
 | |
| %End
 | |
| 
 | |
|     void moved();
 | |
| %Docstring
 | |
| Emitted when the annotation's position has changed and items need
 | |
| to be moved to reflect this.
 | |
| %End
 | |
| 
 | |
|     void mapLayerChanged();
 | |
| %Docstring
 | |
| Emitted when the map layer associated with the annotation changes.
 | |
| %End
 | |
| 
 | |
|   protected:
 | |
| 
 | |
|     virtual void renderAnnotation( QgsRenderContext &context, QSizeF size ) const = 0;
 | |
| %Docstring
 | |
| Renders the annotation's contents to a target /a context at the specified /a size.
 | |
| Derived classes should implement their custom annotation drawing logic here.
 | |
| %End
 | |
| 
 | |
|     virtual QSizeF minimumFrameSize() const;
 | |
| %Docstring
 | |
| Returns the minimum frame size for the annotation. Subclasses should implement this if they
 | |
| cannot be resized smaller than a certain minimum size.
 | |
| %End
 | |
| 
 | |
|     void _writeXml( QDomElement &itemElem, QDomDocument &doc, const QgsReadWriteContext &context ) const;
 | |
| %Docstring
 | |
| Writes common annotation properties to a DOM element.
 | |
| This method should be called from subclasses in their writeXml method.
 | |
| 
 | |
| .. seealso:: :py:func:`writeXml`
 | |
| 
 | |
| .. seealso:: _readXml
 | |
| %End
 | |
| 
 | |
|     void _readXml( const QDomElement &annotationElem, const QgsReadWriteContext &context );
 | |
| %Docstring
 | |
| Reads common annotation properties from a DOM element.
 | |
| This method should be called from subclasses in their readXml method.
 | |
| 
 | |
| .. seealso:: :py:func:`readXml`
 | |
| 
 | |
| .. seealso:: _writeXml
 | |
| %End
 | |
| 
 | |
|     void copyCommonProperties( QgsAnnotation *target ) const;
 | |
| %Docstring
 | |
| Copies common annotation properties to the ``targe``
 | |
| annotation.
 | |
| Can be used within :py:func:`QgsAnnotation.clone()` implementations
 | |
| to assist with creating copies.
 | |
| %End
 | |
| 
 | |
| };
 | |
| 
 | |
| 
 | |
| /************************************************************************
 | |
|  * This file has been generated automatically from                      *
 | |
|  *                                                                      *
 | |
|  * src/core/annotations/qgsannotation.h                                 *
 | |
|  *                                                                      *
 | |
|  * Do not edit manually ! Edit header and run scripts/sipify.pl again   *
 | |
|  ************************************************************************/
 |