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

📄 file_writer_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/File_writer_OFF.h $// $Id: File_writer_OFF.h 35787 2007-01-24 17:16:05Z spion $// //// Author(s)     : Lutz Kettner  <kettner@mpi-sb.mpg.de>#ifndef CGAL_IO_FILE_WRITER_OFF_H#define CGAL_IO_FILE_WRITER_OFF_H 1#include <CGAL/IO/binary_file_io.h>#include <CGAL/IO/File_header_OFF.h>#include <iostream>#include <cstddef>CGAL_BEGIN_NAMESPACEclass File_writer_OFF {    std::ostream*           m_out;    File_header_OFF         m_header;public:    File_writer_OFF( bool verbose = false) : m_header( verbose) {}    File_writer_OFF( const File_header_OFF& h) : m_header( h) {}    std::ostream&           out()          { return *m_out;   }    File_header_OFF&        header()       { return m_header; }    const File_header_OFF&  header() const { return m_header; }    void write_header( std::ostream& out,                       std::size_t   vertices,                       std::size_t   halfedges,                       std::size_t   facets,                       bool          normals = false);    void write_footer() {        if ( m_header.ascii() && m_header.comments())            out() << "\n\n# End of OFF #";        out() << std::endl;    }    void write_vertex( const double& x, const double& y, const double& z) {        if ( m_header.binary()) {            I_Binary_write_big_endian_float32( out(), float(x));            I_Binary_write_big_endian_float32( out(), float(y));            I_Binary_write_big_endian_float32( out(), float(z));        } else {            out() << '\n' << x << ' ' << y << ' ' << z;        }    }    void write_normal( const double& x, const double& y, const double& z) {        if ( m_header.binary()) {            I_Binary_write_big_endian_float32( out(), float(x));            I_Binary_write_big_endian_float32( out(), float(y));            I_Binary_write_big_endian_float32( out(), float(z));        } else {            out() << ' ' << ' ' << x << ' ' << y << ' ' << z;        }    }    void write_facet_header() {        if ( m_header.ascii()) {            if ( m_header.no_comments())                out() << '\n';            else {                out() << "\n\n# " << m_header.size_of_facets()                       << " facets\n";                out() << "# ------------------------------------------"                          "\n\n";            }        }    }    void write_facet_begin( std::size_t no) {        if ( m_header.binary())            I_Binary_write_big_endian_integer32( out(), no);        else            out() << no << ' ';    }    void write_facet_vertex_index( std::size_t index) {        if ( m_header.binary())            I_Binary_write_big_endian_integer32( out(), index);        else            out() << ' ' << index;    }    void write_facet_end() {        if ( m_header.binary())            I_Binary_write_big_endian_integer32( out(), 0);        else            out() << '\n';    }};CGAL_END_NAMESPACE#endif // CGAL_IO_FILE_WRITER_OFF_H //// EOF //

⌨️ 快捷键说明

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