//#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 #include #include #include #include #include #include #include #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 #ifndef WX_PRECOMP #include #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 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 - 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"; }