⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 generic_print_polyhedron.h

📁 很多二维 三维几何计算算法 C++ 类库
💻 H
字号:
// Copyright (c) 1997  ETH Zurich (Switzerland).// All rights reserved.//// This file is part of CGAL (www.cgal.org); you may redistribute it under// the terms of the Q Public License version 1.0.// See the file LICENSE.QPL distributed with CGAL.//// Licensees holding a valid commercial license may use this file in// accordance with the commercial license agreement provided with the software.//// This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE// WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.//// $URL: svn+ssh://scm.gforge.inria.fr/svn/cgal/branches/CGAL-3.3-branch/Polyhedron_IO/include/CGAL/IO/generic_print_polyhedron.h $// $Id: generic_print_polyhedron.h 28567 2006-02-16 14:30:13Z lsaboret $// //// Author(s)     : Lutz Kettner  <kettner@mpi-sb.mpg.de>#ifndef CGAL_IO_GENERIC_PRINT_POLYHEDRON_H#define CGAL_IO_GENERIC_PRINT_POLYHEDRON_H 1#include <CGAL/basic.h>#include <CGAL/Inverse_index.h>#include <iostream>CGAL_BEGIN_NAMESPACEtemplate <class Polyhedron, class Writer>voidgeneric_print_polyhedron( std::ostream&     out,                           const Polyhedron& P,                          Writer&           writer) {    // writes P to `out' in the format provided by `writer'.    typedef typename Polyhedron::Vertex                                 Vertex;    typedef typename Polyhedron::Vertex_const_iterator                  VCI;    typedef typename Polyhedron::Facet_const_iterator                   FCI;    typedef typename Polyhedron::Halfedge_around_facet_const_circulator HFCC;    // Print header.    writer.write_header( out,                         P.size_of_vertices(),                         P.size_of_halfedges(),                         P.size_of_facets());    for( VCI vi = P.vertices_begin(); vi != P.vertices_end(); ++vi) {        writer.write_vertex( ::CGAL::to_double( vi->point().x()),                             ::CGAL::to_double( vi->point().y()),                             ::CGAL::to_double( vi->point().z()));    }    typedef Inverse_index< VCI> Index;    Index index( P.vertices_begin(), P.vertices_end());    writer.write_facet_header();    for( FCI fi = P.facets_begin(); fi != P.facets_end(); ++fi) {        HFCC hc = fi->facet_begin();        HFCC hc_end = hc;        std::size_t n = circulator_size( hc);        CGAL_assertion( n >= 3);        writer.write_facet_begin( n);        do {            writer.write_facet_vertex_index( index[ VCI(hc->vertex())]);            ++hc;        } while( hc != hc_end);        writer.write_facet_end();    }    writer.write_footer();}CGAL_END_NAMESPACE#endif // CGAL_IO_GENERIC_PRINT_POLYHEDRON_H //// EOF //

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -