-/****************************************************************************
-** $Id: rs_actionblockscreate.cpp 1134 2004-07-13 23:26:13Z andrew $
-**
-** Copyright (C) 2001-2003 RibbonSoft. All rights reserved.
-**
-** This file is part of the qcadlib Library project.
-**
-** This file may be distributed and/or modified under the terms of the
-** GNU General Public License version 2 as published by the Free Software
-** Foundation and appearing in the file LICENSE.GPL included in the
-** packaging of this file.
-**
-** Licensees holding valid qcadlib Professional Edition licenses may use
-** this file in accordance with the qcadlib Commercial License
-** Agreement provided with the Software.
-**
-** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
-** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
-**
-** See http://www.ribbonsoft.com for further details.
-**
-** Contact info@ribbonsoft.com if any conditions of this licensing are
-** not clear to you.
-**
-**********************************************************************/
+// rs_actionblockscreate.cpp
+//
+// Part of the Architektonas Project
+// Originally part of QCad Community Edition by Andrew Mustun
+// Extensively rewritten and refactored by James L. Hammons
+// (C) 2010 Underground Software
+//
+// JLH = James L. Hammons <jlhamm@acm.org>
+//
+// Who When What
+// --- ---------- -----------------------------------------------------------
+// JLH 06/03/2010 Added this text. :-)
+// JLH 06/03/2010 Scrubbed out all occurances of RS_CoordinateEvent
+//
#include "rs_actionblockscreate.h"
#include "rs_creation.h"
+#include "rs_dialogfactory.h"
+#include "graphicview.h"
#include "rs_insert.h"
#include "rs_modification.h"
/**
* Constructor.
*/
-RS_ActionBlocksCreate::RS_ActionBlocksCreate(RS_EntityContainer& container,
- RS_GraphicView& graphicView)
- :RS_PreviewActionInterface("Blocks Create",
- container, graphicView)
+RS_ActionBlocksCreate::RS_ActionBlocksCreate(RS_EntityContainer & container, GraphicView & graphicView): RS_PreviewActionInterface("Blocks Create", container, graphicView)
{
- referencePoint = Vector(false);
+ referencePoint = Vector(false);
}
+RS_ActionBlocksCreate::~RS_ActionBlocksCreate()
+{
+}
-
-RS_ActionBlocksCreate::~RS_ActionBlocksCreate() {}
-
-
-
-QAction* RS_ActionBlocksCreate::createGUIAction(RS2::ActionType /*type*/, QObject* /*parent*/)
+#if 0
+QAction * RS_ActionBlocksCreate::createGUIAction(RS2::ActionType /*type*/, QObject * /*parent*/)
{
- QAction * action = new QAction(tr("&Create Block"), 0);
+ QAction * action = new QAction(tr("&Create Block"), 0);
// QAction* action = new QAction(tr("Create Block"),
// tr("&Create Block"),
// QKeySequence(), NULL);
- action->setStatusTip(tr("Create Block"));
+ action->setStatusTip(tr("Create Block"));
- return action;
+ return action;
}
+#endif
-
-void RS_ActionBlocksCreate::init(int status) {
- RS_PreviewActionInterface::init(status);
-
+/*virtual*/ RS2::ActionType RS_ActionBlocksCreate::rtti()
+{
+ return RS2::ActionBlocksCreate;
}
-
-
-void RS_ActionBlocksCreate::trigger() {
- deleteSnapper();
- //deletePreview();
- //clearPreview();
-
- //RS_Modification m(*container, graphicView);
- //m.paste(data.insertionPoint);
- //std::cout << *RS_Clipboard::instance();
-
- if (graphic!=NULL) {
- RS_BlockList* blockList = graphic->getBlockList();
- if (blockList!=NULL) {
- RS_BlockData d =
- RS_DIALOGFACTORY->requestNewBlockDialog(blockList);
-
- if (!d.name.isEmpty()) {
- RS_Creation creation(container, graphicView);
- creation.createBlock(d, referencePoint, true);
-
- RS_InsertData id(
- d.name,
- referencePoint,
- Vector(1.0,1.0),
- 0.0,
- 1, 1, Vector(0.0,0.0)
- );
- creation.createInsert(id);
- }
- }
- }
-
- graphicView->redraw();
- finish();
- graphicView->killSelectActions();
+void RS_ActionBlocksCreate::init(int status)
+{
+ RS_PreviewActionInterface::init(status);
}
-
-void RS_ActionBlocksCreate::mouseMoveEvent(QMouseEvent* e) {
- snapPoint(e);
-
- switch (getStatus()) {
- case SetReferencePoint:
- //data.insertionPoint = snapPoint(e);
-
- /*if (block!=NULL) {
- deletePreview();
- clearPreview();
- //preview->addAllFrom(*block);
- //preview->move(data.insertionPoint);
- RS_Creation creation(preview, NULL, false);
- creation.createInsert(data);
- drawPreview();
- }*/
- break;
-
- default:
- break;
- }
+void RS_ActionBlocksCreate::trigger()
+{
+ deleteSnapper();
+ //deletePreview();
+ //clearPreview();
+
+ //RS_Modification m(*container, graphicView);
+ //m.paste(data.insertionPoint);
+ //std::cout << *RS_Clipboard::instance();
+
+ if (graphic != NULL)
+ {
+ RS_BlockList * blockList = graphic->getBlockList();
+
+ if (blockList != NULL)
+ {
+ RS_BlockData d = RS_DIALOGFACTORY->requestNewBlockDialog(blockList);
+
+ if (!d.name.isEmpty())
+ {
+ RS_Creation creation(container, graphicView);
+ creation.createBlock(d, referencePoint, true);
+
+ RS_InsertData id(d.name, referencePoint, Vector(1.0, 1.0), 0.0, 1, 1, Vector(0.0, 0.0));
+ creation.createInsert(id);
+ }
+ }
+ }
+
+ graphicView->redraw();
+ finish();
+ graphicView->killSelectActions();
}
-
-
-void RS_ActionBlocksCreate::mouseReleaseEvent(QMouseEvent* e) {
- if (RS2::qtToRsButtonState(e->button())==RS2::LeftButton) {
- RS_CoordinateEvent ce(snapPoint(e));
- coordinateEvent(&ce);
- } else if (RS2::qtToRsButtonState(e->button())==RS2::RightButton) {
- deleteSnapper();
- init(getStatus()-1);
- }
+void RS_ActionBlocksCreate::mouseMoveEvent(QMouseEvent * e)
+{
+ snapPoint(e);
+
+ switch (getStatus())
+ {
+ case SetReferencePoint:
+ //data.insertionPoint = snapPoint(e);
+
+ /*if (block!=NULL) {
+ deletePreview();
+ clearPreview();
+ //preview->addAllFrom(*block);
+ //preview->move(data.insertionPoint);
+ RS_Creation creation(preview, NULL, false);
+ creation.createInsert(data);
+ drawPreview();
+ }*/
+ break;
+
+ default:
+ break;
+ }
}
-
-
-void RS_ActionBlocksCreate::coordinateEvent(RS_CoordinateEvent* e) {
- if (e==NULL) {
- return;
- }
-
- switch (getStatus()) {
- case SetReferencePoint:
- referencePoint = e->getCoordinate();
- trigger();
- break;
-
- default:
- break;
-
- }
+void RS_ActionBlocksCreate::mouseReleaseEvent(QMouseEvent * e)
+{
+// if (e->button() == Qt::LeftButton)
+ if (e->button() == Qt::LeftButton)
+ {
+// Vector ce(snapPoint(e));
+// coordinateEvent(&ce);
+ Vector ce(snapPoint(e));
+ coordinateEvent(&ce);
+ }
+// else if (e->button() == Qt::RightButton)
+ else if (e->button() == Qt::RightButton)
+ {
+ deleteSnapper();
+ init(getStatus() - 1);
+ }
}
-
-
-void RS_ActionBlocksCreate::updateMouseButtonHints() {
- switch (getStatus()) {
- case SetReferencePoint:
- RS_DIALOGFACTORY->updateMouseWidget(tr("Specify reference point"),
- tr("Cancel"));
- break;
- default:
- RS_DIALOGFACTORY->updateMouseWidget("", "");
- break;
- }
+//void RS_ActionBlocksCreate::coordinateEvent(Vector * e)
+void RS_ActionBlocksCreate::coordinateEvent(Vector * e)
+{
+ if (e == NULL)
+ return;
+
+ switch (getStatus())
+ {
+ case SetReferencePoint:
+// referencePoint = e->getCoordinate();
+ referencePoint = *e;
+ trigger();
+ break;
+
+ default:
+ break;
+ }
}
-
-
-void RS_ActionBlocksCreate::updateMouseCursor() {
- graphicView->setMouseCursor(RS2::CadCursor);
+void RS_ActionBlocksCreate::updateMouseButtonHints()
+{
+ switch (getStatus())
+ {
+ case SetReferencePoint:
+ RS_DIALOGFACTORY->updateMouseWidget(tr("Specify reference point"), tr("Cancel"));
+ break;
+
+ default:
+ RS_DIALOGFACTORY->updateMouseWidget("", "");
+ break;
+ }
}
-
-
-void RS_ActionBlocksCreate::updateToolBar() {
- if (!isFinished()) {
- RS_DIALOGFACTORY->requestToolBar(RS2::ToolBarSnap);
- } else {
- RS_DIALOGFACTORY->requestToolBar(RS2::ToolBarMain);
- }
+void RS_ActionBlocksCreate::updateMouseCursor()
+{
+ graphicView->setMouseCursor(RS2::CadCursor);
}
+void RS_ActionBlocksCreate::updateToolBar()
+{
+ if (!isFinished())
+ RS_DIALOGFACTORY->requestToolBar(RS2::ToolBarSnap);
+ else
+ RS_DIALOGFACTORY->requestToolBar(RS2::ToolBarMain);
+}
-// EOF