generic_print_polyhedron.h
来自「CGAL is a collaborative effort of severa」· C头文件 代码 · 共 71 行
H
71 行
// 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.//// $Source: /CVSROOT/CGAL/Packages/Polyhedron_IO/include/CGAL/IO/generic_print_polyhedron.h,v $// $Revision: 1.7 $ $Date: 2003/09/18 10:25:05 $// $Name: $//// 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 + =
减小字号Ctrl + -
显示快捷键?