mirror of
https://github.com/FULU-Foundation/OrcaSlicer-bambulab.git
synced 2026-05-14 13:02:39 -07:00
282 lines
9.1 KiB
C++
282 lines
9.1 KiB
C++
//#include "ConfigBase.hpp"
|
|
#include "Config.hpp"
|
|
#include "Geometry.hpp"
|
|
//#include "IO.hpp"
|
|
#include "Model.hpp"
|
|
//#include "SLAPrint.hpp"
|
|
#include "Print.hpp"
|
|
#include "TriangleMesh.hpp"
|
|
#include "Format/3mf.hpp"
|
|
#include "libslic3r.h"
|
|
#include <cstdio>
|
|
#include <string>
|
|
#include <cstring>
|
|
#include <iostream>
|
|
#include <math.h>
|
|
#include <boost/filesystem.hpp>
|
|
#include <boost/nowide/args.hpp>
|
|
#include <boost/nowide/iostream.hpp>
|
|
|
|
#ifdef USE_WX
|
|
// #include "GUI/GUI.hpp"
|
|
#endif
|
|
#include "slic3r/GUI/GUI.hpp"
|
|
|
|
using namespace Slic3r;
|
|
|
|
// wxWidgets "Hello world" Program
|
|
// For compilers that support precompilation, includes "wx/wx.h".
|
|
#include <wx/wxprec.h>
|
|
#ifndef WX_PRECOMP
|
|
#include <wx/wx.h>
|
|
#endif
|
|
class MyApp: public wxApp
|
|
{
|
|
public:
|
|
virtual bool OnInit();
|
|
};
|
|
class MyFrame: public wxFrame
|
|
{
|
|
public:
|
|
MyFrame(const wxString& title, const wxPoint& pos, const wxSize& size);
|
|
private:
|
|
void OnHello(wxCommandEvent& event);
|
|
void OnExit(wxCommandEvent& event);
|
|
void OnAbout(wxCommandEvent& event);
|
|
wxDECLARE_EVENT_TABLE();
|
|
};
|
|
enum
|
|
{
|
|
ID_Hello = 1
|
|
};
|
|
wxBEGIN_EVENT_TABLE(MyFrame, wxFrame)
|
|
EVT_MENU(ID_Hello, MyFrame::OnHello)
|
|
EVT_MENU(wxID_EXIT, MyFrame::OnExit)
|
|
EVT_MENU(wxID_ABOUT, MyFrame::OnAbout)
|
|
wxEND_EVENT_TABLE()
|
|
bool MyApp::OnInit()
|
|
{
|
|
MyFrame *frame = new MyFrame( "Hello World", wxPoint(50, 50), wxSize(450, 340) );
|
|
frame->Show( true );
|
|
return true;
|
|
}
|
|
MyFrame::MyFrame(const wxString& title, const wxPoint& pos, const wxSize& size)
|
|
: wxFrame(NULL, wxID_ANY, title, pos, size)
|
|
{
|
|
wxMenu *menuFile = new wxMenu;
|
|
menuFile->Append(ID_Hello, "&Hello...\tCtrl-H",
|
|
"Help string shown in status bar for this menu item");
|
|
menuFile->AppendSeparator();
|
|
menuFile->Append(wxID_EXIT);
|
|
wxMenu *menuHelp = new wxMenu;
|
|
menuHelp->Append(wxID_ABOUT);
|
|
wxMenuBar *menuBar = new wxMenuBar;
|
|
menuBar->Append( menuFile, "&File" );
|
|
menuBar->Append( menuHelp, "&Help" );
|
|
SetMenuBar( menuBar );
|
|
CreateStatusBar();
|
|
SetStatusText( "Welcome to wxWidgets!" );
|
|
Slic3r::Model model;
|
|
ModelObject *object = model.add_object();
|
|
SetStatusText(Slic3r::GUI::from_u8("HHuhuh"));
|
|
}
|
|
|
|
void MyFrame::OnExit(wxCommandEvent& event)
|
|
{
|
|
Close( true );
|
|
}
|
|
void MyFrame::OnAbout(wxCommandEvent& event)
|
|
{
|
|
wxMessageBox( "This is a wxWidgets' Hello world sample",
|
|
"About Hello World", wxOK | wxICON_INFORMATION );
|
|
}
|
|
void MyFrame::OnHello(wxCommandEvent& event)
|
|
{
|
|
wxLogMessage("Hello world from wxWidgets!");
|
|
}
|
|
|
|
/// utility function for displaying CLI usage
|
|
void printUsage();
|
|
|
|
using namespace Slic3r;
|
|
|
|
int main(int argc, char **argv)
|
|
{
|
|
// Convert arguments to UTF-8 (needed on Windows). argv then points to memory owned by a.
|
|
boost::nowide::args a(argc, argv);
|
|
|
|
// parse all command line options into a DynamicConfig
|
|
DynamicPrintAndCLIConfig config;
|
|
t_config_option_keys input_files;
|
|
// if any option is unsupported, print usage and abort immediately
|
|
if (! config.read_cli(argc, argv, &input_files)) {
|
|
printUsage();
|
|
return 0;
|
|
}
|
|
|
|
// apply command line options to a more handy CLIConfig
|
|
CLIConfig cli_config;
|
|
cli_config.apply(config, true);
|
|
|
|
DynamicPrintConfig print_config;
|
|
|
|
#if 1
|
|
MyApp *gui = new MyApp();
|
|
|
|
MyApp::SetInstance(gui);
|
|
wxEntry(argc, argv);
|
|
#endif
|
|
|
|
#ifdef USE_WX
|
|
if (cli_config.gui) {
|
|
GUI::App *gui = new GUI::App();
|
|
GUI::App::SetInstance(gui);
|
|
wxEntry(argc, argv);
|
|
}
|
|
#else
|
|
if (cli_config.gui) {
|
|
std::cout << "GUI support has not been built." << "\n";
|
|
}
|
|
#endif
|
|
// load config files supplied via --load
|
|
for (const std::string &file : cli_config.load.values) {
|
|
if (!boost::filesystem::exists(file)) {
|
|
boost::nowide::cout << "No such file: " << file << std::endl;
|
|
exit(1);
|
|
}
|
|
DynamicPrintConfig c;
|
|
try {
|
|
c.load(file);
|
|
} catch (std::exception &e) {
|
|
boost::nowide::cout << "Error while reading config file: " << e.what() << std::endl;
|
|
exit(1);
|
|
}
|
|
c.normalize();
|
|
print_config.apply(c);
|
|
}
|
|
|
|
// apply command line options to a more specific DynamicPrintConfig which provides normalize()
|
|
// (command line options override --load files)
|
|
print_config.apply(config, true);
|
|
print_config.normalize();
|
|
|
|
// write config if requested
|
|
if (! cli_config.save.value.empty())
|
|
print_config.save(cli_config.save.value);
|
|
|
|
// read input file(s) if any
|
|
std::vector<Model> models;
|
|
for (const t_config_option_key &file : input_files) {
|
|
if (! boost::filesystem::exists(file)) {
|
|
boost::nowide::cerr << "No such file: " << file << std::endl;
|
|
exit(1);
|
|
}
|
|
|
|
Model model;
|
|
try {
|
|
model = Model::read_from_file(file);
|
|
} catch (std::exception &e) {
|
|
boost::nowide::cerr << file << ": " << e.what() << std::endl;
|
|
exit(1);
|
|
}
|
|
|
|
if (model.objects.empty()) {
|
|
boost::nowide::cerr << "Error: file is empty: " << file << std::endl;
|
|
continue;
|
|
}
|
|
|
|
model.add_default_instances();
|
|
|
|
// apply command line transform options
|
|
for (ModelObject* o : model.objects) {
|
|
/*
|
|
if (cli_config.scale_to_fit.is_positive_volume())
|
|
o->scale_to_fit(cli_config.scale_to_fit.value);
|
|
*/
|
|
// TODO: honor option order?
|
|
o->scale(cli_config.scale.value);
|
|
o->rotate(Geometry::deg2rad(cli_config.rotate_x.value), X);
|
|
o->rotate(Geometry::deg2rad(cli_config.rotate_y.value), Y);
|
|
o->rotate(Geometry::deg2rad(cli_config.rotate.value), Z);
|
|
}
|
|
|
|
// TODO: handle --merge
|
|
models.push_back(model);
|
|
}
|
|
if (cli_config.help) {
|
|
printUsage();
|
|
return 0;
|
|
}
|
|
|
|
for (Model &model : models) {
|
|
if (cli_config.info) {
|
|
// --info works on unrepaired model
|
|
model.print_info();
|
|
} else if (cli_config.export_3mf) {
|
|
std::string outfile = cli_config.output.value;
|
|
if (outfile.empty()) outfile = model.objects.front()->input_file;
|
|
// Check if the file is already a 3mf.
|
|
if(outfile.substr(outfile.find_last_of('.'), outfile.length()) == ".3mf")
|
|
outfile = outfile.substr(0, outfile.find_last_of('.')) + "_2" + ".3mf";
|
|
else
|
|
// Remove the previous extension and add .3mf extention.
|
|
outfile = outfile.substr(0, outfile.find_last_of('.')) + ".3mf";
|
|
store_3mf(outfile.c_str(), &model, nullptr, false);
|
|
boost::nowide::cout << "File file exported to " << outfile << std::endl;
|
|
} else if (cli_config.cut > 0) {
|
|
model.repair();
|
|
model.translate(0, 0, - model.bounding_box().min(2));
|
|
if (! model.objects.empty()) {
|
|
Model out;
|
|
model.objects.front()->cut(cli_config.cut, &out);
|
|
ModelObject &upper = *out.objects[0];
|
|
ModelObject &lower = *out.objects[1];
|
|
// Use the input name and trim off the extension.
|
|
std::string outfile = cli_config.output.value;
|
|
if (outfile.empty())
|
|
outfile = model.objects.front()->input_file;
|
|
outfile = outfile.substr(0, outfile.find_last_of('.'));
|
|
std::cerr << outfile << "\n";
|
|
if (upper.facets_count() > 0)
|
|
upper.mesh().write_binary((outfile + "_upper.stl").c_str());
|
|
if (lower.facets_count() > 0)
|
|
lower.mesh().write_binary((outfile + "_lower.stl").c_str());
|
|
}
|
|
} else if (cli_config.slice) {
|
|
std::string outfile = cli_config.output.value;
|
|
Print print;
|
|
model.arrange_objects(print.config().min_object_distance());
|
|
model.center_instances_around_point(cli_config.center);
|
|
if (outfile.empty()) outfile = model.objects.front()->input_file + ".gcode";
|
|
print.apply_config(print_config);
|
|
for (auto* mo : model.objects) {
|
|
print.auto_assign_extruders(mo);
|
|
print.add_model_object(mo);
|
|
}
|
|
print.validate();
|
|
print.export_gcode(outfile, nullptr);
|
|
} else {
|
|
boost::nowide::cerr << "error: command not supported" << std::endl;
|
|
return 1;
|
|
}
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
void printUsage()
|
|
{
|
|
std::cout << "Slic3r " << SLIC3R_VERSION << " is a STL-to-GCODE translator for RepRap 3D printers" << "\n"
|
|
<< "written by Alessandro Ranellucci <aar@cpan.org> - http://slic3r.org/ - https://github.com/slic3r/Slic3r" << "\n"
|
|
// << "Git Version " << BUILD_COMMIT << "\n\n"
|
|
<< "Usage: ./slic3r [ OPTIONS ] [ file.stl ] [ file2.stl ] ..." << "\n";
|
|
// CLI Options
|
|
std::cout << "** CLI OPTIONS **\n";
|
|
print_cli_options(boost::nowide::cout);
|
|
std::cout << "****\n";
|
|
// Print options
|
|
std::cout << "** PRINT OPTIONS **\n";
|
|
print_print_options(boost::nowide::cout);
|
|
std::cout << "****\n";
|
|
}
|