// This file is part of libigl, a simple c++ geometry processing library. // // Copyright (C) 2013 Alec Jacobson // Copyright (C) 2020 Jérémie Dumas // // This Source Code Form is subject to the terms of the Mozilla Public License // v. 2.0. If a copy of the MPL was not distributed with this file, You can // obtain one at http://mozilla.org/MPL/2.0/. #ifndef IGL_READSTL_H #define IGL_READSTL_H #include "igl_inline.h" #ifndef IGL_NO_EIGEN # include #endif #include #include #include #include namespace igl { /// Read a mesh from an ascii/binary stl file. /// /// @tparam Scalar type for positions and vectors (will be read as double and cast /// to Scalar) /// @param[in] filename path to .stl file /// @param[out] V double matrix of vertex positions #V*3 by 3 /// @param[out] F index matrix of triangle indices #F by 3 /// @param[out] N double matrix of surface normals #F by 3 /// @return true on success, false on errors /// /// #### Example /// /// bool success = readSTL(filename,temp_V,F,N); /// remove_duplicate_vertices(temp_V,0,V,SVI,SVJ); /// for_each(F.data(),F.data()+F.size(),[&SVJ](int & f){f=SVJ(f);}); /// writeOBJ("Downloads/cat.obj",V,F); template IGL_INLINE bool readSTL( std::istream &input, Eigen::PlainObjectBase & V, Eigen::PlainObjectBase & F, Eigen::PlainObjectBase & N); /// \overload template IGL_INLINE bool readSTL( std::istream &input, std::vector > & V, std::vector > & F, std::vector > & N); /// \overload /// @param[in,out] fp pointer to ply file (will be closed) template IGL_INLINE bool readSTL( FILE * fp, Eigen::PlainObjectBase & V, Eigen::PlainObjectBase & F, Eigen::PlainObjectBase & N); } #ifndef IGL_STATIC_LIBRARY # include "readSTL.cpp" #endif #endif