Conductor now support variables. (%F, %id, %total, %f and titleblock and project variables). Minor: labels that use %F update when folio field is changed

git-svn-id: svn+ssh://svn.tuxfamily.org/svnroot/qet/qet/trunk@4586 bfdf4180-ca20-0410-9c96-a3a8aa849046
This commit is contained in:
dfochi
2016-07-20 21:54:54 +00:00
parent 3a7d210bcb
commit 989905da01
5 changed files with 75 additions and 5 deletions

View File

@@ -138,7 +138,10 @@ class BorderTitleBlock : public QObject
}
}
/// @param author the new value of the "Folio" field
void setFolio(const QString &folio) { btb_folio_ = folio; }
void setFolio(const QString &folio) {
btb_folio_ = folio;
emit (titleBlockFolioChanged());
}
void setFolioData(int, int, QString = NULL, const DiagramContext & = DiagramContext());
/// @param author the new value of the "File" field
void setFileName(const QString &filename) { btb_filename_ = filename; }
@@ -192,6 +195,12 @@ class BorderTitleBlock : public QObject
*/
void diagramTitleChanged(const QString &);
/**
@brief titleBlockFolioChanged
Signal emitted after Folio has changed
*/
void titleBlockFolioChanged();
/**
Signal emitted when the title block requires its data to be updated in order
to generate the folio field.

View File

@@ -78,6 +78,7 @@ Diagram::Diagram(QETProject *project) :
connect(&border_and_titleblock, SIGNAL(needTitleBlockTemplate(const QString &)), this, SLOT(setTitleBlockTemplate(const QString &)));
connect(&border_and_titleblock, SIGNAL(diagramTitleChanged(const QString &)), this, SLOT(titleChanged(const QString &)));
connect(&border_and_titleblock, SIGNAL(borderChanged(QRectF,QRectF)), this, SLOT(adjustSceneRect()));
connect(&border_and_titleblock, SIGNAL(titleBlockFolioChanged()), this, SLOT(updateLabels()));
adjustSceneRect();
}
@@ -1056,6 +1057,22 @@ void Diagram::invertSelection() {
emit(selectionChanged());
}
/**
* @brief Diagram::updateLabels
* Update elements and conductors that reference folio field
* in their labels.
*/
void Diagram::updateLabels() {
foreach (Element *elmt, elements()) {
if (elmt->elementInformations()["label"].toString().contains(("%F")))
elmt->updateLabel();
}
foreach (Conductor *cnd, content().conductors()) {
if (cnd->properties().text.contains("%F"))
cnd->setText(cnd->properties().text);
}
}
/**
@return le titre du cartouche
*/

View File

@@ -215,6 +215,7 @@ class Diagram : public QGraphicsScene
void titleBlockTemplateChanged(const QString &);
void titleBlockTemplateRemoved(const QString &, const QString & = QString());
void setTitleBlockTemplate(const QString &);
void updateLabels();
// methods related to graphics items selection
void selectAll();

View File

@@ -1191,16 +1191,58 @@ ConductorProfile Conductor::profile(Qt::Corner path_type) const {
/// @return le texte du conducteur
QString Conductor::text() const {
return(text_item -> toPlainText());
QString label = text_item->toPlainText();
return(label);
}
/**
* @brief Conductor::assignVariables
* Apply variables to conductor label
* @param label to be processed
* @return label with variables assigned
*/
QString Conductor::assignVariables(QString label) {
//Titleblock Variables
for (int i = 0; i < diagram()->border_and_titleblock.additionalFields().count(); i++)
{
QString folio_variable = diagram()->border_and_titleblock.additionalFields().keys().at(i);
QVariant folio_value = diagram()->border_and_titleblock.additionalFields().operator [](folio_variable);
if (label.contains(folio_variable)) {
label.replace("%{" + folio_variable + "}", folio_value.toString());
label.replace("%" + folio_variable , folio_value.toString());
}
}
//Project Variables
for (int i = 0; i < diagram()->project()->projectProperties().count(); i++)
{
QString folio_variable = diagram()->project()->projectProperties().keys().at(i);
QVariant folio_value = diagram()->project()->projectProperties().operator [](folio_variable);
if (label.contains(folio_variable)) {
label.replace("%{" + folio_variable + "}", folio_value.toString());
label.replace("%" + folio_variable , folio_value.toString());
}
}
//Default Variables
label.replace("%f", QString::number(diagram()->folioIndex()+1));
label.replace("%F", diagram() -> border_and_titleblock.folio());
label.replace("%id", QString::number(diagram()->folioIndex()+1));
label.replace("%total", QString::number(diagram()->border_and_titleblock.folioTotal()));
return label;
}
/**
* @brief Conductor::setText
* The text of this conductor
* @param t
*/
void Conductor::setText(const QString &t) {
text_item -> setPlainText(t);
QString label = assignVariables(t);
text_item -> setPlainText(label);
}
/**
@@ -1269,7 +1311,7 @@ void Conductor::setHighlighted(Conductor::Highlight hl) {
*/
void Conductor::displayedTextChanged()
{
if ((text_item->toPlainText() == properties_.text) || !diagram()) return;
if ((text_item->toPlainText() == assignVariables(properties_.text)) || !diagram()) return;
QVariant old_value, new_value;
old_value.setValue(properties_);

View File

@@ -92,6 +92,7 @@ class Conductor : public QObject, public QGraphicsPathItem
ConductorSegment *middleSegment();
QPointF posForText(Qt::Orientations &flag);
QString text() const;
QString assignVariables(QString) ;
void setText(const QString &);
public: