OpenTwin 0.1
OpenTwin
 
Loading...
Searching...
No Matches
ot::GraphicsGroupItem Class Reference

The graphics group item is used to group multiple items into one item. More...

#include "GraphicsGroupItem.h"

Inheritance diagram for ot::GraphicsGroupItem:
ot::GraphicsItem ot::GraphicsElement

Public Member Functions

 GraphicsGroupItem ()
 
virtual ~GraphicsGroupItem ()
 
virtual bool setupFromConfig (const GraphicsItemCfg *_cfg) override
 Will setup the item from the provided configuration and store a copy. The previously stored configuration will be destroyed. Default 0.
 
virtual void removeAllConnections (void) override
 Removes all connections to or from this item.
 
virtual void prepareGraphicsItemGeometryChange (void) override
 Calls QGraphicsLayoutItem::prepareGeometryChange().
 
virtual void callPaint (QPainter *_painter, const QStyleOptionGraphicsItem *_opt, QWidget *_widget) override
 Calls QGraphicsItem::paint().
 
virtual QGraphicsLayoutItem * getQGraphicsLayoutItem (void) override
 Returns the QGraphicsLayoutItem.
 
virtual QGraphicsItem * getQGraphicsItem (void) override
 Returns the QGraphicsItem.
 
virtual const QGraphicsItem * getQGraphicsItem (void) const override
 Returns the const QGraphicsItem.
 
virtual QSizeF graphicsItemSizeHint (Qt::SizeHint _hint, const QSizeF &_constrains) const override
 Calls QGraphicsLayoutItem::sizeHint().
 
virtual ot::GraphicsItemfindItem (const std::string &_itemName) override
 Will return any child item that matches the _itemName.
 
virtual void finalizeGraphicsItem (void) override
 Will be called after setupFromConfig (i.e. if the item is completely created). Here the item structure is complete and the item may adjust settings that depend on parent items (e.g. Text reference for GraphicsTextItem). Container items must override this method to forward the call to their child items.
 
virtual std::list< GraphicsElement * > getAllGraphicsElements (void) override
 Returns all graphics elements nested in this element. The result contains this element and all of its childs.
 
virtual std::list< GraphicsElement * > getAllDirectChildElements (void) override
 
virtual QRectF boundingRect (void) const override
 
virtual QVariant itemChange (QGraphicsItem::GraphicsItemChange _change, const QVariant &_value) override
 
virtual void mousePressEvent (QGraphicsSceneMouseEvent *_event) override
 
virtual void mouseMoveEvent (QGraphicsSceneMouseEvent *_event) override
 
virtual void mouseReleaseEvent (QGraphicsSceneMouseEvent *_event) override
 
virtual void hoverEnterEvent (QGraphicsSceneHoverEvent *_event) override
 
virtual void hoverLeaveEvent (QGraphicsSceneHoverEvent *_event) override
 
virtual void paint (QPainter *_painter, const QStyleOptionGraphicsItem *_opt, QWidget *_widget) override
 
virtual QSizeF sizeHint (Qt::SizeHint _hint, const QSizeF &_constrains) const override
 
virtual void setGeometry (const QRectF &rect) override
 
void addItem (GraphicsItem *_item)
 
virtual double getMaxAdditionalTriggerDistance (void) const override
 Returns the maximum trigger distance in any direction of this item and its childs.
 
void clear (void)
 
- Public Member Functions inherited from ot::GraphicsItem
 GraphicsItem (GraphicsItemCfg *_configuration)
 Constructor.
 
virtual ~GraphicsItem ()
 Destructor.
 
virtual void graphicsItemEventHandler (GraphicsItem *_sender, GraphicsItemEvent _event)
 Will be called when this item was registered as an event handler and the child raised an event.
 
virtual void graphicsItemFlagsChanged (const GraphicsItemCfg::GraphicsItemFlags &_flags)
 Will be called whenever the GraphicsItem flags have changed.
 
virtual void graphicsItemConfigurationChanged (const GraphicsItemCfg *_config)
 Will be called whenever the GraphicsItem configuration has changed.
 
virtual bool graphicsItemRequiresHover (void) const
 
void handleMousePressEvent (QGraphicsSceneMouseEvent *_event)
 
bool handleMouseMoveEvent (QGraphicsSceneMouseEvent *_event)
 General event handler for mouse move events.
 
void handleMouseReleaseEvent (QGraphicsSceneMouseEvent *_event)
 
void handleHoverEnterEvent (QGraphicsSceneHoverEvent *_event)
 
void handleToolTip (QGraphicsSceneHoverEvent *_event)
 
void handleHoverLeaveEvent (QGraphicsSceneHoverEvent *_event)
 
QSizeF handleGetGraphicsItemSizeHint (Qt::SizeHint _hint, const QSizeF &_sizeHint) const
 Will expand the size according to the margins.
 
QRectF handleGetGraphicsItemBoundingRect (const QRectF &_rect) const
 Calculates the actual bounding rect including margins and requested size.
 
void handleItemChange (QGraphicsItem::GraphicsItemChange _change, const QVariant &_value)
 Handles general item updates. The selected state will be forwarded to the GraphicsHighlightItem. Position updates will update the connections and call GraphicsItem::graphicsItemEventHandler() with GraphicsItem::ItemMoved.
 
void handleSetItemGeometry (const QRectF &_geom)
 
void raiseEvent (ot::GraphicsItem::GraphicsItemEvent _event)
 
virtual qreal calculateShortestDistanceToPoint (const QPointF &_pt) const override
 Calculates and returns the shortest distance to the given point. Returns -1 if the distance is invalid (e.g. maximum distance exceeded).
 
QRectF calculatePaintArea (const QSizeF &_innerSize)
 Calculates the draw rect for the item The inner rect takes into account the item geometry, alignment, margins and the actual inner size.
 
virtual GraphicsScenegetGraphicsScene (void) const override
 Returns the GraphicsScene this item is placed at.
 
GraphicsItemgetRootItem (void)
 
const GraphicsItemgetRootItem (void) const
 
void setConfiguration (GraphicsItemCfg *_config)
 Replaces the current configuration with the configuration prvided. The item takes ownership of the configuration.
 
const GraphicsItemCfg *const getConfiguration (void) const
 Returns the current configuration.
 
void setGraphicsItemPos (const QPointF &_pos)
 This function will update the position in the configuration and call QGraphicsItem::setPos.
 
void setGraphicsItemPos (const Point2DD &_pos)
 This function will update the position in the configuration and call QGraphicsItem::setPos.
 
const Point2DDgetGraphicsItemPos (void) const
 Returns the current position set in the configuration.
 
virtual void setParentGraphicsItem (GraphicsItem *_itm)
 
GraphicsItemgetParentGraphicsItem (void) const
 
void setGraphicsItemFlag (ot::GraphicsItemCfg::GraphicsItemFlag _flag, bool _active=true)
 Sets the provided flag.
 
void setGraphicsItemFlags (ot::GraphicsItemCfg::GraphicsItemFlags _flags)
 Replaces the flags with the flags provided.
 
const GraphicsItemCfg::GraphicsItemFlagsgetGraphicsItemFlags (void) const
 Returns the current GraphicsItemFlags set.
 
void setGraphicsItemUid (const ot::UID &_uid)
 Sets the GraphicsItem UID.
 
const ot::UIDgetGraphicsItemUid (void) const
 
virtual void setGraphicsItemName (const std::string &_name)
 
const std::string & getGraphicsItemName (void) const
 
void setGraphicsItemToolTip (const std::string &_toolTip)
 
const std::string & getGraphicsItemToolTip (void) const
 
void setAdditionalTriggerDistance (const ot::MarginsD &_distance)
 
const ot::MarginsDgetAdditionalTriggerDistance (void) const
 
void setGraphicsItemMinimumSize (double _width, double _height)
 
void setGraphicsItemMinimumSize (const QSizeF &_size)
 
QSizeF getGraphicsItemMinimumSize (void) const
 
void setGraphicsItemMaximumSize (double _width, double _height)
 
void setGraphicsItemMaximumSize (const QSizeF &_size)
 
QSizeF getGraphicsItemMaximumSize (void) const
 
void setGraphicsItemSizePolicy (ot::SizePolicy _policy)
 
ot::SizePolicy getGraphicsItemSizePolicy (void) const
 
void setGraphicsItemAlignment (ot::Alignment _align)
 
ot::Alignment getGraphicsItemAlignment (void) const
 
void setGraphicsItemMargins (const ot::MarginsD &_margins)
 
const ot::MarginsDgetGraphicsItemMargins (void) const
 
void setConnectionDirection (ot::ConnectionDirection _direction)
 
ot::ConnectionDirection getConnectionDirection (void) const
 
void setStringMap (const std::map< std::string, std::string > &_map)
 
const std::map< std::string, std::string > & getStringMap (void) const
 
void setGraphicsItemTransform (const Transform &_transform)
 
const TransformgetGraphicsItemTransform (void) const
 
void setForwardSizeChanges (bool _forward)
 
bool getForwardSizeChanges (void) const
 
void storeConnection (GraphicsConnectionItem *_connection)
 
void forgetConnection (GraphicsConnectionItem *_connection)
 Removes the collection from the list (item will not be destroyed)
 
void addGraphicsItemEventHandler (ot::GraphicsItem *_handler)
 
void removeGraphicsItemEventHandler (ot::GraphicsItem *_handler)
 
QSizeF applyGraphicsItemMargins (const QSizeF &_size) const
 
QSizeF removeGraphicsItemMargins (const QSizeF &_size) const
 
virtual void setGraphicsItemRequestedSize (const QSizeF &_size)
 
const QSizeF & graphicsItemRequestedSize (void) const
 
std::list< ot::GraphicsConnectionCfggetConnectionCfgs ()
 
void setGraphicsItemSelected (bool _selected)
 
bool getGraphicsItemSelected (void) const
 
void setBlockFlagNotifications (bool _block)
 
bool getBlockFlagNotifications (void) const
 If enabled the item will not call graphicsItemFlagsChanged() when the flags have changed.
 
void setBlockConfigurationNotifications (bool _block)
 
bool getBlockConfigurationNotifications (void) const
 If enabled the item will not call graphicsItemConfigurationChanged() when the flags have changed.
 
void setCurrentPosAsMoveStart (void)
 Sets the current item position as move start point.
 
void notifyMoveIfRequired (void)
 Notifies the view if the items current position changed relative to the move start point.
 
void parentItemTransformChanged (const QTransform &_parentTransform)
 
QRectF getTriggerBoundingRect (void) const
 Returns the bounding rect in scene coordinates which was expanded by the additional trigger distance according to the config.
 
- Public Member Functions inherited from ot::GraphicsElement
 GraphicsElement ()
 
virtual ~GraphicsElement ()
 
virtual void setGraphicsScene (GraphicsScene *_scene)
 Set the GraphicsScene this element is placed at.
 
void setGraphicsElementState (GraphicsElementState _state, bool _active=true)
 Sets the provided state flag.
 
void setGraphicsElementStateFlags (const GraphicsElementStateFlags &_state)
 Replaces the flags with the flags provided.
 
const GraphicsElementStateFlagsgetGraphicsElementState (void) const
 Returns the current GraphicsItemStateFlags set.
 

Protected Member Functions

virtual void graphicsElementStateChanged (const GraphicsElementStateFlags &_state) override
 
virtual void notifyChildsAboutTransformChange (const QTransform &_newTransform) override
 
- Protected Member Functions inherited from ot::GraphicsItem
template<class T >
T * getItemConfiguration (void)
 Returns the configuration for the current item. The configuration may be modified. The function will cast the current configuration to the type provided. The method will return 0 if the cast failed.
 
template<class T >
const T * getItemConfiguration (void) const
 Returns the configuration for the current item. The configuration may be modified. The function will cast the current configuration to the type provided. The method will return 0 if the cast failed.
 
virtual void applyGraphicsItemTransform (void)
 

Additional Inherited Members

- Public Types inherited from ot::GraphicsItem
enum  GraphicsItemEvent { ItemMoved , ItemResized }
 The GraphicsItemEvent is used to describe the type of an event that occured. More...
 
- Public Types inherited from ot::GraphicsElement
enum  GraphicsElementState { NoState = 0x00 , HoverState = 0x01 , SelectedState = 0x02 }
 The GraphicsElementState is used to describe the current state of a GraphicsElement. More...
 
typedef Flags< GraphicsElementStateGraphicsElementStateFlags
 
- Static Public Member Functions inherited from ot::GraphicsItem
static Painter2DcreateSelectionBorderPainter (void)
 Creates a StyleRefPainter2D painter referencing ot::ColorStyleValueEntry::GraphicsItemSelectionBorder. The caller takes ownership of the painter.
 
static Painter2DcreateHoverBorderPainter (void)
 Creates a StyleRefPainter2D painter referencing ot::ColorStyleValueEntry::GraphicsItemHoverBorder. The caller takes ownership of the painter.
 

Detailed Description

The graphics group item is used to group multiple items into one item.

Constructor & Destructor Documentation

◆ GraphicsGroupItem()

ot::GraphicsGroupItem::GraphicsGroupItem ( )

◆ ~GraphicsGroupItem()

ot::GraphicsGroupItem::~GraphicsGroupItem ( )
virtual

Member Function Documentation

◆ addItem()

void ot::GraphicsGroupItem::addItem ( GraphicsItem * _item)

◆ boundingRect()

QRectF ot::GraphicsGroupItem::boundingRect ( void ) const
overridevirtual

◆ callPaint()

void ot::GraphicsGroupItem::callPaint ( QPainter * _painter,
const QStyleOptionGraphicsItem * _opt,
QWidget * _widget )
overridevirtual

Calls QGraphicsItem::paint().

Implements ot::GraphicsItem.

◆ clear()

void ot::GraphicsGroupItem::clear ( void )

◆ finalizeGraphicsItem()

void ot::GraphicsGroupItem::finalizeGraphicsItem ( void )
overridevirtual

Will be called after setupFromConfig (i.e. if the item is completely created). Here the item structure is complete and the item may adjust settings that depend on parent items (e.g. Text reference for GraphicsTextItem). Container items must override this method to forward the call to their child items.

Reimplemented from ot::GraphicsItem.

◆ findItem()

ot::GraphicsItem * ot::GraphicsGroupItem::findItem ( const std::string & _itemName)
overridevirtual

Will return any child item that matches the _itemName.

Parameters
_itemNameThe name of the item to find.

Reimplemented from ot::GraphicsItem.

◆ getAllDirectChildElements()

std::list< ot::GraphicsElement * > ot::GraphicsGroupItem::getAllDirectChildElements ( void )
overridevirtual

Reimplemented from ot::GraphicsElement.

◆ getAllGraphicsElements()

std::list< ot::GraphicsElement * > ot::GraphicsGroupItem::getAllGraphicsElements ( void )
overridevirtual

Returns all graphics elements nested in this element. The result contains this element and all of its childs.

Reimplemented from ot::GraphicsElement.

◆ getMaxAdditionalTriggerDistance()

double ot::GraphicsGroupItem::getMaxAdditionalTriggerDistance ( void ) const
overridevirtual

Returns the maximum trigger distance in any direction of this item and its childs.

Reimplemented from ot::GraphicsItem.

◆ getQGraphicsItem() [1/2]

virtual const QGraphicsItem * ot::GraphicsGroupItem::getQGraphicsItem ( void ) const
inlineoverridevirtual

Returns the const QGraphicsItem.

Implements ot::GraphicsElement.

◆ getQGraphicsItem() [2/2]

virtual QGraphicsItem * ot::GraphicsGroupItem::getQGraphicsItem ( void )
inlineoverridevirtual

Returns the QGraphicsItem.

Implements ot::GraphicsElement.

◆ getQGraphicsLayoutItem()

virtual QGraphicsLayoutItem * ot::GraphicsGroupItem::getQGraphicsLayoutItem ( void )
inlineoverridevirtual

Returns the QGraphicsLayoutItem.

Implements ot::GraphicsItem.

◆ graphicsElementStateChanged()

void ot::GraphicsGroupItem::graphicsElementStateChanged ( const GraphicsElementStateFlags & _state)
overrideprotectedvirtual

Reimplemented from ot::GraphicsItem.

◆ graphicsItemSizeHint()

QSizeF ot::GraphicsGroupItem::graphicsItemSizeHint ( Qt::SizeHint _hint,
const QSizeF & _constrains ) const
overridevirtual

Calls QGraphicsLayoutItem::sizeHint().

Implements ot::GraphicsItem.

◆ hoverEnterEvent()

void ot::GraphicsGroupItem::hoverEnterEvent ( QGraphicsSceneHoverEvent * _event)
overridevirtual

◆ hoverLeaveEvent()

void ot::GraphicsGroupItem::hoverLeaveEvent ( QGraphicsSceneHoverEvent * _event)
overridevirtual

◆ itemChange()

QVariant ot::GraphicsGroupItem::itemChange ( QGraphicsItem::GraphicsItemChange _change,
const QVariant & _value )
overridevirtual

◆ mouseMoveEvent()

void ot::GraphicsGroupItem::mouseMoveEvent ( QGraphicsSceneMouseEvent * _event)
overridevirtual

◆ mousePressEvent()

void ot::GraphicsGroupItem::mousePressEvent ( QGraphicsSceneMouseEvent * _event)
overridevirtual

◆ mouseReleaseEvent()

void ot::GraphicsGroupItem::mouseReleaseEvent ( QGraphicsSceneMouseEvent * _event)
overridevirtual

◆ notifyChildsAboutTransformChange()

void ot::GraphicsGroupItem::notifyChildsAboutTransformChange ( const QTransform & _newTransform)
overrideprotectedvirtual

Reimplemented from ot::GraphicsItem.

◆ paint()

void ot::GraphicsGroupItem::paint ( QPainter * _painter,
const QStyleOptionGraphicsItem * _opt,
QWidget * _widget )
overridevirtual

◆ prepareGraphicsItemGeometryChange()

void ot::GraphicsGroupItem::prepareGraphicsItemGeometryChange ( void )
overridevirtual

Calls QGraphicsLayoutItem::prepareGeometryChange().

Implements ot::GraphicsItem.

◆ removeAllConnections()

void ot::GraphicsGroupItem::removeAllConnections ( void )
overridevirtual

Removes all connections to or from this item.

Reimplemented from ot::GraphicsItem.

◆ setGeometry()

void ot::GraphicsGroupItem::setGeometry ( const QRectF & rect)
overridevirtual

◆ setupFromConfig()

bool ot::GraphicsGroupItem::setupFromConfig ( const GraphicsItemCfg * _cfg)
overridevirtual

Will setup the item from the provided configuration and store a copy. The previously stored configuration will be destroyed. Default 0.

Parameters
_cfgGraphicsItem configuration (Copy will be stored).

Reimplemented from ot::GraphicsItem.

◆ sizeHint()

QSizeF ot::GraphicsGroupItem::sizeHint ( Qt::SizeHint _hint,
const QSizeF & _constrains ) const
overridevirtual

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