00001 /*************************************************************************** 00002 * Copyright (c) 2005 Werner Mayer <wmayer[at]users.sourceforge.net> * 00003 * * 00004 * This file is part of the FreeCAD CAx development system. * 00005 * * 00006 * This library is free software; you can redistribute it and/or * 00007 * modify it under the terms of the GNU Library General Public * 00008 * License as published by the Free Software Foundation; either * 00009 * version 2 of the License, or (at your option) any later version. * 00010 * * 00011 * This library is distributed in the hope that it will be useful, * 00012 * but WITHOUT ANY WARRANTY; without even the implied warranty of * 00013 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * 00014 * GNU Library General Public License for more details. * 00015 * * 00016 * You should have received a copy of the GNU Library General Public * 00017 * License along with this library; see the file COPYING.LIB. If not, * 00018 * write to the Free Software Foundation, Inc., 59 Temple Place, * 00019 * Suite 330, Boston, MA 02111-1307, USA * 00020 * * 00021 ***************************************************************************/ 00022 00023 00024 #include "PreCompiled.h" 00025 #ifndef _PreComp_ 00026 #endif 00027 00028 #include <Base/Console.h> 00029 #include <Base/Exception.h> 00030 #include <Base/Sequencer.h> 00031 #include <Base/Matrix.h> 00032 #include <Base/Vector3D.h> 00033 00034 #include "FeatureMeshTransformDemolding.h" 00035 00036 #include "Core/MeshIO.h" 00037 00038 00039 using namespace Mesh; 00040 using namespace MeshCore; 00041 00042 PROPERTY_SOURCE(Mesh::TransformDemolding, Mesh::Transform) 00043 00044 00045 TransformDemolding::TransformDemolding(void) 00046 { 00047 ADD_PROPERTY(Source,(0)); 00048 ADD_PROPERTY(Rotation,(0.0)); 00049 ADD_PROPERTY(Axis,(0.0,0.0,1.0)); 00050 } 00051 00052 App::DocumentObjectExecReturn *TransformDemolding::execute(void) 00053 {/* 00054 Feature *pcFirst = dynamic_cast<Feature*>(Source.getValue()); 00055 if(!pcFirst || pcFirst->isError()) 00056 return new App::DocumentObjectExecReturn("Unknown Error"); 00057 00058 MeshCore::MeshKernel *pcKernel = new MeshCore::MeshKernel(pcFirst->Mesh.getValue()); // Result Meshkernel 00059 Base::Matrix4D trans(Base::Vector3f(0,0,0), Axis.getValue(), Rotation.getValue() ); 00060 //Matrix4D trans; 00061 //trans.rotLine( Axis.getValue(), Rotation.getValue() ); 00062 pcKernel->Transform(trans); 00063 Mesh.setValue(pcKernel); 00064 */ 00065 return App::DocumentObject::StdReturn; 00066 } 00067