Projection.h

Go to the documentation of this file.
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 #ifndef MESH_PROJECTION_H
00025 #define MESH_PROJECTION_H
00026 
00027 #include <vector>
00028 
00029 #include <Base/Vector3D.h>
00030 #ifdef FC_USE_OCC
00031 using Base::Vector3f;
00032 
00033 class TopoDS_Edge;
00034 class TopoDS_Shape;
00035 
00036 namespace MeshCore
00037 {
00038 
00039 class MeshFacetGrid;
00040 class MeshKernel;
00041 class MeshGeomFacet;
00042 
00044 struct SplitEdge
00045 {
00046   unsigned long uE0, uE1; 
00047   Base::Vector3f cPt; 
00048 };
00049 
00054 class MeshExport MeshProjection
00055 {
00056 public:
00058   MeshProjection( const MeshKernel& rMesh);
00060   ~MeshProjection();
00061 
00067   void projectToMesh ( const TopoDS_Shape &aShape, float fMaxDist, std::vector<SplitEdge>& rSplitEdges ) const;
00072   void splitMeshByShape ( const TopoDS_Shape &aShape, float fMaxDist ) const;
00073 
00074 protected:
00075   void projectEdgeToEdge( const TopoDS_Edge &aCurve, float fMaxDist, const MeshFacetGrid& rGrid, 
00076                           std::vector<SplitEdge>& rSplitEdges ) const;
00077 
00078 private:
00079   const MeshKernel& _rcMesh;
00080 };
00081 
00082 } // namespace MeshCore
00083 #endif
00084 
00085 #endif  // MESH_PROJECTION_H 

Generated on Wed Nov 23 19:00:30 2011 for FreeCAD by  doxygen 1.6.1