00001 /*************************************************************************** 00002 * Copyright (c) Juergen Riegel <juergen.riegel@web.de> * 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 #ifndef _GTSAlgos_h_ 00025 #define _GTSAlgos_h_ 00026 00027 #include <gts.h> 00028 #include <vector> 00029 00030 #include <Base/Vector3D.h> 00031 #include <Base/Matrix.h> 00032 #include "Mesh.h" 00033 00034 00035 namespace Mesh 00036 { 00037 00040 class MeshExport GTSAlgos 00041 { 00042 public: 00043 //GTSAlgos(MeshCore::MeshKernel* Mesh); 00044 GTSAlgos(Mesh::MeshObject& Mesh):_Mesh(Mesh){}; 00045 00048 void coarsen(float f); 00049 00053 void boolean(const Mesh::MeshObject& ToolMesh, int Type=0); 00054 00057 static GtsSurface* createGTSSurface(const Mesh::MeshObject& Mesh); 00058 00061 static void fillMeshFromGTSSurface(Mesh::MeshObject& Mesh, GtsSurface* pSurface); 00062 00063 private: 00064 00065 Mesh::MeshObject& _Mesh; 00066 }; 00067 00068 00069 00070 } // namespace Mesh 00071 #endif