Load / Save a mesh
Load & Save
A mesh can be opened by using the generic function read_by_extension and written using write_by_extension:
#include <ultimaille/all.h>
using namespace UM;
int main() {
    // Get path of current executable
    const std::string input_dir = ASSETS_INPUT_DIR;
    const std::string ouput_dir = OUTPUT_DIR;
    // Declare a mesh with triangle surface
    Triangles m;
    // Loading catorus.geogram into m
    read_by_extension(input_dir + "catorus.geogram", m);
    // Display the number of vertices, facets and corners
    std::cout 
        << "n vertices: " << m.nverts() 
        << ", n facets: " << m.nfacets() 
        << ", n corners: " << m.ncorners() << std::endl;
    // Save mesh
    write_by_extension(ouput_dir + "catorus_cpy.obj", m);
    return 0;
}
Note
If the file fails to open, the user will be notified by an error message, for example when you try to open a non-existent file: Failed to open /home/tex/Projects/ultimaille-examples/build/examples/assets/unavailable_catorus.geogram
Warning
If the mesh type you're trying to open is not consistent with the mesh type supplied as a parameter, you won't get any errors, but only the vertices will be loaded. For example, you're trying to load a tri surface mesh into a Quads structure.
Supported file types
Ultimaille currently support reading and writing into the following file formats:
- .geogram(graphite)
- .mesh
- .vtk
- .xyz
- .obj