generic_copy_off.h
来自「CGAL is a collaborative effort of severa」· C头文件 代码 · 共 113 行
H
113 行
// Copyright (c) 1997 Utrecht University (The Netherlands),// ETH Zurich (Switzerland), Freie Universitaet Berlin (Germany),// INRIA Sophia-Antipolis (France), Martin-Luther-University Halle-Wittenberg// (Germany), Max-Planck-Institute Saarbruecken (Germany), RISC Linz (Austria),// and Tel-Aviv University (Israel). All rights reserved.//// This file is part of CGAL (www.cgal.org); you can redistribute it and/or// modify it under the terms of the GNU Lesser General Public License as// published by the Free Software Foundation; version 2.1 of the License.// See the file LICENSE.LGPL 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/Stream_support/include/CGAL/IO/generic_copy_OFF.h,v $// $Revision: 1.1 $ $Date: 2003/12/10 13:57:19 $// $Name: $//// Author(s) : Lutz Kettner <kettner@mpi-sb.mpg.de>#ifndef CGAL_IO_GENERIC_COPY_OFF_H#define CGAL_IO_GENERIC_COPY_OFF_H 1#ifndef CGAL_BASIC_H#include <CGAL/basic.h>#endif#ifndef CGAL_PROTECT_CSTDDEF#include <cstddef>#define CGAL_PROTECT_CSTDDEF#endif#ifndef CGAL_IO_FILE_HEADER_OFF_H#include <CGAL/IO/File_header_OFF.h>#endif // CGAL_IO_FILE_HEADER_OFF_H#ifndef CGAL_IO_FILE_SCANNER_OFF_H#include <CGAL/IO/File_scanner_OFF.h>#endif // CGAL_IO_FILE_SCANNER_OFF_H#ifndef CGAL_PROTECT_IOSTREAM#include <iostream>#define CGAL_PROTECT_IOSTREAM#endifCGAL_BEGIN_NAMESPACEtemplate <class Writer>voidgeneric_copy_OFF( File_scanner_OFF& scanner, std::ostream& out, Writer& writer) { std::istream& in = scanner.in(); // scans a polyhedral surface in OFF from `in' and writes it // to `out' in the format provided by `writer'. if ( ! in) { if ( scanner.verbose()) { std::cerr << " " << std::endl; std::cerr << "generic_copy_OFF(): " "input error: file format is not in OFF." << std::endl; } return; } // Print header. Number of halfedges is only trusted if it is // a polyhedral surface. writer.write_header( out, scanner.size_of_vertices(), scanner.polyhedral_surface() ? scanner.size_of_halfedges() : 0, scanner.size_of_facets()); // read in all vertices double x, y, z; // Point coordinates. int i; for ( i = 0; i < scanner.size_of_vertices(); i++) { scanner.scan_vertex( x, y, z); writer.write_vertex( x, y, z); scanner.skip_to_next_vertex( i); } // read in all facets writer.write_facet_header(); for ( i = 0; i < scanner.size_of_facets(); i++) { if ( ! in) return; Integer32 no; scanner.scan_facet( no, i); writer.write_facet_begin( no); for ( int j = 0; j < no; j++) { Integer32 index; scanner.scan_facet_vertex_index( index, i); writer.write_facet_vertex_index( index); } writer.write_facet_end(); scanner.skip_to_next_facet( i); } writer.write_footer();}template <class Writer>voidgeneric_copy_OFF( std::istream& in, std::ostream& out, Writer& writer, bool verbose = false) { // scans a polyhedral surface in OFF from `in' and writes it // to `out' in the format provided by `writer'. File_scanner_OFF scanner( in, verbose); generic_copy_OFF( scanner, out, writer);}CGAL_END_NAMESPACE#endif // CGAL_IO_GENERIC_COPY_OFF_H //// EOF //
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?