2012-08-09 13:58:02 +06:00
|
|
|
// Copyright (C) 2007-2012 CEA/DEN, EDF R&D, OPEN CASCADE
|
2008-03-07 12:45:34 +05:00
|
|
|
//
|
2012-08-09 13:58:02 +06:00
|
|
|
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
|
|
|
|
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
|
2008-03-07 12:45:34 +05:00
|
|
|
//
|
2012-08-09 13:58:02 +06:00
|
|
|
// This library is free software; you can redistribute it and/or
|
|
|
|
// modify it under the terms of the GNU Lesser General Public
|
|
|
|
// License as published by the Free Software Foundation; either
|
|
|
|
// version 2.1 of the License.
|
2005-12-05 21:23:52 +05:00
|
|
|
//
|
2012-08-09 13:58:02 +06:00
|
|
|
// This library 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
|
|
|
|
// Lesser General Public License for more details.
|
2005-12-05 21:23:52 +05:00
|
|
|
//
|
2012-08-09 13:58:02 +06:00
|
|
|
// You should have received a copy of the GNU Lesser General Public
|
|
|
|
// License along with this library; if not, write to the Free Software
|
|
|
|
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
2009-02-13 17:16:39 +05:00
|
|
|
//
|
2012-08-09 13:58:02 +06:00
|
|
|
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
2005-12-05 21:23:52 +05:00
|
|
|
//
|
2012-08-09 13:58:02 +06:00
|
|
|
|
2005-08-11 10:43:57 +06:00
|
|
|
#include <Standard_Stream.hxx>
|
2004-12-01 15:39:14 +05:00
|
|
|
|
2005-08-11 10:43:57 +06:00
|
|
|
#include <GEOMImpl_ITransformOperations.hxx>
|
2004-12-01 15:39:14 +05:00
|
|
|
|
2005-08-11 10:43:57 +06:00
|
|
|
#include <GEOMImpl_TranslateDriver.hxx>
|
|
|
|
#include <GEOMImpl_MirrorDriver.hxx>
|
2012-08-09 13:58:02 +06:00
|
|
|
#include <GEOMImpl_ProjectionDriver.hxx>
|
2005-08-11 10:43:57 +06:00
|
|
|
#include <GEOMImpl_OffsetDriver.hxx>
|
|
|
|
#include <GEOMImpl_ScaleDriver.hxx>
|
|
|
|
#include <GEOMImpl_RotateDriver.hxx>
|
|
|
|
#include <GEOMImpl_PositionDriver.hxx>
|
2004-12-01 15:39:14 +05:00
|
|
|
|
2005-08-11 10:43:57 +06:00
|
|
|
#include <GEOMImpl_ITranslate.hxx>
|
|
|
|
#include <GEOMImpl_IMirror.hxx>
|
|
|
|
#include <GEOMImpl_IOffset.hxx>
|
|
|
|
#include <GEOMImpl_IScale.hxx>
|
|
|
|
#include <GEOMImpl_IRotate.hxx>
|
|
|
|
#include <GEOMImpl_IPosition.hxx>
|
2004-12-01 15:39:14 +05:00
|
|
|
|
2005-08-11 10:43:57 +06:00
|
|
|
#include <GEOMImpl_Types.hxx>
|
2004-12-01 15:39:14 +05:00
|
|
|
|
2012-08-09 13:58:02 +06:00
|
|
|
#include <GEOM_Function.hxx>
|
|
|
|
#include <GEOM_PythonDump.hxx>
|
|
|
|
|
|
|
|
#include <Basics_OCCTVersion.hxx>
|
|
|
|
|
|
|
|
#include "utilities.h"
|
|
|
|
#include <OpUtil.hxx>
|
|
|
|
#include <Utils_ExceptHandlers.hxx>
|
|
|
|
|
|
|
|
#include <TFunction_DriverTable.hxx>
|
|
|
|
#include <TFunction_Driver.hxx>
|
|
|
|
#include <TFunction_Logbook.hxx>
|
|
|
|
#include <TDF_Tool.hxx>
|
|
|
|
|
|
|
|
#include <BRep_Tool.hxx>
|
|
|
|
#include <BRep_Builder.hxx>
|
|
|
|
#include <TopExp.hxx>
|
|
|
|
#include <TopoDS.hxx>
|
|
|
|
#include <TopoDS_Edge.hxx>
|
|
|
|
#include <TopoDS_Vertex.hxx>
|
|
|
|
#include <TopoDS_Compound.hxx>
|
|
|
|
#include <gp_Pnt.hxx>
|
|
|
|
#include <gp_Vec.hxx>
|
|
|
|
#include <gp_Trsf.hxx>
|
|
|
|
|
|
|
|
#include <StdFail_NotDone.hxx>
|
2008-03-07 12:45:34 +05:00
|
|
|
#include <Standard_Failure.hxx>
|
2004-12-01 15:39:14 +05:00
|
|
|
#include <Standard_ErrorHandler.hxx> // CAREFUL ! position of this file is critic : see Lucien PIGNOLONI / OCC
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* constructor:
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
|
|
|
|
GEOMImpl_ITransformOperations::GEOMImpl_ITransformOperations (GEOM_Engine* theEngine, int theDocID)
|
|
|
|
: GEOM_IOperations(theEngine, theDocID)
|
|
|
|
{
|
|
|
|
MESSAGE("GEOMImpl_ITransformOperations::GEOMImpl_ITransformOperations");
|
|
|
|
}
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* destructor
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
|
|
|
|
GEOMImpl_ITransformOperations::~GEOMImpl_ITransformOperations()
|
|
|
|
{
|
|
|
|
MESSAGE("GEOMImpl_ITransformOperations::~GEOMImpl_ITransformOperations");
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* TranslateTwoPoints
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::TranslateTwoPoints
|
|
|
|
(Handle(GEOM_Object) theObject, Handle(GEOM_Object) thePoint1, Handle(GEOM_Object) thePoint2)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull() || thePoint1.IsNull() || thePoint2.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aFunction, aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be moved
|
|
|
|
|
|
|
|
// Get last functions of the arguments
|
|
|
|
Handle(GEOM_Function) aP1F = thePoint1->GetLastFunction();
|
|
|
|
Handle(GEOM_Function) aP2F = thePoint2->GetLastFunction();
|
|
|
|
|
|
|
|
//Add a translate function
|
|
|
|
aFunction = theObject->AddFunction(GEOMImpl_TranslateDriver::GetID(), TRANSLATE_TWO_POINTS);
|
|
|
|
|
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_TranslateDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_ITranslate aTI (aFunction);
|
|
|
|
aTI.SetPoint1(aP1F);
|
|
|
|
aTI.SetPoint2(aP2F);
|
|
|
|
aTI.SetOriginal(aLastFunction);
|
|
|
|
|
|
|
|
//Compute the translation
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Translation driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << "geompy.TrsfOp.TranslateTwoPoints("
|
|
|
|
<< theObject << ", " << thePoint1 << ", " << thePoint2 << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return theObject;
|
|
|
|
}
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* TranslateDXDYDZ
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::TranslateDXDYDZ
|
|
|
|
(Handle(GEOM_Object) theObject, double theX, double theY, double theZ)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aFunction, aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be moved
|
|
|
|
|
|
|
|
//Add a translate function
|
|
|
|
aFunction = theObject->AddFunction(GEOMImpl_TranslateDriver::GetID(), TRANSLATE_XYZ);
|
|
|
|
|
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_TranslateDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_ITranslate aTI(aFunction);
|
|
|
|
aTI.SetDX(theX);
|
|
|
|
aTI.SetDY(theY);
|
|
|
|
aTI.SetDZ(theZ);
|
|
|
|
aTI.SetOriginal(aLastFunction);
|
|
|
|
|
|
|
|
//Compute the translation
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Translation driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2009-02-13 17:16:39 +05:00
|
|
|
GEOM::TPythonDump(aFunction) << "geompy.TranslateDXDYDZ("
|
2005-06-02 13:17:09 +06:00
|
|
|
<< theObject << ", " << theX << ", " << theY << ", " << theZ << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return theObject;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* TranslateTwoPointsCopy
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::TranslateTwoPointsCopy
|
|
|
|
(Handle(GEOM_Object) theObject, Handle(GEOM_Object) thePoint1, Handle(GEOM_Object) thePoint2)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull() || thePoint1.IsNull() || thePoint2.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be moved
|
|
|
|
|
|
|
|
//Add a new Copy object
|
|
|
|
Handle(GEOM_Object) aCopy = GetEngine()->AddObject(GetDocID(), theObject->GetType());
|
|
|
|
|
|
|
|
//Add a translate function
|
|
|
|
Handle(GEOM_Function) aFunction =
|
|
|
|
aCopy->AddFunction(GEOMImpl_TranslateDriver::GetID(), TRANSLATE_TWO_POINTS_COPY);
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_TranslateDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_ITranslate aTI(aFunction);
|
|
|
|
aTI.SetPoint1(thePoint1->GetLastFunction());
|
|
|
|
aTI.SetPoint2(thePoint2->GetLastFunction());
|
|
|
|
//aTI.SetShape(theObject->GetValue());
|
|
|
|
aTI.SetOriginal(aLastFunction);
|
|
|
|
|
|
|
|
//Compute the translation
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Translation driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << aCopy << " = geompy.MakeTranslationTwoPoints("
|
|
|
|
<< theObject << ", " << thePoint1 << ", " << thePoint2 << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return aCopy;
|
|
|
|
}
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* TranslateDXDYDZCopy
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::TranslateDXDYDZCopy
|
|
|
|
(Handle(GEOM_Object) theObject, double theX, double theY, double theZ)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be moved
|
|
|
|
|
|
|
|
//Add a new Copy object
|
|
|
|
Handle(GEOM_Object) aCopy = GetEngine()->AddObject(GetDocID(), theObject->GetType());
|
|
|
|
|
|
|
|
//Add a translate function
|
|
|
|
Handle(GEOM_Function) aFunction =
|
|
|
|
aCopy->AddFunction(GEOMImpl_TranslateDriver::GetID(), TRANSLATE_XYZ_COPY);
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_TranslateDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_ITranslate aTI(aFunction);
|
|
|
|
aTI.SetDX(theX);
|
|
|
|
aTI.SetDY(theY);
|
|
|
|
aTI.SetDZ(theZ);
|
|
|
|
aTI.SetOriginal(aLastFunction);
|
|
|
|
|
|
|
|
//Compute the translation
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Translation driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << aCopy << " = geompy.MakeTranslation("
|
|
|
|
<< theObject << ", " << theX << ", " << theY << ", " << theZ << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return aCopy;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* TranslateVector
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::TranslateVector
|
|
|
|
(Handle(GEOM_Object) theObject, Handle(GEOM_Object) theVector)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull() || theVector.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aFunction, aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be moved
|
|
|
|
|
|
|
|
// Get last functions of the arguments
|
|
|
|
Handle(GEOM_Function) aVF = theVector->GetLastFunction();
|
|
|
|
|
|
|
|
//Add a translate function
|
|
|
|
aFunction = theObject->AddFunction(GEOMImpl_TranslateDriver::GetID(), TRANSLATE_VECTOR);
|
|
|
|
|
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_TranslateDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_ITranslate aTI (aFunction);
|
|
|
|
aTI.SetVector(aVF);
|
|
|
|
aTI.SetOriginal(aLastFunction);
|
|
|
|
|
|
|
|
//Compute the translation
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Translation driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << "geompy.TrsfOp.TranslateVector("
|
|
|
|
<< theObject << ", " << theVector << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return theObject;
|
|
|
|
}
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* TranslateVectorCopy
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::TranslateVectorCopy
|
|
|
|
(Handle(GEOM_Object) theObject, Handle(GEOM_Object) theVector)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull() || theVector.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be moved
|
|
|
|
|
|
|
|
//Add a new Copy object
|
|
|
|
Handle(GEOM_Object) aCopy = GetEngine()->AddObject(GetDocID(), theObject->GetType());
|
|
|
|
|
|
|
|
//Add a translate function
|
|
|
|
Handle(GEOM_Function) aFunction =
|
|
|
|
aCopy->AddFunction(GEOMImpl_TranslateDriver::GetID(), TRANSLATE_VECTOR_COPY);
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_TranslateDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_ITranslate aTI(aFunction);
|
|
|
|
aTI.SetVector(theVector->GetLastFunction());
|
|
|
|
// aTI.SetShape(theObject->GetValue());
|
|
|
|
aTI.SetOriginal(aLastFunction);
|
|
|
|
|
|
|
|
//Compute the translation
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Translation driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << aCopy << " = geompy.MakeTranslationVector("
|
|
|
|
<< theObject << ", " << theVector << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return aCopy;
|
|
|
|
}
|
|
|
|
|
2009-02-13 17:16:39 +05:00
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* TranslateVectorDistance
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::TranslateVectorDistance
|
|
|
|
(Handle(GEOM_Object) theObject, Handle(GEOM_Object) theVector, double theDistance, bool theCopy)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull() || theVector.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be moved
|
|
|
|
|
|
|
|
Handle(GEOM_Object) aCopy; //Add a new Copy object
|
|
|
|
Handle(GEOM_Function) aFunction;
|
|
|
|
|
|
|
|
//Add a translate function
|
|
|
|
if (theCopy) {
|
|
|
|
aCopy = GetEngine()->AddObject(GetDocID(), theObject->GetType());
|
|
|
|
aFunction = aCopy->AddFunction(GEOMImpl_TranslateDriver::GetID(), TRANSLATE_VECTOR_DISTANCE);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
aFunction = theObject->AddFunction(GEOMImpl_TranslateDriver::GetID(), TRANSLATE_VECTOR_DISTANCE);
|
|
|
|
}
|
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_TranslateDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_ITranslate aTI(aFunction);
|
|
|
|
aTI.SetVector(theVector->GetLastFunction());
|
|
|
|
aTI.SetDistance(theDistance);
|
|
|
|
// aTI.SetShape(theObject->GetValue());
|
|
|
|
aTI.SetOriginal(aLastFunction);
|
|
|
|
|
|
|
|
//Compute the translation
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2009-02-13 17:16:39 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Translation driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
|
|
|
if (theCopy) {
|
|
|
|
GEOM::TPythonDump(aFunction) << aCopy << " = geompy.MakeTranslationVectorDistance("
|
2012-08-09 13:58:02 +06:00
|
|
|
<< theObject << ", " << theVector << ", " << theDistance << ")";
|
2009-02-13 17:16:39 +05:00
|
|
|
SetErrorCode(OK);
|
|
|
|
return aCopy;
|
|
|
|
}
|
|
|
|
|
|
|
|
GEOM::TPythonDump(aFunction) << "geompy.TranslateVectorDistance("
|
2012-08-09 13:58:02 +06:00
|
|
|
<< theObject << ", " << theVector << ", " << theDistance << ", " << theCopy << ")";
|
2009-02-13 17:16:39 +05:00
|
|
|
SetErrorCode(OK);
|
|
|
|
return theObject;
|
|
|
|
}
|
|
|
|
|
2004-12-01 15:39:14 +05:00
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* Translate1D
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::Translate1D
|
|
|
|
(Handle(GEOM_Object) theObject, Handle(GEOM_Object) theVector,
|
|
|
|
double theStep, Standard_Integer theNbTimes)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull() || theVector.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be moved
|
|
|
|
|
|
|
|
//Add a new Copy object
|
|
|
|
Handle(GEOM_Object) aCopy = GetEngine()->AddObject(GetDocID(), theObject->GetType());
|
|
|
|
|
|
|
|
//Add a translate function
|
|
|
|
Handle(GEOM_Function) aFunction =
|
|
|
|
aCopy->AddFunction(GEOMImpl_TranslateDriver::GetID(), TRANSLATE_1D);
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_TranslateDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_ITranslate aTI(aFunction);
|
|
|
|
aTI.SetVector(theVector->GetLastFunction());
|
|
|
|
aTI.SetOriginal(aLastFunction);
|
|
|
|
aTI.SetStep1(theStep);
|
|
|
|
aTI.SetNbIter1(theNbTimes);
|
|
|
|
|
|
|
|
//Compute the translation
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Translation driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << aCopy << " = geompy.MakeMultiTranslation1D("
|
|
|
|
<< theObject << ", " << theVector << ", " << theStep << ", " << theNbTimes << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return aCopy;
|
|
|
|
}
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* Translate2D
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::Translate2D (Handle(GEOM_Object) theObject,
|
2012-08-09 13:58:02 +06:00
|
|
|
Handle(GEOM_Object) theVector,
|
|
|
|
double theStep1,
|
|
|
|
Standard_Integer theNbTimes1,
|
|
|
|
Handle(GEOM_Object) theVector2,
|
|
|
|
double theStep2,
|
|
|
|
Standard_Integer theNbTimes2)
|
2004-12-01 15:39:14 +05:00
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull() || theVector.IsNull() || theVector2.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be moved
|
|
|
|
|
|
|
|
//Add a new Copy object
|
|
|
|
Handle(GEOM_Object) aCopy = GetEngine()->AddObject(GetDocID(), theObject->GetType());
|
|
|
|
|
|
|
|
//Add a translate function
|
|
|
|
Handle(GEOM_Function) aFunction =
|
|
|
|
aCopy->AddFunction(GEOMImpl_TranslateDriver::GetID(), TRANSLATE_2D);
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_TranslateDriver::GetID()) return NULL;
|
|
|
|
|
2012-08-09 13:58:02 +06:00
|
|
|
GEOMImpl_ITranslate aTI (aFunction);
|
2004-12-01 15:39:14 +05:00
|
|
|
aTI.SetVector(theVector->GetLastFunction());
|
|
|
|
aTI.SetVector2(theVector2->GetLastFunction());
|
|
|
|
aTI.SetOriginal(aLastFunction);
|
|
|
|
aTI.SetStep1(theStep1);
|
|
|
|
aTI.SetNbIter1(theNbTimes1);
|
|
|
|
aTI.SetStep2(theStep2);
|
|
|
|
aTI.SetNbIter2(theNbTimes2);
|
|
|
|
|
|
|
|
//Compute the translation
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Translation driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << aCopy << " = geompy.MakeMultiTranslation2D("
|
|
|
|
<< theObject << ", " << theVector << ", " << theStep1 << ", " << theNbTimes1
|
|
|
|
<< ", " << theVector2 << ", " << theStep2 << ", " << theNbTimes2 << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return aCopy;
|
|
|
|
}
|
|
|
|
|
2012-08-09 13:58:02 +06:00
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* TranslateShape1D
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
/*
|
|
|
|
TopoDS_Shape GEOMImpl_ITransformOperations::TranslateShape1D (const TopoDS_Shape& theShape,
|
|
|
|
GEOMImpl_ITranslate* theTI)
|
|
|
|
{
|
|
|
|
TopoDS_Shape aRes;
|
|
|
|
|
|
|
|
// Vector
|
|
|
|
Handle(GEOM_Function) aVector = theTI->GetVector();
|
|
|
|
if (aVector.IsNull()) {
|
|
|
|
StdFail_NotDone::Raise("Invalid object is given for vector argument");
|
|
|
|
}
|
|
|
|
TopoDS_Shape aV = aVector->GetValue();
|
|
|
|
if (aV.IsNull() || aV.ShapeType() != TopAbs_EDGE) {
|
|
|
|
StdFail_NotDone::Raise("Invalid object is given for vector argument");
|
|
|
|
}
|
|
|
|
TopoDS_Edge anEdge = TopoDS::Edge(aV);
|
|
|
|
|
|
|
|
gp_Pnt aP1 = BRep_Tool::Pnt(TopExp::FirstVertex(anEdge));
|
|
|
|
gp_Pnt aP2 = BRep_Tool::Pnt(TopExp::LastVertex(anEdge));
|
|
|
|
if (aP1.Distance(aP2) < gp::Resolution()) {
|
|
|
|
StdFail_NotDone::Raise("Invalid object is given for vector argument");
|
|
|
|
}
|
|
|
|
|
|
|
|
// Step and Nb.times
|
|
|
|
Standard_Real step = theTI->GetStep1();
|
|
|
|
Standard_Integer nbtimes = theTI->GetNbIter1();
|
|
|
|
|
|
|
|
// Make multi-translation
|
|
|
|
gp_Trsf aTrsf;
|
|
|
|
gp_Vec aVec;
|
|
|
|
TopoDS_Compound aCompound;
|
|
|
|
BRep_Builder B;
|
|
|
|
B.MakeCompound(aCompound);
|
|
|
|
|
|
|
|
gp_Vec Vec (aP1, aP2);
|
|
|
|
Vec.Normalize();
|
|
|
|
|
|
|
|
TopLoc_Location aLocOrig = theShape.Location();
|
|
|
|
gp_Trsf aTrsfOrig = aLocOrig.Transformation();
|
|
|
|
|
|
|
|
for (int i = 0; i < nbtimes; i++) {
|
|
|
|
aVec = Vec * (i * step);
|
|
|
|
aTrsf.SetTranslation(aVec);
|
|
|
|
//NPAL18620: performance problem: multiple locations are accumulated
|
|
|
|
// in shape and need a great time to process
|
|
|
|
//BRepBuilderAPI_Transform aTransformation(theShape, aTrsf, Standard_False);
|
|
|
|
//B.Add(aCompound, aTransformation.Shape());
|
|
|
|
TopLoc_Location aLocRes (aTrsf * aTrsfOrig);
|
|
|
|
B.Add(aCompound, theShape.Located(aLocRes));
|
|
|
|
}
|
|
|
|
aRes = aCompound;
|
|
|
|
|
|
|
|
return aRes;
|
|
|
|
}
|
|
|
|
*/
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* TranslateShape2D
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
/*
|
|
|
|
TopoDS_Shape GEOMImpl_ITransformOperations::TranslateShape2D (const TopoDS_Shape& theShape,
|
|
|
|
GEOMImpl_ITranslate* theTI)
|
|
|
|
{
|
|
|
|
TopoDS_Shape aRes;
|
|
|
|
|
|
|
|
// Vectors
|
|
|
|
Handle(GEOM_Function) aVector1 = theTI->GetVector();
|
|
|
|
Handle(GEOM_Function) aVector2 = theTI->GetVector2();
|
|
|
|
|
|
|
|
if (aVector1.IsNull() || aVector2.IsNull()) {
|
|
|
|
StdFail_NotDone::Raise("Invalid object is given for vector argument");
|
|
|
|
}
|
|
|
|
|
|
|
|
TopoDS_Shape aV1 = aVector1->GetValue();
|
|
|
|
TopoDS_Shape aV2 = aVector2->GetValue();
|
|
|
|
|
|
|
|
if (aV1.IsNull() || aV1.ShapeType() != TopAbs_EDGE ||
|
|
|
|
aV2.IsNull() || aV2.ShapeType() != TopAbs_EDGE) {
|
|
|
|
StdFail_NotDone::Raise("Invalid object is given for vector argument");
|
|
|
|
}
|
|
|
|
|
|
|
|
TopoDS_Edge anEdge1 = TopoDS::Edge(aV1);
|
|
|
|
TopoDS_Edge anEdge2 = TopoDS::Edge(aV2);
|
|
|
|
|
|
|
|
gp_Pnt aP11 = BRep_Tool::Pnt(TopExp::FirstVertex(anEdge1));
|
|
|
|
gp_Pnt aP12 = BRep_Tool::Pnt(TopExp::LastVertex(anEdge1));
|
|
|
|
gp_Pnt aP21 = BRep_Tool::Pnt(TopExp::FirstVertex(anEdge2));
|
|
|
|
gp_Pnt aP22 = BRep_Tool::Pnt(TopExp::LastVertex(anEdge2));
|
|
|
|
|
|
|
|
if (aP11.Distance(aP12) < gp::Resolution() ||
|
|
|
|
aP21.Distance(aP22) < gp::Resolution()) {
|
|
|
|
StdFail_NotDone::Raise("Invalid object is given for vector argument");
|
|
|
|
}
|
|
|
|
|
|
|
|
gp_Vec Vec1 (aP11, aP12);
|
|
|
|
gp_Vec Vec2 (aP21, aP22);
|
|
|
|
|
|
|
|
Vec1.Normalize();
|
|
|
|
Vec2.Normalize();
|
|
|
|
|
|
|
|
// Step and Nb.times
|
|
|
|
Standard_Real step1 = theTI->GetStep1(), step2 = theTI->GetStep2();
|
|
|
|
Standard_Integer nbtimes1 = theTI->GetNbIter1(), nbtimes2 = theTI->GetNbIter2();
|
|
|
|
|
|
|
|
// Make multi-translation
|
|
|
|
gp_Trsf aTrsf;
|
|
|
|
gp_Vec aVec;
|
|
|
|
Standard_Real DX, DY, DZ;
|
|
|
|
TopoDS_Compound aCompound;
|
|
|
|
BRep_Builder B;
|
|
|
|
B.MakeCompound(aCompound);
|
|
|
|
|
|
|
|
TopLoc_Location aLocOrig = theShape.Location();
|
|
|
|
gp_Trsf aTrsfOrig = aLocOrig.Transformation();
|
|
|
|
|
|
|
|
for (int i = 0; i < nbtimes1; i++) {
|
|
|
|
for (int j = 0; j < nbtimes2; j++) {
|
|
|
|
DX = i * step1 * Vec1.X() + j * step2 * Vec2.X();
|
|
|
|
DY = i * step1 * Vec1.Y() + j * step2 * Vec2.Y();
|
|
|
|
DZ = i * step1 * Vec1.Z() + j * step2 * Vec2.Z();
|
|
|
|
aVec.SetCoord(DX, DY, DZ);
|
|
|
|
aTrsf.SetTranslation(aVec);
|
|
|
|
//NPAL18620: performance problem: multiple locations are accumulated
|
|
|
|
// in shape and need a great time to process
|
|
|
|
//BRepBuilderAPI_Transform aBRepTransformation(theShape, aTrsf, Standard_False);
|
|
|
|
//B.Add(aCompound, aBRepTransformation.Shape());
|
|
|
|
TopLoc_Location aLocRes (aTrsf * aTrsfOrig);
|
|
|
|
B.Add(aCompound, theShape.Located(aLocRes));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
aRes = aCompound;
|
|
|
|
|
|
|
|
return aRes;
|
|
|
|
}
|
|
|
|
*/
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* MirrorPlane
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::MirrorPlane
|
|
|
|
(Handle(GEOM_Object) theObject, Handle(GEOM_Object) thePlane)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull() || thePlane.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be mirrored
|
|
|
|
|
|
|
|
// Get last functions of the arguments
|
|
|
|
Handle(GEOM_Function) aPF = thePlane->GetLastFunction();
|
|
|
|
|
|
|
|
//Add a mirror function
|
|
|
|
Handle(GEOM_Function) aFunction =
|
|
|
|
theObject->AddFunction(GEOMImpl_MirrorDriver::GetID(), MIRROR_PLANE);
|
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_MirrorDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_IMirror aTI (aFunction);
|
|
|
|
aTI.SetPlane(aPF);
|
|
|
|
aTI.SetOriginal(aLastFunction);
|
|
|
|
|
|
|
|
//Compute the mirror
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Mirror driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << "geompy.TrsfOp.MirrorPlane("
|
|
|
|
<< theObject << ", " << thePlane << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return theObject;
|
|
|
|
}
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* MirrorPlaneCopy
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::MirrorPlaneCopy
|
|
|
|
(Handle(GEOM_Object) theObject, Handle(GEOM_Object) thePlane)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull() || thePlane.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be mirrored
|
|
|
|
|
|
|
|
//Add a new Copy object
|
|
|
|
Handle(GEOM_Object) aCopy = GetEngine()->AddObject(GetDocID(), theObject->GetType());
|
|
|
|
|
|
|
|
//Add a mirror function
|
|
|
|
Handle(GEOM_Function) aFunction =
|
|
|
|
aCopy->AddFunction(GEOMImpl_MirrorDriver::GetID(), MIRROR_PLANE_COPY);
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_MirrorDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_IMirror aTI (aFunction);
|
|
|
|
aTI.SetPlane(thePlane->GetLastFunction());
|
|
|
|
aTI.SetOriginal(aLastFunction);
|
|
|
|
|
|
|
|
//Compute the mirror
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Mirror driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << aCopy << " = geompy.MakeMirrorByPlane("
|
|
|
|
<< theObject << ", " << thePlane << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return aCopy;
|
|
|
|
}
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* MirrorPoint
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::MirrorPoint
|
|
|
|
(Handle(GEOM_Object) theObject, Handle(GEOM_Object) thePoint)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull() || thePoint.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be mirrored
|
|
|
|
|
|
|
|
// Get last functions of the arguments
|
|
|
|
Handle(GEOM_Function) aPF = thePoint->GetLastFunction();
|
|
|
|
|
|
|
|
//Add a mirror function
|
|
|
|
Handle(GEOM_Function) aFunction =
|
|
|
|
theObject->AddFunction(GEOMImpl_MirrorDriver::GetID(), MIRROR_POINT);
|
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_MirrorDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_IMirror aTI (aFunction);
|
|
|
|
aTI.SetPoint(aPF);
|
|
|
|
aTI.SetOriginal(aLastFunction);
|
|
|
|
|
|
|
|
//Compute the mirror
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Mirror driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << "geompy.TrsfOp.MirrorPoint("
|
|
|
|
<< theObject << ", " << thePoint << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* MirrorPointCopy
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::MirrorPointCopy
|
|
|
|
(Handle(GEOM_Object) theObject, Handle(GEOM_Object) thePoint)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull() || thePoint.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be mirrored
|
|
|
|
|
|
|
|
//Add a new Copy object
|
|
|
|
Handle(GEOM_Object) aCopy = GetEngine()->AddObject(GetDocID(), theObject->GetType());
|
|
|
|
|
|
|
|
//Add a mirror function
|
|
|
|
Handle(GEOM_Function) aFunction =
|
|
|
|
aCopy->AddFunction(GEOMImpl_MirrorDriver::GetID(), MIRROR_POINT_COPY);
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_MirrorDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_IMirror aTI (aFunction);
|
|
|
|
aTI.SetPoint(thePoint->GetLastFunction());
|
|
|
|
aTI.SetOriginal(aLastFunction);
|
|
|
|
|
|
|
|
//Compute the mirror
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Mirror driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << aCopy << " = geompy.MakeMirrorByPoint("
|
|
|
|
<< theObject << ", " << thePoint << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return aCopy;
|
|
|
|
}
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* MirrorAxis
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::MirrorAxis
|
|
|
|
(Handle(GEOM_Object) theObject, Handle(GEOM_Object) theAxis)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull() || theAxis.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be mirrored
|
|
|
|
|
|
|
|
// Get last functions of the arguments
|
|
|
|
Handle(GEOM_Function) anAF = theAxis->GetLastFunction();
|
|
|
|
|
|
|
|
//Add a mirror function
|
|
|
|
Handle(GEOM_Function) aFunction =
|
|
|
|
theObject->AddFunction(GEOMImpl_MirrorDriver::GetID(), MIRROR_AXIS);
|
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_MirrorDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_IMirror aTI (aFunction);
|
|
|
|
aTI.SetAxis(anAF);
|
|
|
|
aTI.SetOriginal(aLastFunction);
|
|
|
|
|
|
|
|
//Compute the mirror
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Mirror driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << "geompy.TrsfOp.MirrorAxis("
|
|
|
|
<< theObject << ", " << theAxis << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* MirrorAxisCopy
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::MirrorAxisCopy
|
|
|
|
(Handle(GEOM_Object) theObject, Handle(GEOM_Object) theAxis)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull() || theAxis.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be mirrored
|
|
|
|
|
|
|
|
//Add a new Copy object
|
|
|
|
Handle(GEOM_Object) aCopy = GetEngine()->AddObject(GetDocID(), theObject->GetType());
|
|
|
|
|
|
|
|
//Add a mirror function
|
|
|
|
Handle(GEOM_Function) aFunction =
|
|
|
|
aCopy->AddFunction(GEOMImpl_MirrorDriver::GetID(), MIRROR_AXIS_COPY);
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_MirrorDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_IMirror aTI (aFunction);
|
|
|
|
aTI.SetAxis(theAxis->GetLastFunction());
|
|
|
|
aTI.SetOriginal(aLastFunction);
|
|
|
|
|
|
|
|
//Compute the mirror
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Mirror driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << aCopy << " = geompy.MakeMirrorByAxis("
|
|
|
|
<< theObject << ", " << theAxis << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return aCopy;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* OffsetShape
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::OffsetShape
|
|
|
|
(Handle(GEOM_Object) theObject, double theOffset)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) anOriginal = theObject->GetLastFunction();
|
|
|
|
if (anOriginal.IsNull()) return NULL; //There is no function which creates an object to be offset
|
|
|
|
|
|
|
|
//Add a new Offset function
|
|
|
|
Handle(GEOM_Function) aFunction =
|
|
|
|
theObject->AddFunction(GEOMImpl_OffsetDriver::GetID(), OFFSET_SHAPE);
|
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_OffsetDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_IOffset aTI (aFunction);
|
|
|
|
aTI.SetShape(anOriginal);
|
|
|
|
aTI.SetValue(theOffset);
|
|
|
|
|
|
|
|
//Compute the offset
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Offset driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << "geompy.TrsfOp.OffsetShape("
|
|
|
|
<< theObject << ", " << theOffset << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return theObject;
|
|
|
|
}
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* OffsetShapeCopy
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::OffsetShapeCopy
|
|
|
|
(Handle(GEOM_Object) theObject, double theOffset)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) anOriginal = theObject->GetLastFunction();
|
|
|
|
if (anOriginal.IsNull()) return NULL; //There is no function which creates an object to be offset
|
|
|
|
|
|
|
|
//Add a new Copy object
|
|
|
|
Handle(GEOM_Object) aCopy = GetEngine()->AddObject(GetDocID(), theObject->GetType());
|
|
|
|
|
|
|
|
//Add a new Offset function
|
|
|
|
Handle(GEOM_Function) aFunction =
|
|
|
|
aCopy->AddFunction(GEOMImpl_OffsetDriver::GetID(), OFFSET_SHAPE_COPY);
|
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_OffsetDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_IOffset aTI (aFunction);
|
|
|
|
aTI.SetShape(anOriginal);
|
|
|
|
aTI.SetValue(theOffset);
|
|
|
|
|
|
|
|
//Compute the offset
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Offset driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << aCopy << " = geompy.MakeOffset("
|
|
|
|
<< theObject << ", " << theOffset << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return aCopy;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-08-09 13:58:02 +06:00
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* ProjectShapeCopy
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::ProjectShapeCopy
|
|
|
|
(Handle(GEOM_Object) theSource, Handle(GEOM_Object) theTarget)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theSource.IsNull() || theTarget.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aLastFunction = theSource->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be projected
|
|
|
|
|
|
|
|
//Add a new Projection object
|
|
|
|
Handle(GEOM_Object) aCopy = GetEngine()->AddObject(GetDocID(), GEOM_PROJECTION);
|
|
|
|
|
|
|
|
//Add a Projection function
|
|
|
|
Handle(GEOM_Function) aFunction =
|
|
|
|
aCopy->AddFunction(GEOMImpl_ProjectionDriver::GetID(), PROJECTION_COPY);
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_ProjectionDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_IMirror aTI (aFunction);
|
|
|
|
aTI.SetPlane(theTarget->GetLastFunction());
|
|
|
|
aTI.SetOriginal(aLastFunction);
|
|
|
|
|
|
|
|
//Compute the Projection
|
|
|
|
try {
|
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Projection driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
|
|
|
GEOM::TPythonDump(aFunction) << aCopy << " = geompy.MakeProjection("
|
|
|
|
<< theSource << ", " << theTarget << ")";
|
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return aCopy;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2004-12-01 15:39:14 +05:00
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* ScaleShape
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::ScaleShape
|
|
|
|
(Handle(GEOM_Object) theObject, Handle(GEOM_Object) thePoint, double theFactor)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
2009-02-13 17:16:39 +05:00
|
|
|
if (theObject.IsNull()) return NULL;
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
Handle(GEOM_Function) anOriginal = theObject->GetLastFunction();
|
|
|
|
if (anOriginal.IsNull()) return NULL; //There is no function which creates an object to be scaled
|
|
|
|
|
|
|
|
//Add a scale function
|
|
|
|
Handle(GEOM_Function) aFunction =
|
|
|
|
theObject->AddFunction(GEOMImpl_ScaleDriver::GetID(), SCALE_SHAPE);
|
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_ScaleDriver::GetID()) return NULL;
|
|
|
|
|
2009-02-13 17:16:39 +05:00
|
|
|
// Set arguments
|
2004-12-01 15:39:14 +05:00
|
|
|
GEOMImpl_IScale aTI (aFunction);
|
|
|
|
aTI.SetShape(anOriginal);
|
|
|
|
aTI.SetFactor(theFactor);
|
|
|
|
|
2009-02-13 17:16:39 +05:00
|
|
|
// Set point argument
|
|
|
|
if (!thePoint.IsNull()) {
|
|
|
|
Handle(GEOM_Function) aPF = thePoint->GetLastFunction();
|
|
|
|
aTI.SetPoint(aPF);
|
|
|
|
}
|
|
|
|
|
2004-12-01 15:39:14 +05:00
|
|
|
//Compute the scale
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Scale driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << "geompy.TrsfOp.ScaleShape("
|
|
|
|
<< theObject << ", " << thePoint << ", " << theFactor << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return theObject;
|
|
|
|
}
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* ScaleShapeCopy
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::ScaleShapeCopy
|
|
|
|
(Handle(GEOM_Object) theObject, Handle(GEOM_Object) thePoint, double theFactor)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
2009-02-13 17:16:39 +05:00
|
|
|
if (theObject.IsNull()) return NULL;
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
Handle(GEOM_Function) anOriginal = theObject->GetLastFunction();
|
|
|
|
if (anOriginal.IsNull()) return NULL; //There is no function which creates an object to be scaled
|
|
|
|
|
|
|
|
//Add a new Copy object
|
|
|
|
Handle(GEOM_Object) aCopy = GetEngine()->AddObject(GetDocID(), theObject->GetType());
|
|
|
|
|
|
|
|
//Add a scale function
|
|
|
|
Handle(GEOM_Function) aFunction =
|
|
|
|
aCopy->AddFunction(GEOMImpl_ScaleDriver::GetID(), SCALE_SHAPE_COPY);
|
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_ScaleDriver::GetID()) return NULL;
|
|
|
|
|
2009-02-13 17:16:39 +05:00
|
|
|
// Set arguments
|
2004-12-01 15:39:14 +05:00
|
|
|
GEOMImpl_IScale aTI (aFunction);
|
|
|
|
aTI.SetShape(anOriginal);
|
|
|
|
aTI.SetFactor(theFactor);
|
|
|
|
|
2009-02-13 17:16:39 +05:00
|
|
|
// Set point argument
|
|
|
|
if (!thePoint.IsNull()) {
|
|
|
|
Handle(GEOM_Function) aPF = thePoint->GetLastFunction();
|
|
|
|
aTI.SetPoint(aPF);
|
|
|
|
}
|
|
|
|
|
2004-12-01 15:39:14 +05:00
|
|
|
//Compute the scale
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Scale driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << aCopy << " = geompy.MakeScaleTransform("
|
|
|
|
<< theObject << ", " << thePoint << ", " << theFactor << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return aCopy;
|
|
|
|
}
|
|
|
|
|
2009-02-13 17:16:39 +05:00
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* ScaleShapeAlongAxes
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::ScaleShapeAlongAxes (Handle(GEOM_Object) theObject,
|
|
|
|
Handle(GEOM_Object) thePoint,
|
|
|
|
double theFactorX,
|
|
|
|
double theFactorY,
|
|
|
|
double theFactorZ,
|
|
|
|
bool doCopy)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) anOriginal = theObject->GetLastFunction();
|
|
|
|
if (anOriginal.IsNull()) return NULL; //There is no function which creates an object to be scaled
|
|
|
|
|
|
|
|
//Add a scale function
|
|
|
|
Handle(GEOM_Object) aCopy; //Add a new Copy object
|
|
|
|
Handle(GEOM_Function) aFunction;
|
|
|
|
if (doCopy) {
|
|
|
|
aCopy = GetEngine()->AddObject(GetDocID(), theObject->GetType());
|
|
|
|
aFunction = aCopy->AddFunction(GEOMImpl_ScaleDriver::GetID(), SCALE_SHAPE_AXES_COPY);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
aFunction = theObject->AddFunction(GEOMImpl_ScaleDriver::GetID(), SCALE_SHAPE_AXES);
|
|
|
|
}
|
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_ScaleDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
// Set arguments
|
|
|
|
GEOMImpl_IScale aTI (aFunction);
|
|
|
|
aTI.SetShape(anOriginal);
|
|
|
|
aTI.SetFactorX(theFactorX);
|
|
|
|
aTI.SetFactorY(theFactorY);
|
|
|
|
aTI.SetFactorZ(theFactorZ);
|
|
|
|
|
|
|
|
// Set point (optional argument)
|
|
|
|
if (!thePoint.IsNull()) {
|
|
|
|
Handle(GEOM_Function) aPF = thePoint->GetLastFunction();
|
|
|
|
aTI.SetPoint(aPF);
|
|
|
|
}
|
|
|
|
|
|
|
|
//Compute the scale
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2009-02-13 17:16:39 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Scale driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
|
|
|
|
//Make a Python command
|
|
|
|
if (doCopy) {
|
|
|
|
GEOM::TPythonDump(aFunction) << aCopy << " = geompy.MakeScaleAlongAxes("
|
|
|
|
<< theObject << ", " << thePoint << ", "
|
|
|
|
<< theFactorX << ", " << theFactorY << ", " << theFactorZ << ")";
|
|
|
|
return aCopy;
|
|
|
|
}
|
|
|
|
|
|
|
|
GEOM::TPythonDump(aFunction) << "geompy.TrsfOp.ScaleShapeAlongAxes("
|
|
|
|
<< theObject << ", " << thePoint << ", "
|
|
|
|
<< theFactorX << ", " << theFactorY << ", " << theFactorZ << ")";
|
|
|
|
return theObject;
|
|
|
|
}
|
|
|
|
|
2004-12-01 15:39:14 +05:00
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* PositionShape
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::PositionShape
|
|
|
|
(Handle(GEOM_Object) theObject, Handle(GEOM_Object) theStartLCS, Handle(GEOM_Object) theEndLCS)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
2008-03-07 12:45:34 +05:00
|
|
|
if (theObject.IsNull() || theEndLCS.IsNull()) return NULL;
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
Handle(GEOM_Function) anOriginal = theObject->GetLastFunction();
|
|
|
|
if (anOriginal.IsNull()) return NULL; //There is no function which creates an object to be set in position
|
|
|
|
|
|
|
|
//Add a Position function
|
2008-03-07 12:45:34 +05:00
|
|
|
Standard_Integer aType = POSITION_SHAPE;
|
|
|
|
if (theStartLCS.IsNull()) aType = POSITION_SHAPE_FROM_GLOBAL;
|
|
|
|
|
2004-12-01 15:39:14 +05:00
|
|
|
Handle(GEOM_Function) aFunction =
|
2008-03-07 12:45:34 +05:00
|
|
|
theObject->AddFunction(GEOMImpl_PositionDriver::GetID(), aType);
|
2004-12-01 15:39:14 +05:00
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_PositionDriver::GetID()) return NULL;
|
|
|
|
|
2008-03-07 12:45:34 +05:00
|
|
|
//Set operation arguments
|
2004-12-01 15:39:14 +05:00
|
|
|
GEOMImpl_IPosition aTI (aFunction);
|
|
|
|
aTI.SetShape(anOriginal);
|
2008-03-07 12:45:34 +05:00
|
|
|
aTI.SetEndLCS(theEndLCS->GetLastFunction());
|
|
|
|
if (!theStartLCS.IsNull())
|
2012-08-09 13:58:02 +06:00
|
|
|
aTI.SetStartLCS(theObject == theStartLCS ? anOriginal : theStartLCS->GetLastFunction());
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
//Compute the Position
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Position driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << "geompy.TrsfOp.PositionShape("
|
|
|
|
<< theObject << ", " << theStartLCS << ", " << theEndLCS << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return theObject;
|
|
|
|
}
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* PositionShapeCopy
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::PositionShapeCopy
|
|
|
|
(Handle(GEOM_Object) theObject, Handle(GEOM_Object) theStartLCS, Handle(GEOM_Object) theEndLCS)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
2008-03-07 12:45:34 +05:00
|
|
|
if (theObject.IsNull() || theEndLCS.IsNull()) return NULL;
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
Handle(GEOM_Function) anOriginal = theObject->GetLastFunction();
|
|
|
|
if (anOriginal.IsNull()) return NULL; //There is no function which creates an object to be set in position
|
|
|
|
|
|
|
|
//Add a new Copy object
|
|
|
|
Handle(GEOM_Object) aCopy = GetEngine()->AddObject(GetDocID(), theObject->GetType());
|
|
|
|
|
|
|
|
//Add a position function
|
2008-03-07 12:45:34 +05:00
|
|
|
Standard_Integer aType = POSITION_SHAPE_COPY;
|
|
|
|
if (theStartLCS.IsNull()) aType = POSITION_SHAPE_FROM_GLOBAL_COPY;
|
|
|
|
|
2004-12-01 15:39:14 +05:00
|
|
|
Handle(GEOM_Function) aFunction =
|
2008-03-07 12:45:34 +05:00
|
|
|
aCopy->AddFunction(GEOMImpl_PositionDriver::GetID(), aType);
|
2004-12-01 15:39:14 +05:00
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_PositionDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_IPosition aTI (aFunction);
|
|
|
|
aTI.SetShape(anOriginal);
|
|
|
|
aTI.SetEndLCS(theEndLCS->GetLastFunction());
|
2008-03-07 12:45:34 +05:00
|
|
|
if (!theStartLCS.IsNull())
|
|
|
|
aTI.SetStartLCS(theStartLCS->GetLastFunction());
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
//Compute the position
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Position driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << aCopy << " = geompy.MakePosition("
|
|
|
|
<< theObject << ", " << theStartLCS << ", " << theEndLCS << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return aCopy;
|
|
|
|
}
|
|
|
|
|
2009-02-13 17:16:39 +05:00
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* PositionAlongPath
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::PositionAlongPath
|
2012-08-09 13:58:02 +06:00
|
|
|
(Handle(GEOM_Object) theObject, Handle(GEOM_Object) thePath,
|
|
|
|
double theDistance, bool theCopy, bool theReverse)
|
2009-02-13 17:16:39 +05:00
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull() || thePath.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) anOriginal = theObject->GetLastFunction();
|
|
|
|
if (anOriginal.IsNull()) return NULL; //There is no function which creates an object to be set in position
|
|
|
|
|
|
|
|
//Add a position function
|
|
|
|
Handle(GEOM_Function) aFunction;
|
|
|
|
Handle(GEOM_Object) aCopy;
|
|
|
|
|
|
|
|
if (theCopy) {
|
|
|
|
aCopy = GetEngine()->AddObject(GetDocID(), theObject->GetType());
|
|
|
|
aFunction = aCopy->AddFunction(GEOMImpl_PositionDriver::GetID(), POSITION_ALONG_PATH);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
aFunction = theObject->AddFunction(GEOMImpl_PositionDriver::GetID(), POSITION_ALONG_PATH);
|
|
|
|
|
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_PositionDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_IPosition aTI (aFunction);
|
|
|
|
aTI.SetShape(anOriginal);
|
|
|
|
aTI.SetPath(thePath->GetLastFunction());
|
|
|
|
aTI.SetDistance(theDistance);
|
|
|
|
aTI.SetReverse(theReverse);
|
|
|
|
|
|
|
|
//Compute the position
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2009-02-13 17:16:39 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Position driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
|
|
|
if (theCopy) {
|
|
|
|
GEOM::TPythonDump(aFunction) << aCopy << " = geompy.PositionAlongPath("
|
2012-08-09 13:58:02 +06:00
|
|
|
<< theObject << ", " << thePath << ", " << theDistance << ", " << theCopy << ", " << theReverse << ")";
|
2009-02-13 17:16:39 +05:00
|
|
|
SetErrorCode(OK);
|
|
|
|
return aCopy;
|
|
|
|
}
|
|
|
|
|
|
|
|
GEOM::TPythonDump(aFunction) << "geompy.TrsfOp.PositionAlongPath("
|
|
|
|
<< theObject << ", " << thePath << ", " << theDistance << ", " << theCopy << ", " << theReverse << ")";
|
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return theObject;
|
|
|
|
}
|
|
|
|
|
2004-12-01 15:39:14 +05:00
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* Rotate
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::Rotate (Handle(GEOM_Object) theObject,
|
|
|
|
Handle(GEOM_Object) theAxis,
|
|
|
|
double theAngle)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull() || theAxis.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aFunction, aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be rotated
|
|
|
|
|
|
|
|
// Get last functions of the arguments
|
|
|
|
Handle(GEOM_Function) anAF = theAxis->GetLastFunction();
|
|
|
|
|
|
|
|
//Add a rotate function
|
|
|
|
aFunction = theObject->AddFunction(GEOMImpl_RotateDriver::GetID(), ROTATE);
|
|
|
|
|
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_RotateDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_IRotate aRI(aFunction);
|
|
|
|
aRI.SetAxis(anAF);
|
|
|
|
aRI.SetOriginal(aLastFunction);
|
|
|
|
aRI.SetAngle(theAngle);
|
|
|
|
|
|
|
|
//Compute the translation
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Rotate driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2009-02-13 17:16:39 +05:00
|
|
|
GEOM::TPythonDump(aFunction) << "geompy.Rotate(" << theObject
|
2012-08-09 13:58:02 +06:00
|
|
|
<< ", " << theAxis << ", " << theAngle * 180.0 / M_PI << "*math.pi/180.0)";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return theObject;
|
|
|
|
}
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* Rotate
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::RotateCopy (Handle(GEOM_Object) theObject, Handle(GEOM_Object) theAxis, double theAngle)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull() || theAxis.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aFunction, aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be rotated
|
|
|
|
|
|
|
|
//Add a new Copy object
|
|
|
|
Handle(GEOM_Object) aCopy = GetEngine()->AddObject(GetDocID(), theObject->GetType());
|
|
|
|
|
|
|
|
//Add a rotate function
|
|
|
|
aFunction = aCopy->AddFunction(GEOMImpl_RotateDriver::GetID(), ROTATE_COPY);
|
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_RotateDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_IRotate aRI(aFunction);
|
|
|
|
aRI.SetAxis(theAxis->GetLastFunction());
|
|
|
|
aRI.SetOriginal(aLastFunction);
|
|
|
|
aRI.SetAngle(theAngle);
|
|
|
|
|
|
|
|
//Compute the translation
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Rotate driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << aCopy << " = geompy.MakeRotation(" << theObject
|
2012-08-09 13:58:02 +06:00
|
|
|
<< ", " << theAxis << ", " << theAngle * 180.0 / M_PI << "*math.pi/180.0)";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return aCopy;
|
|
|
|
}
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* Rotate1D
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::Rotate1D (Handle(GEOM_Object) theObject,
|
|
|
|
Handle(GEOM_Object) theAxis,
|
|
|
|
Standard_Integer theNbTimes)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull() || theAxis.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aFunction, aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be rotated
|
|
|
|
|
|
|
|
//Add a new Copy object
|
|
|
|
Handle(GEOM_Object) aCopy = GetEngine()->AddObject(GetDocID(), theObject->GetType());
|
|
|
|
|
|
|
|
//Add a rotate function
|
|
|
|
aFunction = aCopy->AddFunction(GEOMImpl_RotateDriver::GetID(), ROTATE_1D);
|
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
2012-08-09 13:58:02 +06:00
|
|
|
//Check if the function is set correctly
|
2004-12-01 15:39:14 +05:00
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_RotateDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_IRotate aRI(aFunction);
|
|
|
|
aRI.SetOriginal(aLastFunction);
|
|
|
|
aRI.SetAxis(theAxis->GetLastFunction());
|
|
|
|
aRI.SetNbIter1(theNbTimes);
|
|
|
|
|
|
|
|
//Compute the translation
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Rotate driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << aCopy << " = geompy.MultiRotate1D("
|
|
|
|
<< theObject << ", " << theAxis << ", " << theNbTimes << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return aCopy;
|
|
|
|
}
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* Rotate2D
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::Rotate2D (Handle(GEOM_Object) theObject,
|
2012-08-09 13:58:02 +06:00
|
|
|
Handle(GEOM_Object) theAxis,
|
|
|
|
double theAngle,
|
|
|
|
Standard_Integer theNbTimes1,
|
|
|
|
double theStep,
|
|
|
|
Standard_Integer theNbTimes2)
|
2004-12-01 15:39:14 +05:00
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull() || theAxis.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aFunction, aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be rotated
|
|
|
|
|
|
|
|
//Add a new Copy object
|
|
|
|
Handle(GEOM_Object) aCopy = GetEngine()->AddObject(GetDocID(), theObject->GetType());
|
|
|
|
|
|
|
|
//Add a rotate function
|
|
|
|
aFunction = aCopy->AddFunction(GEOMImpl_RotateDriver::GetID(), ROTATE_2D);
|
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_RotateDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_IRotate aRI(aFunction);
|
|
|
|
aRI.SetAxis(theAxis->GetLastFunction());
|
|
|
|
aRI.SetOriginal(aLastFunction);
|
|
|
|
aRI.SetNbIter1(theNbTimes1);
|
|
|
|
aRI.SetNbIter2(theNbTimes2);
|
|
|
|
aRI.SetAngle(theAngle);
|
|
|
|
aRI.SetStep(theStep);
|
|
|
|
|
|
|
|
//Compute the translation
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
2004-12-01 15:39:14 +05:00
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Rotate driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
2005-06-02 13:17:09 +06:00
|
|
|
GEOM::TPythonDump(aFunction) << aCopy << " = geompy.MultiRotate2D("
|
|
|
|
<< theObject << ", " << theAxis << ", " << theAngle << ", "
|
|
|
|
<< theNbTimes1 << ", " << theStep << ", " << theNbTimes2 << ")";
|
2004-12-01 15:39:14 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return aCopy;
|
|
|
|
}
|
2008-03-07 12:45:34 +05:00
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* RotateThreePoints
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::RotateThreePoints (Handle(GEOM_Object) theObject,
|
2012-08-09 13:58:02 +06:00
|
|
|
Handle(GEOM_Object) theCentPoint,
|
|
|
|
Handle(GEOM_Object) thePoint1,
|
|
|
|
Handle(GEOM_Object) thePoint2)
|
2008-03-07 12:45:34 +05:00
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull() || theCentPoint.IsNull() || thePoint1.IsNull() || thePoint2.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aFunction, aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be rotated
|
|
|
|
|
|
|
|
// Get last functions of the arguments
|
|
|
|
Handle(GEOM_Function) aCPF = theCentPoint->GetLastFunction();
|
|
|
|
Handle(GEOM_Function) aP1F = thePoint1->GetLastFunction();
|
|
|
|
Handle(GEOM_Function) aP2F = thePoint2->GetLastFunction();
|
|
|
|
|
|
|
|
|
|
|
|
//Add a rotate function
|
|
|
|
aFunction = theObject->AddFunction(GEOMImpl_RotateDriver::GetID(), ROTATE_THREE_POINTS);
|
|
|
|
|
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_RotateDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_IRotate aRI(aFunction);
|
|
|
|
aRI.SetCentPoint(aCPF);
|
|
|
|
aRI.SetPoint1(aP1F);
|
|
|
|
aRI.SetPoint2(aP2F);
|
|
|
|
aRI.SetOriginal(aLastFunction);
|
|
|
|
|
|
|
|
//Compute the translation
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Rotate driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
|
|
|
GEOM::TPythonDump(aFunction) << "geompy.TrsfOp.RotateThreePoints(" << theObject
|
2012-08-09 13:58:02 +06:00
|
|
|
<< ", " << theCentPoint << ", "<<thePoint1 << ", " << thePoint2 << ")";
|
2008-03-07 12:45:34 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return theObject;
|
|
|
|
}
|
|
|
|
|
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* RotateThreePointsCopy
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
2012-08-09 13:58:02 +06:00
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::RotateThreePointsCopy (Handle(GEOM_Object) theObject,
|
|
|
|
Handle(GEOM_Object) theCentPoint,
|
|
|
|
Handle(GEOM_Object) thePoint1,
|
|
|
|
Handle(GEOM_Object) thePoint2)
|
2008-03-07 12:45:34 +05:00
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull() || theCentPoint.IsNull() || thePoint1.IsNull() || thePoint2.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aFunction, aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; //There is no function which creates an object to be rotated
|
|
|
|
|
|
|
|
//Add a new Copy object
|
|
|
|
Handle(GEOM_Object) aCopy = GetEngine()->AddObject(GetDocID(), theObject->GetType());
|
|
|
|
|
|
|
|
//Add a rotate function
|
|
|
|
aFunction = aCopy->AddFunction(GEOMImpl_RotateDriver::GetID(), ROTATE_THREE_POINTS_COPY);
|
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
|
|
|
//Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != GEOMImpl_RotateDriver::GetID()) return NULL;
|
|
|
|
|
|
|
|
GEOMImpl_IRotate aRI(aFunction);
|
|
|
|
aRI.SetCentPoint(theCentPoint->GetLastFunction());
|
|
|
|
aRI.SetPoint1(thePoint1->GetLastFunction());
|
|
|
|
aRI.SetPoint2(thePoint2->GetLastFunction());
|
|
|
|
aRI.SetOriginal(aLastFunction);
|
|
|
|
|
|
|
|
//Compute the translation
|
|
|
|
try {
|
2012-08-09 13:58:02 +06:00
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
2008-03-07 12:45:34 +05:00
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Rotate driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
|
|
|
GEOM::TPythonDump(aFunction) << aCopy << " = geompy.MakeRotationThreePoints(" << theObject
|
2012-08-09 13:58:02 +06:00
|
|
|
<< ", " << theCentPoint << ", "<<thePoint1 << ", " << thePoint2 << ")";
|
2008-03-07 12:45:34 +05:00
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return aCopy;
|
|
|
|
}
|
|
|
|
|
2012-08-09 13:58:02 +06:00
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* TransformLikeOtherCopy
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
Handle(GEOM_Object) GEOMImpl_ITransformOperations::TransformLikeOtherCopy
|
|
|
|
(Handle(GEOM_Object) theObject,
|
|
|
|
Handle(GEOM_Object) theSample)
|
|
|
|
{
|
|
|
|
SetErrorCode(KO);
|
|
|
|
|
|
|
|
if (theObject.IsNull() || theSample.IsNull()) return NULL;
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aLastFunction = theObject->GetLastFunction();
|
|
|
|
if (aLastFunction.IsNull()) return NULL; // There is no function which creates an object to be transformed
|
|
|
|
|
|
|
|
Handle(GEOM_Function) aSampleFunc = theSample->GetLastFunction();
|
|
|
|
if (aSampleFunc.IsNull()) return NULL; // There is no function which creates a sample object
|
|
|
|
|
|
|
|
// Add a new Copy object
|
|
|
|
Handle(GEOM_Object) aCopy = GetEngine()->AddObject(GetDocID(), theObject->GetType());
|
|
|
|
|
|
|
|
// Add a transform function (depends on theSample function)
|
|
|
|
Handle(GEOM_Function) aFunction =
|
|
|
|
aCopy->AddFunction(aSampleFunc->GetDriverGUID(), aSampleFunc->GetType());
|
|
|
|
if (aFunction.IsNull()) return NULL;
|
|
|
|
|
|
|
|
// Check if the function is set correctly
|
|
|
|
if (aFunction->GetDriverGUID() != aSampleFunc->GetDriverGUID()) return NULL;
|
|
|
|
|
|
|
|
if (aSampleFunc->GetDriverGUID() == GEOMImpl_TranslateDriver::GetID()) {
|
|
|
|
switch (aSampleFunc->GetType()) {
|
|
|
|
case TRANSLATE_1D:
|
|
|
|
{
|
|
|
|
GEOMImpl_ITranslate aRI_sample (aSampleFunc);
|
|
|
|
GEOMImpl_ITranslate aRI_target (aFunction);
|
|
|
|
|
|
|
|
aRI_target.SetVector(aRI_sample.GetVector());
|
|
|
|
aRI_target.SetStep1(aRI_sample.GetStep1());
|
|
|
|
aRI_target.SetNbIter1(aRI_sample.GetNbIter1());
|
|
|
|
|
|
|
|
aRI_target.SetOriginal(aLastFunction);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case TRANSLATE_2D:
|
|
|
|
{
|
|
|
|
GEOMImpl_ITranslate aRI_sample (aSampleFunc);
|
|
|
|
GEOMImpl_ITranslate aRI_target (aFunction);
|
|
|
|
|
|
|
|
aRI_target.SetVector(aRI_sample.GetVector());
|
|
|
|
aRI_target.SetStep1(aRI_sample.GetStep1());
|
|
|
|
aRI_target.SetNbIter1(aRI_sample.GetNbIter1());
|
|
|
|
|
|
|
|
aRI_target.SetVector2(aRI_sample.GetVector2());
|
|
|
|
aRI_target.SetStep2(aRI_sample.GetStep2());
|
|
|
|
aRI_target.SetNbIter2(aRI_sample.GetNbIter2());
|
|
|
|
|
|
|
|
aRI_target.SetOriginal(aLastFunction);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
{
|
|
|
|
SetErrorCode("Not implemented case of TransformLikeOtherCopy");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (aSampleFunc->GetDriverGUID() == GEOMImpl_RotateDriver::GetID()) {
|
|
|
|
switch (aSampleFunc->GetType()) {
|
|
|
|
case ROTATE_1D:
|
|
|
|
{
|
|
|
|
GEOMImpl_IRotate aRI_sample (aSampleFunc);
|
|
|
|
GEOMImpl_IRotate aRI_target (aFunction);
|
|
|
|
|
|
|
|
aRI_target.SetAxis(aRI_sample.GetAxis());
|
|
|
|
aRI_target.SetNbIter1(aRI_sample.GetNbIter1());
|
|
|
|
|
|
|
|
aRI_target.SetOriginal(aLastFunction);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case ROTATE_2D:
|
|
|
|
{
|
|
|
|
GEOMImpl_IRotate aRI_sample (aSampleFunc);
|
|
|
|
GEOMImpl_IRotate aRI_target (aFunction);
|
|
|
|
|
|
|
|
aRI_target.SetAxis(aRI_sample.GetAxis());
|
|
|
|
|
|
|
|
aRI_target.SetNbIter1(aRI_sample.GetNbIter1());
|
|
|
|
aRI_target.SetNbIter2(aRI_sample.GetNbIter2());
|
|
|
|
|
|
|
|
aRI_target.SetAngle(aRI_sample.GetAngle());
|
|
|
|
aRI_target.SetStep(aRI_sample.GetStep());
|
|
|
|
|
|
|
|
aRI_target.SetDir2(aRI_sample.GetDir2());
|
|
|
|
|
|
|
|
aRI_target.SetOriginal(aLastFunction);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case ROTATE_THREE_POINTS_COPY:
|
|
|
|
{
|
|
|
|
GEOMImpl_IRotate aRI_sample (aSampleFunc);
|
|
|
|
GEOMImpl_IRotate aRI_target (aFunction);
|
|
|
|
|
|
|
|
aRI_target.SetCentPoint(aRI_sample.GetCentPoint());
|
|
|
|
aRI_target.SetPoint1(aRI_sample.GetPoint1());
|
|
|
|
aRI_target.SetPoint2(aRI_sample.GetPoint2());
|
|
|
|
|
|
|
|
aRI_target.SetOriginal(aLastFunction);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
{
|
|
|
|
SetErrorCode("Not implemented case of TransformLikeOtherCopy");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
SetErrorCode("Not implemented case of TransformLikeOtherCopy");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Compute the transformation
|
|
|
|
try {
|
|
|
|
#if OCC_VERSION_LARGE > 0x06010000
|
|
|
|
OCC_CATCH_SIGNALS;
|
|
|
|
#endif
|
|
|
|
if (!GetSolver()->ComputeFunction(aFunction)) {
|
|
|
|
SetErrorCode("Driver failed");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Standard_Failure) {
|
|
|
|
Handle(Standard_Failure) aFail = Standard_Failure::Caught();
|
|
|
|
SetErrorCode(aFail->GetMessageString());
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Make a Python command
|
|
|
|
//GEOM::TPythonDump(aFunction) << aCopy << " = geompy.TransformLikeOtherCopy("
|
|
|
|
// << theObject << ", " << theSample << ")";
|
|
|
|
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return aCopy;
|
|
|
|
}
|