mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	Merge remote-tracking branch 'origin/ys_cp_improvements'
This commit is contained in:
		
						commit
						52c590f57a
					
				
					 14 changed files with 446 additions and 257 deletions
				
			
		|  | @ -1088,7 +1088,7 @@ namespace Slic3r { | |||
|                 return; | ||||
|             pt::ptree code_tree = main_tree.front().second; | ||||
| 
 | ||||
|             m_model->custom_gcode_per_print_z.clear(); | ||||
|             m_model->custom_gcode_per_print_z.gcodes.clear(); | ||||
| 
 | ||||
|             for (const auto& code : code_tree) | ||||
|             { | ||||
|  | @ -1100,7 +1100,7 @@ namespace Slic3r { | |||
|                 int extruder        = tree.get<int>         ("<xmlattr>.extruder"   ); | ||||
|                 std::string color   = tree.get<std::string> ("<xmlattr>.color"      ); | ||||
| 
 | ||||
|                 m_model->custom_gcode_per_print_z.push_back(Model::CustomGCode{print_z, gcode, extruder, color}) ; | ||||
|                 m_model->custom_gcode_per_print_z.gcodes.push_back(Model::CustomGCode{print_z, gcode, extruder, color}) ; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | @ -2631,12 +2631,12 @@ bool _3MF_Exporter::_add_custom_gcode_per_print_z_file_to_archive( mz_zip_archiv | |||
| { | ||||
|     std::string out = ""; | ||||
| 
 | ||||
|     if (!model.custom_gcode_per_print_z.empty()) | ||||
|     if (!model.custom_gcode_per_print_z.gcodes.empty()) | ||||
|     { | ||||
|         pt::ptree tree; | ||||
|         pt::ptree& main_tree = tree.add("custom_gcodes_per_print_z", ""); | ||||
| 
 | ||||
|         for (const Model::CustomGCode& code : model.custom_gcode_per_print_z) | ||||
|         for (const Model::CustomGCode& code : model.custom_gcode_per_print_z.gcodes) | ||||
|         { | ||||
|             pt::ptree& code_tree = main_tree.add("code", ""); | ||||
|             // store minX and maxZ
 | ||||
|  |  | |||
|  | @ -653,7 +653,7 @@ void AMFParserContext::endElement(const char * /* name */) | |||
|         int extruder = atoi(m_value[2].c_str()); | ||||
|         const std::string& color = m_value[3]; | ||||
| 
 | ||||
|         m_model.custom_gcode_per_print_z.push_back(Model::CustomGCode{height, gcode, extruder, color}); | ||||
|         m_model.custom_gcode_per_print_z.gcodes.push_back(Model::CustomGCode{height, gcode, extruder, color}); | ||||
| 
 | ||||
|         for (std::string& val: m_value) | ||||
|             val.clear(); | ||||
|  | @ -1250,14 +1250,14 @@ bool store_amf(const char *path, Model *model, const DynamicPrintConfig *config) | |||
|         stream << "  </constellation>\n"; | ||||
|     } | ||||
| 
 | ||||
|     if (!model->custom_gcode_per_print_z.empty()) | ||||
|     if (!model->custom_gcode_per_print_z.gcodes.empty()) | ||||
|     { | ||||
|         std::string out = ""; | ||||
|         pt::ptree tree; | ||||
| 
 | ||||
|         pt::ptree& main_tree = tree.add("custom_gcodes_per_height", ""); | ||||
| 
 | ||||
|         for (const Model::CustomGCode& code : model->custom_gcode_per_print_z) | ||||
|         for (const Model::CustomGCode& code : model->custom_gcode_per_print_z.gcodes) | ||||
|         { | ||||
|             pt::ptree& code_tree = main_tree.add("code", ""); | ||||
|             // store minX and maxZ
 | ||||
|  |  | |||
|  | @ -462,13 +462,13 @@ void ToolOrdering::assign_custom_gcodes(const Print &print) | |||
| 	// Only valid for non-sequential print.
 | ||||
| 	assert(! print.config().complete_objects.value); | ||||
| 
 | ||||
| 	const std::vector<Model::CustomGCode>	&custom_gcode_per_print_z = print.model().custom_gcode_per_print_z; | ||||
| 	if (custom_gcode_per_print_z.empty()) | ||||
| 	const Model::CustomGCodeInfo	&custom_gcode_per_print_z = print.model().custom_gcode_per_print_z; | ||||
| 	if (custom_gcode_per_print_z.gcodes.empty()) | ||||
| 		return; | ||||
| 
 | ||||
| 	unsigned int 							 num_extruders = *std::max_element(m_all_printing_extruders.begin(), m_all_printing_extruders.end()) + 1; | ||||
| 	std::vector<unsigned char> 				 extruder_printing_above(num_extruders, false); | ||||
| 	auto 									 custom_gcode_it = custom_gcode_per_print_z.rbegin(); | ||||
| 	auto 									 custom_gcode_it = custom_gcode_per_print_z.gcodes.rbegin(); | ||||
| 	// If printing on a single extruder machine, make the tool changes trigger color change (M600) events.
 | ||||
| 	bool 									 tool_changes_as_color_changes = num_extruders == 1; | ||||
| 	// From the last layer to the first one:
 | ||||
|  | @ -478,8 +478,8 @@ void ToolOrdering::assign_custom_gcodes(const Print &print) | |||
| 		for (unsigned int i : lt.extruders) | ||||
| 			extruder_printing_above[i] = true; | ||||
| 		// Skip all custom G-codes above this layer and skip all extruder switches.
 | ||||
| 		for (; custom_gcode_it != custom_gcode_per_print_z.rend() && (custom_gcode_it->print_z > lt.print_z + EPSILON || custom_gcode_it->gcode == ExtruderChangeCode); ++ custom_gcode_it); | ||||
| 		if (custom_gcode_it == custom_gcode_per_print_z.rend()) | ||||
| 		for (; custom_gcode_it != custom_gcode_per_print_z.gcodes.rend() && (custom_gcode_it->print_z > lt.print_z + EPSILON || custom_gcode_it->gcode == ExtruderChangeCode); ++ custom_gcode_it); | ||||
| 		if (custom_gcode_it == custom_gcode_per_print_z.gcodes.rend()) | ||||
| 			// Custom G-codes were processed.
 | ||||
| 			break; | ||||
| 		// Some custom G-code is configured for this layer or a layer below.
 | ||||
|  | @ -490,7 +490,8 @@ void ToolOrdering::assign_custom_gcodes(const Print &print) | |||
| 			print_z_below = it_lt_below->print_z; | ||||
| 		if (custom_gcode.print_z > print_z_below + 0.5 * EPSILON) { | ||||
| 			// The custom G-code applies to the current layer.
 | ||||
| 			if (tool_changes_as_color_changes || custom_gcode.gcode != ColorChangeCode || extruder_printing_above[unsigned(custom_gcode.extruder - 1)]) | ||||
| 			if ( tool_changes_as_color_changes || custom_gcode.gcode != ColorChangeCode ||  | ||||
|                 (custom_gcode.extruder <= num_extruders && extruder_printing_above[unsigned(custom_gcode.extruder - 1)])) | ||||
| 				// If it is color change, it will actually be useful as the exturder above will print.
 | ||||
|         		lt.custom_gcode = &custom_gcode; | ||||
| 			// Consume that custom G-code event.
 | ||||
|  |  | |||
|  | @ -126,7 +126,7 @@ Model Model::read_from_file(const std::string& input_file, DynamicPrintConfig* c | |||
|     if (add_default_instances) | ||||
|         model.add_default_instances(); | ||||
| 
 | ||||
|     update_custom_gcode_per_print_z_from_config(model.custom_gcode_per_print_z, config); | ||||
|     update_custom_gcode_per_print_z_from_config(model.custom_gcode_per_print_z.gcodes, config); | ||||
| 
 | ||||
|     return model; | ||||
| } | ||||
|  | @ -163,7 +163,7 @@ Model Model::read_from_archive(const std::string& input_file, DynamicPrintConfig | |||
|     if (add_default_instances) | ||||
|         model.add_default_instances(); | ||||
| 
 | ||||
|     update_custom_gcode_per_print_z_from_config(model.custom_gcode_per_print_z, config); | ||||
|     update_custom_gcode_per_print_z_from_config(model.custom_gcode_per_print_z.gcodes, config); | ||||
| 
 | ||||
|     return model; | ||||
| } | ||||
|  | @ -1846,7 +1846,7 @@ arrangement::ArrangePolygon ModelInstance::get_arrange_polygon() const | |||
| std::vector<std::pair<double, unsigned int>> custom_tool_changes(const Model &model, size_t num_extruders) | ||||
| { | ||||
|     std::vector<std::pair<double, unsigned int>> custom_tool_changes; | ||||
|     for (const Model::CustomGCode &custom_gcode : model.custom_gcode_per_print_z) | ||||
|     for (const Model::CustomGCode &custom_gcode : model.custom_gcode_per_print_z.gcodes) | ||||
|         if (custom_gcode.gcode == ExtruderChangeCode) { | ||||
|             // If extruder count in PrinterSettings was changed, use default (0) extruder for extruders, more than num_extruders
 | ||||
|             custom_tool_changes.emplace_back(custom_gcode.print_z, static_cast<unsigned int>(custom_gcode.extruder > num_extruders ? 1 : custom_gcode.extruder)); | ||||
|  |  | |||
|  | @ -772,7 +772,28 @@ public: | |||
|         std::string color;      // if gcode is equal to PausePrintCode, 
 | ||||
|                                 // this field is used for save a short message shown on Printer display 
 | ||||
|     }; | ||||
|     std::vector<CustomGCode> custom_gcode_per_print_z; | ||||
|      | ||||
|     struct CustomGCodeInfo | ||||
|     { | ||||
|         enum MODE | ||||
|         { | ||||
|             SingleExtruder,   // single extruder printer preset is selected
 | ||||
|             MultiAsSingle,    // multiple extruder printer preset is selected, but 
 | ||||
|                               // this mode works just for Single extruder print 
 | ||||
|                               // (For all print from objects settings is used just one extruder) 
 | ||||
|             MultiExtruder     // multiple extruder printer preset is selected
 | ||||
|         } mode; | ||||
|          | ||||
|         std::vector<CustomGCode> gcodes; | ||||
| 
 | ||||
|         bool operator==(const CustomGCodeInfo& rhs) const | ||||
|         { | ||||
|             return  (rhs.mode   == this->mode   ) && | ||||
|                     (rhs.gcodes == this->gcodes ); | ||||
|         } | ||||
|         bool operator!=(const CustomGCodeInfo& rhs) const { return !(*this == rhs); } | ||||
|     }  | ||||
|     custom_gcode_per_print_z; | ||||
|      | ||||
|     // Default constructor assigns a new ID to the model.
 | ||||
|     Model() { assert(this->id().valid()); } | ||||
|  |  | |||
|  | @ -723,7 +723,7 @@ Print::ApplyStatus Print::apply(const Model &model, DynamicPrintConfig new_full_ | |||
| 			model_object_status.emplace(model_object->id(), ModelObjectStatus::New); | ||||
|     } else { | ||||
|         if (m_model.custom_gcode_per_print_z != model.custom_gcode_per_print_z) { | ||||
|             update_apply_status(custom_per_printz_gcodes_tool_changes_differ(m_model.custom_gcode_per_print_z, model.custom_gcode_per_print_z) ? | ||||
|             update_apply_status(custom_per_printz_gcodes_tool_changes_differ(m_model.custom_gcode_per_print_z.gcodes, model.custom_gcode_per_print_z.gcodes) ? | ||||
|             	// The Tool Ordering and the Wipe Tower are no more valid.
 | ||||
|             	this->invalidate_steps({ psWipeTower, psGCodeExport }) : | ||||
|             	// There is no change in Tool Changes stored in custom_gcode_per_print_z, therefore there is no need to update Tool Ordering.
 | ||||
|  |  | |||
|  | @ -401,6 +401,7 @@ public: | |||
| 
 | ||||
|     // Accessed by SupportMaterial
 | ||||
|     const PrintRegion*  get_region(size_t idx) const  { return m_regions[idx]; } | ||||
|     const ToolOrdering& get_tool_ordering() const { return m_wipe_tower_data.tool_ordering; }   // #ys_FIXME just for testing
 | ||||
| 
 | ||||
| protected: | ||||
|     // methods for handling regions
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 YuSanka
						YuSanka