mirror of
https://github.com/qelectrotech/qelectrotech-source-mirror.git
synced 2025-12-18 05:00:33 +01:00
Element editor: add polygon is managed by an esevent
git-svn-id: svn+ssh://svn.tuxfamily.org/svnroot/qet/qet/trunk@3466 bfdf4180-ca20-0410-9c96-a3a8aa849046
This commit is contained in:
@@ -49,7 +49,6 @@ ElementScene::ElementScene(QETElementEditor *editor, QObject *parent) :
|
|||||||
decorator_(0)
|
decorator_(0)
|
||||||
{
|
{
|
||||||
setItemIndexMethod(NoIndex);
|
setItemIndexMethod(NoIndex);
|
||||||
current_polygon = NULL;
|
|
||||||
setGrid(1, 1);
|
setGrid(1, 1);
|
||||||
initPasteArea();
|
initPasteArea();
|
||||||
undo_stack.setClean();
|
undo_stack.setClean();
|
||||||
@@ -61,6 +60,7 @@ ElementScene::ElementScene(QETElementEditor *editor, QObject *parent) :
|
|||||||
/// Destructeur
|
/// Destructeur
|
||||||
ElementScene::~ElementScene() {
|
ElementScene::~ElementScene() {
|
||||||
delete decorator_lock_;
|
delete decorator_lock_;
|
||||||
|
if (m_event_interface) delete m_event_interface;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -79,15 +79,6 @@ void ElementScene::slot_addCircle() {
|
|||||||
if (m_event_interface) delete m_event_interface; m_event_interface = nullptr;
|
if (m_event_interface) delete m_event_interface; m_event_interface = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
Passe la scene en mode "ajout de polygone"
|
|
||||||
*/
|
|
||||||
void ElementScene::slot_addPolygon() {
|
|
||||||
behavior = Polygon;
|
|
||||||
if (m_event_interface) delete m_event_interface; m_event_interface = nullptr;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Passe la scene en mode "ajout de texte statique"
|
Passe la scene en mode "ajout de texte statique"
|
||||||
*/
|
*/
|
||||||
@@ -139,7 +130,6 @@ void ElementScene::mouseMoveEvent(QGraphicsSceneMouseEvent *e) {
|
|||||||
QPointF event_pos = e -> scenePos();
|
QPointF event_pos = e -> scenePos();
|
||||||
if (mustSnapToGrid(e)) event_pos = snapToGrid(event_pos);
|
if (mustSnapToGrid(e)) event_pos = snapToGrid(event_pos);
|
||||||
|
|
||||||
if (behavior != Polygon && current_polygon != NULL) current_polygon = NULL;
|
|
||||||
if (behavior == PasteArea) {
|
if (behavior == PasteArea) {
|
||||||
QRectF current_rect(paste_area_ -> rect());
|
QRectF current_rect(paste_area_ -> rect());
|
||||||
current_rect.moveCenter(event_pos);
|
current_rect.moveCenter(event_pos);
|
||||||
@@ -148,8 +138,6 @@ void ElementScene::mouseMoveEvent(QGraphicsSceneMouseEvent *e) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
QRectF temp_rect;
|
QRectF temp_rect;
|
||||||
QPointF temp_point;
|
|
||||||
QPolygonF temp_polygon;
|
|
||||||
if (e -> buttons() & Qt::LeftButton) {
|
if (e -> buttons() & Qt::LeftButton) {
|
||||||
switch(behavior) {
|
switch(behavior) {
|
||||||
case Arc:
|
case Arc:
|
||||||
@@ -157,23 +145,12 @@ void ElementScene::mouseMoveEvent(QGraphicsSceneMouseEvent *e) {
|
|||||||
temp_rect.setBottomRight(event_pos);
|
temp_rect.setBottomRight(event_pos);
|
||||||
current_arc -> setRect(temp_rect);
|
current_arc -> setRect(temp_rect);
|
||||||
break;
|
break;
|
||||||
case Polygon:
|
|
||||||
if (current_polygon == NULL) break;
|
|
||||||
temp_polygon = current_polygon -> polygon();
|
|
||||||
temp_polygon.pop_back();
|
|
||||||
temp_polygon << event_pos;
|
|
||||||
current_polygon -> setPolygon(temp_polygon);
|
|
||||||
break;
|
|
||||||
case Normal:
|
case Normal:
|
||||||
default:
|
default:
|
||||||
QGraphicsScene::mouseMoveEvent(e);
|
QGraphicsScene::mouseMoveEvent(e);
|
||||||
}
|
}
|
||||||
} else if (behavior == Polygon && current_polygon != NULL) {
|
}
|
||||||
temp_polygon = current_polygon -> polygon();
|
else QGraphicsScene::mouseMoveEvent(e);
|
||||||
temp_polygon.pop_back();
|
|
||||||
temp_polygon << event_pos;
|
|
||||||
current_polygon -> setPolygon(temp_polygon);
|
|
||||||
} else QGraphicsScene::mouseMoveEvent(e);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -194,8 +171,6 @@ void ElementScene::mousePressEvent(QGraphicsSceneMouseEvent *e) {
|
|||||||
QPointF event_pos = e -> scenePos();
|
QPointF event_pos = e -> scenePos();
|
||||||
if (mustSnapToGrid(e)) event_pos = snapToGrid(event_pos);
|
if (mustSnapToGrid(e)) event_pos = snapToGrid(event_pos);
|
||||||
|
|
||||||
if (behavior != Polygon && current_polygon != NULL) current_polygon = NULL;
|
|
||||||
QPolygonF temp_polygon;
|
|
||||||
if (e -> button() & Qt::LeftButton) {
|
if (e -> button() & Qt::LeftButton) {
|
||||||
switch(behavior) {
|
switch(behavior) {
|
||||||
case Arc:
|
case Arc:
|
||||||
@@ -203,16 +178,6 @@ void ElementScene::mousePressEvent(QGraphicsSceneMouseEvent *e) {
|
|||||||
current_arc -> setRect(QRectF(event_pos, QSizeF(0.0, 0.0)));
|
current_arc -> setRect(QRectF(event_pos, QSizeF(0.0, 0.0)));
|
||||||
current_arc -> setProperty("antialias", true);
|
current_arc -> setProperty("antialias", true);
|
||||||
break;
|
break;
|
||||||
case Polygon:
|
|
||||||
if (current_polygon == NULL) {
|
|
||||||
current_polygon = new PartPolygon(element_editor, 0, this);
|
|
||||||
temp_polygon = QPolygonF(0);
|
|
||||||
} else temp_polygon = current_polygon -> polygon();
|
|
||||||
// au debut, on insere deux points
|
|
||||||
if (!temp_polygon.count()) temp_polygon << event_pos;
|
|
||||||
temp_polygon << event_pos;
|
|
||||||
current_polygon -> setPolygon(temp_polygon);
|
|
||||||
break;
|
|
||||||
case Normal:
|
case Normal:
|
||||||
default:
|
default:
|
||||||
QGraphicsScene::mousePressEvent(e);
|
QGraphicsScene::mousePressEvent(e);
|
||||||
@@ -242,7 +207,6 @@ void ElementScene::mouseReleaseEvent(QGraphicsSceneMouseEvent *e) {
|
|||||||
PartTerminal *terminal;
|
PartTerminal *terminal;
|
||||||
PartText *text;
|
PartText *text;
|
||||||
PartTextField *textfield;
|
PartTextField *textfield;
|
||||||
if (behavior != Polygon && current_polygon != NULL) current_polygon = NULL;
|
|
||||||
|
|
||||||
if (behavior == PasteArea) {
|
if (behavior == PasteArea) {
|
||||||
defined_paste_area_ = paste_area_ -> rect();
|
defined_paste_area_ = paste_area_ -> rect();
|
||||||
@@ -288,14 +252,23 @@ void ElementScene::mouseReleaseEvent(QGraphicsSceneMouseEvent *e) {
|
|||||||
QGraphicsScene::mouseReleaseEvent(e);
|
QGraphicsScene::mouseReleaseEvent(e);
|
||||||
moving_parts_ = false;
|
moving_parts_ = false;
|
||||||
}
|
}
|
||||||
} else if (e -> button() & Qt::RightButton) {
|
}
|
||||||
if (behavior == Polygon && current_polygon != NULL) {
|
else QGraphicsScene::mouseReleaseEvent(e);
|
||||||
undo_stack.push(new AddPartCommand(tr("polygone"), this, current_polygon));
|
}
|
||||||
current_polygon = NULL;
|
|
||||||
emit(partsAdded());
|
void ElementScene::mouseDoubleClickEvent(QGraphicsSceneMouseEvent *event) {
|
||||||
endCurrentBehavior(e);
|
if (m_event_interface) {
|
||||||
} else QGraphicsScene::mouseReleaseEvent(e);
|
if (m_event_interface -> mouseDoubleClickEvent(event)) {
|
||||||
} else QGraphicsScene::mouseReleaseEvent(e);
|
if (m_event_interface->isFinish()) {
|
||||||
|
emit(partsAdded());
|
||||||
|
emit(needNormalMode());
|
||||||
|
delete m_event_interface; m_event_interface = nullptr;
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
QGraphicsScene::mouseDoubleClickEvent(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -28,7 +28,6 @@ class CustomElementPart;
|
|||||||
class ElementEditionCommand;
|
class ElementEditionCommand;
|
||||||
class ElementPrimitiveDecorator;
|
class ElementPrimitiveDecorator;
|
||||||
class QETElementEditor;
|
class QETElementEditor;
|
||||||
class PartPolygon;
|
|
||||||
class PartArc;
|
class PartArc;
|
||||||
class ESEventInterface;
|
class ESEventInterface;
|
||||||
class QKeyEvent;
|
class QKeyEvent;
|
||||||
@@ -43,7 +42,7 @@ class ElementScene : public QGraphicsScene {
|
|||||||
|
|
||||||
// enum
|
// enum
|
||||||
public:
|
public:
|
||||||
enum Behavior { Normal, Circle, Polygon, Text, Terminal, Arc, TextField, PasteArea };
|
enum Behavior { Normal, Circle, Text, Terminal, Arc, TextField, PasteArea };
|
||||||
enum ItemOption {
|
enum ItemOption {
|
||||||
SortByZValue = 1,
|
SortByZValue = 1,
|
||||||
IncludeTerminals = 2,
|
IncludeTerminals = 2,
|
||||||
@@ -88,7 +87,6 @@ class ElementScene : public QGraphicsScene {
|
|||||||
/// Variables related to drawing
|
/// Variables related to drawing
|
||||||
ESEventInterface *m_event_interface;
|
ESEventInterface *m_event_interface;
|
||||||
Behavior behavior;
|
Behavior behavior;
|
||||||
PartPolygon *current_polygon;
|
|
||||||
PartArc *current_arc;
|
PartArc *current_arc;
|
||||||
QETElementEditor *element_editor;
|
QETElementEditor *element_editor;
|
||||||
|
|
||||||
@@ -141,10 +139,11 @@ class ElementScene : public QGraphicsScene {
|
|||||||
QETElementEditor* editor() const;
|
QETElementEditor* editor() const;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual void mouseMoveEvent (QGraphicsSceneMouseEvent *);
|
virtual void mouseMoveEvent (QGraphicsSceneMouseEvent *);
|
||||||
virtual void mousePressEvent (QGraphicsSceneMouseEvent *);
|
virtual void mousePressEvent (QGraphicsSceneMouseEvent *);
|
||||||
virtual void mouseReleaseEvent (QGraphicsSceneMouseEvent *);
|
virtual void mouseReleaseEvent (QGraphicsSceneMouseEvent *);
|
||||||
virtual void keyPressEvent (QKeyEvent *event);
|
virtual void mouseDoubleClickEvent (QGraphicsSceneMouseEvent *event);
|
||||||
|
virtual void keyPressEvent (QKeyEvent *event);
|
||||||
|
|
||||||
virtual void drawForeground(QPainter *, const QRectF &);
|
virtual void drawForeground(QPainter *, const QRectF &);
|
||||||
virtual void endCurrentBehavior(const QGraphicsSceneMouseEvent *);
|
virtual void endCurrentBehavior(const QGraphicsSceneMouseEvent *);
|
||||||
@@ -165,7 +164,6 @@ class ElementScene : public QGraphicsScene {
|
|||||||
public slots:
|
public slots:
|
||||||
void slot_move();
|
void slot_move();
|
||||||
void slot_addCircle();
|
void slot_addCircle();
|
||||||
void slot_addPolygon();
|
|
||||||
void slot_addText();
|
void slot_addText();
|
||||||
void slot_addArc();
|
void slot_addArc();
|
||||||
void slot_addTerminal();
|
void slot_addTerminal();
|
||||||
|
|||||||
@@ -25,6 +25,10 @@ class ElementScene;
|
|||||||
class PartEllipse;
|
class PartEllipse;
|
||||||
class QGraphicsSceneMouseEvent;
|
class QGraphicsSceneMouseEvent;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief The ESEventAddEllipse class
|
||||||
|
* This ESEvent manage creation of ellpise in an ElementScene
|
||||||
|
*/
|
||||||
class ESEventAddEllipse : public ESEventInterface
|
class ESEventAddEllipse : public ESEventInterface
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|||||||
117
sources/editor/esevent/eseventaddpolygon.cpp
Normal file
117
sources/editor/esevent/eseventaddpolygon.cpp
Normal file
@@ -0,0 +1,117 @@
|
|||||||
|
/*
|
||||||
|
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 <QObject>
|
||||||
|
|
||||||
|
#include "eseventaddpolygon.h"
|
||||||
|
#include "elementscene.h"
|
||||||
|
#include "partpolygon.h"
|
||||||
|
#include "editorcommands.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief ESEventAddPolygon::ESEventAddPolygon
|
||||||
|
* @param scene
|
||||||
|
*/
|
||||||
|
ESEventAddPolygon::ESEventAddPolygon(ElementScene *scene) :
|
||||||
|
ESEventInterface(scene),
|
||||||
|
m_polygon(nullptr)
|
||||||
|
{}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief ESEventAddPolygon::~ESEventAddPolygon
|
||||||
|
*/
|
||||||
|
ESEventAddPolygon::~ESEventAddPolygon() {
|
||||||
|
if (m_running || m_abort)
|
||||||
|
delete m_polygon;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief ESEventAddPolygon::mousePressEvent
|
||||||
|
* @param event
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
bool ESEventAddPolygon::mousePressEvent(QGraphicsSceneMouseEvent *event) {
|
||||||
|
if (event -> button() == Qt::LeftButton) {
|
||||||
|
if(!m_running) m_running = true;
|
||||||
|
QPointF pos = m_scene->snapToGrid(event -> scenePos());
|
||||||
|
|
||||||
|
//create new polygon
|
||||||
|
if (!m_polygon) {
|
||||||
|
m_polygon = new PartPolygon(m_editor, 0, m_scene);
|
||||||
|
m_polygon -> addPoint(pos);
|
||||||
|
}
|
||||||
|
|
||||||
|
m_polygon -> addPoint(pos);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief ESEventAddPolygon::mouseMoveEvent
|
||||||
|
* @param event
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
bool ESEventAddPolygon::mouseMoveEvent(QGraphicsSceneMouseEvent *event) {
|
||||||
|
updateHelpCross(event -> scenePos());
|
||||||
|
if (!m_polygon) return false;
|
||||||
|
|
||||||
|
m_polygon -> setLastPoint(m_scene -> snapToGrid(event -> scenePos()));
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief ESEventAddPolygon::mouseReleaseEvent
|
||||||
|
* @param event
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
bool ESEventAddPolygon::mouseReleaseEvent(QGraphicsSceneMouseEvent *event) {
|
||||||
|
if (event -> button() == Qt::RightButton) {
|
||||||
|
if (m_polygon) {
|
||||||
|
m_polygon -> removeLastPoint();
|
||||||
|
|
||||||
|
if (m_polygon -> polygon().size() > 1)
|
||||||
|
{ m_polygon -> setLastPoint(m_scene -> snapToGrid(event -> scenePos())); }
|
||||||
|
else
|
||||||
|
{ delete m_polygon; m_polygon = nullptr; }
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{ m_running = false; }
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief ESEventAddPolygon::mouseDoubleClickEvent
|
||||||
|
* @param event
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
bool ESEventAddPolygon::mouseDoubleClickEvent(QGraphicsSceneMouseEvent *event) {
|
||||||
|
if (event -> button() == Qt::LeftButton) {
|
||||||
|
if (m_polygon) {
|
||||||
|
m_polygon -> addPoint(m_scene -> snapToGrid(event -> scenePos()));
|
||||||
|
m_scene -> undoStack().push(new AddPartCommand(QObject::tr("Polygone"), m_scene, m_polygon));
|
||||||
|
|
||||||
|
//Set m_polygon to nullptr for create new polygon at next mouse press
|
||||||
|
m_polygon = nullptr;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
46
sources/editor/esevent/eseventaddpolygon.h
Normal file
46
sources/editor/esevent/eseventaddpolygon.h
Normal file
@@ -0,0 +1,46 @@
|
|||||||
|
/*
|
||||||
|
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 ESEVENTADDPOLYGON_H
|
||||||
|
#define ESEVENTADDPOLYGON_H
|
||||||
|
|
||||||
|
#include "eseventinterface.h"
|
||||||
|
|
||||||
|
class ElementScene;
|
||||||
|
class PartPolygon;
|
||||||
|
class QGraphicsSceneMouseEvent;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief The ESEventAddPolygon class
|
||||||
|
* This ESEvent manage creation of polygon in an ElementScene
|
||||||
|
*/
|
||||||
|
class ESEventAddPolygon : public ESEventInterface
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
ESEventAddPolygon(ElementScene *scene);
|
||||||
|
virtual ~ESEventAddPolygon();
|
||||||
|
|
||||||
|
virtual bool mousePressEvent (QGraphicsSceneMouseEvent *event);
|
||||||
|
virtual bool mouseMoveEvent (QGraphicsSceneMouseEvent *event);
|
||||||
|
virtual bool mouseReleaseEvent (QGraphicsSceneMouseEvent *event);
|
||||||
|
virtual bool mouseDoubleClickEvent (QGraphicsSceneMouseEvent *event);
|
||||||
|
|
||||||
|
private:
|
||||||
|
PartPolygon *m_polygon;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // ESEVENTADDPOLYGON_H
|
||||||
@@ -173,6 +173,45 @@ QET::ScalingMethod PartPolygon::preferredScalingMethod() const {
|
|||||||
return(QET::RoundScaleRatios);
|
return(QET::RoundScaleRatios);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief PartPolygon::addPoint
|
||||||
|
* Add new point to polygon
|
||||||
|
* @param point
|
||||||
|
*/
|
||||||
|
void PartPolygon::addPoint(const QPointF &point) {
|
||||||
|
QPolygonF poly = polygon();
|
||||||
|
poly << point;
|
||||||
|
setPolygon(poly);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief PartPolygon::setLastPoint
|
||||||
|
* Set the last point of polygon to @point
|
||||||
|
* @param point
|
||||||
|
*/
|
||||||
|
void PartPolygon::setLastPoint(const QPointF &point) {
|
||||||
|
QPolygonF poly = polygon();
|
||||||
|
|
||||||
|
if (poly.size())
|
||||||
|
poly.pop_back();
|
||||||
|
|
||||||
|
poly << point;
|
||||||
|
setPolygon(poly);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief PartPolygon::removeLastPoint
|
||||||
|
* Remove the last point of polygon
|
||||||
|
*/
|
||||||
|
void PartPolygon::removeLastPoint() {
|
||||||
|
QPolygonF poly = polygon();
|
||||||
|
|
||||||
|
if (poly.size())
|
||||||
|
poly.pop_back();
|
||||||
|
|
||||||
|
setPolygon(poly);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@return le rectangle delimitant cette partie.
|
@return le rectangle delimitant cette partie.
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -58,6 +58,10 @@ class PartPolygon : public CustomElementGraphicPart, public QGraphicsPolygonItem
|
|||||||
virtual void handleUserTransformation(const QRectF &, const QRectF &);
|
virtual void handleUserTransformation(const QRectF &, const QRectF &);
|
||||||
virtual QET::ScalingMethod preferredScalingMethod() const;
|
virtual QET::ScalingMethod preferredScalingMethod() const;
|
||||||
|
|
||||||
|
void addPoint (const QPointF &point);
|
||||||
|
void setLastPoint (const QPointF &point);
|
||||||
|
void removeLastPoint ();
|
||||||
|
|
||||||
///PROPERTY
|
///PROPERTY
|
||||||
// Closed (join the first and last point by a line)
|
// Closed (join the first and last point by a line)
|
||||||
Q_PROPERTY(bool closed READ isClosed WRITE setClosed)
|
Q_PROPERTY(bool closed READ isClosed WRITE setClosed)
|
||||||
|
|||||||
@@ -44,6 +44,7 @@
|
|||||||
#include "eseventaddline.h"
|
#include "eseventaddline.h"
|
||||||
#include "eseventaddrect.h"
|
#include "eseventaddrect.h"
|
||||||
#include "eseventaddellipse.h"
|
#include "eseventaddellipse.h"
|
||||||
|
#include "eseventaddpolygon.h"
|
||||||
|
|
||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
/*
|
/*
|
||||||
@@ -251,7 +252,7 @@ void QETElementEditor::setupActions() {
|
|||||||
connect(add_line, SIGNAL(triggered()), this, SLOT(addLine()));
|
connect(add_line, SIGNAL(triggered()), this, SLOT(addLine()));
|
||||||
connect(add_rectangle, SIGNAL(triggered()), this, SLOT(addRect()));
|
connect(add_rectangle, SIGNAL(triggered()), this, SLOT(addRect()));
|
||||||
connect(add_ellipse, SIGNAL(triggered()), this, SLOT(addEllipse()));
|
connect(add_ellipse, SIGNAL(triggered()), this, SLOT(addEllipse()));
|
||||||
connect(add_polygon, SIGNAL(triggered()), ce_scene, SLOT(slot_addPolygon()));
|
connect(add_polygon, SIGNAL(triggered()), this, SLOT(addPolygon()));
|
||||||
connect(add_text, SIGNAL(triggered()), ce_scene, SLOT(slot_addText()));
|
connect(add_text, SIGNAL(triggered()), ce_scene, SLOT(slot_addText()));
|
||||||
connect(add_arc, SIGNAL(triggered()), ce_scene, SLOT(slot_addArc()));
|
connect(add_arc, SIGNAL(triggered()), ce_scene, SLOT(slot_addArc()));
|
||||||
connect(add_terminal, SIGNAL(triggered()), ce_scene, SLOT(slot_addTerminal()));
|
connect(add_terminal, SIGNAL(triggered()), ce_scene, SLOT(slot_addTerminal()));
|
||||||
@@ -948,6 +949,14 @@ void QETElementEditor::addEllipse() {
|
|||||||
ce_scene -> setEventInterface(new ESEventAddEllipse(ce_scene));
|
ce_scene -> setEventInterface(new ESEventAddEllipse(ce_scene));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief QETElementEditor::addPolygon
|
||||||
|
* Set polygon creation interface to scene
|
||||||
|
*/
|
||||||
|
void QETElementEditor::addPolygon() {
|
||||||
|
ce_scene -> setEventInterface(new ESEventAddPolygon(ce_scene));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Lance l'assistant de creation d'un nouvel element.
|
Lance l'assistant de creation d'un nouvel element.
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -23,8 +23,10 @@
|
|||||||
#include "elementscene.h"
|
#include "elementscene.h"
|
||||||
#include "orientationset.h"
|
#include "orientationset.h"
|
||||||
#include "elementslocation.h"
|
#include "elementslocation.h"
|
||||||
|
|
||||||
class ElementItemEditor;
|
class ElementItemEditor;
|
||||||
class ElementView;
|
class ElementView;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
This class represents an element editor, allowing users to draw, change and
|
This class represents an element editor, allowing users to draw, change and
|
||||||
configure a particular electrical element.
|
configure a particular electrical element.
|
||||||
@@ -129,6 +131,7 @@ class QETElementEditor : public QETMainWindow {
|
|||||||
void addLine();
|
void addLine();
|
||||||
void addRect();
|
void addRect();
|
||||||
void addEllipse();
|
void addEllipse();
|
||||||
|
void addPolygon();
|
||||||
|
|
||||||
void slot_new();
|
void slot_new();
|
||||||
void slot_open();
|
void slot_open();
|
||||||
|
|||||||
Reference in New Issue
Block a user