2007-12-01 10:47:15 +00:00
|
|
|
/*
|
|
|
|
Copyright 2006-2007 Xavier Guerrin
|
|
|
|
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/>.
|
|
|
|
*/
|
2007-07-10 22:54:22 +00:00
|
|
|
#include "partarc.h"
|
|
|
|
#include "arceditor.h"
|
|
|
|
|
2007-12-05 21:16:01 +00:00
|
|
|
/**
|
|
|
|
Constructeur
|
|
|
|
@param editor L'editeur d'element concerne
|
|
|
|
@param parent Le QGraphicsItem parent de cet arc
|
|
|
|
@param scene La scene sur laquelle figure cet arc
|
|
|
|
*/
|
2007-08-25 03:43:05 +00:00
|
|
|
PartArc::PartArc(QETElementEditor *editor, QGraphicsItem *parent, QGraphicsScene *scene) :
|
2007-07-10 22:54:22 +00:00
|
|
|
QGraphicsEllipseItem(parent, scene),
|
2007-08-25 03:43:05 +00:00
|
|
|
CustomElementGraphicPart(editor),
|
2007-07-10 22:54:22 +00:00
|
|
|
_angle(-90),
|
|
|
|
start_angle(0)
|
|
|
|
{
|
|
|
|
setFlags(QGraphicsItem::ItemIsMovable | QGraphicsItem::ItemIsSelectable);
|
|
|
|
setAcceptedMouseButtons(Qt::LeftButton);
|
2007-08-25 03:43:05 +00:00
|
|
|
informations = new ArcEditor(elementEditor(), this);
|
2007-11-07 20:23:24 +00:00
|
|
|
informations -> setElementTypeName(name());
|
2007-07-10 22:54:22 +00:00
|
|
|
style_editor -> appendWidget(informations);
|
2007-11-07 20:23:24 +00:00
|
|
|
style_editor -> setElementTypeName(name());
|
2007-07-10 22:54:22 +00:00
|
|
|
}
|
|
|
|
|
2007-12-05 21:16:01 +00:00
|
|
|
/// Destructeur
|
|
|
|
PartArc::~PartArc() {
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Dessine l'arc de cercle
|
|
|
|
@param painter QPainter a utiliser pour rendre le dessin
|
|
|
|
@param options Options pour affiner le rendu
|
|
|
|
@param widget Widget sur lequel le rendu est effectue
|
|
|
|
*/
|
2007-07-10 22:54:22 +00:00
|
|
|
void PartArc::paint(QPainter *painter, const QStyleOptionGraphicsItem *, QWidget *) {
|
|
|
|
applyStylesToQPainter(*painter);
|
|
|
|
// enleve systematiquement la couleur de fond
|
|
|
|
painter -> setBrush(Qt::NoBrush);
|
|
|
|
QPen t = painter -> pen();
|
|
|
|
if (isSelected()) {
|
|
|
|
// dessine l'ellipse en noir
|
|
|
|
painter -> drawEllipse(rect());
|
|
|
|
|
|
|
|
// dessine l'arc en rouge
|
|
|
|
t.setColor(Qt::red);
|
|
|
|
painter -> setPen(t);
|
|
|
|
}
|
|
|
|
painter -> drawArc(rect(), start_angle * 16, _angle * 16);
|
|
|
|
if (isSelected()) {
|
|
|
|
// dessine la croix au centre de l'ellipse
|
|
|
|
painter -> setRenderHint(QPainter::Antialiasing, false);
|
|
|
|
painter -> setPen((painter -> brush().color() == QColor(Qt::black) && painter -> brush().isOpaque()) ? Qt::yellow : Qt::blue);
|
|
|
|
QPointF center = rect().center();
|
|
|
|
painter -> drawLine(QLineF(center.x() - 2.0, center.y(), center.x() + 2.0, center.y()));
|
|
|
|
painter -> drawLine(QLineF(center.x(), center.y() - 2.0, center.x(), center.y() + 2.0));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-12-05 21:16:01 +00:00
|
|
|
/**
|
|
|
|
Exporte l'arc de cercle en XML
|
|
|
|
@param xml_document Document XML a utiliser pour creer l'element XML
|
|
|
|
@return un element XML decrivant l'arc de cercle
|
|
|
|
*/
|
2007-07-10 22:54:22 +00:00
|
|
|
const QDomElement PartArc::toXml(QDomDocument &xml_document) const {
|
|
|
|
QDomElement xml_element = xml_document.createElement("arc");
|
|
|
|
QPointF top_left(sceneTopLeft());
|
|
|
|
xml_element.setAttribute("x", top_left.x());
|
|
|
|
xml_element.setAttribute("y", top_left.y());
|
|
|
|
xml_element.setAttribute("width", rect().width());
|
|
|
|
xml_element.setAttribute("height", rect().height());
|
|
|
|
xml_element.setAttribute("start", start_angle);
|
|
|
|
xml_element.setAttribute("angle", _angle);
|
|
|
|
stylesToXml(xml_element);
|
|
|
|
return(xml_element);
|
|
|
|
}
|
|
|
|
|
2007-12-05 21:16:01 +00:00
|
|
|
/**
|
|
|
|
Importe les proprietes d'un arc de cercle depuis un element XML
|
|
|
|
@param qde Element XML a lire
|
|
|
|
*/
|
2007-07-10 22:54:22 +00:00
|
|
|
void PartArc::fromXml(const QDomElement &qde) {
|
|
|
|
stylesFromXml(qde);
|
|
|
|
setRect(
|
|
|
|
QRectF(
|
|
|
|
mapFromScene(
|
|
|
|
qde.attribute("x", "0").toDouble(),
|
|
|
|
qde.attribute("y", "0").toDouble()
|
|
|
|
),
|
|
|
|
QSizeF(
|
|
|
|
qde.attribute("width", "0").toDouble(),
|
|
|
|
qde.attribute("height", "0").toDouble()
|
|
|
|
)
|
|
|
|
)
|
|
|
|
);
|
|
|
|
setStartAngle(qde.attribute("start", "0").toInt());
|
|
|
|
setAngle(qde.attribute("angle", "-90").toInt());
|
|
|
|
}
|
|
|
|
|
2007-12-05 21:16:01 +00:00
|
|
|
/**
|
|
|
|
@return le coin superieur gauche du rectangle dans lequel s'inscrit
|
|
|
|
l'ellipse dont fait partie cet arc, dans les coordonnees de la scene.
|
|
|
|
*/
|
2007-07-10 22:54:22 +00:00
|
|
|
QPointF PartArc::sceneTopLeft() const {
|
|
|
|
return(mapToScene(rect().topLeft()));
|
|
|
|
}
|
|
|
|
|
2007-12-05 21:16:01 +00:00
|
|
|
/**
|
|
|
|
Specifie la valeur d'une propriete donnee de l'arc
|
|
|
|
@param property propriete a modifier. Valeurs acceptees :
|
|
|
|
* x : abscisse du centre de l'ellipse dont fait partie l'arc
|
|
|
|
* y : ordonnee du centre de l'ellipse dont fait partie l'arc
|
|
|
|
* diameter_h : diametre horizontal de l'ellipse dont fait partie l'arc
|
|
|
|
* diameter_v : diametre vertical de l'ellipse dont fait partie l'arc
|
|
|
|
* start_angle : angle de depart
|
|
|
|
* angle : taille de l'arc de cercle
|
|
|
|
@param value Valeur a attribuer a la propriete
|
|
|
|
*/
|
2007-08-25 03:43:05 +00:00
|
|
|
void PartArc::setProperty(const QString &property, const QVariant &value) {
|
|
|
|
CustomElementGraphicPart::setProperty(property, value);
|
|
|
|
if (!value.canConvert(QVariant::Double)) return;
|
|
|
|
if (property == "x") {
|
|
|
|
QRectF current_rect = rect();
|
|
|
|
QPointF current_pos = mapToScene(current_rect.center());
|
|
|
|
setRect(current_rect.translated(value.toDouble() - current_pos.x(), 0.0));
|
|
|
|
} else if (property == "y") {
|
|
|
|
QRectF current_rect = rect();
|
|
|
|
QPointF current_pos = mapToScene(current_rect.center());
|
|
|
|
setRect(current_rect.translated(0.0, value.toDouble() - current_pos.y()));
|
|
|
|
} else if (property == "diameter_h") {
|
|
|
|
qreal new_width = qAbs(value.toDouble());
|
|
|
|
QRectF current_rect = rect();
|
|
|
|
current_rect.translate((new_width - current_rect.width()) / -2.0, 0.0);
|
|
|
|
current_rect.setWidth(new_width);
|
|
|
|
setRect(current_rect);
|
|
|
|
} else if (property == "diameter_v") {
|
|
|
|
qreal new_height = qAbs(value.toDouble());
|
|
|
|
QRectF current_rect = rect();
|
|
|
|
current_rect.translate(0.0, (new_height - current_rect.height()) / -2.0);
|
|
|
|
current_rect.setHeight(new_height);
|
|
|
|
setRect(current_rect);
|
|
|
|
} else if (property == "start_angle") {
|
|
|
|
setStartAngle(value.toInt() );
|
|
|
|
} else if (property == "angle") {
|
|
|
|
setAngle(value.toInt());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-12-05 21:16:01 +00:00
|
|
|
/**
|
|
|
|
Permet d'acceder a la valeur d'une propriete donnee de l'arc de cercle
|
|
|
|
@param property propriete lue. Valeurs acceptees :
|
|
|
|
* x : abscisse du centre de l'ellipse dont fait partie l'arc
|
|
|
|
* y : ordonnee du centre de l'ellipse dont fait partie l'arc
|
|
|
|
* diameter_h : diametre horizontal de l'ellipse dont fait partie l'arc
|
|
|
|
* diameter_v : diametre vertical de l'ellipse dont fait partie l'arc
|
|
|
|
* start_angle : angle de depart
|
|
|
|
* angle : taille de l'arc de cercle
|
|
|
|
@return La valeur de la propriete property
|
|
|
|
*/
|
2007-08-25 03:43:05 +00:00
|
|
|
QVariant PartArc::property(const QString &property) {
|
|
|
|
// appelle la methode property de CustomElementGraphicpart pour les styles
|
|
|
|
QVariant style_property = CustomElementGraphicPart::property(property);
|
|
|
|
if (style_property != QVariant()) return(style_property);
|
|
|
|
|
|
|
|
if (property == "x") {
|
|
|
|
return(mapToScene(rect().center()).x());
|
|
|
|
} else if (property == "y") {
|
|
|
|
return(mapToScene(rect().center()).y());
|
|
|
|
} else if (property == "diameter_h") {
|
|
|
|
return(rect().width());
|
|
|
|
} else if (property == "diameter_v") {
|
|
|
|
return(rect().height());
|
|
|
|
} else if (property == "start_angle") {
|
|
|
|
return(start_angle);
|
|
|
|
} else if (property == "angle") {
|
|
|
|
return(_angle);
|
|
|
|
}
|
|
|
|
return(QVariant());
|
|
|
|
}
|
|
|
|
|
2007-12-05 21:16:01 +00:00
|
|
|
/**
|
|
|
|
Gere les changements intervenant sur cette partie
|
|
|
|
@param change Type de changement
|
|
|
|
@param value Valeur numerique relative au changement
|
|
|
|
*/
|
2007-07-10 22:54:22 +00:00
|
|
|
QVariant PartArc::itemChange(GraphicsItemChange change, const QVariant &value) {
|
|
|
|
if (scene()) {
|
|
|
|
if (change == QGraphicsItem::ItemPositionChange || change == QGraphicsItem::ItemSelectedChange) {
|
|
|
|
informations -> updateForm();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return(QGraphicsEllipseItem::itemChange(change, value));
|
|
|
|
}
|
|
|
|
|
2007-12-05 21:16:01 +00:00
|
|
|
/**
|
|
|
|
Permet de modifier l'etendue de l'arc de cercle.
|
|
|
|
Il s'agit d'un angle, exprime en degres.
|
|
|
|
Si l'angle est positif, l'arc s'etendra dans le sens des aiguilles d'une
|
|
|
|
montre.
|
|
|
|
@param a la nouvelle taille de l'arc de cercle
|
|
|
|
*/
|
2007-07-10 22:54:22 +00:00
|
|
|
void PartArc::setAngle(int a) {
|
|
|
|
_angle = a;
|
|
|
|
}
|
|
|
|
|
2007-12-05 21:16:01 +00:00
|
|
|
/**
|
|
|
|
Permet de modifier la position de depart de l'arc de cercle.
|
|
|
|
Il s'agit d'un angle, exprime en degres.
|
|
|
|
l'angle "0 degre" est situe a "3 heures".
|
|
|
|
@param a la nouvelle taille de l'arc de cercle
|
|
|
|
*/
|
2007-07-10 22:54:22 +00:00
|
|
|
void PartArc::setStartAngle(int a) {
|
|
|
|
start_angle = a;
|
|
|
|
}
|
|
|
|
|
2007-12-05 21:16:01 +00:00
|
|
|
/**
|
|
|
|
@return l'etendue de l'arc de cercle
|
|
|
|
*/
|
2007-07-10 22:54:22 +00:00
|
|
|
int PartArc::angle() const {
|
|
|
|
return(_angle);
|
|
|
|
}
|
|
|
|
|
2007-12-05 21:16:01 +00:00
|
|
|
/**
|
|
|
|
@return la position de depart de l'arc de cercle
|
|
|
|
*/
|
2007-07-10 22:54:22 +00:00
|
|
|
int PartArc::startAngle() const {
|
|
|
|
return(start_angle);
|
|
|
|
}
|
2007-12-15 21:57:00 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
@return true si cette partie n'est pas pertinente et ne merite pas d'etre
|
|
|
|
conservee / enregistree.
|
|
|
|
Un arc est pertinent des lors que ses dimensions et son etendue ne sont
|
|
|
|
pas nulles.
|
|
|
|
*/
|
|
|
|
bool PartArc::isUseless() const {
|
|
|
|
return(rect().isNull() || !angle());
|
|
|
|
}
|
2008-01-07 19:40:08 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
@return le rectangle delimitant cette partie.
|
|
|
|
*/
|
|
|
|
QRectF PartArc::boundingRect() const {
|
|
|
|
qreal adjust = 1.5;
|
|
|
|
QRectF r(QGraphicsEllipseItem::boundingRect().normalized());
|
|
|
|
r.adjust(-adjust, -adjust, adjust, adjust);
|
|
|
|
return(r);
|
|
|
|
}
|