2014-06-14 16:04:34 +00:00
|
|
|
/*
|
2015-02-20 14:56:22 +00:00
|
|
|
Copyright 2006-2015 The QElectroTech Team
|
2014-06-14 16:04:34 +00:00
|
|
|
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/>.
|
|
|
|
*/
|
2014-02-23 18:55:26 +00:00
|
|
|
#include "qetshapeitem.h"
|
2014-06-14 16:04:34 +00:00
|
|
|
#include "createdxf.h"
|
|
|
|
#include "diagram.h"
|
2014-06-17 09:08:41 +00:00
|
|
|
#include "qet.h"
|
2015-06-21 20:16:41 +00:00
|
|
|
#include "shapegraphicsitempropertieswidget.h"
|
2015-06-23 20:40:05 +00:00
|
|
|
#include "PropertiesEditor/propertieseditordialog.h"
|
2015-07-09 18:33:14 +00:00
|
|
|
#include "QetGraphicsItemModeler/qetgraphicshandlerutility.h"
|
2015-07-12 13:35:40 +00:00
|
|
|
#include "qetshapegeometrycommand.h"
|
2014-06-14 16:04:34 +00:00
|
|
|
|
2015-07-09 18:33:14 +00:00
|
|
|
typedef QetGraphicsHandlerUtility QGHU;
|
2014-06-14 16:04:34 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::QetShapeItem
|
|
|
|
* Constructor of shape item. point 1 and 2 must be in scene coordinate
|
|
|
|
* @param p1 first point
|
|
|
|
* @param p2 second point
|
|
|
|
* @param type type of item (line, rectangle, ellipse)
|
|
|
|
* @param parent parent item
|
|
|
|
*/
|
|
|
|
QetShapeItem::QetShapeItem(QPointF p1, QPointF p2, ShapeType type, QGraphicsItem *parent) :
|
2014-02-23 18:55:26 +00:00
|
|
|
QetGraphicsItem(parent),
|
2014-06-14 16:04:34 +00:00
|
|
|
m_shapeType(type),
|
|
|
|
m_shapeStyle(Qt::DashLine),
|
|
|
|
m_P1 (Diagram::snapToGrid(p1)),
|
2014-11-24 17:36:02 +00:00
|
|
|
m_P2 (Diagram::snapToGrid(p2)),
|
2015-07-09 18:33:14 +00:00
|
|
|
m_hovered(false),
|
2015-07-12 13:35:40 +00:00
|
|
|
m_mouse_grab_handler(false),
|
|
|
|
m_undo_command(nullptr)
|
2014-06-14 16:04:34 +00:00
|
|
|
|
2014-02-23 18:55:26 +00:00
|
|
|
{
|
2014-06-17 09:08:41 +00:00
|
|
|
if (type == Polyline) m_polygon << m_P1 << m_P2;
|
2014-06-14 16:04:34 +00:00
|
|
|
setFlags(QGraphicsItem::ItemIsMovable | QGraphicsItem::ItemIsSelectable);
|
2014-11-24 17:36:02 +00:00
|
|
|
setAcceptHoverEvents(true);
|
2014-02-23 18:55:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
QetShapeItem::~QetShapeItem()
|
2015-07-12 13:35:40 +00:00
|
|
|
{
|
|
|
|
if (m_undo_command) delete m_undo_command;
|
|
|
|
}
|
2014-02-23 18:55:26 +00:00
|
|
|
|
2014-06-14 16:04:34 +00:00
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::setStyle
|
|
|
|
* Set the new style of pen for thi item
|
|
|
|
* @param newStyle
|
|
|
|
*/
|
2014-02-23 18:55:26 +00:00
|
|
|
void QetShapeItem::setStyle(Qt::PenStyle newStyle)
|
|
|
|
{
|
2014-06-14 16:04:34 +00:00
|
|
|
m_shapeStyle = newStyle;
|
2014-05-25 18:33:06 +00:00
|
|
|
update();
|
2015-06-21 20:16:41 +00:00
|
|
|
emit styleChanged();
|
2014-05-25 18:33:06 +00:00
|
|
|
}
|
|
|
|
|
2014-06-14 16:04:34 +00:00
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::setP2
|
2014-06-17 09:08:41 +00:00
|
|
|
* Set the second point of this item.
|
|
|
|
* If this item is a polyline,
|
|
|
|
* the last point of the polyline is replaced by P2.
|
2014-06-14 16:04:34 +00:00
|
|
|
* @param P2
|
|
|
|
*/
|
2015-07-12 13:35:40 +00:00
|
|
|
void QetShapeItem::setP2(const QPointF &P2)
|
|
|
|
{
|
|
|
|
if (m_shapeType == Polyline && m_polygon.last() != P2)
|
|
|
|
{
|
2014-06-17 09:08:41 +00:00
|
|
|
prepareGeometryChange();
|
|
|
|
m_polygon.replace(m_polygon.size()-1, P2);
|
|
|
|
}
|
2015-07-12 13:35:40 +00:00
|
|
|
else if (P2 != m_P2)
|
|
|
|
{
|
2014-06-17 09:08:41 +00:00
|
|
|
prepareGeometryChange();
|
|
|
|
m_P2 = P2;
|
|
|
|
}
|
|
|
|
setTransformOriginPoint(boundingRect().center());
|
|
|
|
}
|
|
|
|
|
2015-07-12 13:35:40 +00:00
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::setLine
|
|
|
|
* Set item geometry to line (only available for line shape)
|
|
|
|
* @param line
|
|
|
|
*/
|
|
|
|
void QetShapeItem::setLine(const QLineF &line)
|
|
|
|
{
|
|
|
|
if (Q_LIKELY(m_shapeType == Line))
|
|
|
|
{
|
|
|
|
prepareGeometryChange();
|
|
|
|
m_P1 = line.p1();
|
|
|
|
m_P2 = line.p2();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-07-09 18:33:14 +00:00
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::setRect
|
|
|
|
* Set this item geometry to rect (only available if shape is a rectangle or an ellipse)
|
|
|
|
* @param rect : new rect
|
|
|
|
* @return : true when shape is rectangle or ellipse, else false
|
|
|
|
*/
|
|
|
|
bool QetShapeItem::setRect(const QRectF &rect)
|
|
|
|
{
|
|
|
|
if (Q_LIKELY(m_shapeType == Rectangle || m_shapeType == Ellipse))
|
|
|
|
{
|
|
|
|
prepareGeometryChange();
|
|
|
|
m_P1 = rect.topLeft();
|
|
|
|
m_P2 = rect.bottomRight();
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::setPolygon
|
|
|
|
* Set this item geometry to polygon (only available if shape is a polyline)
|
|
|
|
* @param polygon : new polygon
|
|
|
|
* @return true if item is polygon, else false
|
|
|
|
*/
|
2015-07-12 13:35:40 +00:00
|
|
|
bool QetShapeItem::setPolygon(const QPolygonF &polygon)
|
2015-07-09 18:33:14 +00:00
|
|
|
{
|
|
|
|
if (Q_UNLIKELY(m_shapeType != Polyline)) return false;
|
|
|
|
prepareGeometryChange();
|
|
|
|
m_polygon = polygon;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2014-12-29 23:18:00 +00:00
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::pointCount
|
|
|
|
* @return the number of point in the polygon
|
|
|
|
*/
|
|
|
|
int QetShapeItem::pointsCount() const
|
|
|
|
{
|
|
|
|
return m_polygon.size();
|
|
|
|
}
|
|
|
|
|
2014-06-17 09:08:41 +00:00
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::setNextPoint
|
|
|
|
* Add a new point to the curent polygon
|
|
|
|
* @param P the new point.
|
|
|
|
*/
|
|
|
|
void QetShapeItem::setNextPoint(QPointF P) {
|
2014-06-14 16:04:34 +00:00
|
|
|
prepareGeometryChange();
|
2014-06-17 09:08:41 +00:00
|
|
|
m_polygon.append(Diagram::snapToGrid(P));
|
2014-06-14 16:04:34 +00:00
|
|
|
setTransformOriginPoint(boundingRect().center());
|
2014-02-28 08:20:00 +00:00
|
|
|
}
|
|
|
|
|
2014-12-29 23:18:00 +00:00
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::removePoints
|
|
|
|
* Number of point to remove on the polygon
|
|
|
|
* If @number is superior to number of polygon points-2,
|
|
|
|
* all points of polygon will be removed except the first two (minimum point for the polygon);
|
|
|
|
*/
|
|
|
|
void QetShapeItem::removePoints(int number)
|
|
|
|
{
|
|
|
|
if (pointsCount() == 2 || number < 1) return;
|
|
|
|
if ((pointsCount()-2) < number)
|
|
|
|
number = pointsCount() - 2;
|
|
|
|
|
|
|
|
int i = 0;
|
|
|
|
do
|
|
|
|
{
|
|
|
|
i++;
|
|
|
|
prepareGeometryChange();
|
|
|
|
m_polygon.pop_back();
|
|
|
|
setTransformOriginPoint(boundingRect().center());
|
|
|
|
|
|
|
|
} while (i < number);
|
|
|
|
}
|
|
|
|
|
2014-06-14 16:04:34 +00:00
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::boundingRect
|
|
|
|
* @return the bounding rect of this item
|
|
|
|
*/
|
|
|
|
QRectF QetShapeItem::boundingRect() const {
|
2014-11-24 17:36:02 +00:00
|
|
|
return shape().boundingRect();
|
2014-02-23 18:55:26 +00:00
|
|
|
}
|
|
|
|
|
2014-06-14 16:04:34 +00:00
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::shape
|
|
|
|
* @return the shape of this item
|
|
|
|
*/
|
2015-07-12 13:35:40 +00:00
|
|
|
QPainterPath QetShapeItem::shape() const
|
|
|
|
{
|
2014-02-27 09:55:54 +00:00
|
|
|
QPainterPath path;
|
|
|
|
|
2015-07-12 13:35:40 +00:00
|
|
|
switch (m_shapeType)
|
|
|
|
{
|
|
|
|
case Line: path.moveTo(m_P1);
|
|
|
|
path.lineTo(m_P2); break;
|
|
|
|
case Rectangle: path.addRect(QRectF(m_P1, m_P2)); break;
|
|
|
|
case Ellipse: path.addEllipse(QRectF(m_P1, m_P2)); break;
|
|
|
|
case Polyline: path.addPolygon(m_polygon); break;
|
|
|
|
default: Q_ASSERT(false); break;
|
2014-02-27 09:55:54 +00:00
|
|
|
}
|
|
|
|
|
2014-11-24 17:36:02 +00:00
|
|
|
QPainterPathStroker pps;
|
|
|
|
pps.setWidth(10);
|
|
|
|
pps.setJoinStyle(Qt::RoundJoin);
|
2015-07-09 18:33:14 +00:00
|
|
|
path = pps.createStroke(path);
|
|
|
|
|
|
|
|
if (isSelected())
|
|
|
|
{
|
|
|
|
QVector <QPointF> vector;
|
|
|
|
|
|
|
|
if (m_shapeType == Line)
|
|
|
|
vector << m_P1 << m_P2;
|
|
|
|
else if (m_shapeType == Rectangle || m_shapeType == Ellipse) {
|
|
|
|
QRectF rect (m_P1, m_P2);
|
|
|
|
vector << rect.topLeft() << rect.topRight() << rect.bottomRight() << rect.bottomLeft();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
vector = m_polygon;
|
|
|
|
|
|
|
|
foreach(QRectF r, QGHU::handlerRect(vector))
|
|
|
|
path.addRect(r);
|
|
|
|
}
|
2014-11-24 17:36:02 +00:00
|
|
|
|
2015-07-09 18:33:14 +00:00
|
|
|
return (path);
|
2014-02-27 09:55:54 +00:00
|
|
|
}
|
|
|
|
|
2014-06-14 16:04:34 +00:00
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::changeGraphicsItem
|
|
|
|
* Change the curent type of this item to newtype
|
|
|
|
* @param newtype
|
|
|
|
*/
|
|
|
|
void QetShapeItem::changeGraphicsItem(const ShapeType &newtype) {
|
|
|
|
if (newtype == m_shapeType) return;
|
|
|
|
prepareGeometryChange();
|
|
|
|
m_shapeType = newtype;
|
2014-06-17 09:08:41 +00:00
|
|
|
setTransformOriginPoint(boundingRect().center());
|
2014-03-07 12:34:47 +00:00
|
|
|
}
|
|
|
|
|
2014-06-14 16:04:34 +00:00
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::paint
|
|
|
|
* Paint this item
|
|
|
|
* @param painter
|
|
|
|
* @param option
|
|
|
|
* @param widget
|
|
|
|
*/
|
|
|
|
void QetShapeItem::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget)
|
2014-03-07 12:34:47 +00:00
|
|
|
{
|
2014-06-14 16:04:34 +00:00
|
|
|
Q_UNUSED(option); Q_UNUSED(widget);
|
2014-03-07 12:34:47 +00:00
|
|
|
|
2014-11-24 17:36:02 +00:00
|
|
|
QPen pen(m_shapeStyle);
|
2014-11-24 17:51:13 +00:00
|
|
|
painter -> setRenderHint(QPainter::Antialiasing, false);
|
2014-11-24 18:00:37 +00:00
|
|
|
pen.setWidthF(1);
|
|
|
|
|
2015-07-09 18:33:14 +00:00
|
|
|
//Draw hovered shadow
|
|
|
|
if (m_hovered)
|
|
|
|
{
|
2014-11-24 17:36:02 +00:00
|
|
|
painter->save();
|
|
|
|
QColor color(Qt::darkBlue);
|
|
|
|
color.setAlpha(25);
|
|
|
|
painter -> setBrush (QBrush (color));
|
|
|
|
painter -> setPen (Qt::NoPen);
|
|
|
|
painter -> drawPath (shape());
|
|
|
|
painter -> restore ();
|
|
|
|
}
|
2015-07-09 18:33:14 +00:00
|
|
|
//Draw red if selected
|
|
|
|
if (isSelected())
|
2014-11-24 17:36:02 +00:00
|
|
|
pen.setColor(Qt::red);
|
2014-10-26 12:38:04 +00:00
|
|
|
|
2014-11-24 17:36:02 +00:00
|
|
|
painter -> setPen(pen);
|
2014-06-15 13:29:30 +00:00
|
|
|
|
2015-07-09 18:33:14 +00:00
|
|
|
//vector use to draw handler if needed
|
|
|
|
QVector <QPointF> point_vector;
|
|
|
|
|
|
|
|
//Draw the shape
|
|
|
|
switch (m_shapeType)
|
|
|
|
{
|
2014-06-14 16:04:34 +00:00
|
|
|
case Line:
|
|
|
|
painter->drawLine(QLineF(m_P1, m_P2));
|
2015-07-09 18:33:14 +00:00
|
|
|
if (isSelected())
|
|
|
|
point_vector << m_P1 << m_P2;
|
2014-06-14 16:04:34 +00:00
|
|
|
break;
|
2015-07-09 18:33:14 +00:00
|
|
|
|
2014-06-14 16:04:34 +00:00
|
|
|
case Rectangle:
|
2014-11-24 17:36:02 +00:00
|
|
|
painter->drawRect(QRectF(m_P1, m_P2));
|
2015-07-09 18:33:14 +00:00
|
|
|
if (isSelected())
|
|
|
|
{
|
|
|
|
QRectF rect (m_P1, m_P2);
|
|
|
|
point_vector << rect.topLeft() << rect.topRight() << rect.bottomRight() << rect.bottomLeft();
|
|
|
|
}
|
2014-06-14 16:04:34 +00:00
|
|
|
break;
|
2015-07-09 18:33:14 +00:00
|
|
|
|
2014-06-14 16:04:34 +00:00
|
|
|
case Ellipse:
|
2014-11-24 17:36:02 +00:00
|
|
|
painter->drawEllipse(QRectF(m_P1, m_P2));
|
2015-07-09 18:33:14 +00:00
|
|
|
if (isSelected())
|
|
|
|
{
|
|
|
|
QRectF rect (m_P1, m_P2);
|
|
|
|
point_vector << rect.topLeft() << rect.topRight() << rect.bottomRight() << rect.bottomLeft();
|
|
|
|
}
|
2014-06-14 16:04:34 +00:00
|
|
|
break;
|
2015-07-09 18:33:14 +00:00
|
|
|
|
2014-06-17 09:08:41 +00:00
|
|
|
case Polyline:
|
2015-07-09 18:33:14 +00:00
|
|
|
{
|
2014-06-17 09:08:41 +00:00
|
|
|
painter->drawPolyline(m_polygon);
|
2015-07-09 18:33:14 +00:00
|
|
|
point_vector = m_polygon;
|
|
|
|
}
|
2014-06-17 09:08:41 +00:00
|
|
|
break;
|
2014-02-28 14:30:59 +00:00
|
|
|
}
|
2015-07-09 18:33:14 +00:00
|
|
|
|
|
|
|
//Draw handler if shape is selected
|
|
|
|
if (isSelected())
|
|
|
|
foreach(QPointF point, point_vector)
|
|
|
|
painter->drawPixmap(QGHU::posForHandler(point), QGHU::pixmapHandler());
|
2014-06-14 16:04:34 +00:00
|
|
|
}
|
2014-02-28 14:30:59 +00:00
|
|
|
|
2014-11-24 17:36:02 +00:00
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::hoverEnterEvent
|
|
|
|
* Handle hover enter event
|
|
|
|
* @param event
|
|
|
|
*/
|
|
|
|
void QetShapeItem::hoverEnterEvent(QGraphicsSceneHoverEvent *event) {
|
|
|
|
Q_UNUSED(event);
|
|
|
|
|
|
|
|
m_hovered = true;
|
|
|
|
update();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::hoverLeaveEvent
|
|
|
|
* Handle hover leave event
|
|
|
|
* @param event
|
|
|
|
*/
|
|
|
|
void QetShapeItem::hoverLeaveEvent(QGraphicsSceneHoverEvent *event) {
|
|
|
|
Q_UNUSED(event);
|
|
|
|
|
|
|
|
m_hovered = false;
|
|
|
|
update();
|
|
|
|
}
|
|
|
|
|
2015-07-09 18:33:14 +00:00
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::mousePressEvent
|
|
|
|
* Handle mouse press event
|
|
|
|
* @param event
|
|
|
|
*/
|
|
|
|
void QetShapeItem::mousePressEvent(QGraphicsSceneMouseEvent *event)
|
|
|
|
{
|
|
|
|
//Shape is selected, we see if user click in a handler
|
|
|
|
if (isSelected())
|
|
|
|
{
|
|
|
|
QVector <QPointF> vector;
|
|
|
|
switch (m_shapeType)
|
|
|
|
{
|
|
|
|
case Line:
|
|
|
|
vector << m_P1 << m_P2;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case Rectangle: {
|
|
|
|
QRectF rect (m_P1, m_P2);
|
|
|
|
vector << rect.topLeft() << rect.topRight() << rect.bottomLeft() << rect.bottomRight();
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case Ellipse: {
|
|
|
|
QRectF rect (m_P1, m_P2);
|
|
|
|
vector << rect.topLeft() << rect.topRight() << rect.bottomLeft() << rect.bottomRight();
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case Polyline:
|
|
|
|
vector = m_polygon;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
m_vector_index = QGHU::pointIsHoverHandler(event->pos(), vector);
|
|
|
|
if (m_vector_index != -1)
|
|
|
|
{
|
|
|
|
//User click on an handler
|
|
|
|
m_mouse_grab_handler = true;
|
2015-07-12 13:35:40 +00:00
|
|
|
|
|
|
|
switch (m_shapeType)
|
|
|
|
{
|
|
|
|
case Line: m_undo_command = new QetShapeGeometryCommand(this, QLineF(m_P1, m_P2)); break;
|
|
|
|
case Rectangle: m_undo_command = new QetShapeGeometryCommand(this, QRectF(m_P1, m_P2)); break;
|
|
|
|
case Ellipse: m_undo_command = new QetShapeGeometryCommand(this, QRectF(m_P1, m_P2)); break;
|
|
|
|
case Polyline: m_undo_command = new QetShapeGeometryCommand(this, m_polygon); break;
|
|
|
|
}
|
2015-07-09 18:33:14 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
QetGraphicsItem::mousePressEvent(event);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::mouseMoveEvent
|
|
|
|
* Handle move event
|
|
|
|
* @param event
|
|
|
|
*/
|
|
|
|
void QetShapeItem::mouseMoveEvent(QGraphicsSceneMouseEvent *event)
|
|
|
|
{
|
|
|
|
if (m_mouse_grab_handler)
|
|
|
|
{
|
|
|
|
QPointF new_pos = event->pos();
|
|
|
|
if (event->modifiers() != Qt::ControlModifier)
|
|
|
|
new_pos = mapFromScene(Diagram::snapToGrid(event->scenePos()));
|
|
|
|
|
|
|
|
switch (m_shapeType)
|
|
|
|
{
|
|
|
|
case Line: {
|
|
|
|
prepareGeometryChange();
|
|
|
|
m_vector_index == 0 ? m_P1 = new_pos : m_P2 = new_pos;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case Rectangle: {
|
|
|
|
QRectF rect(m_P1, m_P2);
|
|
|
|
if (m_vector_index == 0) rect.setTopLeft(new_pos);
|
|
|
|
else if (m_vector_index == 1) rect.setTopRight(new_pos);
|
|
|
|
else if (m_vector_index == 2) rect.setBottomLeft(new_pos);
|
|
|
|
else if (m_vector_index == 3) rect.setBottomRight(new_pos);
|
|
|
|
|
|
|
|
setRect(rect);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case Ellipse: {
|
|
|
|
QRectF rect(m_P1, m_P2);
|
|
|
|
if (m_vector_index == 0) rect.setTopLeft(new_pos);
|
|
|
|
else if (m_vector_index == 1) rect.setTopRight(new_pos);
|
|
|
|
else if (m_vector_index == 2) rect.setBottomLeft(new_pos);
|
|
|
|
else if (m_vector_index == 3) rect.setBottomRight(new_pos);
|
|
|
|
|
|
|
|
setRect(rect);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case Polyline: {
|
|
|
|
prepareGeometryChange();
|
|
|
|
m_polygon.replace(m_vector_index, new_pos);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
} //End switch
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
QetGraphicsItem::mouseMoveEvent(event);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::mouseReleaseEvent
|
|
|
|
* Handle mouse release event
|
|
|
|
* @param event
|
|
|
|
*/
|
|
|
|
void QetShapeItem::mouseReleaseEvent(QGraphicsSceneMouseEvent *event)
|
|
|
|
{
|
2015-07-12 13:35:40 +00:00
|
|
|
if (m_mouse_grab_handler)
|
|
|
|
{
|
|
|
|
m_mouse_grab_handler = false;
|
|
|
|
switch(m_shapeType)
|
|
|
|
{
|
|
|
|
case Line: m_undo_command->setNewLine(QLineF(m_P1, m_P2)); break;
|
|
|
|
case Rectangle: m_undo_command->setNewRect(QRectF(m_P1, m_P2)); break;
|
|
|
|
case Ellipse: m_undo_command->setNewRect(QRectF(m_P1, m_P2)); break;
|
|
|
|
case Polyline : m_undo_command->setNewPolygon(m_polygon); break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (diagram())
|
|
|
|
{
|
|
|
|
diagram()->undoStack().push(m_undo_command);
|
|
|
|
m_undo_command = nullptr;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
delete m_undo_command;
|
|
|
|
}
|
|
|
|
|
2015-07-09 18:33:14 +00:00
|
|
|
QetGraphicsItem::mouseReleaseEvent(event);
|
|
|
|
}
|
|
|
|
|
2014-06-14 16:04:34 +00:00
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::fromXml
|
|
|
|
* Build this item from the xml description
|
|
|
|
* @param e element where is stored this item
|
|
|
|
* @return true if load success
|
|
|
|
*/
|
|
|
|
bool QetShapeItem::fromXml(const QDomElement &e) {
|
|
|
|
if (e.tagName() != "shape") return (false);
|
|
|
|
|
2014-11-13 11:21:06 +00:00
|
|
|
is_movable_ = (e.attribute("is_movable").toInt());
|
2014-06-14 16:04:34 +00:00
|
|
|
m_shapeStyle = Qt::PenStyle(e.attribute("style","0").toInt());
|
2014-06-17 09:08:41 +00:00
|
|
|
|
|
|
|
if (e.attribute("type", "0").toInt() != Polyline) {
|
|
|
|
m_P1.setX(e.attribute("x1", 0).toDouble());
|
|
|
|
m_P1.setY(e.attribute("y1", 0).toDouble());
|
|
|
|
m_P2.setX(e.attribute("x2", 0).toDouble());
|
|
|
|
m_P2.setY(e.attribute("y2", 0).toDouble());
|
|
|
|
}
|
|
|
|
|
|
|
|
else {
|
|
|
|
foreach(QDomElement de, QET::findInDomElement(e, "points", "point")) {
|
|
|
|
m_polygon << QPointF(de.attribute("x", 0).toDouble(), de.attribute("y", 0).toDouble());
|
|
|
|
}
|
|
|
|
}
|
2014-06-14 16:04:34 +00:00
|
|
|
|
|
|
|
changeGraphicsItem(QetShapeItem::ShapeType(e.attribute("type","0").toInt()));
|
2014-02-28 14:30:59 +00:00
|
|
|
return (true);
|
|
|
|
}
|
|
|
|
|
2014-06-14 16:04:34 +00:00
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::toXml
|
|
|
|
* Save this item to xml element
|
|
|
|
* @param document parent document xml
|
|
|
|
* @return element xml where is write this item
|
|
|
|
*/
|
2014-02-28 14:30:59 +00:00
|
|
|
QDomElement QetShapeItem::toXml(QDomDocument &document) const {
|
|
|
|
QDomElement result = document.createElement("shape");
|
|
|
|
|
|
|
|
//write some attribute
|
2014-06-14 16:04:34 +00:00
|
|
|
result.setAttribute("type", QString::number(m_shapeType));
|
|
|
|
result.setAttribute("style", QString::number(m_shapeStyle));
|
2014-11-13 11:04:34 +00:00
|
|
|
result.setAttribute("is_movable", bool(is_movable_));
|
2014-06-17 09:08:41 +00:00
|
|
|
if (m_shapeType != Polyline) {
|
|
|
|
result.setAttribute("x1", mapToScene(m_P1).x());
|
|
|
|
result.setAttribute("y1", mapToScene(m_P1).y());
|
|
|
|
result.setAttribute("x2", mapToScene(m_P2).x());
|
|
|
|
result.setAttribute("y2", mapToScene(m_P2).y());
|
|
|
|
}
|
|
|
|
|
|
|
|
else {
|
|
|
|
QDomElement points = document.createElement("points");
|
|
|
|
foreach(QPointF p, m_polygon) {
|
|
|
|
QDomElement point = document.createElement("point");
|
|
|
|
QPointF pf = mapToScene(p);
|
|
|
|
point.setAttribute("x", pf.x());
|
|
|
|
point.setAttribute("y", pf.y());
|
|
|
|
points.appendChild(point);
|
|
|
|
}
|
|
|
|
result.appendChild(points);
|
|
|
|
}
|
2014-02-28 14:30:59 +00:00
|
|
|
|
|
|
|
return(result);
|
|
|
|
}
|
2014-03-07 08:05:25 +00:00
|
|
|
|
2014-06-14 16:04:34 +00:00
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::toDXF
|
|
|
|
* Draw this element to the dxf document
|
|
|
|
* @param filepath file path of the the dxf document
|
|
|
|
* @return true if draw success
|
|
|
|
*/
|
|
|
|
bool QetShapeItem::toDXF(const QString &filepath) {
|
|
|
|
switch (m_shapeType) {
|
|
|
|
case Line:
|
|
|
|
Createdxf::drawLine(filepath, QLineF(mapToScene(m_P1), mapToScene(m_P2)), 0);
|
|
|
|
return true;
|
|
|
|
break;
|
|
|
|
case Rectangle:
|
|
|
|
Createdxf::drawRectangle(filepath, QRectF(mapToScene(m_P1), mapToScene(m_P2)).normalized(), 0);
|
|
|
|
return true;
|
|
|
|
break;
|
|
|
|
case Ellipse:
|
|
|
|
Createdxf::drawEllipse(filepath, QRectF(mapToScene(m_P1), mapToScene(m_P2)).normalized(), 0);
|
|
|
|
return true;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
return false;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::editProperty
|
|
|
|
* Edit the property of this item
|
|
|
|
*/
|
2014-03-07 08:05:25 +00:00
|
|
|
void QetShapeItem::editProperty()
|
|
|
|
{
|
|
|
|
if (diagram() -> isReadOnly()) return;
|
|
|
|
|
2015-06-23 20:40:05 +00:00
|
|
|
PropertiesEditorDialog ped(new ShapeGraphicsItemPropertiesWidget(this), diagram()->views().at(0));
|
|
|
|
ped.exec();
|
2014-03-07 08:05:25 +00:00
|
|
|
}
|
2014-10-11 17:45:11 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief QetShapeItem::name
|
|
|
|
* @return the name of the curent shape.
|
|
|
|
*/
|
2015-07-09 18:33:14 +00:00
|
|
|
QString QetShapeItem::name() const
|
|
|
|
{
|
|
|
|
switch (m_shapeType)
|
|
|
|
{
|
|
|
|
case Line: return tr("une ligne"); break;
|
|
|
|
case Rectangle: return tr("un rectangle"); break;
|
|
|
|
case Ellipse: return tr("une éllipse"); break;
|
|
|
|
case Polyline: return tr("une polyligne"); break;
|
|
|
|
default: return tr("une shape"); break;
|
2014-10-11 17:45:11 +00:00
|
|
|
}
|
|
|
|
}
|