2007-12-01 10:47:15 +00:00
|
|
|
/*
|
2010-01-03 16:25:37 +00:00
|
|
|
Copyright 2006-2010 Xavier Guerrin
|
2007-12-01 10:47:15 +00:00
|
|
|
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-02-24 00:26:04 +00:00
|
|
|
#include "elementtextitem.h"
|
2007-09-25 23:24:36 +00:00
|
|
|
#include "diagram.h"
|
2007-09-26 22:57:53 +00:00
|
|
|
#include "diagramcommands.h"
|
2010-04-18 17:59:54 +00:00
|
|
|
#include "element.h"
|
2007-02-24 00:26:04 +00:00
|
|
|
|
2007-04-09 02:56:47 +00:00
|
|
|
/**
|
|
|
|
Constructeur
|
2010-04-18 17:59:54 +00:00
|
|
|
@param parent_element Le QGraphicsItem parent du champ de texte
|
|
|
|
@param parent_diagram Le schema auquel appartient le champ de texte
|
2007-04-09 02:56:47 +00:00
|
|
|
*/
|
2010-04-18 17:59:54 +00:00
|
|
|
ElementTextItem::ElementTextItem(Element *parent_element, Diagram *parent_diagram) :
|
|
|
|
DiagramTextItem(parent_element, parent_diagram),
|
|
|
|
parent_element_(parent_element),
|
2009-12-13 22:12:52 +00:00
|
|
|
follow_parent_rotations(false),
|
|
|
|
original_rotation_angle_(0.0)
|
2007-09-26 22:57:53 +00:00
|
|
|
{
|
2009-12-06 23:18:47 +00:00
|
|
|
// par defaut, les DiagramTextItem sont Selectable et Movable
|
|
|
|
// on desactive Movable pour les textes des elements
|
|
|
|
setFlag(QGraphicsItem::ItemIsMovable, false);
|
2009-12-13 22:12:52 +00:00
|
|
|
|
|
|
|
// ajuste la position du QGraphicsItem lorsque le QTextDocument change
|
|
|
|
connect(document(), SIGNAL(blockCountChanged(int)), this, SLOT(adjustItemPosition(int)));
|
2007-02-24 00:26:04 +00:00
|
|
|
}
|
|
|
|
|
2007-04-09 02:56:47 +00:00
|
|
|
/**
|
|
|
|
Constructeur
|
2010-04-18 17:59:54 +00:00
|
|
|
@param parent_element L'element parent du champ de texte
|
|
|
|
@param parent_diagram Le schema auquel appartient le champ de texte
|
2007-04-09 02:56:47 +00:00
|
|
|
@param text Le texte affiche par le champ de texte
|
|
|
|
*/
|
2010-04-18 17:59:54 +00:00
|
|
|
ElementTextItem::ElementTextItem(const QString &text, Element *parent_element, Diagram *parent_diagram) :
|
|
|
|
DiagramTextItem(text, parent_element, parent_diagram),
|
|
|
|
parent_element_(parent_element),
|
2009-12-13 22:12:52 +00:00
|
|
|
follow_parent_rotations(false),
|
|
|
|
original_rotation_angle_(0.0)
|
2007-09-26 22:57:53 +00:00
|
|
|
{
|
2009-12-06 23:18:47 +00:00
|
|
|
// par defaut, les DiagramTextItem sont Selectable et Movable
|
|
|
|
// on desactive Movable pour les textes des elements
|
|
|
|
setFlag(QGraphicsItem::ItemIsMovable, false);
|
2009-12-13 22:12:52 +00:00
|
|
|
|
|
|
|
// ajuste la position du QGraphicsItem lorsque le QTextDocument change
|
|
|
|
connect(document(), SIGNAL(blockCountChanged(int)), this, SLOT(adjustItemPosition(int)));
|
2007-02-24 00:26:04 +00:00
|
|
|
}
|
|
|
|
|
2007-09-26 22:57:53 +00:00
|
|
|
/// Destructeur
|
2007-04-12 03:13:13 +00:00
|
|
|
ElementTextItem::~ElementTextItem() {
|
|
|
|
}
|
|
|
|
|
2010-04-18 17:59:54 +00:00
|
|
|
/**
|
|
|
|
@return L'element parent de ce champ de texte, ou 0 si celui-ci n'en a pas.
|
|
|
|
*/
|
|
|
|
Element *ElementTextItem::parentElement() const {
|
|
|
|
return(parent_element_);
|
|
|
|
}
|
|
|
|
|
2007-04-09 02:56:47 +00:00
|
|
|
/**
|
|
|
|
Modifie la position du champ de texte
|
|
|
|
@param pos La nouvelle position du champ de texte
|
|
|
|
*/
|
2007-02-24 00:26:04 +00:00
|
|
|
void ElementTextItem::setPos(const QPointF &pos) {
|
2010-01-01 14:41:15 +00:00
|
|
|
// annule toute transformation (rotation notamment)
|
|
|
|
resetTransform();
|
|
|
|
|
|
|
|
// effectue le positionnement en lui-meme
|
2007-02-24 00:26:04 +00:00
|
|
|
QPointF actual_pos = pos;
|
2009-12-27 22:46:35 +00:00
|
|
|
actual_pos -= QPointF(0.0, boundingRect().bottom() / 2.0);
|
2009-12-13 22:12:52 +00:00
|
|
|
QGraphicsTextItem::setPos(actual_pos);
|
2010-01-01 14:41:15 +00:00
|
|
|
|
|
|
|
// applique a nouveau la rotation du champ de texte
|
|
|
|
applyRotation(rotationAngle());
|
2007-02-24 00:26:04 +00:00
|
|
|
}
|
|
|
|
|
2007-04-09 02:56:47 +00:00
|
|
|
/**
|
|
|
|
Modifie la position du champ de texte
|
|
|
|
@param x La nouvelle abscisse du champ de texte
|
|
|
|
@param y La nouvelle ordonnee du champ de texte
|
|
|
|
*/
|
2007-02-24 00:26:04 +00:00
|
|
|
void ElementTextItem::setPos(qreal x, qreal y) {
|
|
|
|
setPos(QPointF(x, y));
|
|
|
|
}
|
|
|
|
|
2007-04-09 02:56:47 +00:00
|
|
|
/**
|
|
|
|
@return La position (bidouillee) du champ de texte
|
|
|
|
*/
|
2007-02-24 00:26:04 +00:00
|
|
|
QPointF ElementTextItem::pos() const {
|
2007-09-26 22:57:53 +00:00
|
|
|
QPointF actual_pos = DiagramTextItem::pos();
|
2009-12-27 22:46:35 +00:00
|
|
|
actual_pos += QPointF(0.0, boundingRect().bottom() / 2.0);
|
2007-02-24 00:26:04 +00:00
|
|
|
return(actual_pos);
|
|
|
|
}
|
2007-02-24 19:56:29 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Permet de lire le texte a mettre dans le champ a partir d'un element XML.
|
|
|
|
Cette methode se base sur la position du champ pour assigner ou non la
|
|
|
|
valeur a ce champ.
|
|
|
|
@param e L'element XML representant le champ de texte
|
|
|
|
*/
|
2007-04-12 03:13:13 +00:00
|
|
|
void ElementTextItem::fromXml(const QDomElement &e) {
|
2007-02-24 19:56:29 +00:00
|
|
|
QPointF _pos = pos();
|
2009-12-13 22:12:52 +00:00
|
|
|
if (
|
|
|
|
qFuzzyCompare(qreal(e.attribute("x").toDouble()), _pos.x()) &&
|
|
|
|
qFuzzyCompare(qreal(e.attribute("y").toDouble()), _pos.y())
|
|
|
|
) {
|
2007-02-24 19:56:29 +00:00
|
|
|
setPlainText(e.attribute("text"));
|
2009-12-13 22:12:52 +00:00
|
|
|
qreal xml_rotation_angle;
|
|
|
|
if (QET::attributeIsAReal(e, "userrotation", &xml_rotation_angle)) {
|
|
|
|
setRotationAngle(xml_rotation_angle);
|
|
|
|
}
|
2007-02-24 19:56:29 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
@param document Le document XML a utiliser
|
|
|
|
@return L'element XML representant ce champ de texte
|
|
|
|
*/
|
2007-04-12 03:13:13 +00:00
|
|
|
QDomElement ElementTextItem::toXml(QDomDocument &document) const {
|
2007-02-24 19:56:29 +00:00
|
|
|
QDomElement result = document.createElement("input");
|
2008-08-23 19:27:14 +00:00
|
|
|
result.setAttribute("x", QString("%1").arg(originalPos().x()));
|
|
|
|
result.setAttribute("y", QString("%1").arg(originalPos().y()));
|
2007-02-24 19:56:29 +00:00
|
|
|
result.setAttribute("text", toPlainText());
|
2009-12-13 22:12:52 +00:00
|
|
|
if (rotationAngle() != originalRotationAngle()) {
|
|
|
|
result.setAttribute("userrotation", QString("%1").arg(rotationAngle()));
|
|
|
|
}
|
2007-02-24 19:56:29 +00:00
|
|
|
return(result);
|
|
|
|
}
|
2008-01-11 20:01:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
@param p Position originale / de reference pour ce champ
|
|
|
|
Cette position est utilisee lors de l'export en XML
|
|
|
|
*/
|
|
|
|
void ElementTextItem::setOriginalPos(const QPointF &p) {
|
|
|
|
original_position = p;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
@return la position originale / de reference pour ce champ
|
|
|
|
*/
|
|
|
|
QPointF ElementTextItem::originalPos() const {
|
|
|
|
return(original_position);
|
|
|
|
}
|
2009-12-13 22:12:52 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Definit l'angle de rotation original de ce champ de texte
|
|
|
|
@param rotation_angle un angle de rotation
|
|
|
|
*/
|
|
|
|
void ElementTextItem::setOriginalRotationAngle(const qreal &rotation_angle) {
|
|
|
|
original_rotation_angle_ = QET::correctAngle(rotation_angle);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
@return l'angle de rotation original de ce champ de texte
|
|
|
|
*/
|
|
|
|
qreal ElementTextItem::originalRotationAngle() const {
|
|
|
|
return(original_rotation_angle_);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Cette methode s'assure que la position de l'ElementTextItem est coherente
|
|
|
|
en repositionnant son origine (c-a-d le milieu du bord gauche du champ de
|
|
|
|
texte) a la position originale. Cela est notamment utile lorsque le champ
|
|
|
|
de texte est agrandi ou retreci verticalement (ajout ou retrait de lignes).
|
2010-01-01 14:41:15 +00:00
|
|
|
@param new_block_count Nombre de blocs dans l'ElementTextItem
|
2009-12-13 22:12:52 +00:00
|
|
|
@see originalPos()
|
|
|
|
*/
|
|
|
|
void ElementTextItem::adjustItemPosition(int new_block_count) {
|
|
|
|
Q_UNUSED(new_block_count);
|
|
|
|
setPos(originalPos());
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Effetue la rotation du texte en elle-meme
|
|
|
|
Pour les ElementTextItem, la rotation s'effectue autour du milieu du bord
|
|
|
|
gauche du champ de texte.
|
|
|
|
@param angle Angle de la rotation a effectuer
|
|
|
|
*/
|
|
|
|
void ElementTextItem::applyRotation(const qreal &angle) {
|
2009-12-27 22:46:35 +00:00
|
|
|
qreal origin_offset = boundingRect().bottom() / 2.0;
|
2009-12-13 22:12:52 +00:00
|
|
|
|
|
|
|
QTransform rotation;
|
|
|
|
rotation.translate(0.0, origin_offset);
|
|
|
|
rotation.rotate(angle);
|
|
|
|
rotation.translate(0.0, -origin_offset);
|
|
|
|
|
|
|
|
QGraphicsTextItem::setTransform(rotation, true);
|
|
|
|
}
|