/*===========================================================================*\ * * * IsoEx * * Copyright (C) 2002 by Computer Graphics Group, RWTH Aachen * * www.rwth-graphics.de * * * *---------------------------------------------------------------------------* * * * License * * * * This library is free software; you can redistribute it and/or modify it * * under the terms of the GNU Library General Public License as published * * by the Free Software Foundation, version 2. * * * * 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 * * Library General Public License for more details. * * * * You should have received a copy of the GNU Library General Public * * License along with this library; if not, write to the Free Software * * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. * * * \*===========================================================================*/ //============================================================================= // // CLASS ExtendedMarchingCubesT // //============================================================================= #ifndef ISOEX_EXTMARCHINGCUBEST_HH #define ISOEX_EXTMARCHINGCUBEST_HH //== INCLUDES ================================================================= #include #include #include //== NAMESPACES =============================================================== namespace IsoEx { //== CLASS DEFINITION ========================================================= /** \class ExtendedMarchingCubesT ExtendedMarchingCubesT.hh This class implements the Extended Marching Cubes of Kobbelt et al, Siggraph 2001. The 0-level iso-surface is extracted in the constructor. Use it through the convenience function IsoEx::extended_marching_cubes(). \ingroup extractors */ template class ExtendedMarchingCubesT { public: ExtendedMarchingCubesT(const Grid& _grid, Mesh& _mesh, double _iso_value, double _feature_angle); private: typedef typename Grid::PointIdx PointIdx; typedef typename Grid::CubeIdx CubeIdx; typedef typename Grid::CubeIterator CubeIterator; typedef typename Mesh::VertexHandle VertexHandle; typedef std::vector VertexHandleVector; void process_cube(CubeIdx _idx, double _iso_value); VertexHandle add_vertex(PointIdx _p0, PointIdx _p1, double _iso_value); VertexHandle find_feature(const VertexHandleVector& _vhandles); void flip_edges(); const Grid& grid_; Mesh& mesh_; float feature_angle_; unsigned int n_edges_, n_corners_; // maps an edge to the sample vertex generated on it Edge2VertexMapT edge2vertex_; }; //----------------------------------------------------------------------------- /** Convenience wrapper for the Extended Marching Cubes algorithm. \see IsoEx::ExtendedMarchingCubesT \ingroup extractors */ template void extended_marching_cubes(const Grid& _grid, Mesh& _mesh, double _iso_value, double _feature_angle) { ExtendedMarchingCubesT emc(_grid, _mesh, _iso_value, _feature_angle); } //============================================================================= } // namespace IsoEx //============================================================================= #if defined(INCLUDE_TEMPLATES) && !defined(ISOEX_EXTMARCHINGCUBEST_C) #define ISOEX_EXTMARCHINGCUBEST_TEMPLATES #include "ExtendedMarchingCubesT.cc" #endif //============================================================================= #endif // ISOEX_EXTMARCHINGCUBEST_HH defined //=============================================================================