#ifndef slic3r_Format_3mf_hpp_ #define slic3r_Format_3mf_hpp_ namespace Slic3r { /* The format for saving the SLA points was changing in the past. This enum holds the latest version that is being currently used. * Examples of the Slic3r_PE_sla_support_points.txt for historically used versions: * version 0 : object_id=1|-12.055421 -2.658771 10.000000 object_id=2|-14.051745 -3.570338 5.000000 // no header and x,y,z positions of the points) * version 1 : ThreeMF_support_points_version=1 object_id=1|-12.055421 -2.658771 10.000000 0.4 0.0 object_id=2|-14.051745 -3.570338 5.000000 0.6 1.0 // introduced header with version number; x,y,z,head_size,is_new_island) */ enum { support_points_format_version = 1 }; enum { drain_holes_format_version = 1 }; class Model; class DynamicPrintConfig; struct ThumbnailData; // Load the content of a 3mf file into the given model and preset bundle. extern bool load_3mf(const char* path, DynamicPrintConfig* config, Model* model, bool check_version); // Save the given model and the config data contained in the given Print into a 3mf file. // The model could be modified during the export process if meshes are not repaired or have no shared vertices extern bool store_3mf(const char* path, Model* model, const DynamicPrintConfig* config, bool fullpath_sources, const ThumbnailData* thumbnail_data = nullptr, bool zip64 = true); } // namespace Slic3r #endif /* slic3r_Format_3mf_hpp_ */