OpenTwin 0.1
OpenTwin
 
Loading...
Searching...
No Matches
ot::GraphicsLayoutItem Class Referenceabstract

#include "GraphicsLayoutItem.h"

Inheritance diagram for ot::GraphicsLayoutItem:
ot::GraphicsItem ot::GraphicsElement ot::GraphicsBoxLayoutItem ot::GraphicsGridLayoutItem ot::GraphicsHBoxLayoutItem ot::GraphicsVBoxLayoutItem

Public Member Functions

 GraphicsLayoutItem (GraphicsItemCfg *_configuration)
 
virtual ~GraphicsLayoutItem ()
 
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 setGraphicsItemName (const std::string &_name) override
 
virtual void removeAllConnections (void) override
 Removes all connections to or from this item.
 
virtual void prepareGraphicsItemGeometryChange (void) override
 Calls QGraphicsLayoutItem::prepareGeometryChange().
 
virtual void setParentGraphicsItem (GraphicsItem *_itm) override
 
virtual void setGraphicsScene (GraphicsScene *_scene) override
 Set the GraphicsScene this element is placed at.
 
virtual void getAllItems (std::list< QGraphicsLayoutItem * > &_items) const =0
 
virtual void callPaint (QPainter *_painter, const QStyleOptionGraphicsItem *_opt, QWidget *_widget) override
 Calls QGraphicsItem::paint().
 
virtual void graphicsItemFlagsChanged (const GraphicsItemCfg::GraphicsItemFlags &_flags) override
 Will be called whenever the GraphicsItem flags have changed.
 
virtual void graphicsItemConfigurationChanged (const GraphicsItemCfg *_config) override
 Will be called whenever the GraphicsItem configuration has changed.
 
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 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 void setGraphicsItemRequestedSize (const QSizeF &_size) override
 
virtual double getMaxAdditionalTriggerDistance (void) const override
 Returns the maximum trigger distance in any direction of this item and its childs.
 
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
 
GraphicsLayoutItemWrappergetLayoutWrapper (void) const
 
- Public Member Functions inherited from ot::GraphicsItem
 GraphicsItem (GraphicsItemCfg *_configuration)
 Constructor.
 
virtual ~GraphicsItem ()
 Destructor.
 
virtual QSizeF graphicsItemSizeHint (Qt::SizeHint _hint, const QSizeF &_constrains) const =0
 Calls QGraphicsLayoutItem::sizeHint().
 
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 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.
 
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
 
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
 
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 ()
 
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
 
void createLayoutWrapper (QGraphicsLayout *_layout)
 Call this function from the item constructor to create the layout wrapper instance.
 
- 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.
 

Constructor & Destructor Documentation

◆ GraphicsLayoutItem()

ot::GraphicsLayoutItem::GraphicsLayoutItem ( GraphicsItemCfg * _configuration)

◆ ~GraphicsLayoutItem()

ot::GraphicsLayoutItem::~GraphicsLayoutItem ( )
virtual

Member Function Documentation

◆ callPaint()

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

Calls QGraphicsItem::paint().

Implements ot::GraphicsItem.

◆ createLayoutWrapper()

void ot::GraphicsLayoutItem::createLayoutWrapper ( QGraphicsLayout * _layout)
protected

Call this function from the item constructor to create the layout wrapper instance.

◆ finalizeGraphicsItem()

void ot::GraphicsLayoutItem::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::GraphicsLayoutItem::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::GraphicsLayoutItem::getAllDirectChildElements ( void )
overridevirtual

Reimplemented from ot::GraphicsElement.

◆ getAllGraphicsElements()

std::list< ot::GraphicsElement * > ot::GraphicsLayoutItem::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.

◆ getAllItems()

virtual void ot::GraphicsLayoutItem::getAllItems ( std::list< QGraphicsLayoutItem * > & _items) const
pure virtual

◆ getLayoutWrapper()

GraphicsLayoutItemWrapper * ot::GraphicsLayoutItem::getLayoutWrapper ( void ) const
inline

◆ getMaxAdditionalTriggerDistance()

double ot::GraphicsLayoutItem::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]

const QGraphicsItem * ot::GraphicsLayoutItem::getQGraphicsItem ( void ) const
overridevirtual

Returns the const QGraphicsItem.

Implements ot::GraphicsElement.

◆ getQGraphicsItem() [2/2]

QGraphicsItem * ot::GraphicsLayoutItem::getQGraphicsItem ( void )
overridevirtual

Returns the QGraphicsItem.

Implements ot::GraphicsElement.

◆ getQGraphicsLayoutItem()

QGraphicsLayoutItem * ot::GraphicsLayoutItem::getQGraphicsLayoutItem ( void )
overridevirtual

Returns the QGraphicsLayoutItem.

Implements ot::GraphicsItem.

◆ graphicsElementStateChanged()

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

Reimplemented from ot::GraphicsItem.

◆ graphicsItemConfigurationChanged()

void ot::GraphicsLayoutItem::graphicsItemConfigurationChanged ( const GraphicsItemCfg * _config)
overridevirtual

Will be called whenever the GraphicsItem configuration has changed.

Reimplemented from ot::GraphicsItem.

◆ graphicsItemFlagsChanged()

void ot::GraphicsLayoutItem::graphicsItemFlagsChanged ( const GraphicsItemCfg::GraphicsItemFlags & _flags)
overridevirtual

Will be called whenever the GraphicsItem flags have changed.

Reimplemented from ot::GraphicsItem.

◆ notifyChildsAboutTransformChange()

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

Reimplemented from ot::GraphicsItem.

◆ prepareGraphicsItemGeometryChange()

void ot::GraphicsLayoutItem::prepareGraphicsItemGeometryChange ( void )
overridevirtual

Calls QGraphicsLayoutItem::prepareGeometryChange().

Implements ot::GraphicsItem.

◆ removeAllConnections()

void ot::GraphicsLayoutItem::removeAllConnections ( void )
overridevirtual

Removes all connections to or from this item.

Reimplemented from ot::GraphicsItem.

◆ setGraphicsItemName()

void ot::GraphicsLayoutItem::setGraphicsItemName ( const std::string & _name)
overridevirtual

Reimplemented from ot::GraphicsItem.

◆ setGraphicsItemRequestedSize()

void ot::GraphicsLayoutItem::setGraphicsItemRequestedSize ( const QSizeF & _size)
overridevirtual

Reimplemented from ot::GraphicsItem.

◆ setGraphicsScene()

void ot::GraphicsLayoutItem::setGraphicsScene ( GraphicsScene * _scene)
overridevirtual

Set the GraphicsScene this element is placed at.

Reimplemented from ot::GraphicsElement.

◆ setParentGraphicsItem()

void ot::GraphicsLayoutItem::setParentGraphicsItem ( GraphicsItem * _itm)
overridevirtual

Reimplemented from ot::GraphicsItem.

◆ setupFromConfig()

bool ot::GraphicsLayoutItem::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.

Reimplemented in ot::GraphicsBoxLayoutItem, ot::GraphicsGridLayoutItem, ot::GraphicsHBoxLayoutItem, and ot::GraphicsVBoxLayoutItem.


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