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

📄 generic_copy_off.h

📁 很多二维 三维几何计算算法 C++ 类库
💻 H
字号:
// 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.//// $URL: svn+ssh://scm.gforge.inria.fr/svn/cgal/branches/CGAL-3.3-branch/Stream_support/include/CGAL/IO/generic_copy_OFF.h $// $Id: generic_copy_OFF.h 35787 2007-01-24 17:16:05Z spion $// //// Author(s)     : Lutz Kettner  <kettner@mpi-sb.mpg.de>#ifndef CGAL_IO_GENERIC_COPY_OFF_H#define CGAL_IO_GENERIC_COPY_OFF_H 1#include <CGAL/basic.h>#include <cstddef>#include <CGAL/IO/File_header_OFF.h>#include <CGAL/IO/File_scanner_OFF.h>#include <iostream>CGAL_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 + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -