mirror of
https://github.com/qelectrotech/qelectrotech-source-mirror.git
synced 2025-12-17 12:40:35 +01:00
Editeur d'elements : mise a jour de la gestion du positionnement et de la rotation des champs de texte dynamiques.
git-svn-id: svn+ssh://svn.tuxfamily.org/svnroot/qet/qet/branches/0.3@1089 bfdf4180-ca20-0410-9c96-a3a8aa849046
This commit is contained in:
@@ -29,8 +29,7 @@
|
||||
PartTextField::PartTextField(QETElementEditor *editor, QGraphicsItem *parent, QGraphicsScene *scene) :
|
||||
QGraphicsTextItem(parent, scene),
|
||||
CustomElementPart(editor),
|
||||
follow_parent_rotations(true),
|
||||
rotation_angle_(0.0)
|
||||
follow_parent_rotations(true)
|
||||
{
|
||||
setDefaultTextColor(Qt::black);
|
||||
setFont(QETApp::diagramTextsFont());
|
||||
@@ -40,8 +39,10 @@ PartTextField::PartTextField(QETElementEditor *editor, QGraphicsItem *parent, QG
|
||||
#endif
|
||||
setPlainText(QObject::tr("_", "default text when adding a textfield in the element editor"));
|
||||
|
||||
// ajuste la position du champ de texte lorsqu'on lui ajoute/retire des lignes
|
||||
adjustItemPosition(1);
|
||||
// ajuste la position du champ de texte lorsqu'on lui ajoute/retire des lignes ou lorsqu'on change sa taille de police
|
||||
connect(document(), SIGNAL(blockCountChanged(int)), this, SLOT(adjustItemPosition(int)));
|
||||
connect(document(), SIGNAL(contentsChanged()), this, SLOT(adjustItemPosition()));
|
||||
}
|
||||
|
||||
/// Destructeur
|
||||
@@ -69,7 +70,6 @@ void PartTextField::fromXml(const QDomElement &xml_element) {
|
||||
xml_element.attribute("x").toDouble(),
|
||||
xml_element.attribute("y").toDouble()
|
||||
);
|
||||
known_position_ = pos();
|
||||
|
||||
follow_parent_rotations = (xml_element.attribute("rotate") == "true");
|
||||
}
|
||||
@@ -96,58 +96,18 @@ const QDomElement PartTextField::toXml(QDomDocument &xml_document) const {
|
||||
return(xml_element);
|
||||
}
|
||||
|
||||
/**
|
||||
Retourne la position du texte, l'origine etant le milieu du bord gauche du
|
||||
champ
|
||||
@return la position du texte
|
||||
*/
|
||||
QPointF PartTextField::pos() const {
|
||||
return(mapToScene(margin()));
|
||||
}
|
||||
|
||||
/**
|
||||
Specifie la position du champ de texte
|
||||
@param new_pos Nouvelle position
|
||||
*/
|
||||
void PartTextField::setPos(const QPointF &new_pos) {
|
||||
// annule toute transformation (rotation notamment)
|
||||
resetTransform();
|
||||
|
||||
// effectue le positionnement en lui-meme
|
||||
QPointF m = margin();
|
||||
QGraphicsTextItem::setPos(new_pos - m);
|
||||
|
||||
// applique a nouveau la rotation du champ de texte
|
||||
setTransform(QTransform().translate(m.x(), m.y()).rotate(rotation_angle_).translate(-m.x(), -m.y()));
|
||||
}
|
||||
|
||||
/**
|
||||
Specifie la position du champ de texte
|
||||
@param x abscisse de la nouvelle position
|
||||
@param y ordonnee de la nouvelle position
|
||||
*/
|
||||
void PartTextField::setPos(qreal x, qreal y) {
|
||||
PartTextField::setPos(QPointF(x, y));
|
||||
}
|
||||
|
||||
/**
|
||||
@return l'angle de rotation de ce champ de texte
|
||||
*/
|
||||
qreal PartTextField::rotationAngle() const {
|
||||
return(rotation_angle_);
|
||||
return(rotation());
|
||||
}
|
||||
|
||||
/**
|
||||
@param angle Le nouvel angle de rotation de ce champ de texte
|
||||
*/
|
||||
void PartTextField::setRotationAngle(const qreal &angle) {
|
||||
qreal applied_rotation = QET::correctAngle(angle);
|
||||
|
||||
QPointF t = margin();
|
||||
translate(t.x(), t.y());
|
||||
rotate(applied_rotation - rotation_angle_);
|
||||
rotation_angle_ = applied_rotation;
|
||||
translate(-t.x(), -t.y());
|
||||
setRotation(QET::correctAngle(angle));
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -234,7 +194,6 @@ void PartTextField::setProperty(const QString &property, const QVariant &value)
|
||||
} else if (property == "size") {
|
||||
if (!value.canConvert(QVariant::Int)) return;
|
||||
setFont(QETApp::diagramTextsFont(value.toInt()));
|
||||
adjustItemPosition(0);
|
||||
} else if (property == "text") {
|
||||
setPlainText(value.toString());
|
||||
} else if (property == "rotation angle") {
|
||||
@@ -265,7 +224,7 @@ QVariant PartTextField::property(const QString &property) {
|
||||
} else if (property == "text") {
|
||||
return(toPlainText());
|
||||
} else if (property == "rotation angle") {
|
||||
return(rotation_angle_);
|
||||
return(rotation());
|
||||
} else if (property == "rotate") {
|
||||
return(follow_parent_rotations);
|
||||
}
|
||||
@@ -279,9 +238,6 @@ QVariant PartTextField::property(const QString &property) {
|
||||
*/
|
||||
QVariant PartTextField::itemChange(GraphicsItemChange change, const QVariant &value) {
|
||||
if (change == QGraphicsItem::ItemPositionHasChanged || change == QGraphicsItem::ItemSceneHasChanged) {
|
||||
// memorise la nouvelle position "officielle" du champ de texte
|
||||
// cette information servira a le recentrer en cas d'ajout / retrait de lignes
|
||||
known_position_ = pos();
|
||||
updateCurrentPartEditor();
|
||||
} else if (change == QGraphicsItem::ItemSelectedHasChanged) {
|
||||
if (value.toBool() == true) {
|
||||
@@ -340,7 +296,12 @@ void PartTextField::paint(QPainter *painter, const QStyleOptionGraphicsItem *qso
|
||||
*/
|
||||
void PartTextField::adjustItemPosition(int new_block_count) {
|
||||
Q_UNUSED(new_block_count);
|
||||
setPos(known_position_);
|
||||
qreal origin_offset = boundingRect().bottom() / 2.0;
|
||||
|
||||
QTransform base_translation;
|
||||
base_translation.translate(0.0, -origin_offset);
|
||||
setTransform(base_translation, false);
|
||||
setTransformOriginPoint(0.0, origin_offset);
|
||||
}
|
||||
|
||||
#ifdef QET_DEBUG_EDITOR_TEXTS
|
||||
|
||||
@@ -40,7 +40,6 @@ class PartTextField : public QGraphicsTextItem, public CustomElementPart {
|
||||
|
||||
// attributs
|
||||
bool follow_parent_rotations;
|
||||
qreal rotation_angle_;
|
||||
|
||||
// methodes
|
||||
public:
|
||||
@@ -54,9 +53,6 @@ class PartTextField : public QGraphicsTextItem, public CustomElementPart {
|
||||
virtual QString xmlName() const { return(QString("input")); }
|
||||
void fromXml(const QDomElement &);
|
||||
const QDomElement toXml(QDomDocument &) const;
|
||||
QPointF pos() const;
|
||||
void setPos(const QPointF &);
|
||||
void setPos(qreal, qreal);
|
||||
qreal rotationAngle() const;
|
||||
void setRotationAngle(const qreal &);
|
||||
bool followParentRotations();
|
||||
@@ -67,7 +63,7 @@ class PartTextField : public QGraphicsTextItem, public CustomElementPart {
|
||||
virtual void paint(QPainter *, const QStyleOptionGraphicsItem *, QWidget * = 0 );
|
||||
|
||||
public slots:
|
||||
void adjustItemPosition(int);
|
||||
void adjustItemPosition(int = 0);
|
||||
|
||||
protected:
|
||||
virtual void focusOutEvent(QFocusEvent *);
|
||||
@@ -81,6 +77,5 @@ class PartTextField : public QGraphicsTextItem, public CustomElementPart {
|
||||
void drawPoint(QPainter *, const QPointF &);
|
||||
#endif
|
||||
QString previous_text;
|
||||
QPointF known_position_;
|
||||
};
|
||||
#endif
|
||||
|
||||
Reference in New Issue
Block a user