186 lines
4.8 KiB
C++
Raw Normal View History

/*
2023-01-01 17:05:57 +01:00
Copyright 2006-2023 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 <http://www.gnu.org/licenses/>.
*/
#include "masterelement.h"
2020-12-08 19:57:35 +01:00
#include "../diagram.h"
#include "crossrefitem.h"
#include "dynamicelementtextitem.h"
2020-12-08 19:57:35 +01:00
#include <QRegularExpression>
/**
2020-08-16 11:19:36 +02:00
@brief MasterElement::MasterElement
Default constructor
2020-08-20 21:57:35 +02:00
@param location : location of xml definition
@param qgi : parent QGraphicItem
@param state : int used to know if the creation of element have error
2020-08-16 11:19:36 +02:00
*/
2020-09-07 22:03:40 +02:00
MasterElement::MasterElement(
const ElementsLocation &location,
QGraphicsItem *qgi,
int *state) :
Element(location, qgi, state, Element::Master)
{}
/**
2020-08-16 11:19:36 +02:00
@brief MasterElement::~MasterElement
default destructor
*/
2020-09-07 22:03:40 +02:00
MasterElement::~MasterElement()
{
unlinkAllElements();
}
/**
2020-08-16 11:19:36 +02:00
@brief MasterElement::linkToElement
Link this master to another element
For this class element must be a slave
@param elmt
*/
void MasterElement::linkToElement(Element *elmt)
{
// check if element is slave and if isn't already linked
if (elmt->linkType() == Slave && !connected_elements.contains(elmt))
{
connected_elements << elmt;
elmt->linkToElement(this);
XRefProperties xrp = diagram()->project()->defaultXRefProperties(kindInformations()["type"].toString());
if (!m_Xref_item && xrp.snapTo() == XRefProperties::Bottom)
m_Xref_item = new CrossRefItem(this); //create cross ref item if not yet
emit linkedElementChanged();
aboutDeleteXref();
}
}
/**
2020-08-16 11:19:36 +02:00
@brief MasterElement::unlinkAllElements
Unlink all of the element in the QList connected_elements
*/
void MasterElement::unlinkAllElements()
{
// if this element is free no need to do something
if (!isFree())
{
foreach(Element *elmt, connected_elements)
unlinkElement(elmt);
emit linkedElementChanged();
}
}
/**
2020-08-16 11:19:36 +02:00
@brief MasterElement::unlinkElement
Unlink the given element in parameter
2020-08-16 11:19:36 +02:00
@param elmt element to unlink from this
*/
void MasterElement::unlinkElement(Element *elmt)
{
//Ensure elmt is linked to this element
if (connected_elements.contains(elmt))
{
connected_elements.removeOne(elmt);
elmt -> unlinkElement (this);
elmt -> setHighlighted (false);
aboutDeleteXref();
emit linkedElementChanged();
}
}
/**
2020-08-16 11:19:36 +02:00
@brief MasterElement::initLink
@param project
Call init Link from custom element and after
call update label for setup it.
*/
void MasterElement::initLink(QETProject *project) {
//Create the link with other element if needed
Element::initLink(project);
}
/**
2020-08-16 11:19:36 +02:00
@brief MasterElement::XrefBoundingRect
@return The bounding rect of the Xref, if this element
haven't got a xref, return a default QRectF
*/
QRectF MasterElement::XrefBoundingRect() const
{
if(m_Xref_item)
return m_Xref_item->boundingRect();
else
return QRectF();
}
QVariant MasterElement::itemChange(QGraphicsItem::GraphicsItemChange change, const QVariant &value)
{
if(change == QGraphicsItem::ItemSceneHasChanged && m_first_scene_change)
{
m_first_scene_change = false;
connect(diagram()->project(), &QETProject::XRefPropertiesChanged, this, &MasterElement::xrefPropertiesChanged);
}
return Element::itemChange(change, value);
}
void MasterElement::xrefPropertiesChanged()
{
if(!diagram())
return;
XRefProperties xrp = diagram()->project()->defaultXRefProperties(kindInformations()["type"].toString());
if(xrp.snapTo() == XRefProperties::Bottom)
{
//We create a Xref, and just after we call aboutDeleteXref,
//because the Xref may be useless.
if(!m_Xref_item)
m_Xref_item = new CrossRefItem(this);
}
aboutDeleteXref();
}
/**
2020-08-16 11:19:36 +02:00
@brief MasterElement::aboutDeleteXref
Check if Xref item must be displayed, if not, delete it.
If Xref item is deleted or already not used (nullptr) return true;
Else return false if Xref item is used
NOTICE : Xref can display nothing but not be deleted so far.
For example, if Xref is display has cross, only power contact are linked and
2020-08-16 11:19:36 +02:00
option show power contact is disable, the cross isn't draw.
@return
*/
void MasterElement::aboutDeleteXref()
{
if(!m_Xref_item)
return;
XRefProperties xrp = diagram()->project()->defaultXRefProperties(kindInformations()["type"].toString());
if (xrp.snapTo() != XRefProperties::Bottom && m_Xref_item)
{
delete m_Xref_item;
m_Xref_item = nullptr;
return;
}
if (m_Xref_item->boundingRect().isNull())
{
delete m_Xref_item;
m_Xref_item = nullptr;
return;
}
}