mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 09:11:23 -06:00 
			
		
		
		
	Merge branch 'master' of https://github.com/prusa3d/PrusaSlicer into et_gcode_window
This commit is contained in:
		
						commit
						8027c94a41
					
				
					 15 changed files with 86 additions and 69 deletions
				
			
		|  | @ -285,6 +285,7 @@ namespace Slic3r { | |||
|             config.set_key_value("next_extruder", new ConfigOptionInt((int)new_extruder_id)); | ||||
|             config.set_key_value("layer_num", new ConfigOptionInt(gcodegen.m_layer_index)); | ||||
|             config.set_key_value("layer_z", new ConfigOptionFloat(tcr.print_z)); | ||||
|             config.set_key_value("toolchange_z", new ConfigOptionFloat(z)); | ||||
| //            config.set_key_value("max_layer_z", new ConfigOptionFloat(m_max_layer_z));
 | ||||
|             toolchange_gcode_str = gcodegen.placeholder_parser_process("toolchange_gcode", toolchange_gcode, new_extruder_id, &config); | ||||
|             check_add_eol(toolchange_gcode_str); | ||||
|  | @ -3011,6 +3012,7 @@ std::string GCode::set_extruder(unsigned int extruder_id, double print_z) | |||
|         config.set_key_value("next_extruder",     new ConfigOptionInt((int)extruder_id)); | ||||
|         config.set_key_value("layer_num",         new ConfigOptionInt(m_layer_index)); | ||||
|         config.set_key_value("layer_z",           new ConfigOptionFloat(print_z)); | ||||
|         config.set_key_value("toolchange_z",      new ConfigOptionFloat(print_z)); | ||||
|         config.set_key_value("max_layer_z",       new ConfigOptionFloat(m_max_layer_z)); | ||||
|         toolchange_gcode_parsed = placeholder_parser_process("toolchange_gcode", toolchange_gcode, extruder_id, &config); | ||||
|         gcode += toolchange_gcode_parsed; | ||||
|  |  | |||
|  | @ -520,6 +520,7 @@ WipeTower::WipeTower(const PrintConfig& config, const std::vector<std::vector<fl | |||
|     m_wipe_tower_pos(config.wipe_tower_x, config.wipe_tower_y), | ||||
|     m_wipe_tower_width(float(config.wipe_tower_width)), | ||||
|     m_wipe_tower_rotation_angle(float(config.wipe_tower_rotation_angle)), | ||||
|     m_wipe_tower_brim_width(float(config.wipe_tower_brim_width)), | ||||
|     m_y_shift(0.f), | ||||
|     m_z_pos(0.f), | ||||
|     m_is_first_layer(false), | ||||
|  | @ -816,24 +817,32 @@ WipeTower::ToolChangeResult WipeTower::toolchange_Brim(bool sideOnly, float y_of | |||
| 		  .append(";-------------------------------------\n" | ||||
| 				  "; CP WIPE TOWER FIRST LAYER BRIM START\n"); | ||||
| 
 | ||||
| 	Vec2f initial_position = wipeTower_box.lu - Vec2f(m_perimeter_width * 6.f, 0); | ||||
|     Vec2f initial_position = wipeTower_box.lu - Vec2f(m_wipe_tower_brim_width + 2*m_perimeter_width, 0); | ||||
| 	writer.set_initial_position(initial_position, m_wipe_tower_width, m_wipe_tower_depth, m_internal_rotation); | ||||
| 
 | ||||
|     writer.extrude_explicit(wipeTower_box.ld - Vec2f(m_perimeter_width * 6.f, 0), // Prime the extruder left of the wipe tower.
 | ||||
|     // Prime the extruder left of the wipe tower.
 | ||||
|     writer.extrude_explicit(wipeTower_box.ld - Vec2f(m_wipe_tower_brim_width + 2*m_perimeter_width, 0), | ||||
|         1.5f * m_extrusion_flow * (wipeTower_box.lu.y() - wipeTower_box.ld.y()), 2400); | ||||
| 
 | ||||
|     // The tool is supposed to be active and primed at the time when the wipe tower brim is extruded.
 | ||||
|     // Extrude 4 rounds of a brim around the future wipe tower.
 | ||||
|     box_coordinates box(wipeTower_box); | ||||
|     // the brim shall have 'normal' spacing with no extra void space
 | ||||
|     // Extrude brim around the future wipe tower ('normal' spacing with no extra void space).
 | ||||
|     box_coordinates box(wipeTower_box);     | ||||
|     float spacing = m_perimeter_width - m_layer_height*float(1.-M_PI_4); | ||||
|     for (size_t i = 0; i < 4; ++ i) { | ||||
| 
 | ||||
|     // How many perimeters shall the brim have?
 | ||||
|     size_t loops_num = (m_wipe_tower_brim_width + spacing/2.f) / spacing; | ||||
| 
 | ||||
|     for (size_t i = 0; i < loops_num; ++ i) { | ||||
|         box.expand(spacing); | ||||
|         writer.travel (box.ld, 7000) | ||||
|               .extrude(box.lu, 2100).extrude(box.ru) | ||||
|               .extrude(box.rd      ).extrude(box.ld); | ||||
|     } | ||||
| 
 | ||||
|     // Save actual brim width to be later passed to the Print object, which will use it
 | ||||
|     // for skirt calculation and pass it to GLCanvas for precise preview box
 | ||||
|     m_wipe_tower_brim_width_real = wipeTower_box.ld.x() - box.ld.x() + spacing/2.f; | ||||
| 
 | ||||
|     box.expand(-spacing); | ||||
|     writer.add_wipe_point(writer.x(), writer.y()) | ||||
|           .add_wipe_point(box.ld) | ||||
|  | @ -842,10 +851,6 @@ WipeTower::ToolChangeResult WipeTower::toolchange_Brim(bool sideOnly, float y_of | |||
|     writer.append("; CP WIPE TOWER FIRST LAYER BRIM END\n" | ||||
|                   ";-----------------------------------\n"); | ||||
| 
 | ||||
|     // Save actual brim width to be later passed to the Print object, which will use it
 | ||||
|     // for skirt calculation and pass it to GLCanvas for precise preview box
 | ||||
|     m_wipe_tower_brim_width = wipeTower_box.ld.x() - box.ld.x() + spacing/2.f; | ||||
| 
 | ||||
|     m_print_brim = false;  // Mark the brim as extruded
 | ||||
| 
 | ||||
|     // Ask our writer about how much material was consumed:
 | ||||
|  |  | |||
|  | @ -108,7 +108,7 @@ public: | |||
| 	void generate(std::vector<std::vector<ToolChangeResult>> &result); | ||||
| 
 | ||||
|     float get_depth() const { return m_wipe_tower_depth; } | ||||
|     float get_brim_width() const { return m_wipe_tower_brim_width; } | ||||
|     float get_brim_width() const { return m_wipe_tower_brim_width_real; } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|  | @ -220,7 +220,8 @@ private: | |||
|     Vec2f  m_wipe_tower_pos; 			// Left front corner of the wipe tower in mm.
 | ||||
| 	float  m_wipe_tower_width; 			// Width of the wipe tower.
 | ||||
| 	float  m_wipe_tower_depth 	= 0.f; 	// Depth of the wipe tower
 | ||||
|     float  m_wipe_tower_brim_width     = 0.f; 	// Width of brim (mm)
 | ||||
|     float  m_wipe_tower_brim_width      = 0.f; 	// Width of brim (mm) from config
 | ||||
|     float  m_wipe_tower_brim_width_real = 0.f; 	// Width of brim (mm) after generation
 | ||||
| 	float  m_wipe_tower_rotation_angle = 0.f; // Wipe tower rotation angle in degrees (with respect to x axis)
 | ||||
|     float  m_internal_rotation  = 0.f; | ||||
| 	float  m_y_shift			= 0.f;  // y shift passed to writer
 | ||||
|  |  | |||
|  | @ -437,7 +437,7 @@ const std::vector<std::string>& Preset::print_options() | |||
|         "perimeter_extrusion_width", "external_perimeter_extrusion_width", "infill_extrusion_width", "solid_infill_extrusion_width", | ||||
|         "top_infill_extrusion_width", "support_material_extrusion_width", "infill_overlap", "infill_anchor", "infill_anchor_max", "bridge_flow_ratio", "clip_multipart_objects", | ||||
|         "elefant_foot_compensation", "xy_size_compensation", "threads", "resolution", "wipe_tower", "wipe_tower_x", "wipe_tower_y", | ||||
|         "wipe_tower_width", "wipe_tower_rotation_angle", "wipe_tower_bridging", "single_extruder_multi_material_priming", | ||||
|         "wipe_tower_width", "wipe_tower_rotation_angle", "wipe_tower_brim_width", "wipe_tower_bridging", "single_extruder_multi_material_priming", | ||||
|         "wipe_tower_no_sparse_layers", "compatible_printers", "compatible_printers_condition", "inherits" | ||||
|     }; | ||||
|     return s_opts; | ||||
|  |  | |||
|  | @ -202,6 +202,7 @@ bool Print::invalidate_state_by_config_options(const ConfigOptionResolver & /* n | |||
|             || opt_key == "temperature" | ||||
|             || opt_key == "wipe_tower" | ||||
|             || opt_key == "wipe_tower_width" | ||||
|             || opt_key == "wipe_tower_brim_width" | ||||
|             || opt_key == "wipe_tower_bridging" | ||||
|             || opt_key == "wipe_tower_no_sparse_layers" | ||||
|             || opt_key == "wiping_volumes_matrix" | ||||
|  | @ -1909,16 +1910,15 @@ bool Print::has_wipe_tower() const | |||
|         m_config.nozzle_diameter.values.size() > 1; | ||||
| } | ||||
| 
 | ||||
| const WipeTowerData& Print::wipe_tower_data(size_t extruders_cnt, double first_layer_height, double nozzle_diameter) const | ||||
| const WipeTowerData& Print::wipe_tower_data(size_t extruders_cnt) const | ||||
| { | ||||
|     // If the wipe tower wasn't created yet, make sure the depth and brim_width members are set to default.
 | ||||
|     if (! is_step_done(psWipeTower) && extruders_cnt !=0) { | ||||
| 
 | ||||
|         float width = float(m_config.wipe_tower_width); | ||||
|         float brim_spacing = float(nozzle_diameter * 1.25f - first_layer_height * (1. - M_PI_4)); | ||||
| 
 | ||||
|         const_cast<Print*>(this)->m_wipe_tower_data.depth = (900.f/width) * float(extruders_cnt - 1); | ||||
|         const_cast<Print*>(this)->m_wipe_tower_data.brim_width = 4.5f * brim_spacing; | ||||
|         const_cast<Print*>(this)->m_wipe_tower_data.brim_width = m_config.wipe_tower_brim_width; | ||||
|     } | ||||
| 
 | ||||
|     return m_wipe_tower_data; | ||||
|  |  | |||
|  | @ -493,7 +493,7 @@ public: | |||
| 
 | ||||
|     // Wipe tower support.
 | ||||
|     bool                        has_wipe_tower() const; | ||||
|     const WipeTowerData&        wipe_tower_data(size_t extruders_cnt = 0, double first_layer_height = 0., double nozzle_diameter = 0.) const; | ||||
|     const WipeTowerData&        wipe_tower_data(size_t extruders_cnt = 0) const; | ||||
|     const ToolOrdering& 		tool_ordering() const { return m_tool_ordering; } | ||||
| 
 | ||||
| 	std::string                 output_filename(const std::string &filename_base = std::string()) const override; | ||||
|  |  | |||
|  | @ -2438,7 +2438,7 @@ void PrintConfigDef::init_fff_params() | |||
|     def = this->add("toolchange_gcode", coString); | ||||
|     def->label = L("Tool change G-code"); | ||||
|     def->tooltip = L("This custom code is inserted before every toolchange. Placeholder variables for all PrusaSlicer settings " | ||||
|                      "as well as {previous_extruder} and {next_extruder} can be used. When a tool-changing command " | ||||
|                      "as well as {toolchange_z}, {previous_extruder} and {next_extruder} can be used. When a tool-changing command " | ||||
|                      "which changes to the correct extruder is included (such as T{next_extruder}), PrusaSlicer will emit no other such command. " | ||||
|                      "It is therefore possible to script custom behaviour both before and after the toolchange."); | ||||
|     def->multiline = true; | ||||
|  | @ -2594,10 +2594,18 @@ void PrintConfigDef::init_fff_params() | |||
|     def->mode = comAdvanced; | ||||
|     def->set_default_value(new ConfigOptionFloat(0.)); | ||||
| 
 | ||||
|     def = this->add("wipe_tower_brim_width", coFloat); | ||||
|     def->label = L("Wipe tower brim width"); | ||||
|     def->tooltip = L("Wipe tower brim width"); | ||||
|     def->sidetext = L("mm"); | ||||
|     def->mode = comAdvanced; | ||||
|     def->min = 0.f; | ||||
|     def->set_default_value(new ConfigOptionFloat(2.)); | ||||
| 
 | ||||
|     def = this->add("wipe_into_infill", coBool); | ||||
|     def->category = L("Wipe options"); | ||||
|     def->label = L("Wipe into this object's infill"); | ||||
|     def->tooltip = L("Purging after toolchange will done inside this object's infills. " | ||||
|     def->tooltip = L("Purging after toolchange will be done inside this object's infills. " | ||||
|                      "This lowers the amount of waste but may result in longer print time " | ||||
|                      " due to additional travel moves."); | ||||
|     def->set_default_value(new ConfigOptionBool(false)); | ||||
|  |  | |||
|  | @ -962,6 +962,7 @@ public: | |||
|     ConfigOptionFloat               wipe_tower_width; | ||||
|     ConfigOptionFloat               wipe_tower_per_color_wipe; | ||||
|     ConfigOptionFloat               wipe_tower_rotation_angle; | ||||
|     ConfigOptionFloat               wipe_tower_brim_width; | ||||
|     ConfigOptionFloat               wipe_tower_bridging; | ||||
|     ConfigOptionFloats              wiping_volumes_matrix; | ||||
|     ConfigOptionFloats              wiping_volumes_extruders; | ||||
|  | @ -1036,6 +1037,7 @@ protected: | |||
|         OPT_PTR(wipe_tower_width); | ||||
|         OPT_PTR(wipe_tower_per_color_wipe); | ||||
|         OPT_PTR(wipe_tower_rotation_angle); | ||||
|         OPT_PTR(wipe_tower_brim_width); | ||||
|         OPT_PTR(wipe_tower_bridging); | ||||
|         OPT_PTR(wiping_volumes_matrix); | ||||
|         OPT_PTR(wiping_volumes_extruders); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 enricoturri1966
						enricoturri1966