mirror of
https://github.com/qelectrotech/qelectrotech-source-mirror.git
synced 2025-12-17 12:40:35 +01:00
Basic Shapes: Dynamic Preview added when constructing the shape.
git-svn-id: svn+ssh://svn.tuxfamily.org/svnroot/qet/qet/trunk@2876 bfdf4180-ca20-0410-9c96-a3a8aa849046
This commit is contained in:
@@ -43,7 +43,6 @@
|
||||
#include <QGraphicsPixmapItem>
|
||||
#include <QGraphicsSceneMouseEvent>
|
||||
#include "factory/elementfactory.h"
|
||||
#include "qetgraphicsitem/qetshapeitem.h"
|
||||
|
||||
|
||||
/**
|
||||
@@ -51,7 +50,7 @@
|
||||
@param diagram Schema a afficher ; si diagram vaut 0, un nouveau Diagram est utilise
|
||||
@param parent Le QWidget parent de cette vue de schema
|
||||
*/
|
||||
DiagramView::DiagramView(Diagram *diagram, QWidget *parent) : QGraphicsView(parent) {
|
||||
DiagramView::DiagramView(Diagram *diagram, QWidget *parent) : QGraphicsView(parent), newItem(0){
|
||||
setAttribute(Qt::WA_DeleteOnClose, true);
|
||||
setInteractive(true);
|
||||
current_behavior = noAction;
|
||||
@@ -459,28 +458,19 @@ void DiagramView::mousePressEvent(QMouseEvent *e) {
|
||||
current_behavior = noAction;
|
||||
break;
|
||||
case addingLine:
|
||||
// if (!rubber_band) {
|
||||
rubber_band_origin = mapToScene(e -> pos());
|
||||
// rubber_band = new QRubberBand(QRubberBand::Rectangle, this);
|
||||
//}
|
||||
//rubber_band->setGeometry(QRectF(rubber_band_origin, QSize()).toRect());
|
||||
//rubber_band->show();
|
||||
rubber_band_origin = mapToScene(e -> pos());
|
||||
newItem = new QetShapeItem(rubber_band_origin, rubber_band_origin, QetShapeItem::Line, false);
|
||||
scene -> addItem(newItem);
|
||||
break;
|
||||
case addingRectangle:
|
||||
//if (!rubber_band) {
|
||||
rubber_band_origin = mapToScene(e -> pos());
|
||||
//rubber_band = new QRubberBand(QRubberBand::Rectangle, this);
|
||||
// }
|
||||
//rubber_band->setGeometry(QRectF(rubber_band_origin, QSize()).toRect());
|
||||
//rubber_band->show();
|
||||
rubber_band_origin = mapToScene(e -> pos());
|
||||
newItem = new QetShapeItem(rubber_band_origin, rubber_band_origin, QetShapeItem::Rectangle);
|
||||
scene -> addItem(newItem);
|
||||
break;
|
||||
case addingEllipse:
|
||||
// if (!rubber_band) {
|
||||
rubber_band_origin = mapToScene(e -> pos());
|
||||
// rubber_band = new QRubberBand(QRubberBand::Rectangle, this);
|
||||
//}
|
||||
//rubber_band->setGeometry(QRectF(rubber_band_origin, QSize()).toRect());
|
||||
//rubber_band->show();
|
||||
rubber_band_origin = mapToScene(e -> pos());
|
||||
newItem = new QetShapeItem(rubber_band_origin, rubber_band_origin, QetShapeItem::Ellipse);
|
||||
scene -> addItem(newItem);
|
||||
break;
|
||||
case dragView:
|
||||
current_behavior = noAction;
|
||||
@@ -512,9 +502,15 @@ void DiagramView::mouseMoveEvent(QMouseEvent *e) {
|
||||
center_view_ = mapToScene(this -> viewport() -> rect()).boundingRect().center();
|
||||
return;
|
||||
}
|
||||
/*if ((e -> buttons() & Qt::LeftButton) &&
|
||||
(current_behavior == addingLine || current_behavior == addingRectangle || current_behavior == addingEllipse))
|
||||
rubber_band -> setGeometry(QRectF(rubber_band_origin, mapToScene(e->pos())).normalized().toRect());*/
|
||||
if ((e -> buttons() & Qt::LeftButton) &&
|
||||
(current_behavior == addingLine || current_behavior == addingRectangle || current_behavior == addingEllipse)) {
|
||||
QRectF rec = QRectF(rubber_band_origin, mapToScene(e->pos())).normalized();
|
||||
scene ->removeItem(newItem);
|
||||
newItem -> setBoundingRect(rec);
|
||||
if (current_behavior == addingLine)
|
||||
newItem -> setLineAngle(rubber_band_origin != rec.topLeft() && rubber_band_origin != rec.bottomRight());
|
||||
scene ->addItem(newItem);
|
||||
}
|
||||
QGraphicsView::mouseMoveEvent(e);
|
||||
}
|
||||
|
||||
@@ -528,26 +524,12 @@ void DiagramView::mouseReleaseEvent(QMouseEvent *e) {
|
||||
return;
|
||||
}
|
||||
if (current_behavior == addingLine || current_behavior == addingRectangle || current_behavior == addingEllipse) {
|
||||
QRectF rec = QRectF(rubber_band_origin, mapToScene(e->pos())).normalized();
|
||||
if (current_behavior == addingLine) {
|
||||
QetShapeItem *line;
|
||||
if (rubber_band_origin == rec.topLeft() || rubber_band_origin == rec.bottomRight())
|
||||
line = new QetShapeItem(rec.topLeft(), rec.bottomRight(), QetShapeItem::Line, false);
|
||||
else
|
||||
line = new QetShapeItem(rec.topLeft(), rec.bottomRight(), QetShapeItem::Line, true);
|
||||
scene -> addItem(line);
|
||||
if (current_behavior == addingLine)
|
||||
emit(LineAdded(false));
|
||||
} else if (current_behavior == addingRectangle) {
|
||||
QetShapeItem *rect = new QetShapeItem(rec.topLeft(), rec.bottomRight(), QetShapeItem::Rectangle);
|
||||
scene -> addItem(rect);
|
||||
else if (current_behavior == addingRectangle)
|
||||
emit(RectangleAdded(false));
|
||||
} else { // ellipse
|
||||
QetShapeItem *ellipse = new QetShapeItem(rec.topLeft(), rec.bottomRight(), QetShapeItem::Ellipse);
|
||||
scene -> addItem(ellipse);
|
||||
else // ellipse
|
||||
emit(EllipseAdded(false));
|
||||
}
|
||||
//rubber_band -> hide();
|
||||
//rubber_band = 0;
|
||||
current_behavior = noAction;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user