mirror of
https://github.com/FULU-Foundation/OrcaSlicer-bambulab.git
synced 2026-06-06 05:42:59 -04:00
All requested config values are written into SL1 ini file inside the zip * TIme.hpp and Time.cpp is now part of libslic3r instead of libslic3r_gui * Updated time manipulation function: separate timestamp_local_str and timestamp_utc_str * timestamp_utc_str is used in header_slic3r_generated(). Gcode now contains UTC timestamps
132 lines
4.1 KiB
C++
132 lines
4.1 KiB
C++
#include "SLARasterWriter.hpp"
|
|
#include "libslic3r/Zipper.hpp"
|
|
#include "libslic3r/Time.hpp"
|
|
|
|
#include "ExPolygon.hpp"
|
|
#include <libnest2d/backends/clipper/clipper_polygon.hpp>
|
|
|
|
#include <boost/log/trivial.hpp>
|
|
#include <boost/filesystem/path.hpp>
|
|
|
|
namespace Slic3r { namespace sla {
|
|
|
|
std::string SLARasterWriter::createIniContent(const std::string& projectname) const
|
|
{
|
|
std::string out("action = print\njobDir = ");
|
|
out += projectname + "\n";
|
|
|
|
for (auto ¶m : m_config)
|
|
out += param.first + " = " + param.second + "\n";
|
|
|
|
return out;
|
|
}
|
|
|
|
void SLARasterWriter::flpXY(ClipperLib::Polygon &poly)
|
|
{
|
|
for(auto& p : poly.Contour) std::swap(p.X, p.Y);
|
|
std::reverse(poly.Contour.begin(), poly.Contour.end());
|
|
|
|
for(auto& h : poly.Holes) {
|
|
for(auto& p : h) std::swap(p.X, p.Y);
|
|
std::reverse(h.begin(), h.end());
|
|
}
|
|
}
|
|
|
|
void SLARasterWriter::flpXY(ExPolygon &poly)
|
|
{
|
|
for(auto& p : poly.contour.points) p = Point(p.y(), p.x());
|
|
std::reverse(poly.contour.points.begin(), poly.contour.points.end());
|
|
|
|
for(auto& h : poly.holes) {
|
|
for(auto& p : h.points) p = Point(p.y(), p.x());
|
|
std::reverse(h.points.begin(), h.points.end());
|
|
}
|
|
}
|
|
|
|
SLARasterWriter::SLARasterWriter(const Raster::Resolution &res,
|
|
const Raster::PixelDim &pixdim,
|
|
const std::array<bool, 2> &mirror,
|
|
double gamma)
|
|
: m_res(res), m_pxdim(pixdim), m_mirror(mirror), m_gamma(gamma)
|
|
{
|
|
// PNG raster will implicitly do an Y mirror
|
|
m_mirror[1] = !m_mirror[1];
|
|
}
|
|
|
|
void SLARasterWriter::save(const std::string &fpath, const std::string &prjname)
|
|
{
|
|
try {
|
|
Zipper zipper(fpath); // zipper with no compression
|
|
|
|
std::string project = prjname.empty()?
|
|
boost::filesystem::path(fpath).stem().string() : prjname;
|
|
|
|
zipper.add_entry("config.ini");
|
|
|
|
zipper << createIniContent(project);
|
|
|
|
for(unsigned i = 0; i < m_layers_rst.size(); i++)
|
|
{
|
|
if(m_layers_rst[i].rawbytes.size() > 0) {
|
|
char lyrnum[6];
|
|
std::sprintf(lyrnum, "%.5d", i);
|
|
auto zfilename = project + lyrnum + ".png";
|
|
|
|
// Add binary entry to the zipper
|
|
zipper.add_entry(zfilename,
|
|
m_layers_rst[i].rawbytes.data(),
|
|
m_layers_rst[i].rawbytes.size());
|
|
}
|
|
}
|
|
|
|
zipper.finalize();
|
|
} catch(std::exception& e) {
|
|
BOOST_LOG_TRIVIAL(error) << e.what();
|
|
// Rethrow the exception
|
|
throw;
|
|
}
|
|
}
|
|
|
|
namespace {
|
|
|
|
std::string get_cfg_value(const DynamicPrintConfig &cfg, const std::string &key)
|
|
{
|
|
std::string ret;
|
|
|
|
if (cfg.has(key)) {
|
|
auto opt = cfg.option(key);
|
|
if (opt) ret = opt->serialize();
|
|
}
|
|
|
|
return ret;
|
|
}
|
|
|
|
} // namespace
|
|
|
|
void SLARasterWriter::set_config(const DynamicPrintConfig &cfg)
|
|
{
|
|
m_config["layerHeight"] = get_cfg_value(cfg, "layer_height");
|
|
m_config["expTime"] = get_cfg_value(cfg, "exposure_time");
|
|
m_config["expTimeFirst"] = get_cfg_value(cfg, "initial_exposure_time");
|
|
m_config["materialName"] = get_cfg_value(cfg, "sla_material_settings_id");
|
|
m_config["printerModel"] = get_cfg_value(cfg, "printer_model");
|
|
m_config["printerVariant"] = get_cfg_value(cfg, "printer_variant");
|
|
m_config["printerProfile"] = get_cfg_value(cfg, "printer_settings_id");
|
|
m_config["printProfile"] = get_cfg_value(cfg, "sla_print_settings_id");
|
|
|
|
m_config["fileCreationTimestamp"] = Utils::current_utc_time2str();
|
|
m_config["prusaSlicerVersion"] = SLIC3R_BUILD_ID;
|
|
}
|
|
|
|
void SLARasterWriter::set_statistics(const PrintStatistics &stats)
|
|
{
|
|
m_config["usedMaterial"] = std::to_string(stats.used_material);
|
|
m_config["numFade"] = std::to_string(stats.num_fade);
|
|
m_config["numSlow"] = std::to_string(stats.num_slow);
|
|
m_config["numFast"] = std::to_string(stats.num_fast);
|
|
m_config["printTime"] = std::to_string(stats.estimated_print_time_s);
|
|
}
|
|
|
|
} // namespace sla
|
|
} // namespace Slic3r
|