QGIS API Documentation  2.8.2-Wien
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
Public Slots | Public Member Functions | List of all members
QgsComposerLabel Class Reference

A label that can be placed onto a map composition. More...

#include <qgscomposerlabel.h>

Inheritance diagram for QgsComposerLabel:
Inheritance graph
[legend]

Public Slots

void refreshExpressionContext ()
- Public Slots inherited from QgsComposerItem
virtual void refreshDataDefinedProperty (const QgsComposerObject::DataDefinedProperty property=QgsComposerObject::AllProperties) override
 Refreshes a data defined property for the item by reevaluating the property's value and redrawing the item with this new value.
void repaint () override
virtual void setItemRotation (const double r, const bool adjustPosition=false)
 Sets the item rotation.
virtual void setRotation (double r)
 Sets the item rotation.
- Public Slots inherited from QgsComposerObject
virtual void refreshDataDefinedProperty (const DataDefinedProperty property=AllProperties)
 Refreshes a data defined property for the item by reevaluating the property's value and redrawing the item with this new value.
virtual void repaint ()
 Triggers a redraw for the item.

Public Member Functions

 QgsComposerLabel (QgsComposition *composition)
 ~QgsComposerLabel ()
void adjustSizeToText ()
 resizes the widget such that the text fits to the item.
QRectF boundingRect () const override
 In case of negative margins, the bounding rect may be larger than the label's frame.
virtual QString displayName () const override
 Get item display name.
QString displayText () const
 Returns the text as it appears on screen (with replaced data field)
QFont font () const
QColor fontColor () const
 Get font color.
Qt::AlignmentFlag hAlign () const
 Accessor for the horizontal alignment of the label.
int htmlState ()
Q_DECL_DEPRECATED double margin ()
 Returns the margin between the edge of the frame and the label contents.
double marginX () const
 Returns the horizontal margin between the edge of the frame and the label contents.
double marginY () const
 Returns the vertical margin between the edge of the frame and the label contents.
void paint (QPainter *painter, const QStyleOptionGraphicsItem *itemStyle, QWidget *pWidget) override
 Reimplementation of QCanvasItem::paint.
bool readXML (const QDomElement &itemElem, const QDomDocument &doc) override
 sets state from Dom document
void setExpressionContext (QgsFeature *feature, QgsVectorLayer *layer, QMap< QString, QVariant > substitutions=(QMap< QString, QVariant >()))
 Sets the current feature, the current layer and a list of local variable substitutions for evaluating expressions.
void setFont (const QFont &f)
void setFontColor (const QColor &c)
 Sets text color.
virtual void setFrameEnabled (const bool drawFrame) override
 Reimplemented to call prepareGeometryChange after toggling frame.
virtual void setFrameOutlineWidth (const double outlineWidth) override
 Reimplemented to call prepareGeometryChange after changing outline width.
void setHAlign (Qt::AlignmentFlag a)
 Mutator for the horizontal alignment of the label.
void setHtmlState (int state)
void setMargin (const double m)
 Sets the margin between the edge of the frame and the label contents.
void setMarginX (const double margin)
 Sets the horizontal margin between the edge of the frame and the label contents.
void setMarginY (const double margin)
 Sets the vertical margin between the edge of the frame and the label contents.
void setText (const QString &text)
void setVAlign (Qt::AlignmentFlag a)
 Mutator for the vertical alignment of the label.
QString text ()
virtual int type () const override
 return correct graphics item type.
Qt::AlignmentFlag vAlign () const
 Accessor for the vertical alignment of the label.
bool writeXML (QDomElement &elem, QDomDocument &doc) const override
 stores state in Dom element
- Public Member Functions inherited from QgsComposerItem
 QgsComposerItem (QgsComposition *composition, bool manageZValue=true)
 Constructor.
 QgsComposerItem (qreal x, qreal y, qreal width, qreal height, QgsComposition *composition, bool manageZValue=true)
 Constructor with box position and composer object.
virtual ~QgsComposerItem ()
bool _readXML (const QDomElement &itemElem, const QDomDocument &doc)
 Reads parameter that are not subclass specific in document.
bool _writeXML (QDomElement &itemElem, QDomDocument &doc) const
 Writes parameter that are not subclass specific in document.
virtual void addItem (QgsComposerItem *item)
 Composite operations for item groups do nothing per default.
QColor backgroundColor () const
 Gets the background color for this item.
void beginCommand (const QString &commandText, QgsComposerMergeCommand::Context c=QgsComposerMergeCommand::Unknown)
 Starts new composer undo command.
virtual void beginItemCommand (const QString &text)
QPainter::CompositionMode blendMode () const
 Returns the item's composition blending mode.
void cancelCommand ()
Q_DECL_DEPRECATED void drawText (QPainter *p, double x, double y, const QString &text, const QFont &font, const QColor &c=QColor()) const
 Draws Text.
Q_DECL_DEPRECATED void drawText (QPainter *p, const QRectF &rect, const QString &text, const QFont &font, Qt::AlignmentFlag halignment=Qt::AlignLeft, Qt::AlignmentFlag valignment=Qt::AlignTop, int flags=Qt::TextWordWrap) const
 Like the above, but with a rectangle for multiline text.
bool effectsEnabled () const
 Returns whether effects (eg blend modes) are enabled for the item.
void endCommand ()
 Finish current command and push it onto the undo stack.
virtual void endItemCommand ()
virtual double estimatedFrameBleed () const
 Returns the estimated amount the item's frame bleeds outside the item's actual rectangle.
bool excludeFromExports (const QgsComposerObject::PropertyValueType valueType=QgsComposerObject::EvaluatedValue)
 Returns whether the item should be excluded from composer exports and prints.
Q_DECL_DEPRECATED double fontAscentMillimeters (const QFont &font) const
 Returns the font ascent in Millimeters (considers upscaling and downscaling with FONT_WORKAROUND_SCALE.
Q_DECL_DEPRECATED double fontDescentMillimeters (const QFont &font) const
 Returns the font descent in Millimeters (considers upscaling and downscaling with FONT_WORKAROUND_SCALE.
Q_DECL_DEPRECATED double fontHeightCharacterMM (const QFont &font, const QChar &c) const
 Returns the font height of a character in millimeters.
Q_DECL_DEPRECATED double fontHeightMillimeters (const QFont &font) const
 Returns the font height in Millimeters (considers upscaling and downscaling with FONT_WORKAROUND_SCALE.
Qt::PenJoinStyle frameJoinStyle () const
 Returns the join style used for drawing the item's frame.
QColor frameOutlineColor () const
 Returns the frame's outline color.
double frameOutlineWidth () const
 Returns the frame's outline width.
bool hasBackground () const
 Whether this item has a Background or not.
bool hasFrame () const
 Whether this item has a frame or not.
QString id () const
 Get item's id (which is not necessarly unique)
bool isGroupMember () const
 Returns whether this item is part of a group.
virtual bool isRemoved () const
 Returns whether this item has been removed from the composition.
double itemRotation (const QgsComposerObject::PropertyValueType valueType=QgsComposerObject::EvaluatedValue) const
 Returns the current rotation for the composer item.
ItemPositionMode lastUsedPositionMode ()
 Returns item's last used position mode.
void move (double dx, double dy)
 Moves item in canvas coordinates.
virtual void moveContent (double dx, double dy)
 Move Content of item.
virtual int numberExportLayers () const
 Get the number of layers that this item requires for exporting as layers.
int page () const
 Gets the page the item is currently on.
QPointF pagePos () const
 Returns the item's position relative to its current page.
Q_DECL_DEPRECATED double pixelFontSize (double pointSize) const
 Calculates font size in mm from a font point size.
bool positionLock () const
 Returns whether position lock for mouse drags is enabled returns true if item is locked for mouse movement and resizing.
virtual QRectF rectWithFrame () const
 Returns the item's rectangular bounds, including any bleed caused by the item's frame.
virtual void removeItems ()
Q_DECL_DEPRECATED double rotation () const
 Returns the rotation for the composer item.
Q_DECL_DEPRECATED QFont scaledFontPixelSize (const QFont &font) const
 Returns a font where size is in pixel and font size is upscaled with FONT_WORKAROUND_SCALE.
virtual bool selected () const
 Is selected.
void setBackgroundColor (const QColor &backgroundColor)
 Sets the background color for this item.
void setBackgroundEnabled (const bool drawBackground)
 Set whether this item has a Background drawn around it or not.
void setBlendMode (const QPainter::CompositionMode blendMode)
 Sets the item's composition blending mode.
virtual void setCurrentExportLayer (const int layerIdx=-1)
 Sets the current layer to draw for exporting.
void setEffectsEnabled (const bool effectsEnabled)
 Sets whether effects (eg blend modes) are enabled for the item.
virtual void setExcludeFromExports (const bool exclude)
 Sets whether the item should be excluded from composer exports and prints.
void setFrameJoinStyle (const Qt::PenJoinStyle style)
 Sets join style used when drawing the item's frame.
virtual void setFrameOutlineColor (const QColor &color)
 Sets frame outline color.
virtual void setId (const QString &id)
 Set item's id (which is not necessarly unique)
void setIsGroupMember (const bool isGroupMember)
 Sets whether this item is part of a group.
void setIsRemoved (const bool removed)
 Sets whether this item has been removed from the composition.
void setItemPosition (double x, double y, ItemPositionMode itemPoint=UpperLeft, int page=-1)
 Moves the item to a new position (in canvas coordinates)
void setItemPosition (double x, double y, double width, double height, ItemPositionMode itemPoint=UpperLeft, bool posIncludesFrame=false, int page=-1)
 Sets item position and width / height in one go.
void setPositionLock (const bool lock)
 Locks / unlocks the item position for mouse drags.
virtual void setSceneRect (const QRectF &rectangle)
 Sets this items bound in scene coordinates such that 1 item size units corresponds to 1 scene size unit.
virtual void setSelected (bool s)
 Set selected, selected item should be highlighted.
void setTransparency (const int transparency)
 Sets the item's transparency.
virtual void setVisibility (const bool visible)
 Sets visibility for item.
Q_DECL_DEPRECATED double textWidthMillimeters (const QFont &font, const QString &text) const
 Returns the font width in millimeters (considers upscaling and downscaling with FONT_WORKAROUND_SCALE.
int transparency () const
 Returns the item's transparency.
virtual void updateItem ()
 Updates item, with the possibility to do custom update for subclasses.
void updatePagePos (double newPageWidth, double newPageHeight)
 Moves the item so that it retains its relative position on the page when the paper size changes.
QString uuid () const
 Get item identification name.
virtual Q_DECL_DEPRECATED void zoomContent (int delta, double x, double y)
 Zoom content of item.
virtual void zoomContent (const double factor, const QPointF point, const ZoomMode mode=QgsComposerItem::Zoom)
 Zoom content of item.
- Public Member Functions inherited from QgsComposerObject
 QgsComposerObject (QgsComposition *composition)
 Constructor.
virtual ~QgsComposerObject ()
const QgsCompositioncomposition () const
 Returns the composition the item is attached to.
QgsCompositioncomposition ()
QgsDataDefineddataDefinedProperty (const DataDefinedProperty property) const
 Returns a reference to the data defined settings for one of the item's data defined properties.
void setDataDefinedProperty (const DataDefinedProperty property, const bool active, const bool useExpression, const QString &expression, const QString &field)
 Sets parameters for a data defined property for the item.

Additional Inherited Members

- Public Types inherited from QgsComposerItem
enum  ItemPositionMode {
  UpperLeft, UpperMiddle, UpperRight, MiddleLeft,
  Middle, MiddleRight, LowerLeft, LowerMiddle,
  LowerRight
}
enum  ItemType {
  ComposerItem = UserType + 100, ComposerArrow, ComposerItemGroup, ComposerLabel,
  ComposerLegend, ComposerMap, ComposerPaper, ComposerPicture,
  ComposerScaleBar, ComposerShape, ComposerTable, ComposerAttributeTable,
  ComposerTextTable, ComposerFrame
}
enum  MouseMoveAction {
  MoveItem, ResizeUp, ResizeDown, ResizeLeft,
  ResizeRight, ResizeLeftUp, ResizeRightUp, ResizeLeftDown,
  ResizeRightDown, NoAction
}
 Describes the action (move or resize in different directon) to be done during mouse move. More...
enum  ZoomMode { Zoom = 0, ZoomRecenter, ZoomToPoint, NoZoom }
 Modes for zooming item content. More...
- Signals inherited from QgsComposerItem
void frameChanged ()
 Emitted if the item's frame style changes.
void itemRotationChanged (double newRotation)
 Is emitted on item rotation change.
void lockChanged ()
 Emitted if the item's lock status changes.
void sizeChanged ()
 Emitted if the rectangle changes.
- Protected Member Functions inherited from QgsComposerItem
Q_DECL_DEPRECATED double angle (const QPointF &p1, const QPointF &p2) const
 Returns angle of the line from p1 to p2 (clockwise, starting at N)
Q_DECL_DEPRECATED bool cornerPointOnRotatedAndScaledRect (double &x, double &y, double width, double height, double rotation) const
 Calculates corner point after rotation and scaling.
Q_DECL_DEPRECATED bool cornerPointOnRotatedAndScaledRect (double &x, double &y, double width, double height) const
 Calculates corner point after rotation and scaling.
void deleteAlignItems ()
void deleteHAlignSnapItem ()
void deleteVAlignSnapItem ()
Q_DECL_DEPRECATED void drawArrowHead (QPainter *p, double x, double y, double angle, double arrowHeadWidth) const
 Draws arrowhead.
virtual void drawBackground (QPainter *p)
 Draw background.
virtual void drawFrame (QPainter *p)
 Draw black frame around item.
virtual void drawSelectionBoxes (QPainter *p)
 Draws additional graphics on selected items.
QRectF evalItemRect (const QRectF &newRect, const bool resizeOnly=false)
 Evaluates an item's bounding rect to consider data defined position and size of item and reference point.
QGraphicsLineItem * hAlignSnapItem ()
 Return horizontal align snap item.
double horizontalViewScaleFactor () const
 Returns the zoom factor of the graphics view.
Q_DECL_DEPRECATED bool imageSizeConsideringRotation (double &width, double &height, double rotation) const
 Calculates width and hight of the picture (in mm) such that it fits into the item frame with the given rotation.
Q_DECL_DEPRECATED bool imageSizeConsideringRotation (double &width, double &height) const
 Calculates width and hight of the picture (in mm) such that it fits into the item frame with the given rotation.
Q_DECL_DEPRECATED QRectF largestRotatedRectWithinBounds (QRectF originalRect, QRectF boundsRect, double rotation) const
 Calculates the largest scaled version of originalRect which fits within boundsRect, when it is rotated by a specified amount.
Q_DECL_DEPRECATED double lockSymbolSize () const
 Returns the size of the lock symbol depending on the composer zoom level and the item size.
double rectHandlerBorderTolerance () const
 Returns the current (zoom level dependent) tolerance to decide if mouse position is close enough to the item border for resizing.
Q_DECL_DEPRECATED void rotate (double angle, double &x, double &y) const
 Rotates a point / vector.
bool shouldDrawItem () const
 Returns whether the item should be drawn in the current context.
Q_DECL_DEPRECATED void sizeChangedByRotation (double &width, double &height, double rotation)
 Calculates width / height of the bounding box of a rotated rectangle.
Q_DECL_DEPRECATED void sizeChangedByRotation (double &width, double &height)
 Calculates width / height of the bounding box of a rotated rectangle.
QGraphicsLineItem * vAlignSnapItem ()
 Return vertical align snap item.
- Protected Attributes inherited from QgsComposerItem
bool mBackground
 True if item background needs to be painted.
QColor mBackgroundColor
 Background color.
QPainter::CompositionMode mBlendMode
 Composition blend mode for item.
QGraphicsRectItem * mBoundingResizeRectangle
 Rectangle used during move and resize actions.
int mCurrentExportLayer
 The layer that needs to be exported.
QgsComposerItem::MouseMoveAction mCurrentMouseMoveAction
QgsComposerEffectmEffect
bool mEffectsEnabled
bool mEvaluatedExcludeFromExports
 Temporary evaluated item exclusion.
double mEvaluatedItemRotation
 Temporary evaluated item rotation in degrees, clockwise.
bool mExcludeFromExports
 Whether item should be excluded in exports.
bool mFrame
 True if item fram needs to be painted.
Qt::PenJoinStyle mFrameJoinStyle
 Frame join style.
QGraphicsLineItem * mHAlignSnapItem
bool mIsGroupMember
 Whether or not this item is part of a group.
bool mItemPositionLocked
 True if item position and size cannot be changed with mouse move.
double mItemRotation
 Item rotation in degrees, clockwise.
QPointF mLastMouseEventPos
 Position of the last mouse move event (in scene coordinates)
ItemPositionMode mLastUsedPositionMode
 The item's position mode.
double mLastValidViewScaleFactor
 Backup to restore item appearance if no view scale factor is available.
QPointF mMouseMoveStartPos
 Start point of the last mouse move action (in scene coordinates)
bool mRemovedFromComposition
 True if item has been removed from the composition.
int mTransparency
 Item transparency.
QGraphicsLineItem * mVAlignSnapItem

Detailed Description

A label that can be placed onto a map composition.

Definition at line 30 of file qgscomposerlabel.h.

Constructor & Destructor Documentation

QgsComposerLabel::QgsComposerLabel ( QgsComposition composition)

Definition at line 37 of file qgscomposerlabel.cpp.

QgsComposerLabel::~QgsComposerLabel ( )

Definition at line 83 of file qgscomposerlabel.cpp.

Member Function Documentation

void QgsComposerLabel::adjustSizeToText ( )

resizes the widget such that the text fits to the item.

Keeps top left point

Definition at line 334 of file qgscomposerlabel.cpp.

QRectF QgsComposerLabel::boundingRect ( ) const
override

In case of negative margins, the bounding rect may be larger than the label's frame.

Definition at line 500 of file qgscomposerlabel.cpp.

QString QgsComposerLabel::displayName ( ) const
overridevirtual

Get item display name.

This is the item's id if set, and if not, a user-friendly string identifying item type.

Returns
display name for item
See Also
id
setId
Note
added in version 2.5

Reimplemented from QgsComposerItem.

Definition at line 472 of file qgscomposerlabel.cpp.

QString QgsComposerLabel::displayText ( ) const

Returns the text as it appears on screen (with replaced data field)

Definition at line 276 of file qgscomposerlabel.cpp.

QFont QgsComposerLabel::font ( ) const

Definition at line 354 of file qgscomposerlabel.cpp.

QColor QgsComposerLabel::fontColor ( ) const
inline

Get font color.

Definition at line 130 of file qgscomposerlabel.h.

Qt::AlignmentFlag QgsComposerLabel::hAlign ( ) const
inline

Accessor for the horizontal alignment of the label.

Returns
Qt::AlignmentFlag

Definition at line 67 of file qgscomposerlabel.h.

int QgsComposerLabel::htmlState ( )
inline

Definition at line 49 of file qgscomposerlabel.h.

Q_DECL_DEPRECATED double QgsComposerLabel::margin ( )
inline

Returns the margin between the edge of the frame and the label contents.

Returns
margin in mm
Deprecated:
use marginX and marginY instead

Definition at line 83 of file qgscomposerlabel.h.

double QgsComposerLabel::marginX ( ) const
inline

Returns the horizontal margin between the edge of the frame and the label contents.

Returns
horizontal margin in mm
Note
added in QGIS 2.7

Definition at line 90 of file qgscomposerlabel.h.

double QgsComposerLabel::marginY ( ) const
inline

Returns the vertical margin between the edge of the frame and the label contents.

Returns
vertical margin in mm
Note
added in QGIS 2.7

Definition at line 97 of file qgscomposerlabel.h.

void QgsComposerLabel::paint ( QPainter *  painter,
const QStyleOptionGraphicsItem *  itemStyle,
QWidget *  pWidget 
)
override

Reimplementation of QCanvasItem::paint.

Definition at line 88 of file qgscomposerlabel.cpp.

bool QgsComposerLabel::readXML ( const QDomElement &  itemElem,
const QDomDocument &  doc 
)
overridevirtual

sets state from Dom document

Parameters
itemElemis Dom element corresponding to 'ComposerLabel' tag
docdocument

Reimplemented from QgsComposerObject.

Definition at line 394 of file qgscomposerlabel.cpp.

void QgsComposerLabel::refreshExpressionContext ( )
slot

Definition at line 259 of file qgscomposerlabel.cpp.

void QgsComposerLabel::setExpressionContext ( QgsFeature feature,
QgsVectorLayer layer,
QMap< QString, QVariant >  substitutions = ( QMap<QString, QVariant>() ) 
)

Sets the current feature, the current layer and a list of local variable substitutions for evaluating expressions.

Definition at line 233 of file qgscomposerlabel.cpp.

void QgsComposerLabel::setFont ( const QFont &  f)

Definition at line 310 of file qgscomposerlabel.cpp.

void QgsComposerLabel::setFontColor ( const QColor &  c)
inline

Sets text color.

Definition at line 128 of file qgscomposerlabel.h.

void QgsComposerLabel::setFrameEnabled ( const bool  drawFrame)
overridevirtual

Reimplemented to call prepareGeometryChange after toggling frame.

Reimplemented from QgsComposerItem.

Definition at line 518 of file qgscomposerlabel.cpp.

void QgsComposerLabel::setFrameOutlineWidth ( const double  outlineWidth)
overridevirtual

Reimplemented to call prepareGeometryChange after changing outline width.

Reimplemented from QgsComposerItem.

Definition at line 524 of file qgscomposerlabel.cpp.

void QgsComposerLabel::setHAlign ( Qt::AlignmentFlag  a)
inline

Mutator for the horizontal alignment of the label.

Parameters
aalignment
Returns
void

Definition at line 72 of file qgscomposerlabel.h.

void QgsComposerLabel::setHtmlState ( int  state)

Definition at line 217 of file qgscomposerlabel.cpp.

void QgsComposerLabel::setMargin ( const double  m)

Sets the margin between the edge of the frame and the label contents.

This method sets both the horizontal and vertical margins to the same value. The margins can be individually controlled using the setMarginX and setMarginY methods.

Parameters
mmargin in mm
See Also
setMarginX
setMarginY

Definition at line 315 of file qgscomposerlabel.cpp.

void QgsComposerLabel::setMarginX ( const double  margin)

Sets the horizontal margin between the edge of the frame and the label contents.

Parameters
marginhorizontal margin in mm
See Also
setMargin
setMarginY
Note
added in QGIS 2.7

Definition at line 322 of file qgscomposerlabel.cpp.

void QgsComposerLabel::setMarginY ( const double  margin)

Sets the vertical margin between the edge of the frame and the label contents.

Parameters
marginvertical margin in mm
See Also
setMargin
setMarginX
Note
added in QGIS 2.7

Definition at line 328 of file qgscomposerlabel.cpp.

void QgsComposerLabel::setText ( const QString &  text)

Definition at line 205 of file qgscomposerlabel.cpp.

void QgsComposerLabel::setVAlign ( Qt::AlignmentFlag  a)
inline

Mutator for the vertical alignment of the label.

Parameters
aalignment
Returns
void

Definition at line 77 of file qgscomposerlabel.h.

QString QgsComposerLabel::text ( void  )
inline

Definition at line 46 of file qgscomposerlabel.h.

virtual int QgsComposerLabel::type ( ) const
inlineoverridevirtual

return correct graphics item type.

Reimplemented from QgsComposerItem.

Definition at line 38 of file qgscomposerlabel.h.

Qt::AlignmentFlag QgsComposerLabel::vAlign ( ) const
inline

Accessor for the vertical alignment of the label.

Returns
Qt::AlignmentFlag

Definition at line 63 of file qgscomposerlabel.h.

bool QgsComposerLabel::writeXML ( QDomElement &  elem,
QDomDocument &  doc 
) const
overridevirtual

stores state in Dom element

Parameters
elemis Dom element corresponding to 'Composer' tag
docdocument

Reimplemented from QgsComposerObject.

Definition at line 359 of file qgscomposerlabel.cpp.


The documentation for this class was generated from the following files: