Skip to content

File simplicial_complex_io.h

File List > include > uipc > io > simplicial_complex_io.h

Go to the documentation of this file

#pragma once
#include <uipc/common/exception.h>
#include <uipc/geometry/simplicial_complex.h>


namespace uipc::geometry
{
class UIPC_IO_API SimplicialComplexIO
{
  public:
    SimplicialComplexIO() = default;
    explicit SimplicialComplexIO(const Matrix4x4& pre_transform) noexcept;
    explicit SimplicialComplexIO(const Transform& pre_transform) noexcept;

    // default copy/move ctor/assignment
    SimplicialComplexIO(const SimplicialComplexIO&)            = default;
    SimplicialComplexIO(SimplicialComplexIO&&)                 = default;
    SimplicialComplexIO& operator=(const SimplicialComplexIO&) = default;
    SimplicialComplexIO& operator=(SimplicialComplexIO&&)      = default;

    [[nodiscard]] SimplicialComplex read(std::string_view file_name);

    [[nodiscard]] SimplicialComplex read_msh(std::string_view file_name);

    [[nodiscard]] SimplicialComplex read_obj(std::string_view file_name);

    [[nodiscard]] SimplicialComplex read_ply(std::string_view file_name);


    void write(std::string_view file_name, const SimplicialComplex& sc);

    void write_obj(std::string_view file_name, const SimplicialComplex& sc);

    void write_msh(std::string_view file_name, const SimplicialComplex& sc);

  private:
    Matrix4x4 m_pre_transform = Matrix4x4::Identity();
    void      apply_pre_transform(Vector3& v) const noexcept;
};
}  // namespace uipc::geometry

namespace uipc::geometry
{
class GeometryIOError : public Exception
{
  public:
    using Exception::Exception;
};
}  // namespace uipc::geometry