Master element : comment is displayed even if there isn't slave linked

git-svn-id: svn+ssh://svn.tuxfamily.org/svnroot/qet/qet/trunk@3414 bfdf4180-ca20-0410-9c96-a3a8aa849046
This commit is contained in:
blacksun
2014-10-28 15:45:28 +00:00
parent 23457271e6
commit cf887b8c3c
7 changed files with 117 additions and 33 deletions

View File

@@ -78,6 +78,15 @@ void CommentItem::paint(QPainter *painter, const QStyleOptionGraphicsItem *optio
m_picture.play(painter);
}
/**
* @brief CommentItem::mouseDoubleClickEvent
* @param event
*/
void CommentItem::mouseDoubleClickEvent(QGraphicsSceneMouseEvent *event) {
event -> accept();
m_element -> editProperty();
}
/**
* @brief CommentItem::updateLabel
* update the content of this item

View File

@@ -44,6 +44,7 @@ class CommentItem : public QGraphicsObject
protected:
virtual void paint (QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget);
virtual void mouseDoubleClickEvent (QGraphicsSceneMouseEvent * event );
private:
Element *m_element;

View File

@@ -17,6 +17,7 @@
*/
#include "masterelement.h"
#include "crossrefitem.h"
#include "commentitem.h"
/**
* @brief MasterElement::MasterElement
@@ -27,10 +28,11 @@
* @param state int used to know if the creation of element have error
*/
MasterElement::MasterElement(const ElementsLocation &location, QGraphicsItem *qgi, Diagram *s, int *state) :
CustomElement(location, qgi, s, state)
CustomElement(location, qgi, s, state),
cri_ (nullptr),
m_ci (nullptr)
{
link_type_ = Master;
cri_ = nullptr;
connect(this, SIGNAL(elementInfoChange(DiagramContext)), this, SLOT(updateLabel()));
}
@@ -40,6 +42,7 @@ MasterElement::MasterElement(const ElementsLocation &location, QGraphicsItem *qg
*/
MasterElement::~MasterElement() {
unlinkAllElements();
if (m_ci) delete m_ci;
disconnect(this, SIGNAL(elementInfoChange(DiagramContext)), this, SLOT(updateLabel()));
}
@@ -56,10 +59,18 @@ void MasterElement::linkToElement(Element *elmt) {
elmt->linkToElement(this);
if (!cri_) cri_ = new CrossRefItem(this); //create cross ref item if not yet
connect(elmt, SIGNAL(xChanged()), cri_, SLOT(updateLabel()));
connect(elmt, SIGNAL(yChanged()), cri_, SLOT(updateLabel()));
cri_->updateLabel();
connect(elmt, SIGNAL(xChanged()), cri_, SLOT(updateLabel()));
connect(elmt, SIGNAL(yChanged()), cri_, SLOT(updateLabel()));
cri_ -> updateLabel();
//If there is a comment item, we delete it
//because cross ref item display comment too.
if (m_ci) {
delete m_ci;
m_ci = nullptr;
}
}
}
/**
@@ -93,6 +104,7 @@ void MasterElement::unlinkElement(Element *elmt) {
if (linkedElements().isEmpty()) {
delete cri_;
cri_ = nullptr;
updateLabel();
}
else {
cri_->updateLabel();
@@ -100,9 +112,24 @@ void MasterElement::unlinkElement(Element *elmt) {
}
}
/**
* @brief MasterElement::initLink
* Initialise the links between this element and other element.
* @param project
*/
void MasterElement::initLink(QETProject *project) {
//Create the link with other element if needed
CustomElement::initLink(project);
//If no link that mean there are no cross ref item (cri)
//So we call @updateLabel for add comment item (m_ci) if needed.
if (!cri_) updateLabel();
}
/**
* @brief MasterElement::updateLabel
* update label of this element
* and the comment item if he's displayed.
*/
void MasterElement::updateLabel() {
QString label = elementInformations()["label"].toString();
@@ -112,4 +139,20 @@ void MasterElement::updateLabel() {
(label.isEmpty() || !show)?
setTaggedText("label", "_", false):
setTaggedText("label", label, true);
if (cri_) return;
//At this point there isn't a cross ref item displayed,
//but if element have comment and must be show, we add a comment item
QString comment = elementInformations()["comment"].toString();
bool must_show = elementInformations().keyMustShow("comment");
if (!(comment.isEmpty() || !must_show) && !m_ci) {
m_ci = new CommentItem(this);
}
else if ((comment.isEmpty() || !must_show) && m_ci) {
delete m_ci;
m_ci = nullptr;
}
}

View File

@@ -21,25 +21,35 @@
#include "customelement.h"
class CrossRefItem;
class CommentItem;
/**
* @brief The MasterElement class
* This class is a custom element, with extended behavior
* to be a master element. Master element can be linked with slave element
* and display a cross ref item for know with what other element he is linked
*/
class MasterElement : public CustomElement
{
Q_OBJECT
public:
explicit MasterElement(const ElementsLocation &, QGraphicsItem * = 0, Diagram * = 0, int * = 0);
~MasterElement();
virtual void linkToElement(Element *elmt);
virtual void unlinkAllElements();
virtual void unlinkElement(Element *elmt);
explicit MasterElement(const ElementsLocation &, QGraphicsItem * = 0, Diagram * = 0, int * = 0);
~MasterElement();
virtual void linkToElement (Element *elmt);
virtual void unlinkAllElements ();
virtual void unlinkElement (Element *elmt);
virtual void initLink (QETProject *project);
signals:
public slots:
void updateLabel();
void updateLabel();
private:
CrossRefItem *cri_;
CrossRefItem *cri_;
CommentItem *m_ci;
};
#endif // MASTERELEMENT_H