// Copyright (c) 2015-2020 GeometryFactory (France). All rights reserved. // // This file is part of CGAL (www.cgal.org) // // $URL$ // $Id$ // SPDX-License-Identifier: LGPL-3.0-or-later OR LicenseRef-Commercial // // Author(s) : Andreas Fabri // Mael Rouxel-Labbé #ifndef CGAL_BGL_IO_OFF_H #define CGAL_BGL_IO_OFF_H #include #include #include #include #include #include #include #include #include #include #include #include #ifdef DOXYGEN_RUNNING #define CGAL_BGL_NP_TEMPLATE_PARAMETERS NamedParameters #define CGAL_BGL_NP_CLASS NamedParameters #endif namespace CGAL { //////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////// // Read namespace IO { namespace internal { // Use CRTP to gain access to the protected members without getters/setters. template class OFF_builder : public Generic_facegraph_builder > { typedef OFF_builder Self; typedef Generic_facegraph_builder Base; typedef typename Base::Point_container Point_container; typedef typename Base::Face Face; typedef typename Base::Face_container Face_container; public: OFF_builder(std::istream& is) : Base(is) { } template bool read(std::istream& is, Point_container& points, Face_container& faces, const NamedParameters& np) { return read_OFF(is, points, faces, np); } }; // Because some packages can provide overloads with the same signature to automatically initialize // property maps (see Surface_mesh/IO/ for example) template bool read_OFF_BGL(std::istream& is, Graph& g, const CGAL_BGL_NP_CLASS& np) { typedef typename CGAL::GetVertexPointMap::type VPM; typedef typename boost::property_traits::value_type Point; IO::internal::OFF_builder builder(is); return builder(g, np); } } // namespace internal } // namespace IO /*! \ingroup PkgBGLIoFuncsOFF \brief reads the graph `g` from data in the input stream, using the \ref IOStreamOFF. This function reads the point property as well as vertex normals (NOFF), vertex and face colors (COFF), and texture vertex coordinates (TOFF). Those properties are stored in property maps that are passed through named parameters (see below), when passed. Ignores comment lines which start with a hash, and lines with whitespace. \attention The graph `g` is not cleared, and the data from the stream is added. \tparam Graph a model of `MutableFaceGraph` \tparam NamedParameters a sequence of \ref bgl_namedparameters "Named Parameters" \param is the input stream \param g the graph to be built from the input data \param np optional \ref bgl_namedparameters "Named Parameters" described below \cgalNamedParamsBegin \cgalParamNBegin{vertex_point_map} \cgalParamDescription{a property map associating points to the vertices of `g`} \cgalParamType{a class model of `ReadWritePropertyMap` with `boost::graph_traits::%vertex_descriptor` as key type and `%Point_3` as value type} \cgalParamDefault{`boost::get(CGAL::vertex_point, g)`} \cgalParamExtra{If this parameter is omitted, an internal property map for `CGAL::vertex_point_t` must be available in `Graph`.} \cgalParamNEnd \cgalParamNBegin{vertex_normal_map} \cgalParamDescription{a property map associating normals to the vertices of `g`} \cgalParamType{a class model of `ReadWritePropertyMap` with `boost::graph_traits::%vertex_descriptor` as key type and `%Vector_3` as value type} \cgalParamDefault{vertex normals that may exist in the input will be ignored} \cgalParamNEnd \cgalParamNBegin{vertex_color_map} \cgalParamDescription{a property map associating colors to the vertices of `g`} \cgalParamType{a class model of `ReadWritePropertyMap` with `boost::graph_traits::%vertex_descriptor` as key type and `CGAL::Color` as value type} \cgalParamDefault{vertex colors that may exist in the input will be ignored} \cgalParamNEnd \cgalParamNBegin{vertex_texture_map} \cgalParamDescription{a property map associating textures to the vertices of `g`} \cgalParamType{a class model of `ReadWritePropertyMap` with `boost::graph_traits::%vertex_descriptor` as key type and `%Point_2` as value type} \cgalParamDefault{vertex textures that may exist in the input will be ignored} \cgalParamNEnd \cgalParamNBegin{face_color_map} \cgalParamDescription{a property map associating colors to the faces of `g`} \cgalParamType{a class model of `ReadWritePropertyMap` with `boost::graph_traits::%face_descriptor` as key type and `CGAL::Color` as value type} \cgalParamDefault{face colors that may exist in the input will be ignored} \cgalParamNEnd \cgalParamNBegin{verbose} \cgalParamDescription{whether extra information is printed when an incident occurs during reading} \cgalParamType{Boolean} \cgalParamDefault{`true`} \cgalParamNEnd \cgalNamedParamsEnd \pre The data must represent a 2-manifold \returns `true` if reading was succesful and the resulting mesh is valid, `false` otherwise. \sa Overloads of this function for specific models of the concept `FaceGraph`. */ template bool read_OFF(std::istream& is, Graph& g, const CGAL_BGL_NP_CLASS& np #ifndef DOXYGEN_RUNNING , typename boost::disable_if >::type* = nullptr #endif ) { return IO::internal::read_OFF_BGL(is, g, np); } /// \cond SKIP_IN_MANUAL template bool read_OFF(std::istream& is, Graph& g, typename boost::disable_if >::type* = nullptr) { return read_OFF(is, g, parameters::all_default()); } /// \endcond /*! \ingroup PkgBGLIoFuncsOFF \brief reads the graph `g` from the file `fname`, using the \ref IOStreamOFF. This function reads the point property as well as vertex normals (NOFF), vertex and face colors (COFF), and texture vertex coordinates (TOFF). Those properties are stored in property maps that are passed through named parameters (see below), when passed. Ignores comment lines which start with a hash, and lines with whitespace. \attention The graph `g` is not cleared, and the data from the stream is added. \tparam Graph a model of `MutableFaceGraph` \tparam NamedParameters a sequence of \ref bgl_namedparameters "Named Parameters" \param fname the name of the input file \param g the graph to be built from the input data \param np optional \ref bgl_namedparameters "Named Parameters" described below \cgalNamedParamsBegin \cgalParamNBegin{vertex_point_map} \cgalParamDescription{a property map associating points to the vertices of `g`} \cgalParamType{a class model of `ReadWritePropertyMap` with `boost::graph_traits::%vertex_descriptor` as key type and `%Point_3` as value type} \cgalParamDefault{`boost::get(CGAL::vertex_point, g)`} \cgalParamExtra{If this parameter is omitted, an internal property map for `CGAL::vertex_point_t` must be available in `Graph`.} \cgalParamNEnd \cgalParamNBegin{vertex_normal_map} \cgalParamDescription{a property map associating normals to the vertices of `g`} \cgalParamType{a class model of `ReadWritePropertyMap` with `boost::graph_traits::%vertex_descriptor` as key type and `%Vector_3` as value type} \cgalParamDefault{vertex normals that may exist in the input will be ignored} \cgalParamNEnd \cgalParamNBegin{vertex_color_map} \cgalParamDescription{a property map associating colors to the vertices of `g`} \cgalParamType{a class model of `ReadWritePropertyMap` with `boost::graph_traits::%vertex_descriptor` as key type and `CGAL::Color` as value type} \cgalParamDefault{vertex colors that may exist in the input will be ignored} \cgalParamNEnd \cgalParamNBegin{vertex_texture_map} \cgalParamDescription{a property map associating textures to the vertices of `g`} \cgalParamType{a class model of `ReadWritePropertyMap` with `boost::graph_traits::%vertex_descriptor` as key type and `%Point_2` as value type} \cgalParamDefault{vertex textures that may exist in the input will be ignored} \cgalParamNEnd \cgalParamNBegin{face_color_map} \cgalParamDescription{a property map associating colors to the faces of `g`} \cgalParamType{a class model of `ReadWritePropertyMap` with `boost::graph_traits::%face_descriptor` as key type and `CGAL::Color` as value type} \cgalParamDefault{face colors that may exist in the input will be ignored} \cgalParamNEnd \cgalParamNBegin{verbose} \cgalParamDescription{whether extra information is printed when an incident occurs during reading} \cgalParamType{Boolean} \cgalParamDefault{`true`} \cgalParamNEnd \cgalNamedParamsEnd \pre The data must represent a 2-manifold \returns `true` if reading was succesful and the resulting mesh is valid, `false` otherwise. \sa Overloads of this function for specific models of the concept `FaceGraph`. */ template bool read_OFF(const char* fname, Graph& g, const CGAL_BGL_NP_CLASS& np #ifndef DOXYGEN_RUNNING , typename boost::disable_if >::type* = nullptr #endif ) { std::ifstream is(fname); return read_OFF(is, g, np); } /// \cond SKIP_IN_MANUAL template bool read_OFF(const char* fname, Graph& g, typename boost::disable_if >::type* = nullptr) { return read_OFF(fname, g, parameters::all_default()); } template bool read_OFF(const std::string& fname, Graph& g, const CGAL_BGL_NP_CLASS& np) { return read_OFF(fname.c_str(), g, np); } template bool read_OFF(const std::string& fname, Graph& g, typename boost::disable_if >::type* = nullptr) { return read_OFF(fname, g, parameters::all_default()); } /// \endcond #ifndef CGAL_NO_DEPRECATED_CODE /*! \ingroup PkgBGLIOFctDeprecated \deprecated This function is deprecated since \cgal 5.2, `CGAL::read_OFF()` should be used instead. */ template CGAL_DEPRECATED bool read_off(std::ostream& os, Graph& g, const CGAL_BGL_NP_CLASS& np) { return read_OFF(os, g, np); } /*! \ingroup PkgBGLIOFctDeprecated \deprecated This function is deprecated since \cgal 5.2, `CGAL::read_OFF()` should be used instead. */ template CGAL_DEPRECATED bool read_off(const char* fname, Graph& g, const CGAL_BGL_NP_CLASS& np) { return read_OFF(fname, g, np); } #endif // CGAL_NO_DEPRECATED_CODE //////////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////////// // Write namespace IO { namespace internal { template bool write_OFF_BGL(std::ostream& os, const Graph& g, const CGAL_BGL_NP_CLASS& np) { IO::internal::Generic_facegraph_printer printer(os); return printer(g, np); } } // namespace internal } // namespace IO /*! \ingroup PkgBGLIoFuncsOFF \brief writes the graph `g` in the output stream, using the \ref IOStreamOFF. \tparam Graph a model of `FaceListGraph` and `HalfedgeListGraph` \tparam NamedParameters a sequence of \ref bgl_namedparameters "Named Parameters" \param os the output stream \param g the graph to be written \param np optional \ref bgl_namedparameters "Named Parameters" described below \cgalNamedParamsBegin \cgalParamNBegin{vertex_point_map} \cgalParamDescription{a property map associating points to the vertices of `g`} \cgalParamType{a class model of `ReadablePropertyMap` with `boost::graph_traits::%vertex_descriptor` as key type and `%Point_3` as value type} \cgalParamDefault{`boost::get(CGAL::vertex_point, g)`} \cgalParamExtra{If this parameter is omitted, an internal property map for `CGAL::vertex_point_t` must be available in `Graph`.} \cgalParamNEnd \cgalParamNBegin{vertex_normal_map} \cgalParamDescription{a property map associating normals to the vertices of `g`} \cgalParamType{a class model of `ReadablePropertyMap` with `boost::graph_traits::%vertex_descriptor` as key type and `%Vector_3` as value type} \cgalParamDefault{no vertex normals in the output} \cgalParamNEnd \cgalParamNBegin{vertex_color_map} \cgalParamDescription{a property map associating colors to the vertices of `g`} \cgalParamType{a class model of `ReadablePropertyMap` with `boost::graph_traits::%vertex_descriptor` as key type and `CGAL::Color` as value type} \cgalParamDefault{no vertex colors in the output} \cgalParamNEnd \cgalParamNBegin{vertex_texture_map} \cgalParamDescription{a property map associating textures to the vertices of `g`} \cgalParamType{a class model of `ReadablePropertyMap` with `boost::graph_traits::%vertex_descriptor` as key type and `%Point_2` as value type} \cgalParamDefault{no vertex textures in the output} \cgalParamNEnd \cgalParamNBegin{face_color_map} \cgalParamDescription{a property map associating colors to the faces of `g`} \cgalParamType{a class model of `ReadablePropertyMap` with `boost::graph_traits::%face_descriptor` as key type and `CGAL::Color` as value type} \cgalParamDefault{no face colors in the output} \cgalParamNEnd \cgalParamNBegin{stream_precision} \cgalParamDescription{a parameter used to set the precision (i.e. how many digits are generated) of the output stream} \cgalParamType{int} \cgalParamDefault{`6`} \cgalParamNEnd \cgalNamedParamsEnd \returns `true` if writing was successful, `false` otherwise. \sa Overloads of this function for specific models of the concept `FaceGraph`. */ template bool write_OFF(std::ostream& os, const Graph& g, const CGAL_BGL_NP_CLASS& np #ifndef DOXYGEN_RUNNING , typename boost::disable_if >::type* = nullptr #endif ) { return IO::internal::write_OFF_BGL(os, g, np); } /// \cond SKIP_IN_MANUAL template bool write_OFF(std::ostream& os, const Graph& g, typename boost::disable_if >::type* = nullptr) { return write_OFF(os, g, parameters::all_default()); } /// \endcond /*! \ingroup PkgBGLIoFuncsOFF \brief writes the graph `g` in the file `fname`, using the \ref IOStreamOFF. \tparam Graph a model of `FaceListGraph` and `HalfedgeListGraph` \tparam NamedParameters a sequence of \ref bgl_namedparameters "Named Parameters" \param fname the name of the output file \param g the graph to be written \param np optional \ref bgl_namedparameters "Named Parameters" described below \cgalNamedParamsBegin \cgalParamNBegin{vertex_point_map} \cgalParamDescription{a property map associating points to the vertices of `g`} \cgalParamType{a class model of `ReadablePropertyMap` with `boost::graph_traits::%vertex_descriptor` as key type and `%Point_3` as value type} \cgalParamDefault{`boost::get(CGAL::vertex_point, g)`} \cgalParamExtra{If this parameter is omitted, an internal property map for `CGAL::vertex_point_t` must be available in `Graph`.} \cgalParamNEnd \cgalParamNBegin{vertex_normal_map} \cgalParamDescription{a property map associating normals to the vertices of `g`} \cgalParamType{a class model of `ReadablePropertyMap` with `boost::graph_traits::%vertex_descriptor` as key type and `%Vector_3` as value type} \cgalParamDefault{no vertex normals in the output} \cgalParamNEnd \cgalParamNBegin{vertex_color_map} \cgalParamDescription{a property map associating colors to the vertices of `g`} \cgalParamType{a class model of `ReadablePropertyMap` with `boost::graph_traits::%vertex_descriptor` as key type and `CGAL::Color` as value type} \cgalParamDefault{no vertex colors in the output} \cgalParamNEnd \cgalParamNBegin{vertex_texture_map} \cgalParamDescription{a property map associating textures to the vertices of `g`} \cgalParamType{a class model of `ReadablePropertyMap` with `boost::graph_traits::%vertex_descriptor` as key type and `%Point_2` as value type} \cgalParamDefault{no vertex textures in the output} \cgalParamNEnd \cgalParamNBegin{face_color_map} \cgalParamDescription{a property map associating colors to the faces of `g`} \cgalParamType{a class model of `ReadablePropertyMap` with `boost::graph_traits::%face_descriptor` as key type and `CGAL::Color` as value type} \cgalParamDefault{no face colors in the output} \cgalParamNEnd \cgalParamNBegin{stream_precision} \cgalParamDescription{a parameter used to set the precision (i.e. how many digits are generated) of the output stream} \cgalParamType{int} \cgalParamDefault{`6`} \cgalParamNEnd \cgalNamedParamsEnd \returns `true` if writing was successful, `false` otherwise. \sa Overloads of this function for specific models of the concept `FaceGraph`. */ template bool write_OFF(const char* fname, const Graph& g, const CGAL_BGL_NP_CLASS& np #ifndef DOXYGEN_RUNNING , typename boost::disable_if >::type* = nullptr #endif ) { std::ofstream os(fname); if(!os) { std::cerr<<"Could not create file."; return false; } return write_OFF(os, g, np); } /// \cond SKIP_IN_MANUAL template bool write_OFF(const char* fname, const Graph& g, typename boost::disable_if >::type* = nullptr) { return write_OFF(fname, g, parameters::all_default()); } template bool write_OFF(const std::string& fname, const Graph& g, const CGAL_BGL_NP_CLASS& np, typename boost::disable_if >::type* = nullptr) { return write_OFF(fname.c_str(), g, np); } template bool write_OFF(const std::string& fname, const Graph& g, typename boost::disable_if >::type* = nullptr) { return write_OFF(fname.c_str(), g, parameters::all_default()); } /// \endcond #ifndef CGAL_NO_DEPRECATED_CODE /*! \ingroup PkgBGLIOFctDeprecated \deprecated This function is deprecated since \cgal 5.2, `CGAL::write_OFF()` should be used instead. */ template CGAL_DEPRECATED bool write_off(std::ostream& os, const Graph& g, const CGAL_BGL_NP_CLASS& np) { return write_OFF(os, g, np); } /*! \ingroup PkgBGLIOFctDeprecated \deprecated This function is deprecated since \cgal 5.2, `CGAL::write_OFF()` should be used instead. */ template CGAL_DEPRECATED bool write_off(const char* fname, const Graph& g, const CGAL_BGL_NP_CLASS& np) { return write_OFF(fname, g, np); } #endif // CGAL_NO_DEPRECATED_CODE } // namespace CGAL #endif // CGAL_BGL_IO_OFF_H