]> Shamusworld >> Repos - architektonas/blobdiff - src/actions/rs_actionblockscreate.cpp
Major refactoring of actions: Moved implementation from header files
[architektonas] / src / actions / rs_actionblockscreate.cpp
index 77f0126e582366525f8b0c51c4b47566a87a0928..083f2fe4e4588f25b3beea28b6ab8077e880120f 100644 (file)
-/****************************************************************************
-** $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 "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, RS_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 (RS2::qtToRsButtonState(e->button()) == RS2::LeftButton)
+       if (e->button() == Qt::LeftButton)
+       {
+//             Vector ce(snapPoint(e));
+//             coordinateEvent(&ce);
+               Vector ce(snapPoint(e));
+               coordinateEvent(&ce);
+       }
+//     else if (RS2::qtToRsButtonState(e->button()) == RS2::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