mirror of
https://github.com/qelectrotech/qelectrotech-source-mirror.git
synced 2025-09-13 20:23:04 +02:00
Element editor : alignment of text field can be edited
git-svn-id: svn+ssh://svn.tuxfamily.org/svnroot/qet/qet/trunk@5362 bfdf4180-ca20-0410-9c96-a3a8aa849046
This commit is contained in:
parent
a0b26b847b
commit
31e6db8757
@ -99,6 +99,21 @@ const QDomElement PartDynamicTextField::toXml(QDomDocument &dom_doc) const
|
|||||||
QMetaEnum me = DynamicElementTextItem::textFromMetaEnum();
|
QMetaEnum me = DynamicElementTextItem::textFromMetaEnum();
|
||||||
root_element.setAttribute("text_from", me.valueToKey(m_text_from));
|
root_element.setAttribute("text_from", me.valueToKey(m_text_from));
|
||||||
|
|
||||||
|
me = QMetaEnum::fromType<Qt::Alignment>();
|
||||||
|
if(this->alignment() &Qt::AlignRight)
|
||||||
|
root_element.setAttribute("Halignment", me.valueToKey(Qt::AlignRight));
|
||||||
|
else if(this->alignment() &Qt::AlignLeft)
|
||||||
|
root_element.setAttribute("Halignment", me.valueToKey(Qt::AlignLeft));
|
||||||
|
else if(this->alignment() &Qt::AlignHCenter)
|
||||||
|
root_element.setAttribute("Halignment", me.valueToKey(Qt::AlignHCenter));
|
||||||
|
|
||||||
|
if(this->alignment() &Qt::AlignBottom)
|
||||||
|
root_element.setAttribute("Valignment", me.valueToKey(Qt::AlignBottom));
|
||||||
|
else if(this->alignment() & Qt::AlignTop)
|
||||||
|
root_element.setAttribute("Valignment", me.valueToKey(Qt::AlignTop));
|
||||||
|
else if(this->alignment() &Qt::AlignVCenter)
|
||||||
|
root_element.setAttribute("Valignment", me.valueToKey(Qt::AlignVCenter));
|
||||||
|
|
||||||
QDomElement dom_text = dom_doc.createElement("text");
|
QDomElement dom_text = dom_doc.createElement("text");
|
||||||
dom_text.appendChild(dom_doc.createTextNode(toPlainText()));
|
dom_text.appendChild(dom_doc.createTextNode(toPlainText()));
|
||||||
root_element.appendChild(dom_text);
|
root_element.appendChild(dom_text);
|
||||||
@ -152,13 +167,21 @@ void PartDynamicTextField::fromXml(const QDomElement &dom_elmt)
|
|||||||
|
|
||||||
QMetaEnum me = DynamicElementTextItem::textFromMetaEnum();
|
QMetaEnum me = DynamicElementTextItem::textFromMetaEnum();
|
||||||
m_text_from = DynamicElementTextItem::TextFrom(me.keyToValue(dom_elmt.attribute("text_from").toStdString().data()));
|
m_text_from = DynamicElementTextItem::TextFrom(me.keyToValue(dom_elmt.attribute("text_from").toStdString().data()));
|
||||||
|
|
||||||
|
me = QMetaEnum::fromType<Qt::Alignment>();
|
||||||
|
if(dom_elmt.hasAttribute("Halignment"))
|
||||||
|
setAlignment(Qt::Alignment(me.keyToValue(dom_elmt.attribute("Halignment").toStdString().data())));
|
||||||
|
if(dom_elmt.hasAttribute(("Valignment")))
|
||||||
|
setAlignment(Qt::Alignment(me.keyToValue(dom_elmt.attribute("Valignment").toStdString().data())) | this->alignment());
|
||||||
|
|
||||||
//Text
|
//Text
|
||||||
QDomElement dom_text = dom_elmt.firstChildElement("text");
|
QDomElement dom_text = dom_elmt.firstChildElement("text");
|
||||||
if (!dom_text.isNull())
|
if (!dom_text.isNull())
|
||||||
{
|
{
|
||||||
m_text = dom_text.text();
|
m_text = dom_text.text();
|
||||||
|
m_block_alignment = true;
|
||||||
setPlainText(m_text);
|
setPlainText(m_text);
|
||||||
|
m_block_alignment = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
//Info name
|
//Info name
|
||||||
@ -363,6 +386,10 @@ void PartDynamicTextField::setTextWidth(qreal width)
|
|||||||
|
|
||||||
void PartDynamicTextField::setPlainText(const QString &text)
|
void PartDynamicTextField::setPlainText(const QString &text)
|
||||||
{
|
{
|
||||||
|
if(toPlainText() == text)
|
||||||
|
return;
|
||||||
|
|
||||||
|
prepareAlignment();
|
||||||
QGraphicsTextItem::setPlainText(text);
|
QGraphicsTextItem::setPlainText(text);
|
||||||
|
|
||||||
//User define a text width
|
//User define a text width
|
||||||
@ -377,6 +404,17 @@ void PartDynamicTextField::setPlainText(const QString &text)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
finishAlignment();
|
||||||
|
}
|
||||||
|
|
||||||
|
void PartDynamicTextField::setAlignment(Qt::Alignment alignment)
|
||||||
|
{
|
||||||
|
m_alignment = alignment;
|
||||||
|
emit alignmentChanged(m_alignment);
|
||||||
|
}
|
||||||
|
|
||||||
|
Qt::Alignment PartDynamicTextField::alignment() const {
|
||||||
|
return m_alignment;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -509,3 +547,48 @@ void PartDynamicTextField::elementInfoChanged()
|
|||||||
else if (m_text_from == DynamicElementTextItem::CompositeText && elementScene())
|
else if (m_text_from == DynamicElementTextItem::CompositeText && elementScene())
|
||||||
setPlainText(autonum::AssignVariables::replaceVariable(m_composite_text, elementScene()->elementInformation()));
|
setPlainText(autonum::AssignVariables::replaceVariable(m_composite_text, elementScene()->elementInformation()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void PartDynamicTextField::prepareAlignment()
|
||||||
|
{
|
||||||
|
m_alignment_rect = boundingRect();
|
||||||
|
}
|
||||||
|
|
||||||
|
void PartDynamicTextField::finishAlignment()
|
||||||
|
{
|
||||||
|
if(m_block_alignment)
|
||||||
|
return;
|
||||||
|
|
||||||
|
QTransform transform;
|
||||||
|
transform.rotate(this->rotation());
|
||||||
|
qreal x,xa, y,ya;
|
||||||
|
x=xa=0;
|
||||||
|
y=ya=0;
|
||||||
|
|
||||||
|
if(m_alignment &Qt::AlignRight)
|
||||||
|
{
|
||||||
|
x = m_alignment_rect.right();
|
||||||
|
xa = boundingRect().right();
|
||||||
|
}
|
||||||
|
else if(m_alignment &Qt::AlignHCenter)
|
||||||
|
{
|
||||||
|
x = m_alignment_rect.center().x();
|
||||||
|
xa = boundingRect().center().x();
|
||||||
|
}
|
||||||
|
|
||||||
|
if(m_alignment &Qt::AlignBottom)
|
||||||
|
{
|
||||||
|
y = m_alignment_rect.bottom();
|
||||||
|
ya = boundingRect().bottom();
|
||||||
|
}
|
||||||
|
else if(m_alignment &Qt::AlignVCenter)
|
||||||
|
{
|
||||||
|
y = m_alignment_rect.center().y();
|
||||||
|
ya = boundingRect().center().y();
|
||||||
|
}
|
||||||
|
|
||||||
|
QPointF p = transform.map(QPointF(x,y));
|
||||||
|
QPointF pa = transform.map(QPointF(xa,ya));
|
||||||
|
QPointF diff = pa-p;
|
||||||
|
|
||||||
|
setPos(this->pos() - diff);
|
||||||
|
}
|
||||||
|
@ -41,6 +41,7 @@ class PartDynamicTextField : public QGraphicsTextItem, public CustomElementPart
|
|||||||
Q_PROPERTY(int fontSize READ fontSize WRITE setFontSize NOTIFY fontSizeChanged)
|
Q_PROPERTY(int fontSize READ fontSize WRITE setFontSize NOTIFY fontSizeChanged)
|
||||||
Q_PROPERTY(bool frame READ frame WRITE setFrame NOTIFY frameChanged)
|
Q_PROPERTY(bool frame READ frame WRITE setFrame NOTIFY frameChanged)
|
||||||
Q_PROPERTY(qreal textWidth READ textWidth WRITE setTextWidth NOTIFY textWidthChanged)
|
Q_PROPERTY(qreal textWidth READ textWidth WRITE setTextWidth NOTIFY textWidthChanged)
|
||||||
|
Q_PROPERTY(Qt::Alignment alignment READ alignment WRITE setAlignment NOTIFY alignmentChanged)
|
||||||
|
|
||||||
public:
|
public:
|
||||||
///PROPERTY
|
///PROPERTY
|
||||||
@ -57,6 +58,7 @@ class PartDynamicTextField : public QGraphicsTextItem, public CustomElementPart
|
|||||||
void fontSizeChanged(int size);
|
void fontSizeChanged(int size);
|
||||||
void frameChanged(bool frame);
|
void frameChanged(bool frame);
|
||||||
void textWidthChanged(qreal width);
|
void textWidthChanged(qreal width);
|
||||||
|
void alignmentChanged(Qt::Alignment alignment);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
PartDynamicTextField(QETElementEditor *editor, QGraphicsItem *parent = nullptr);
|
PartDynamicTextField(QETElementEditor *editor, QGraphicsItem *parent = nullptr);
|
||||||
@ -92,6 +94,8 @@ class PartDynamicTextField : public QGraphicsTextItem, public CustomElementPart
|
|||||||
bool frame() const;
|
bool frame() const;
|
||||||
void setTextWidth(qreal width);
|
void setTextWidth(qreal width);
|
||||||
void setPlainText(const QString &text);
|
void setPlainText(const QString &text);
|
||||||
|
void setAlignment(Qt::Alignment alignment);
|
||||||
|
Qt::Alignment alignment() const;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void mouseMoveEvent(QGraphicsSceneMouseEvent *event) override;
|
void mouseMoveEvent(QGraphicsSceneMouseEvent *event) override;
|
||||||
@ -103,6 +107,9 @@ class PartDynamicTextField : public QGraphicsTextItem, public CustomElementPart
|
|||||||
private:
|
private:
|
||||||
void elementInfoChanged();
|
void elementInfoChanged();
|
||||||
|
|
||||||
|
void prepareAlignment();
|
||||||
|
void finishAlignment();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QPointF m_origine_pos,
|
QPointF m_origine_pos,
|
||||||
m_saved_point;
|
m_saved_point;
|
||||||
@ -112,8 +119,11 @@ class PartDynamicTextField : public QGraphicsTextItem, public CustomElementPart
|
|||||||
DynamicElementTextItem::TextFrom m_text_from = DynamicElementTextItem::UserText;
|
DynamicElementTextItem::TextFrom m_text_from = DynamicElementTextItem::UserText;
|
||||||
QUuid m_uuid;
|
QUuid m_uuid;
|
||||||
bool m_frame = false,
|
bool m_frame = false,
|
||||||
m_first_add = true;
|
m_first_add = true,
|
||||||
|
m_block_alignment = false;
|
||||||
qreal m_text_width = -1;
|
qreal m_text_width = -1;
|
||||||
|
Qt::Alignment m_alignment = Qt::AlignTop|Qt::AlignLeft;
|
||||||
|
QRectF m_alignment_rect;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // PARTDYNAMICTEXTFIELD_H
|
#endif // PARTDYNAMICTEXTFIELD_H
|
||||||
|
@ -23,6 +23,7 @@
|
|||||||
#include "qetelementeditor.h"
|
#include "qetelementeditor.h"
|
||||||
#include "qetapp.h"
|
#include "qetapp.h"
|
||||||
#include "compositetexteditdialog.h"
|
#include "compositetexteditdialog.h"
|
||||||
|
#include "alignmenttextdialog.h"
|
||||||
|
|
||||||
#include <QPointer>
|
#include <QPointer>
|
||||||
#include <QGraphicsItem>
|
#include <QGraphicsItem>
|
||||||
@ -292,3 +293,16 @@ void DynamicTextFieldEditor::on_m_composite_text_pb_clicked()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void DynamicTextFieldEditor::on_m_alignment_pb_clicked()
|
||||||
|
{
|
||||||
|
AlignmentTextDialog atd(m_text_field.data()->alignment(), this);
|
||||||
|
atd.exec();
|
||||||
|
|
||||||
|
if(atd.alignment() != m_text_field.data()->alignment())
|
||||||
|
{
|
||||||
|
QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_text_field.data(), "alignment", QVariant(m_text_field.data()->alignment()), QVariant(atd.alignment()));
|
||||||
|
undo->setText(tr("Modifier l'alignement d'un champ texte"));
|
||||||
|
undoStack().push(undo);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -56,8 +56,8 @@ class DynamicTextFieldEditor : public ElementItemEditor
|
|||||||
void on_m_width_sb_editingFinished();
|
void on_m_width_sb_editingFinished();
|
||||||
void on_m_elmt_info_cb_activated(const QString &arg1);
|
void on_m_elmt_info_cb_activated(const QString &arg1);
|
||||||
void on_m_text_from_cb_activated(int index);
|
void on_m_text_from_cb_activated(int index);
|
||||||
|
|
||||||
void on_m_composite_text_pb_clicked();
|
void on_m_composite_text_pb_clicked();
|
||||||
|
void on_m_alignment_pb_clicked();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Ui::DynamicTextFieldEditor *ui;
|
Ui::DynamicTextFieldEditor *ui;
|
||||||
|
@ -196,6 +196,13 @@
|
|||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
<item row="1" column="6">
|
||||||
|
<widget class="QPushButton" name="m_alignment_pb">
|
||||||
|
<property name="text">
|
||||||
|
<string>Alignement</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
@ -19,30 +19,29 @@
|
|||||||
#include "ui_alignmenttextdialog.h"
|
#include "ui_alignmenttextdialog.h"
|
||||||
#include "dynamicelementtextitem.h"
|
#include "dynamicelementtextitem.h"
|
||||||
|
|
||||||
AlignmentTextDialog::AlignmentTextDialog(DynamicElementTextItem *text, QWidget *parent) :
|
AlignmentTextDialog::AlignmentTextDialog(Qt::Alignment alignment, QWidget *parent) :
|
||||||
QDialog(parent),
|
QDialog(parent),
|
||||||
ui(new Ui::AlignmentTextDialog)
|
ui(new Ui::AlignmentTextDialog)
|
||||||
{
|
{
|
||||||
ui->setupUi(this);
|
ui->setupUi(this);
|
||||||
|
|
||||||
Qt::Alignment align = text->alignment();
|
if(alignment == (Qt::AlignTop|Qt::AlignLeft))
|
||||||
if(align == (Qt::AlignTop|Qt::AlignLeft))
|
|
||||||
ui->top_left->setChecked(true);
|
ui->top_left->setChecked(true);
|
||||||
else if(align == (Qt::AlignTop|Qt::AlignHCenter))
|
else if(alignment == (Qt::AlignTop|Qt::AlignHCenter))
|
||||||
ui->top->setChecked(true);
|
ui->top->setChecked(true);
|
||||||
else if(align == (Qt::AlignTop|Qt::AlignRight))
|
else if(alignment == (Qt::AlignTop|Qt::AlignRight))
|
||||||
ui->top_right->setChecked(true);
|
ui->top_right->setChecked(true);
|
||||||
else if(align == (Qt::AlignVCenter|Qt::AlignLeft))
|
else if(alignment == (Qt::AlignVCenter|Qt::AlignLeft))
|
||||||
ui->left->setChecked(true);
|
ui->left->setChecked(true);
|
||||||
else if(align == Qt::AlignCenter)
|
else if(alignment == Qt::AlignCenter)
|
||||||
ui->center->setChecked(true);
|
ui->center->setChecked(true);
|
||||||
else if(align == (Qt::AlignVCenter|Qt::AlignRight))
|
else if(alignment == (Qt::AlignVCenter|Qt::AlignRight))
|
||||||
ui->right->setChecked(true);
|
ui->right->setChecked(true);
|
||||||
else if(align == (Qt::AlignBottom|Qt::AlignLeft))
|
else if(alignment == (Qt::AlignBottom|Qt::AlignLeft))
|
||||||
ui->bottom_left->setChecked(true);
|
ui->bottom_left->setChecked(true);
|
||||||
else if(align == (Qt::AlignBottom|Qt::AlignHCenter))
|
else if(alignment == (Qt::AlignBottom|Qt::AlignHCenter))
|
||||||
ui->bottom->setChecked(true);
|
ui->bottom->setChecked(true);
|
||||||
else if(align == (Qt::AlignBottom|Qt::AlignRight))
|
else if(alignment == (Qt::AlignBottom|Qt::AlignRight))
|
||||||
ui->bottom_right->setChecked(true);
|
ui->bottom_right->setChecked(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -81,7 +80,7 @@ Qt::Alignment AlignmentTextDialog::alignment() const
|
|||||||
|
|
||||||
bool AlignmentTextDialog::event(QEvent *event)
|
bool AlignmentTextDialog::event(QEvent *event)
|
||||||
{
|
{
|
||||||
//Little hack to set focus to a radio button
|
//Little hack when this dialog is called from a QAbstractItemModel, to set focus to a radio button
|
||||||
//if we not do that, when the user click on the title bar (for move the dialog) or try to resize the dialog,
|
//if we not do that, when the user click on the title bar (for move the dialog) or try to resize the dialog,
|
||||||
//the dialog lose focus and close.
|
//the dialog lose focus and close.
|
||||||
if(event->type() == QEvent::Show && m_first_show)
|
if(event->type() == QEvent::Show && m_first_show)
|
||||||
|
@ -20,8 +20,6 @@
|
|||||||
|
|
||||||
#include <QDialog>
|
#include <QDialog>
|
||||||
|
|
||||||
class DynamicElementTextItem;
|
|
||||||
|
|
||||||
namespace Ui {
|
namespace Ui {
|
||||||
class AlignmentTextDialog;
|
class AlignmentTextDialog;
|
||||||
}
|
}
|
||||||
@ -31,7 +29,7 @@ class AlignmentTextDialog : public QDialog
|
|||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
explicit AlignmentTextDialog(DynamicElementTextItem *text, QWidget *parent = nullptr);
|
explicit AlignmentTextDialog(Qt::Alignment alignment, QWidget *parent = nullptr);
|
||||||
~AlignmentTextDialog();
|
~AlignmentTextDialog();
|
||||||
|
|
||||||
Qt::Alignment alignment() const;
|
Qt::Alignment alignment() const;
|
||||||
|
@ -1406,7 +1406,7 @@ QWidget *DynamicTextItemDelegate::createEditor(QWidget *parent, const QStyleOpti
|
|||||||
if(!deti)
|
if(!deti)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
AlignmentTextDialog *atd = new AlignmentTextDialog(deti, parent);
|
AlignmentTextDialog *atd = new AlignmentTextDialog(deti->alignment(), parent);
|
||||||
atd->setObjectName("alignment_text");
|
atd->setObjectName("alignment_text");
|
||||||
return atd;
|
return atd;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user