mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	Merge remote-tracking branch 'origin/master' into feature_arrange_with_libnest2d
This commit is contained in:
		
						commit
						3c32a7c3db
					
				
					 29 changed files with 540 additions and 105 deletions
				
			
		|  | @ -644,20 +644,62 @@ std::vector<int> GLVolumeCollection::load_object( | |||
|     return volumes_idx;  | ||||
| } | ||||
| 
 | ||||
| int GLVolumeCollection::load_wipe_tower_preview( | ||||
|     int obj_idx, float pos_x, float pos_y, float width, float depth, float height, float rotation_angle, bool use_VBOs) | ||||
| { | ||||
|     float color[4] = { 0.5f, 0.5f, 0.0f, 0.5f }; | ||||
|     this->volumes.emplace_back(new GLVolume(color)); | ||||
|     GLVolume &v = *this->volumes.back(); | ||||
| 
 | ||||
| int GLVolumeCollection::load_wipe_tower_preview( | ||||
|     int obj_idx, float pos_x, float pos_y, float width, float depth, float height, float rotation_angle, bool use_VBOs, bool size_unknown, float brim_width) | ||||
| { | ||||
|     if (depth < 0.01f) | ||||
|         return int(this->volumes.size() - 1); | ||||
|     if (height == 0.0f) | ||||
|         height = 0.1f; | ||||
| 
 | ||||
|     auto mesh = make_cube(width, depth, height); | ||||
|     mesh.translate(-width / 2.f, -depth / 2.f, 0.f); | ||||
|     Point origin_of_rotation(0.f, 0.f); | ||||
|     mesh.rotate(rotation_angle,&origin_of_rotation); | ||||
|     TriangleMesh mesh; | ||||
|     float color[4] = { 0.5f, 0.5f, 0.0f, 1.f }; | ||||
| 
 | ||||
|     // In case we don't know precise dimensions of the wipe tower yet, we'll draw the box with different color with one side jagged:
 | ||||
|     if (size_unknown) { | ||||
|         color[0] = 0.9f; | ||||
|         color[1] = 0.6f; | ||||
| 
 | ||||
|         depth = std::max(depth, 10.f); // Too narrow tower would interfere with the teeth. The estimate is not precise anyway.
 | ||||
|         float min_width = 30.f; | ||||
|         // We'll now create the box with jagged edge. y-coordinates of the pre-generated model are shifted so that the front
 | ||||
|         // edge has y=0 and centerline of the back edge has y=depth:
 | ||||
|         Pointf3s points; | ||||
|         std::vector<Point3> facets; | ||||
|         float out_points_idx[][3] = {{0, -depth, 0}, {0, 0, 0}, {38.453, 0, 0}, {61.547, 0, 0}, {100, 0, 0}, {100, -depth, 0}, {55.7735, -10, 0}, {44.2265, 10, 0}, | ||||
|                                      {38.453, 0, 1}, {0, 0, 1}, {0, -depth, 1}, {100, -depth, 1}, {100, 0, 1}, {61.547, 0, 1}, {55.7735, -10, 1}, {44.2265, 10, 1}}; | ||||
|         int out_facets_idx[][3] = {{0, 1, 2}, {3, 4, 5}, {6, 5, 0}, {3, 5, 6}, {6, 2, 7}, {6, 0, 2}, {8, 9, 10}, {11, 12, 13}, {10, 11, 14}, {14, 11, 13}, {15, 8, 14}, | ||||
|                                    {8, 10, 14}, {3, 12, 4}, {3, 13, 12}, {6, 13, 3}, {6, 14, 13}, {7, 14, 6}, {7, 15, 14}, {2, 15, 7}, {2, 8, 15}, {1, 8, 2}, {1, 9, 8}, | ||||
|                                    {0, 9, 1}, {0, 10, 9}, {5, 10, 0}, {5, 11, 10}, {4, 11, 5}, {4, 12, 11}}; | ||||
|         for (int i=0;i<16;++i) | ||||
|             points.push_back(Pointf3(out_points_idx[i][0] / (100.f/min_width), out_points_idx[i][1] + depth, out_points_idx[i][2])); | ||||
|         for (int i=0;i<28;++i) | ||||
|             facets.push_back(Point3(out_facets_idx[i][0], out_facets_idx[i][1], out_facets_idx[i][2])); | ||||
|         TriangleMesh tooth_mesh(points, facets); | ||||
| 
 | ||||
|         // We have the mesh ready. It has one tooth and width of min_width. We will now append several of these together until we are close to
 | ||||
|         // the required width of the block. Than we can scale it precisely.
 | ||||
|         size_t n = std::max(1, int(width/min_width)); // How many shall be merged?
 | ||||
|         for (size_t i=0;i<n;++i) { | ||||
|             mesh.merge(tooth_mesh); | ||||
|             tooth_mesh.translate(min_width, 0.f, 0.f); | ||||
|         } | ||||
| 
 | ||||
|         mesh.scale(Pointf3(width/(n*min_width), 1.f, height)); // Scaling to proper width
 | ||||
|     } | ||||
|     else | ||||
|         mesh = make_cube(width, depth, height); | ||||
| 
 | ||||
|     // We'll make another mesh to show the brim (fixed layer height):
 | ||||
|     TriangleMesh brim_mesh = make_cube(width+2.f*brim_width, depth+2.f*brim_width, 0.2f); | ||||
|     brim_mesh.translate(-brim_width, -brim_width, 0.f); | ||||
|     mesh.merge(brim_mesh); | ||||
| 
 | ||||
|     mesh.rotate(rotation_angle, &origin_of_rotation); // rotates the box according to the config rotation setting
 | ||||
| 
 | ||||
|     this->volumes.emplace_back(new GLVolume(color)); | ||||
|     GLVolume &v = *this->volumes.back(); | ||||
| 
 | ||||
|     if (use_VBOs) | ||||
|         v.indexed_vertex_array.load_mesh_full_shading(mesh); | ||||
|  |  | |||
|  | @ -401,7 +401,7 @@ public: | |||
|         bool                     use_VBOs); | ||||
| 
 | ||||
|     int load_wipe_tower_preview( | ||||
|         int obj_idx, float pos_x, float pos_y, float width, float depth, float height, float rotation_angle, bool use_VBOs); | ||||
|         int obj_idx, float pos_x, float pos_y, float width, float depth, float height, float rotation_angle, bool use_VBOs, bool size_unknown, float brim_width); | ||||
| 
 | ||||
|     // Render the volumes by OpenGL.
 | ||||
|     void render_VBOs() const; | ||||
|  |  | |||
|  | @ -305,10 +305,14 @@ const Pointfs& GLCanvas3D::Bed::get_shape() const | |||
|     return m_shape; | ||||
| } | ||||
| 
 | ||||
| void GLCanvas3D::Bed::set_shape(const Pointfs& shape) | ||||
| bool GLCanvas3D::Bed::set_shape(const Pointfs& shape) | ||||
| { | ||||
|     EType new_type = _detect_type(); | ||||
|     if (m_shape == shape && m_type == new_type) | ||||
|         // No change, no need to update the UI.
 | ||||
|         return false; | ||||
|     m_shape = shape; | ||||
|     m_type = _detect_type(); | ||||
|     m_type = new_type; | ||||
| 
 | ||||
|     _calc_bounding_box(); | ||||
| 
 | ||||
|  | @ -324,6 +328,8 @@ void GLCanvas3D::Bed::set_shape(const Pointfs& shape) | |||
|     _calc_gridlines(poly, bed_bbox); | ||||
| 
 | ||||
|     m_polygon = offset_ex(poly.contour, (float)bed_bbox.radius() * 1.7f, jtRound, scale_(0.5))[0].contour; | ||||
|     // Let the calee to update the UI.
 | ||||
|     return true; | ||||
| } | ||||
| 
 | ||||
| const BoundingBoxf3& GLCanvas3D::Bed::get_bounding_box() const | ||||
|  | @ -1941,9 +1947,7 @@ void GLCanvas3D::set_model(Model* model) | |||
| 
 | ||||
| void GLCanvas3D::set_bed_shape(const Pointfs& shape) | ||||
| { | ||||
|     bool new_shape = (shape != m_bed.get_shape()); | ||||
|     if (new_shape) | ||||
|         m_bed.set_shape(shape); | ||||
|     bool new_shape = m_bed.set_shape(shape); | ||||
| 
 | ||||
|     // Set the origin and size for painting of the coordinate system axes.
 | ||||
|     m_axes.origin = Pointf3(0.0, 0.0, (coordf_t)GROUND_Z); | ||||
|  | @ -2314,7 +2318,12 @@ void GLCanvas3D::reload_scene(bool force) | |||
|             float w = dynamic_cast<const ConfigOptionFloat*>(m_config->option("wipe_tower_width"))->value; | ||||
|             float a = dynamic_cast<const ConfigOptionFloat*>(m_config->option("wipe_tower_rotation_angle"))->value; | ||||
| 
 | ||||
|             m_volumes.load_wipe_tower_preview(1000, x, y, w, 15.0f * (float)(extruders_count - 1), (float)height, a, m_use_VBOs && m_initialized); | ||||
|             float depth = m_print->get_wipe_tower_depth(); | ||||
|             if (!m_print->state.is_done(psWipeTower)) | ||||
|                 depth = (900.f/w) * (float)(extruders_count - 1) ; | ||||
| 
 | ||||
|             m_volumes.load_wipe_tower_preview(1000, x, y, w, depth, (float)height, a, m_use_VBOs && m_initialized, !m_print->state.is_done(psWipeTower), | ||||
|                                               m_print->config.nozzle_diameter.values[0] * 1.25f * 4.5f); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|  | @ -4063,6 +4072,8 @@ void GLCanvas3D::_load_wipe_tower_toolpaths(const std::vector<std::string>& str_ | |||
|     { | ||||
|         const Print                 *print; | ||||
|         const std::vector<float>    *tool_colors; | ||||
|         WipeTower::xy                wipe_tower_pos; | ||||
|         float                        wipe_tower_angle; | ||||
| 
 | ||||
|         // Number of vertices (each vertex is 6x4=24 bytes long)
 | ||||
|         static const size_t          alloc_size_max() { return 131072; } // 3.15MB
 | ||||
|  | @ -4095,6 +4106,9 @@ void GLCanvas3D::_load_wipe_tower_toolpaths(const std::vector<std::string>& str_ | |||
|     if (m_print->m_wipe_tower_final_purge) | ||||
|         ctxt.final.emplace_back(*m_print->m_wipe_tower_final_purge.get()); | ||||
| 
 | ||||
|     ctxt.wipe_tower_angle = ctxt.print->config.wipe_tower_rotation_angle.value/180.f * M_PI; | ||||
|     ctxt.wipe_tower_pos = WipeTower::xy(ctxt.print->config.wipe_tower_x.value, ctxt.print->config.wipe_tower_y.value); | ||||
| 
 | ||||
|     BOOST_LOG_TRIVIAL(debug) << "Loading wipe tower toolpaths in parallel - start"; | ||||
| 
 | ||||
|     //FIXME Improve the heuristics for a grain size.
 | ||||
|  | @ -4152,12 +4166,25 @@ void GLCanvas3D::_load_wipe_tower_toolpaths(const std::vector<std::string>& str_ | |||
|                     lines.reserve(n_lines); | ||||
|                     widths.reserve(n_lines); | ||||
|                     heights.assign(n_lines, extrusions.layer_height); | ||||
|                     WipeTower::Extrusion e_prev = extrusions.extrusions[i-1]; | ||||
| 
 | ||||
|                     if (!extrusions.priming) { // wipe tower extrusions describe the wipe tower at the origin with no rotation
 | ||||
|                         e_prev.pos.rotate(ctxt.wipe_tower_angle); | ||||
|                         e_prev.pos.translate(ctxt.wipe_tower_pos); | ||||
|                     } | ||||
| 
 | ||||
|                     for (; i < j; ++i) { | ||||
|                         const WipeTower::Extrusion &e = extrusions.extrusions[i]; | ||||
|                         WipeTower::Extrusion e = extrusions.extrusions[i]; | ||||
|                         assert(e.width > 0.f); | ||||
|                         const WipeTower::Extrusion &e_prev = *(&e - 1); | ||||
|                         if (!extrusions.priming) { | ||||
|                             e.pos.rotate(ctxt.wipe_tower_angle); | ||||
|                             e.pos.translate(ctxt.wipe_tower_pos); | ||||
|                         } | ||||
| 
 | ||||
|                         lines.emplace_back(Point::new_scale(e_prev.pos.x, e_prev.pos.y), Point::new_scale(e.pos.x, e.pos.y)); | ||||
|                         widths.emplace_back(e.width); | ||||
| 
 | ||||
|                         e_prev = e; | ||||
|                     } | ||||
|                     _3DScene::thick_lines_to_verts(lines, widths, heights, lines.front().a == lines.back().b, extrusions.print_z, | ||||
|                         *vols[ctxt.volume_idx(e.tool, 0)]); | ||||
|  | @ -4716,8 +4743,11 @@ void GLCanvas3D::_load_shells() | |||
|     const PrintConfig& config = m_print->config; | ||||
|     unsigned int extruders_count = config.nozzle_diameter.size(); | ||||
|     if ((extruders_count > 1) && config.single_extruder_multi_material && config.wipe_tower && !config.complete_objects) { | ||||
|         const float width_per_extruder = 15.0f; // a simple workaround after wipe_tower_per_color_wipe got obsolete
 | ||||
|         m_volumes.load_wipe_tower_preview(1000, config.wipe_tower_x, config.wipe_tower_y, config.wipe_tower_width, width_per_extruder * (extruders_count - 1), max_z, config.wipe_tower_rotation_angle, m_use_VBOs && m_initialized); | ||||
|         float depth = m_print->get_wipe_tower_depth(); | ||||
|         if (!m_print->state.is_done(psWipeTower)) | ||||
|             depth = (900.f/config.wipe_tower_width) * (float)(extruders_count - 1) ; | ||||
|         m_volumes.load_wipe_tower_preview(1000, config.wipe_tower_x, config.wipe_tower_y, config.wipe_tower_width, depth, max_z, config.wipe_tower_rotation_angle, | ||||
|                                           m_use_VBOs && m_initialized, !m_print->state.is_done(psWipeTower), m_print->config.nozzle_diameter.values[0] * 1.25f * 4.5f); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -162,7 +162,8 @@ public: | |||
|         bool is_custom() const; | ||||
| 
 | ||||
|         const Pointfs& get_shape() const; | ||||
|         void set_shape(const Pointfs& shape); | ||||
|         // Return true if the bed shape changed, so the calee will update the UI.
 | ||||
|         bool set_shape(const Pointfs& shape); | ||||
| 
 | ||||
|         const BoundingBoxf3& get_bounding_box() const; | ||||
|         bool contains(const Point& point) const; | ||||
|  |  | |||
|  | @ -903,6 +903,7 @@ void add_frequently_changed_parameters(wxWindow* parent, wxBoxSizer* sizer, wxFl | |||
|                     std::vector<float> extruders = dlg.get_extruders(); | ||||
|                     (config.option<ConfigOptionFloats>("wiping_volumes_matrix"))->values = std::vector<double>(matrix.begin(),matrix.end()); | ||||
|                     (config.option<ConfigOptionFloats>("wiping_volumes_extruders"))->values = std::vector<double>(extruders.begin(),extruders.end()); | ||||
|                     g_on_request_update_callback.call(); | ||||
|                 } | ||||
| 			})); | ||||
| 			return sizer; | ||||
|  | @ -919,7 +920,6 @@ ConfigOptionsGroup* get_optgroup() | |||
| 	return m_optgroup.get(); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| wxButton* get_wiping_dialog_button() | ||||
| { | ||||
| 	return g_wiping_dialog_button; | ||||
|  |  | |||
|  | @ -4,6 +4,7 @@ | |||
| #include <string> | ||||
| #include <vector> | ||||
| #include "Config.hpp" | ||||
| #include "../../libslic3r/Utils.hpp" | ||||
| 
 | ||||
| #include <wx/intl.h> | ||||
| #include <wx/string.h> | ||||
|  | @ -171,6 +172,9 @@ wxString	from_u8(const std::string &str); | |||
| 
 | ||||
| void add_frequently_changed_parameters(wxWindow* parent, wxBoxSizer* sizer, wxFlexGridSizer* preset_sizer); | ||||
| 
 | ||||
| // Callback to trigger a configuration update timer on the Plater.
 | ||||
| static PerlCallback g_on_request_update_callback; | ||||
|   | ||||
| ConfigOptionsGroup* get_optgroup(); | ||||
| wxButton*			get_wiping_dialog_button(); | ||||
| 
 | ||||
|  |  | |||
|  | @ -313,11 +313,13 @@ const std::vector<std::string>& Preset::filament_options() | |||
| {     | ||||
|     static std::vector<std::string> s_opts { | ||||
|         "filament_colour", "filament_diameter", "filament_type", "filament_soluble", "filament_notes", "filament_max_volumetric_speed", | ||||
|         "extrusion_multiplier", "filament_density", "filament_cost", "filament_loading_speed", "filament_unloading_speed", "filament_toolchange_delay", | ||||
|         "filament_cooling_moves", "filament_cooling_initial_speed", "filament_cooling_final_speed", "filament_ramming_parameters", "temperature", | ||||
|         "first_layer_temperature", "bed_temperature", "first_layer_bed_temperature", "fan_always_on", "cooling", "min_fan_speed", "max_fan_speed", | ||||
|         "bridge_fan_speed", "disable_fan_first_layers", "fan_below_layer_time", "slowdown_below_layer_time", "min_print_speed", | ||||
|         "start_filament_gcode", "end_filament_gcode","compatible_printers", "compatible_printers_condition", "inherits" | ||||
|         "extrusion_multiplier", "filament_density", "filament_cost",  | ||||
|         "filament_loading_speed", "filament_load_time", "filament_unloading_speed", "filament_unload_time", "filament_toolchange_delay", | ||||
|         "filament_cooling_moves", "filament_cooling_initial_speed", "filament_cooling_final_speed", "filament_ramming_parameters", | ||||
|         "filament_minimal_purge_on_wipe_tower", "temperature", "first_layer_temperature", "bed_temperature", "first_layer_bed_temperature", | ||||
|         "fan_always_on", "cooling", "min_fan_speed", "max_fan_speed", "bridge_fan_speed", "disable_fan_first_layers", "fan_below_layer_time", | ||||
|         "slowdown_below_layer_time", "min_print_speed", "start_filament_gcode", "end_filament_gcode","compatible_printers", "compatible_printers_condition", | ||||
|         "inherits" | ||||
|     }; | ||||
|     return s_opts; | ||||
| } | ||||
|  | @ -332,7 +334,7 @@ const std::vector<std::string>& Preset::printer_options() | |||
|             "single_extruder_multi_material", "start_gcode", "end_gcode", "before_layer_gcode", "layer_gcode", "toolchange_gcode", | ||||
|             "between_objects_gcode", "printer_vendor", "printer_model", "printer_variant", "printer_notes", "cooling_tube_retraction", | ||||
|             "cooling_tube_length", "parking_pos_retraction", "extra_loading_move", "max_print_height", "default_print_profile", "inherits", | ||||
|             "silent_mode", "machine_max_acceleration_extruding", "machine_max_acceleration_retracting", | ||||
|             "remaining_times", "silent_mode", "machine_max_acceleration_extruding", "machine_max_acceleration_retracting", | ||||
| 			"machine_max_acceleration_x", "machine_max_acceleration_y", "machine_max_acceleration_z", "machine_max_acceleration_e", | ||||
|         	"machine_max_feedrate_x", "machine_max_feedrate_y", "machine_max_feedrate_z", "machine_max_feedrate_e", | ||||
|         	"machine_min_extruding_rate", "machine_min_travel_rate", | ||||
|  |  | |||
|  | @ -1292,10 +1292,13 @@ void TabFilament::build() | |||
|         optgroup = page->new_optgroup(_(L("Toolchange parameters with single extruder MM printers"))); | ||||
| 		optgroup->append_single_option_line("filament_loading_speed"); | ||||
|         optgroup->append_single_option_line("filament_unloading_speed"); | ||||
| 		optgroup->append_single_option_line("filament_load_time"); | ||||
| 		optgroup->append_single_option_line("filament_unload_time"); | ||||
|         optgroup->append_single_option_line("filament_toolchange_delay"); | ||||
|         optgroup->append_single_option_line("filament_cooling_moves"); | ||||
|         optgroup->append_single_option_line("filament_cooling_initial_speed"); | ||||
|         optgroup->append_single_option_line("filament_cooling_final_speed"); | ||||
|         optgroup->append_single_option_line("filament_minimal_purge_on_wipe_tower"); | ||||
| 
 | ||||
|         line = { _(L("Ramming")), "" }; | ||||
|         line.widget = [this](wxWindow* parent){ | ||||
|  | @ -1607,6 +1610,7 @@ void TabPrinter::build() | |||
| 		optgroup = page->new_optgroup(_(L("Firmware"))); | ||||
| 		optgroup->append_single_option_line("gcode_flavor"); | ||||
| 		optgroup->append_single_option_line("silent_mode"); | ||||
| 		optgroup->append_single_option_line("remaining_times"); | ||||
| 
 | ||||
| 		optgroup->m_on_change = [this, optgroup](t_config_option_key opt_key, boost::any value){ | ||||
| 			wxTheApp->CallAfter([this, opt_key, value](){ | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 tamasmeszaros
						tamasmeszaros