Il est desormais possible de pivoter les textes des elements dans l'editeur de schema.

git-svn-id: svn+ssh://svn.tuxfamily.org/svnroot/qet/qet/branches/0.3@815 bfdf4180-ca20-0410-9c96-a3a8aa849046
This commit is contained in:
xavier
2009-12-13 22:12:52 +00:00
parent 2bc0ab2f3b
commit 030f82f5c8
7 changed files with 120 additions and 24 deletions

View File

@@ -611,9 +611,19 @@ ElementTextItem *CustomElement::parseInput(QDomElement &e) {
ElementTextItem *eti = new ElementTextItem(e.attribute("text"), this); ElementTextItem *eti = new ElementTextItem(e.attribute("text"), this);
eti -> setFont(QETApp::diagramTextsFont(size)); eti -> setFont(QETApp::diagramTextsFont(size));
eti -> setPos(pos_x, pos_y);
// position du champ de texte
eti -> setOriginalPos(QPointF(pos_x, pos_y)); eti -> setOriginalPos(QPointF(pos_x, pos_y));
if (e.attribute("rotate") == "true") eti -> setFollowParentRotations(true); eti -> setPos(pos_x, pos_y);
// rotation du champ de texte
qreal original_rotation_angle = 0.0;
QET::attributeIsAReal(e, "rotation", &original_rotation_angle);
eti -> setOriginalRotationAngle(original_rotation_angle);
eti -> setRotationAngle(original_rotation_angle);
// comportement du champ lorsque son element parent est pivote
eti -> setFollowParentRotations(e.attribute("rotate") == "true");
list_texts_ << eti; list_texts_ << eti;

View File

@@ -1072,6 +1072,8 @@ bool Diagram::canRotateSelection() const {
foreach(QGraphicsItem * qgi, selectedItems()) { foreach(QGraphicsItem * qgi, selectedItems()) {
if (/*DiagramTextItem *dti = */qgraphicsitem_cast<DiagramTextItem *>(qgi)) { if (/*DiagramTextItem *dti = */qgraphicsitem_cast<DiagramTextItem *>(qgi)) {
return(true); return(true);
} else if (qgraphicsitem_cast<ElementTextItem *>(qgi)) {
return(true);
} else if (Element *e = qgraphicsitem_cast<Element *>(qgi)) { } else if (Element *e = qgraphicsitem_cast<Element *>(qgi)) {
// l'element est-il pivotable ? // l'element est-il pivotable ?
if (e -> orientation().current() != e -> orientation().next()) { if (e -> orientation().current() != e -> orientation().next()) {

View File

@@ -17,6 +17,7 @@
*/ */
#include "diagramtextitem.h" #include "diagramtextitem.h"
#include "diagramcommands.h" #include "diagramcommands.h"
#include "qet.h"
#include "qetapp.h" #include "qetapp.h"
/** /**
@@ -68,32 +69,27 @@ qreal DiagramTextItem::rotationAngle() const {
} }
/** /**
Permet de tourner le texte a un angle donne. La rotation s'effectue par Permet de tourner le texte a un angle donne de maniere absolue.
rapport au point (0, 0) du texte. Un angle de 0 degres correspond a un texte horizontal non retourne.
@param rotation Nouvel angle de rotation de ce texte @param rotation Nouvel angle de rotation de ce texte
@see applyRotation
*/ */
void DiagramTextItem::setRotationAngle(const qreal &rotation) { void DiagramTextItem::setRotationAngle(const qreal &rotation) {
// ramene l'angle demande entre -360.0 et +360.0 degres qreal applied_rotation = QET::correctAngle(rotation);
qreal applied_rotation = rotation; applyRotation(applied_rotation - rotation_angle_);
while (applied_rotation < -360.0) applied_rotation += 360.0;
while (applied_rotation > 360.0) applied_rotation -= 360.0;
rotate(applied_rotation - rotation_angle_);
rotation_angle_ = applied_rotation; rotation_angle_ = applied_rotation;
} }
/** /**
Ajoute Permet de tourner le texte de maniere relative.
L'angle added_rotation est ajoute a l'orientation actuelle du texte.
@param added_rotation Angle a ajouter a la rotation actuelle @param added_rotation Angle a ajouter a la rotation actuelle
@see applyRotation
*/ */
void DiagramTextItem::rotateBy(const qreal &added_rotation) { void DiagramTextItem::rotateBy(const qreal &added_rotation) {
// ramene l'angle demande entre -360.0 et +360.0 degres qreal applied_added_rotation = QET::correctAngle(added_rotation);
qreal applied_added_rotation = added_rotation; rotation_angle_ = QET::correctAngle(rotation_angle_ + applied_added_rotation);
while (applied_added_rotation < 360.0) applied_added_rotation += 360.0; applyRotation(applied_added_rotation);
while (applied_added_rotation > 360.0) applied_added_rotation -= 360.0;
rotation_angle_ += applied_added_rotation;
rotate(applied_added_rotation);
} }
/** /**
@@ -210,6 +206,17 @@ void DiagramTextItem::mouseReleaseEvent(QGraphicsSceneMouseEvent *e) {
} }
} }
/**
Effetue la rotation du texte en elle-meme
Pour les DiagramTextItem, la rotation s'effectue autour du point (0, 0).
Cette methode peut toutefois etre redefinie dans des classes
@param angle Angle de la rotation a effectuer
*/
void DiagramTextItem::applyRotation(const qreal &angle) {
// un simple appel a QGraphicsTextItem::rotate suffit
QGraphicsTextItem::rotate(angle);
}
/** /**
Change la position du champ de texte en veillant a ce qu'il Change la position du champ de texte en veillant a ce qu'il
reste sur la grille du schema auquel il appartient. reste sur la grille du schema auquel il appartient.

View File

@@ -60,6 +60,7 @@ class DiagramTextItem : public QGraphicsTextItem {
virtual void mousePressEvent(QGraphicsSceneMouseEvent *); virtual void mousePressEvent(QGraphicsSceneMouseEvent *);
virtual void mouseMoveEvent(QGraphicsSceneMouseEvent *); virtual void mouseMoveEvent(QGraphicsSceneMouseEvent *);
virtual void mouseReleaseEvent(QGraphicsSceneMouseEvent *); virtual void mouseReleaseEvent(QGraphicsSceneMouseEvent *);
virtual void applyRotation(const qreal &);
// signaux // signaux
signals: signals:

View File

@@ -124,8 +124,12 @@ void DiagramView::rotateSelection() {
elements_to_rotate.insert(e, e -> orientation().current()); elements_to_rotate.insert(e, e -> orientation().current());
} else if (DiagramTextItem *dti = qgraphicsitem_cast<DiagramTextItem *>(item)) { } else if (DiagramTextItem *dti = qgraphicsitem_cast<DiagramTextItem *>(item)) {
texts_to_rotate << dti; texts_to_rotate << dti;
} /*else if (ElementTextItem *eti = qgraphicsitem_cast<ElementTextItem *>(item)) { } else if (ElementTextItem *eti = qgraphicsitem_cast<ElementTextItem *>(item)) {
}*/ // on ne pivote un texte d'element que si son parent n'est pas selectionne
if (eti -> parentItem() && !eti -> parentItem() -> isSelected()) {
texts_to_rotate << eti;
}
}
} }
// effectue les rotations s'il y a quelque chose a pivoter // effectue les rotations s'il y a quelque chose a pivoter

View File

@@ -26,11 +26,15 @@
*/ */
ElementTextItem::ElementTextItem(QGraphicsItem *parent, QGraphicsScene *scene) : ElementTextItem::ElementTextItem(QGraphicsItem *parent, QGraphicsScene *scene) :
DiagramTextItem(parent, scene), DiagramTextItem(parent, scene),
follow_parent_rotations(false) follow_parent_rotations(false),
original_rotation_angle_(0.0)
{ {
// par defaut, les DiagramTextItem sont Selectable et Movable // par defaut, les DiagramTextItem sont Selectable et Movable
// on desactive Movable pour les textes des elements // on desactive Movable pour les textes des elements
setFlag(QGraphicsItem::ItemIsMovable, false); setFlag(QGraphicsItem::ItemIsMovable, false);
// ajuste la position du QGraphicsItem lorsque le QTextDocument change
connect(document(), SIGNAL(blockCountChanged(int)), this, SLOT(adjustItemPosition(int)));
} }
/** /**
@@ -41,11 +45,15 @@ ElementTextItem::ElementTextItem(QGraphicsItem *parent, QGraphicsScene *scene) :
*/ */
ElementTextItem::ElementTextItem(const QString &text, QGraphicsItem *parent, QGraphicsScene *scene) : ElementTextItem::ElementTextItem(const QString &text, QGraphicsItem *parent, QGraphicsScene *scene) :
DiagramTextItem(text, parent, scene), DiagramTextItem(text, parent, scene),
follow_parent_rotations(false) follow_parent_rotations(false),
original_rotation_angle_(0.0)
{ {
// par defaut, les DiagramTextItem sont Selectable et Movable // par defaut, les DiagramTextItem sont Selectable et Movable
// on desactive Movable pour les textes des elements // on desactive Movable pour les textes des elements
setFlag(QGraphicsItem::ItemIsMovable, false); setFlag(QGraphicsItem::ItemIsMovable, false);
// ajuste la position du QGraphicsItem lorsque le QTextDocument change
connect(document(), SIGNAL(blockCountChanged(int)), this, SLOT(adjustItemPosition(int)));
} }
/// Destructeur /// Destructeur
@@ -59,7 +67,7 @@ ElementTextItem::~ElementTextItem() {
void ElementTextItem::setPos(const QPointF &pos) { void ElementTextItem::setPos(const QPointF &pos) {
QPointF actual_pos = pos; QPointF actual_pos = pos;
actual_pos -= QPointF(0.0, boundingRect().height() / 2.0); actual_pos -= QPointF(0.0, boundingRect().height() / 2.0);
DiagramTextItem::setPos(actual_pos); QGraphicsTextItem::setPos(actual_pos);
} }
/** /**
@@ -88,9 +96,16 @@ QPointF ElementTextItem::pos() const {
*/ */
void ElementTextItem::fromXml(const QDomElement &e) { void ElementTextItem::fromXml(const QDomElement &e) {
QPointF _pos = pos(); QPointF _pos = pos();
if (qFuzzyCompare(qreal(e.attribute("x").toDouble()), _pos.x()) && qFuzzyCompare(qreal(e.attribute("y").toDouble()), _pos.y())) { if (
qFuzzyCompare(qreal(e.attribute("x").toDouble()), _pos.x()) &&
qFuzzyCompare(qreal(e.attribute("y").toDouble()), _pos.y())
) {
setPlainText(e.attribute("text")); setPlainText(e.attribute("text"));
previous_text = e.attribute("text"); previous_text = e.attribute("text");
qreal xml_rotation_angle;
if (QET::attributeIsAReal(e, "userrotation", &xml_rotation_angle)) {
setRotationAngle(xml_rotation_angle);
}
} }
} }
@@ -103,6 +118,9 @@ QDomElement ElementTextItem::toXml(QDomDocument &document) const {
result.setAttribute("x", QString("%1").arg(originalPos().x())); result.setAttribute("x", QString("%1").arg(originalPos().x()));
result.setAttribute("y", QString("%1").arg(originalPos().y())); result.setAttribute("y", QString("%1").arg(originalPos().y()));
result.setAttribute("text", toPlainText()); result.setAttribute("text", toPlainText());
if (rotationAngle() != originalRotationAngle()) {
result.setAttribute("userrotation", QString("%1").arg(rotationAngle()));
}
return(result); return(result);
} }
@@ -120,3 +138,48 @@ void ElementTextItem::setOriginalPos(const QPointF &p) {
QPointF ElementTextItem::originalPos() const { QPointF ElementTextItem::originalPos() const {
return(original_position); return(original_position);
} }
/**
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).
@param new_bloc_count Nombre de blocs dans l'ElementTextItem
@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) {
qreal origin_offset = boundingRect().height() / 2.0;
QTransform rotation;
rotation.translate(0.0, origin_offset);
rotation.rotate(angle);
rotation.translate(0.0, -origin_offset);
QGraphicsTextItem::setTransform(rotation, true);
}

View File

@@ -40,6 +40,7 @@ class ElementTextItem : public DiagramTextItem {
private: private:
bool follow_parent_rotations; bool follow_parent_rotations;
QPointF original_position; QPointF original_position;
qreal original_rotation_angle_;
// methodes // methodes
public: public:
@@ -55,6 +56,14 @@ class ElementTextItem : public DiagramTextItem {
QPointF pos() const; QPointF pos() const;
void setOriginalPos(const QPointF &); void setOriginalPos(const QPointF &);
QPointF originalPos() const; QPointF originalPos() const;
void setOriginalRotationAngle(const qreal &);
qreal originalRotationAngle() const;
public slots:
void adjustItemPosition(int);
protected:
virtual void applyRotation(const qreal &);
}; };
/** /**