Conductor properties dialog: dialog is now build in is own class.

The conductor himself call the dialog when he have mouse double click.
The dialog isn't managed by the diagram view anymore. 


git-svn-id: svn+ssh://svn.tuxfamily.org/svnroot/qet/qet/trunk@3295 bfdf4180-ca20-0410-9c96-a3a8aa849046
This commit is contained in:
blacksun
2014-09-02 18:41:25 +00:00
parent 209a6277b8
commit 818a7601d9
9 changed files with 270 additions and 111 deletions

View File

@@ -37,7 +37,6 @@
#include "qetmessagebox.h" #include "qetmessagebox.h"
#include "qtextorientationspinboxwidget.h" #include "qtextorientationspinboxwidget.h"
#include <QGraphicsObject> #include <QGraphicsObject>
#include <ui/elementpropertieswidget.h>
#include <QGraphicsPixmapItem> #include <QGraphicsPixmapItem>
#include <QGraphicsSceneMouseEvent> #include <QGraphicsSceneMouseEvent>
#include "factory/elementfactory.h" #include "factory/elementfactory.h"
@@ -914,7 +913,7 @@ void DiagramView::editSelectionProperties() {
DiagramContent::SelectedOnly).size()) { DiagramContent::SelectedOnly).size()) {
// edit conductor // edit conductor
if (selection.conductors(DiagramContent::AnyConductor | DiagramContent::SelectedOnly).size()) if (selection.conductors(DiagramContent::AnyConductor | DiagramContent::SelectedOnly).size())
editConductor(selection.conductors().first()); selection.conductors().first()->editProperty();
// edit element // edit element
else if (selection.elements.size()) else if (selection.elements.size())
selection.elements.toList().first() -> editProperty(); selection.elements.toList().first() -> editProperty();
@@ -948,88 +947,6 @@ void DiagramView::editSelectedConductorColor() {
} }
} }
/**
Affiche un dialogue permettant d'editer le conducteur selectionne.
Ne fait rien s'il y a 0 ou plusieurs conducteurs selectionnes.
*/
void DiagramView::editConductor() {
QList<Conductor *> selected_conductors(scene -> selectedConductors().toList());
// on ne peut editer qu'un conducteur a la fois
if (selected_conductors.count() != 1) return;
Conductor *edited_conductor = selected_conductors.first();
editConductor(edited_conductor);
}
/**
Edite le conducteur passe en parametre
@param edited_conductor Conducteur a editer
*/
void DiagramView::editConductor(Conductor *edited_conductor) {
if (scene -> isReadOnly() || !edited_conductor) return;
// initialise l'editeur de proprietes pour le conducteur
ConductorProperties old_properties = edited_conductor -> properties();
ConductorPropertiesWidget *cpw = new ConductorPropertiesWidget(old_properties);
// l'insere dans un dialogue
QDialog conductor_dialog(diagramEditor());
#ifdef Q_WS_MAC
conductor_dialog.setWindowFlags(Qt::Sheet);
#endif
conductor_dialog.setWindowTitle(tr("\311diter les propri\351t\351s d'un conducteur", "window title"));
QVBoxLayout *dialog_layout = new QVBoxLayout(&conductor_dialog);
dialog_layout -> addWidget(cpw);
QCheckBox *cb_apply_all = new QCheckBox(tr("Appliquer les propri\351t\351s \340 l'ensemble des conducteurs de ce potentiel"), &conductor_dialog);
cb_apply_all->setChecked(true);
dialog_layout -> addStretch();
dialog_layout -> addWidget(cb_apply_all);
QDialogButtonBox *dbb = new QDialogButtonBox(QDialogButtonBox::Ok | QDialogButtonBox::Cancel);
dbb -> setParent(&conductor_dialog);
dialog_layout -> addWidget(dbb);
connect(dbb, SIGNAL(accepted()), &conductor_dialog, SLOT(accept()));
connect(dbb, SIGNAL(rejected()), &conductor_dialog, SLOT(reject()));
cpw -> setFocus(Qt::ActiveWindowFocusReason);
// execute le dialogue et met a jour le conducteur
if (conductor_dialog.exec() == QDialog::Accepted) {
// recupere les nouvelles proprietes
ConductorProperties new_properties = cpw -> properties();
if (new_properties != old_properties) {
if (cb_apply_all -> isChecked()) {
QList <Conductor *> conductorslist = edited_conductor -> relatedPotentialConductors().toList();
conductorslist << edited_conductor;
QList <ConductorProperties> old_properties_list;
foreach (Conductor *c, conductorslist) {
if (c == edited_conductor) {
old_properties_list << old_properties;
}
else {
old_properties_list << c -> properties();
c -> setProperties(new_properties);
}
}
//initialize the corresponding UndoCommand object
ChangeSeveralConductorsPropertiesCommand *cscpc = new ChangeSeveralConductorsPropertiesCommand(conductorslist);
cscpc -> setOldSettings(old_properties_list);
cscpc -> setNewSettings(new_properties);
diagram() -> undoStack().push(cscpc);
}
else {
// initialise l'objet UndoCommand correspondant
ChangeConductorPropertiesCommand *ccpc = new ChangeConductorPropertiesCommand(edited_conductor);
ccpc -> setOldSettings(old_properties);
ccpc -> setNewSettings(new_properties);
diagram() -> undoStack().push(ccpc);
}
}
}
}
/** /**
Edit the color of the given conductor Edit the color of the given conductor
@param edited_conductor Conductor we want to change the color @param edited_conductor Conductor we want to change the color
@@ -1383,7 +1300,7 @@ QETDiagramEditor *DiagramView::diagramEditor() const {
void DiagramView::mouseDoubleClickEvent(QMouseEvent *e) { void DiagramView::mouseDoubleClickEvent(QMouseEvent *e) {
BorderTitleBlock &bi = scene -> border_and_titleblock; BorderTitleBlock &bi = scene -> border_and_titleblock;
// recupere le rectangle corespondant au cartouche //Get the rectangle of the titleblock
QRectF titleblock_rect( QRectF titleblock_rect(
Diagram::margin, Diagram::margin,
Diagram::margin + bi.diagramHeight(), Diagram::margin + bi.diagramHeight(),
@@ -1391,7 +1308,7 @@ void DiagramView::mouseDoubleClickEvent(QMouseEvent *e) {
bi.titleBlockHeight() bi.titleBlockHeight()
); );
// recupere le rectangle correspondant aux en-tetes des colonnes // Get the rectangle of the header column
QRectF columns_rect( QRectF columns_rect(
Diagram::margin, Diagram::margin,
Diagram::margin, Diagram::margin,
@@ -1399,7 +1316,7 @@ void DiagramView::mouseDoubleClickEvent(QMouseEvent *e) {
bi.columnsHeaderHeight() bi.columnsHeaderHeight()
); );
// recupere le rectangle correspondant aux en-tetes des lignes // Get the rectangle of the header row
QRectF rows_rect( QRectF rows_rect(
Diagram::margin, Diagram::margin,
Diagram::margin, Diagram::margin,
@@ -1407,22 +1324,15 @@ void DiagramView::mouseDoubleClickEvent(QMouseEvent *e) {
bi.diagramHeight() bi.diagramHeight()
); );
// coordonnees du clic par rapport au schema //Get the click pos on the diagram
QPointF click_pos = viewportTransform().inverted().map(e -> pos()); QPointF click_pos = viewportTransform().inverted().map(e -> pos());
// detecte le double-clic sur le cartouche ou les colonnes if (titleblock_rect.contains(click_pos) || columns_rect.contains(click_pos) || rows_rect.contains(click_pos)) {
if (QGraphicsItem *qgi = itemAt(e -> pos())) { e->accept();
if (Conductor *c = qgraphicsitem_cast<Conductor *>(qgi)) {
editConductor(c);
} else {
QGraphicsView::mouseDoubleClickEvent(e);
}
} else if (titleblock_rect.contains(click_pos) || columns_rect.contains(click_pos) || rows_rect.contains(click_pos)) {
// edite les proprietes du schema
editDiagramProperties(); editDiagramProperties();
} else { return;
QGraphicsView::mouseDoubleClickEvent(e);
} }
QGraphicsView::mouseDoubleClickEvent(e);
} }
/** /**

View File

@@ -176,8 +176,6 @@ class DiagramView : public QGraphicsView {
void updateWindowTitle(); void updateWindowTitle();
void editSelectionProperties(); void editSelectionProperties();
void editSelectedConductorColor(); void editSelectedConductorColor();
void editConductor();
void editConductor(Conductor *);
void editConductorColor(Conductor *); void editConductorColor(Conductor *);
void resetConductors(); void resetConductors();

View File

@@ -1496,15 +1496,6 @@ void QETDiagramEditor::editSelectionProperties() {
} }
} }
/**
Edite les proprietes du conducteur selectionne
*/
void QETDiagramEditor::slot_editConductor() {
if (DiagramView *dv = currentDiagram()) {
dv -> editConductor();
}
}
/** /**
Reinitialise les conducteurs selectionnes Reinitialise les conducteurs selectionnes
*/ */

View File

@@ -125,7 +125,6 @@ class QETDiagramEditor : public QETMainWindow {
void slot_addRow(); void slot_addRow();
void slot_removeRow(); void slot_removeRow();
void editSelectionProperties(); void editSelectionProperties();
void slot_editConductor();
void slot_resetConductors(); void slot_resetConductors();
void slot_addText(); void slot_addText();
void slot_addImage(); void slot_addImage();

View File

@@ -26,6 +26,7 @@
#include "qetdiagrameditor.h" #include "qetdiagrameditor.h"
#include "terminal.h" #include "terminal.h"
#include "conductorautonumerotation.h" #include "conductorautonumerotation.h"
#include "conductorpropertiesdialog.h"
#define PR(x) qDebug() << #x " = " << x; #define PR(x) qDebug() << #x " = " << x;
bool Conductor::pen_and_brush_initialized = false; bool Conductor::pen_and_brush_initialized = false;
@@ -556,6 +557,16 @@ bool Conductor::valideXml(QDomElement &e){
return(true); return(true);
} }
/**
* @brief Conductor::mouseDoubleClickEvent
* Action at double click on this item
* @param e
*/
void Conductor::mouseDoubleClickEvent(QGraphicsSceneMouseEvent *e) {
e->accept();
editProperty();
}
/** /**
Gere les clics sur le conducteur. Gere les clics sur le conducteur.
@param e L'evenement decrivant le clic. @param e L'evenement decrivant le clic.
@@ -1406,6 +1417,13 @@ QETDiagramEditor* Conductor::diagramEditor() const {
return(qobject_cast<QETDiagramEditor *>(w)); return(qobject_cast<QETDiagramEditor *>(w));
} }
/**
* @brief Conductor::editProperty
*/
void Conductor::editProperty() {
ConductorPropertiesDialog::PropertiesDialog(this, diagramEditor());
}
/** /**
@param a reel @param a reel
@param b reel @param b reel

View File

@@ -108,11 +108,13 @@ class Conductor : public QObject, public QGraphicsPathItem {
void autoText(); void autoText();
QSet<Conductor *> relatedPotentialConductors(QList <Terminal *> *t_list=0); QSet<Conductor *> relatedPotentialConductors(QList <Terminal *> *t_list=0);
QETDiagramEditor* diagramEditor() const; QETDiagramEditor* diagramEditor() const;
void editProperty ();
public slots: public slots:
void displayedTextChanged(); void displayedTextChanged();
protected: protected:
virtual void mouseDoubleClickEvent(QGraphicsSceneMouseEvent *);
virtual void mousePressEvent(QGraphicsSceneMouseEvent *); virtual void mousePressEvent(QGraphicsSceneMouseEvent *);
virtual void mouseMoveEvent(QGraphicsSceneMouseEvent *); virtual void mouseMoveEvent(QGraphicsSceneMouseEvent *);
virtual void mouseReleaseEvent(QGraphicsSceneMouseEvent *); virtual void mouseReleaseEvent(QGraphicsSceneMouseEvent *);

View File

@@ -0,0 +1,105 @@
/*
Copyright 2006-2014 The QElectroTech Team
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/>.
*/
#include "conductorpropertiesdialog.h"
#include "ui_conductorpropertiesdialog.h"
#include "conductor.h"
#include "conductorpropertieswidget.h"
#include "diagramcommands.h"
#include "diagram.h"
/**
* @brief ConductorPropertiesDialog::ConductorPropertiesDialog
* Constructor
* @param conductor, conductor to edit propertie
* @param parent, parent widget
*/
ConductorPropertiesDialog::ConductorPropertiesDialog(Conductor *conductor, QWidget *parent) :
QDialog(parent),
ui(new Ui::ConductorPropertiesDialog)
{
ui->setupUi(this);
m_cpw = new ConductorPropertiesWidget(conductor->properties());
ui -> main_layout -> insertWidget(1, m_cpw);
}
/**
* @brief ConductorPropertiesDialog::~ConductorPropertiesDialog
*/
ConductorPropertiesDialog::~ConductorPropertiesDialog()
{
delete ui;
}
/**
* @brief ConductorPropertiesDialog::PropertiesDialog
* Static method for open and apply properties.
* @param conductor, conductor to edit propertie
* @param parent, parent widget
*/
void ConductorPropertiesDialog::PropertiesDialog(Conductor *conductor, QWidget *parent) {
ConductorPropertiesDialog cpd (conductor, parent);
if (cpd.exec() == QDialog::Accepted && cpd.properties() != conductor->properties()) {
if (cpd.applyAll()) {
QList <Conductor *> conductorslist = conductor -> relatedPotentialConductors().toList();
conductorslist << conductor;
QList <ConductorProperties> old_properties_list;
foreach (Conductor *c, conductorslist) {
if (c == conductor) {
old_properties_list << conductor -> properties();
} else {
old_properties_list << c -> properties();
c -> setProperties( cpd.properties() );
}
}
//initialize the corresponding UndoCommand object
ChangeSeveralConductorsPropertiesCommand *cscpc = new ChangeSeveralConductorsPropertiesCommand(conductorslist);
cscpc -> setOldSettings(old_properties_list);
cscpc -> setNewSettings(cpd.properties());
conductor -> diagram() -> undoStack().push(cscpc);
} else {
// initialize the corresponding UndoCommand object
ChangeConductorPropertiesCommand *ccpc = new ChangeConductorPropertiesCommand(conductor);
ccpc -> setOldSettings(conductor -> properties());
ccpc -> setNewSettings(cpd.properties());
conductor -> diagram() -> undoStack().push(ccpc);
}
}
}
/**
* @brief ConductorPropertiesDialog::properties
* @return the edited properties
*/
ConductorProperties ConductorPropertiesDialog::properties() const {
return m_cpw -> properties();
}
/**
* @brief ConductorPropertiesDialog::applyAll
* @return
* true -> must apply the propertie to all conductor at the same potential
* false -> must apply properties only for the edited conductor
*/
bool ConductorPropertiesDialog::applyAll() const {
return ui -> m_apply_all_cb -> isChecked();
}

View File

@@ -0,0 +1,49 @@
/*
Copyright 2006-2014 The QElectroTech Team
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/>.
*/
#ifndef CONDUCTORPROPERTIESDIALOG_H
#define CONDUCTORPROPERTIESDIALOG_H
#include <QDialog>
#include "conductorproperties.h"
class Conductor;
class ConductorPropertiesWidget;
namespace Ui {
class ConductorPropertiesDialog;
}
class ConductorPropertiesDialog : public QDialog
{
Q_OBJECT
public:
explicit ConductorPropertiesDialog (Conductor *conductor, QWidget *parent = 0);
static void PropertiesDialog (Conductor *conductor, QWidget *parent = 0);
~ConductorPropertiesDialog();
ConductorProperties properties() const;
bool applyAll() const;
private:
Ui::ConductorPropertiesDialog *ui;
ConductorPropertiesWidget *m_cpw;
};
#endif // CONDUCTORPROPERTIESDIALOG_H

View File

@@ -0,0 +1,87 @@
<?xml version="1.0" encoding="UTF-8"?>
<ui version="4.0">
<class>ConductorPropertiesDialog</class>
<widget class="QDialog" name="ConductorPropertiesDialog">
<property name="geometry">
<rect>
<x>0</x>
<y>0</y>
<width>430</width>
<height>300</height>
</rect>
</property>
<property name="windowTitle">
<string>Éditer les propriétés d'un conducteur</string>
</property>
<layout class="QVBoxLayout" name="main_layout">
<item>
<spacer name="verticalSpacer">
<property name="orientation">
<enum>Qt::Vertical</enum>
</property>
<property name="sizeHint" stdset="0">
<size>
<width>20</width>
<height>40</height>
</size>
</property>
</spacer>
</item>
<item>
<widget class="QCheckBox" name="m_apply_all_cb">
<property name="text">
<string>Appliquer les propriétés à l'ensemble des conducteurs de ce potentiel</string>
</property>
<property name="checked">
<bool>true</bool>
</property>
</widget>
</item>
<item>
<widget class="QDialogButtonBox" name="buttonBox">
<property name="orientation">
<enum>Qt::Horizontal</enum>
</property>
<property name="standardButtons">
<set>QDialogButtonBox::Cancel|QDialogButtonBox::Ok</set>
</property>
</widget>
</item>
</layout>
</widget>
<resources/>
<connections>
<connection>
<sender>buttonBox</sender>
<signal>accepted()</signal>
<receiver>ConductorPropertiesDialog</receiver>
<slot>accept()</slot>
<hints>
<hint type="sourcelabel">
<x>248</x>
<y>254</y>
</hint>
<hint type="destinationlabel">
<x>157</x>
<y>274</y>
</hint>
</hints>
</connection>
<connection>
<sender>buttonBox</sender>
<signal>rejected()</signal>
<receiver>ConductorPropertiesDialog</receiver>
<slot>reject()</slot>
<hints>
<hint type="sourcelabel">
<x>316</x>
<y>260</y>
</hint>
<hint type="destinationlabel">
<x>286</x>
<y>274</y>
</hint>
</hints>
</connection>
</connections>
</ui>