File indexing completed on 2024-09-08 11:04:02

0001 /***************************************************************************
0002  *   Copyright (C) 2003-2005 by David Saxton                               *
0003  *   david@bluehaze.org                                                    *
0004  *                                                                         *
0005  *   This program is free software; you can redistribute it and/or modify  *
0006  *   it under the terms of the GNU General Public License as published by  *
0007  *   the Free Software Foundation; either version 2 of the License, or     *
0008  *   (at your option) any later version.                                   *
0009  ***************************************************************************/
0010 
0011 #ifndef CNITEM_H
0012 #define CNITEM_H
0013 
0014 #include "ciwidgetmgr.h"
0015 #include "item.h"
0016 
0017 class Button;
0018 class CNItem;
0019 class ICNDocument;
0020 class Connector;
0021 class DoubleSpinBox;
0022 class LibraryItem;
0023 class Node;
0024 class QSlider;
0025 class QString;
0026 class QToolButton;
0027 class Slider;
0028 class Text;
0029 
0030 class NodeInfo
0031 {
0032 public:
0033     NodeInfo();
0034 
0035     QString id;      // External id (ICNDocument scope)
0036     Node *node;      // Pointer to the node
0037     double x;        // X position relative to item
0038     double y;        // Y position relative to item
0039     int orientation; // Orientation relative to item
0040 };
0041 
0042 typedef QMap<QString, QString> StringMap;
0043 typedef QMap<QString, NodeInfo> NodeInfoMap; // Internal id, node info
0044 typedef QList<QPointer<Connector>> ConnectorList;
0045 typedef QMap<QString, QPointer<Text>> TextMap;
0046 
0047 /**
0048 Essentially, all items that live on ICNDocument should inherit from this class.
0049 This class provides much functionality (moving items, creation of associated nodes,
0050 saving and editing of associated data, cutting / copying, etc)
0051 @short Base class for all components/flowparts/etc
0052 @author Daniel Clarke
0053 @author David Saxton
0054 */
0055 class CNItem : public Item, public CIWidgetMgr
0056 {
0057     Q_OBJECT
0058 public:
0059     CNItem(ICNDocument *_icnView, bool newItem, const QString &id);
0060     ~CNItem() override;
0061 
0062     /**
0063      * Creates a node which is attached to the item. The node will be moved
0064      * about with the item, and destroyed along with the item. The position
0065      * coordinates of the node are relative to the upper left corner of the item.
0066      * @param type See Node::node_type
0067      */
0068     Node *createNode(double _x, double _y, int orientation, const QString &name, uint type);
0069     /**
0070      * Removes a child node. You should use this function if you want to remove
0071      * any nodes during the lifetime of the CNItem.
0072      */
0073     bool removeNode(const QString &name);
0074     /**
0075      * Returns the closest node that is associated with the CNItem
0076      */
0077     Node *getClosestNode(const QPoint &pos);
0078     /**
0079      * Returns a list of connectors associated with the CNItem
0080      */
0081     ConnectorList connectorList();
0082     bool preResize(QRect sizeRect) override;
0083     bool mousePressEvent(const EventInfo &eventInfo) override;
0084     bool mouseReleaseEvent(const EventInfo &eventInfo) override;
0085     bool mouseDoubleClickEvent(const EventInfo &eventInfo) override;
0086     bool mouseMoveEvent(const EventInfo &eventInfo) override;
0087     bool wheelEvent(const EventInfo &eventInfo) override;
0088     void enterEvent(QEvent *) override;
0089     void leaveEvent(QEvent *) override;
0090     /**
0091      * ICNDocument needs to know what 'cells' a CNItem is present in,
0092      * so that connection mapping can be done to avoid CNItems.
0093      * This function will add the hit penalty to the cells pointed to
0094      * by ICNDocument::cells()
0095      */
0096     virtual void updateConnectorPoints(bool add);
0097     /**
0098      * Converts the id used to internally identify a node to the global
0099      * ICNDocument node id. eg "vss" might return "node__13".
0100      */
0101     QString nodeId(const QString &internalNodeId);
0102     /**
0103      * Returns a pointer to the node with the given internal (child) id
0104      */
0105     Node *childNode(const QString &childId);
0106     /**
0107      * Returns the node map used:
0108      * QMap<QString, NodeInfo> NodeInfoMap
0109      * It's probably best to cache this data
0110      */
0111     NodeInfoMap nodeMap() const
0112     {
0113         return m_nodeMap;
0114     }
0115     /**
0116      * Returns the TextMap used for canvas text
0117      */
0118     TextMap textMap() const
0119     {
0120         return m_textMap;
0121     }
0122     void setVisible(bool yes) override;
0123     void updateZ(int baseZ) override;
0124 
0125     ItemData itemData() const override;
0126     void restoreFromItemData(const ItemData &itemData) override;
0127     virtual void updateNodeLevels();
0128     void drawShape(QPainter &p) override;
0129 
0130 signals:
0131     /**
0132      * Emitted when the angle or flipped'ness changes. Note that CNItem doesn't
0133      * actually emit this signal - instead, Component and FlowPart classes do.
0134      */
0135     void orientationChanged();
0136 
0137 public slots:
0138     /**
0139      * Moves item - use this instead of moveBy() so that associated Nodes also get moved
0140      */
0141     void moveBy(double dx, double dy) override;
0142     /**
0143      * Remove the item and associated nodes. It appends the item to the
0144      * ICNDocument's delete list, so you must call ICNDocument::flushDeleteList()
0145      * after calling this (and possible ICNDocument::clearDeleteList() befor
0146      * calling it) The virtual function void handleRemove() is called to allow
0147      * any child classes to clear up any neccessary data (which doesn't do
0148      * anything by default), before CNItem does the rest
0149      */
0150     void removeItem() override;
0151     /**
0152      * This item has been resized, so update the nodes relative positions
0153      */
0154     virtual void updateAttachedPositioning();
0155 
0156 protected:
0157     void reparented(Item *oldParent, Item *newParent) override;
0158     void postResize() override;
0159     /**
0160      * CNItem handles drawing of text associated with the CNItem.
0161      * @param id is a unique identifier that can be used to change the text displayed.
0162      * @param pos is the position that the text occupies relative to the top left corner of the CNItem.
0163      * @param display is the actual text to be displayed.
0164      * @param internal is used to determine the z-level of the text - whether it should be below or above the item
0165      * @param flags Text alignment flags - Qt::AlignmentFlags and Qt::TextFlags OR'd together.
0166      */
0167     Text *addDisplayText(const QString &id, const QRect &pos, const QString &display, bool internal = true, int flags = Qt::AlignHCenter | Qt::AlignVCenter);
0168     void setDisplayText(const QString &id, const QString &display);
0169     /**
0170      * Remove the display text with the given id
0171      */
0172     void removeDisplayText(const QString &id);
0173     /**
0174      * Sets the right colour if selected, transforms the matrix of the painter
0175      */
0176     virtual void initPainter(QPainter &p);
0177 
0178     QPointer<ICNDocument> p_icnDocument;
0179     TextMap m_textMap;
0180     NodeInfoMap m_nodeMap;
0181     QColor m_selectedCol;
0182     QColor m_brushCol;
0183     bool b_pointsAdded;
0184 };
0185 typedef QList<CNItem *> CNItemList;
0186 
0187 #endif