/* Copyright 2006-2014 The QElectroTech Team This file is part of QElectroTech. QElectroTech is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 2 of the License, or (at your option) any later version. QElectroTech is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with QElectroTech. If not, see . */ #ifndef ELEMENT_H #define ELEMENT_H #include "qet.h" #include "qetgraphicsitem.h" #include "diagramcontext.h" class Diagram; class ElementTextItem; class QETProject; class Terminal; class Conductor; /** This is the base class for electrical elements. */ class Element : public QetGraphicsItem { Q_OBJECT // constructors, destructor public: Element(QGraphicsItem * = 0, Diagram * = 0); virtual ~Element(); private: Element(const Element &); // attributes public: enum { Type = UserType + 1000 }; // this enum is use to know the kind of element and // to use flag for element provider class enum kind {Simple = 1, NextReport = 2, PreviousReport = 4, AllReport = 6, Master = 8, Slave = 16, Terminale = 32}; private: QSize dimensions; QPoint hotspot_coord; QPixmap preview; // methods public: /** Enable the use of qgraphicsitem_cast to safely cast a QGraphicsItem into an Element. @return the QGraphicsItem type */ virtual int type() const { return Type; } // pure virtual methods to be defined in derived classes /// @return the list of terminals for this element virtual QList terminals() const = 0; /// @return the list of conductors attached to this element virtual QList conductors() const = 0; /// @return the list of text items attached to this element virtual QList texts() const = 0; /// @return the text field tagged with @tagg or NULL if text field isn't found virtual ElementTextItem* taggedText(const QString &tagg) const = 0; /// @return the list of lines items in this element virtual QList lines() const = 0; /// @return the list of rectangles items in this element virtual QList rectangles() const = 0; /// @return the list of bounding rectangles for circles items in this element virtual QList circles() const = 0; /// @return the list of polygons in this element virtual QList *> polygons() const = 0; /// @return the list of arcs in this element virtual QList *> arcs() const = 0; /// @return the current number of terminals of this element virtual int terminalsCount() const = 0; /// @return the minimum number of terminals for this element virtual int minTerminalsCount() const = 0; /// @return the maximum number of terminals for this element virtual int maxTerminalsCount() const = 0; /** *related method and attributes, *about none graphic thing *like the linked element or information about this element */ //METHODS related to linked element public: bool isFree () const; virtual void linkToElement(Element *) {} virtual void unlinkAllElements() {} virtual void unlinkElement(Element *) {} virtual void initLink(QETProject *); QList linkedElements (); virtual int linkType() const {return link_type_;} // @return the linkable type void newUuid() {uuid_ = QUuid::createUuid();} //create new uuid for this element //ATTRIBUTES related to linked element protected: QList connected_elements; QList tmp_uuids_link; QUuid uuid_; kind link_type_; signals: void elementInfoChange(DiagramContext); //METHODS related to information public: DiagramContext elementInformations ()const {return element_informations_;} DiagramContext& rElementInformations () {return element_informations_;} virtual void setElementInformations (DiagramContext dc); DiagramContext kindInformations () const {return kind_informations_;} //@kind_information_ is used to store more information //about the herited class like contactelement for know // kind of contact (simple tempo) or number of contact show by the element. //ATTRIBUTES protected: DiagramContext element_informations_, kind_informations_; /** Draw this element */ public: virtual void paint(QPainter *, const QStyleOptionGraphicsItem *) = 0; /// @return This element type ID virtual QString typeId() const = 0; /// @return the human name for this element virtual QString name() const = 0; virtual bool isHighlighted() const; virtual void setHighlighted(bool); void paint(QPainter *, const QStyleOptionGraphicsItem *, QWidget *); QRectF boundingRect() const; QRectF boundingRectTrue() const; QSize setSize(int, int); QSize size() const; QPixmap pixmap(); // methods related to the hotspot QPoint setHotspot(QPoint); QPoint hotspot() const; // selection-related methods void select(); void deselect(); // methods related to internal connections bool internalConnections(); void setInternalConnections(bool); virtual void rotateBy(const qreal &); virtual void editProperty(); // methods related to XML import/export static bool valideXml(QDomElement &); virtual bool fromXml(QDomElement &, QHash &, bool = false); virtual QDomElement toXml(QDomDocument &, QHash &) const; QUuid uuid() const; // orientation-related methods int orientation() const; protected: void drawAxes(QPainter *, const QStyleOptionGraphicsItem *); private: bool bMouseHover; bool internal_connections_; bool must_highlight_; void drawSelection(QPainter *, const QStyleOptionGraphicsItem *); void drawHighlight(QPainter *, const QStyleOptionGraphicsItem *); void updatePixmap(); protected: virtual void hoverEnterEvent(QGraphicsSceneHoverEvent *); virtual void hoverLeaveEvent(QGraphicsSceneHoverEvent *); virtual void hoverMoveEvent(QGraphicsSceneHoverEvent *); bool bMouseOver; }; bool comparPos(const Element * elmt1, const Element * elmt2); inline bool Element::isFree() const { return (connected_elements.isEmpty()); } /** Indicate whether this element allows internal connections, i.e. whether its terminals can be linked together using a conductor. @return true if internal connections are accepted, false otherwise */ inline bool Element::internalConnections() { return(internal_connections_); } /** Specify whether this element allows internal connections, i.e. whether its terminals can be linked together using a conductor. @return true for internal connections to be accepted, false otherwise */ inline void Element::setInternalConnections(bool ic) { internal_connections_ = ic; } /** Indicate the current orientation of this element O = 0° 1 = 90° 2 = 180° 3 = 270° @return the current orientation of this element */ inline int Element::orientation() const { return(QET::correctAngle(rotation())/90); } /** * @brief Element::uuid * @return the uuid of this element */ inline QUuid Element::uuid() const { return uuid_; } /** * @brief Element::linkedElements * @return the list of linked elements, the list is sorted by position */ inline QList Element::linkedElements() { qSort(connected_elements.begin(), connected_elements.end(), comparPos); return connected_elements; } #endif