mirror of
https://github.com/qelectrotech/qelectrotech-source-mirror.git
synced 2025-12-17 20:50:34 +01:00
Element Terminale add label
Nomenclature Add terminal element git-svn-id: svn+ssh://svn.tuxfamily.org/svnroot/qet/qet/trunk@4681 bfdf4180-ca20-0410-9c96-a3a8aa849046
This commit is contained in:
@@ -26,6 +26,7 @@
|
|||||||
*/
|
*/
|
||||||
PartTerminal::PartTerminal(QETElementEditor *editor, QGraphicsItem *parent) :
|
PartTerminal::PartTerminal(QETElementEditor *editor, QGraphicsItem *parent) :
|
||||||
CustomElementGraphicPart(editor, parent),
|
CustomElementGraphicPart(editor, parent),
|
||||||
|
m_tagg("none"),
|
||||||
m_orientation(Qet::North)
|
m_orientation(Qet::North)
|
||||||
{
|
{
|
||||||
updateSecondPoint();
|
updateSecondPoint();
|
||||||
@@ -64,6 +65,7 @@ const QDomElement PartTerminal::toXml(QDomDocument &xml_document) const {
|
|||||||
// ecrit la position de la borne
|
// ecrit la position de la borne
|
||||||
xml_element.setAttribute("x", QString("%1").arg(scenePos().x()));
|
xml_element.setAttribute("x", QString("%1").arg(scenePos().x()));
|
||||||
xml_element.setAttribute("y", QString("%1").arg(scenePos().y()));
|
xml_element.setAttribute("y", QString("%1").arg(scenePos().y()));
|
||||||
|
xml_element.setAttribute("tagg", m_tagg);
|
||||||
|
|
||||||
// ecrit l'orientation de la borne
|
// ecrit l'orientation de la borne
|
||||||
xml_element.setAttribute("orientation", Qet::orientationToString(m_orientation));
|
xml_element.setAttribute("orientation", Qet::orientationToString(m_orientation));
|
||||||
|
|||||||
@@ -19,6 +19,9 @@
|
|||||||
#define PART_TERMINAL_H
|
#define PART_TERMINAL_H
|
||||||
|
|
||||||
#include "customelementgraphicpart.h"
|
#include "customelementgraphicpart.h"
|
||||||
|
#include "customelementpart.h"
|
||||||
|
class TextFieldEditor;
|
||||||
|
class QETElementEditor;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
This class represents a terminal which may be used to compose the drawing of
|
This class represents a terminal which may be used to compose the drawing of
|
||||||
@@ -30,6 +33,11 @@ class PartTerminal : public CustomElementGraphicPart
|
|||||||
|
|
||||||
Q_PROPERTY(Qet::Orientation orientation READ orientation WRITE setOrientation)
|
Q_PROPERTY(Qet::Orientation orientation READ orientation WRITE setOrientation)
|
||||||
|
|
||||||
|
// tagg of text
|
||||||
|
Q_PROPERTY(QString tagg READ tagg WRITE setTagg)
|
||||||
|
QString tagg() const {return m_tagg;}
|
||||||
|
void setTagg(const QString &tagg) {m_tagg = tagg;}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
// constructors, destructor
|
// constructors, destructor
|
||||||
PartTerminal(QETElementEditor *editor, QGraphicsItem *parent = 0);
|
PartTerminal(QETElementEditor *editor, QGraphicsItem *parent = 0);
|
||||||
@@ -44,6 +52,7 @@ class PartTerminal : public CustomElementGraphicPart
|
|||||||
private:
|
private:
|
||||||
Qet::Orientation m_orientation;
|
Qet::Orientation m_orientation;
|
||||||
QPointF second_point;
|
QPointF second_point;
|
||||||
|
QString m_tagg;
|
||||||
|
|
||||||
// methods
|
// methods
|
||||||
public:
|
public:
|
||||||
|
|||||||
@@ -105,7 +105,7 @@ QString nomenclature::getNomenclature()
|
|||||||
//Get only simple, master and unlinked slave element.
|
//Get only simple, master and unlinked slave element.
|
||||||
ElementProvider ep(d);
|
ElementProvider ep(d);
|
||||||
QList <Element *> list_elements;
|
QList <Element *> list_elements;
|
||||||
list_elements << ep.find(Element::Simple | Element::Master);
|
list_elements << ep.find(Element::Simple | Element::Master | Element::Terminale);
|
||||||
list_elements << ep.freeElement(Element::Slave);
|
list_elements << ep.freeElement(Element::Slave);
|
||||||
|
|
||||||
foreach (Element *elmt, list_elements) {
|
foreach (Element *elmt, list_elements) {
|
||||||
|
|||||||
@@ -16,6 +16,8 @@
|
|||||||
along with QElectroTech. If not, see <http://www.gnu.org/licenses/>.
|
along with QElectroTech. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
#include "terminalelement.h"
|
#include "terminalelement.h"
|
||||||
|
#include "commentitem.h"
|
||||||
|
#include "elementtextitem.h"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief TerminalElement::TerminalElement
|
* @brief TerminalElement::TerminalElement
|
||||||
@@ -26,9 +28,76 @@
|
|||||||
* @param state int used to know if the creation of element have error
|
* @param state int used to know if the creation of element have error
|
||||||
*/
|
*/
|
||||||
TerminalElement::TerminalElement(const ElementsLocation &location, QGraphicsItem *qgi, int *state) :
|
TerminalElement::TerminalElement(const ElementsLocation &location, QGraphicsItem *qgi, int *state) :
|
||||||
CustomElement(location, qgi, state)
|
CustomElement(location, qgi, state),
|
||||||
|
m_comment_item (nullptr),
|
||||||
|
m_location_item (nullptr)
|
||||||
{
|
{
|
||||||
link_type_ = Terminale;
|
link_type_ = Terminale;
|
||||||
|
connect(this, SIGNAL(elementInfoChange(DiagramContext, DiagramContext)), this, SLOT(updateLabel(DiagramContext, DiagramContext)));
|
||||||
|
connect(this, SIGNAL(xChanged()),this, SLOT(changeElementInfo()));
|
||||||
|
connect(this, SIGNAL(yChanged()),this, SLOT(changeElementInfo()));
|
||||||
|
connect(this, SIGNAL(updateLabel()),this,SLOT(changeElementInfo()));
|
||||||
|
}
|
||||||
|
|
||||||
|
TerminalElement::~TerminalElement() {
|
||||||
|
if (m_comment_item) delete m_comment_item;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief TerminalElement::initLink
|
||||||
|
* @param project
|
||||||
|
*/
|
||||||
|
void TerminalElement::initLink(QETProject *project) {
|
||||||
|
CustomElement::initLink(project);
|
||||||
|
updateLabel(DiagramContext(), elementInformations());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief SimpleElement::changeElementInfo()
|
||||||
|
* Update label if it contains %c, %l, %f or %F variables
|
||||||
|
*/
|
||||||
|
void TerminalElement::changeElementInfo(){
|
||||||
|
QString temp_label = this->elementInformations()["label"].toString();
|
||||||
|
if (temp_label.contains("\%")) {
|
||||||
|
if (this->diagram()!=NULL)
|
||||||
|
this->updateLabel(this->elementInformations(),this->elementInformations());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief SimpleElement::updateLabel
|
||||||
|
* update label of this element
|
||||||
|
*/
|
||||||
|
void TerminalElement::updateLabel(DiagramContext old_info, DiagramContext new_info) {
|
||||||
|
QString label = new_info["label"].toString();
|
||||||
|
Element *elmt = this;
|
||||||
|
label = assignVariables(label,elmt);
|
||||||
|
|
||||||
|
//Label of element
|
||||||
|
if (old_info["label"].toString() != label) {
|
||||||
|
if (new_info["label"].toString().isEmpty())
|
||||||
|
setTaggedText("label", "_", false);
|
||||||
|
else {
|
||||||
|
setTaggedText("label", label, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ElementTextItem *eti = taggedText("label")) {
|
||||||
|
new_info["label"].toString().isEmpty() ? eti->setVisible(true) : eti -> setVisible(new_info.keyMustShow("label"));
|
||||||
|
}
|
||||||
|
|
||||||
|
//Comment and Location of element
|
||||||
|
QString comment = new_info["comment"].toString();
|
||||||
|
bool must_show = new_info.keyMustShow("comment");
|
||||||
|
QString location = new_info["location"].toString();
|
||||||
|
bool must_show_location = new_info.keyMustShow("location");
|
||||||
|
|
||||||
|
if ((!(comment.isEmpty() || !must_show) && !m_comment_item)||(!(location.isEmpty() || !must_show_location) && !m_comment_item)) {
|
||||||
|
m_comment_item = new CommentItem(this);
|
||||||
|
}
|
||||||
|
else if (((comment.isEmpty() || !must_show) && m_comment_item) && ((location.isEmpty() || !must_show_location) && m_comment_item)) {
|
||||||
|
delete m_comment_item;
|
||||||
|
m_comment_item = nullptr;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
TerminalElement::~TerminalElement() {}
|
|
||||||
|
|||||||
@@ -20,12 +20,26 @@
|
|||||||
|
|
||||||
#include "customelement.h"
|
#include "customelement.h"
|
||||||
|
|
||||||
|
class CommentItem;
|
||||||
|
class QETProject;
|
||||||
|
|
||||||
class TerminalElement : public CustomElement
|
class TerminalElement : public CustomElement
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
TerminalElement(const ElementsLocation &, QGraphicsItem * = 0, int * = 0);
|
TerminalElement(const ElementsLocation &, QGraphicsItem * = 0, int * = 0);
|
||||||
~TerminalElement();
|
~TerminalElement();
|
||||||
|
virtual void initLink(QETProject *project);
|
||||||
|
|
||||||
|
signals:
|
||||||
|
|
||||||
|
public slots:
|
||||||
|
void updateLabel(DiagramContext old_info, DiagramContext new_info);
|
||||||
|
void changeElementInfo();
|
||||||
|
|
||||||
|
private:
|
||||||
|
CommentItem *m_comment_item;
|
||||||
|
CommentItem *m_location_item;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // TERMINALELEMENT_H
|
#endif // TERMINALELEMENT_H
|
||||||
|
|||||||
@@ -198,6 +198,7 @@ void ElementPropertiesWidget::updateUi()
|
|||||||
m_list_editor << new LinkSingleElementWidget(m_element, this);
|
m_list_editor << new LinkSingleElementWidget(m_element, this);
|
||||||
break;
|
break;
|
||||||
case Element::Terminale:
|
case Element::Terminale:
|
||||||
|
m_list_editor << new ElementInfoWidget(m_element, this);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
|||||||
Reference in New Issue
Block a user