mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 01:31:14 -06:00 
			
		
		
		
	Color change - handling Color Change data stored for different
printer configuration: ss -> sm : Just apply the color changes of the original ss project at the active extruder. ss -> mm : There are no tool changes stored. Ignore color changes, they are invalid because they are extruder non-specific. sm -> ss : Apply tool changes as color changes (tool changes remember the target color), apply original color changes. sm -> mm : Ignore both color changes and tool changes. mm -> ss/sm : Ignore both color changes and tool changes.
This commit is contained in:
		
							parent
							
								
									acf5bfd8e2
								
							
						
					
					
						commit
						fb235cb675
					
				
					 4 changed files with 45 additions and 17 deletions
				
			
		|  | @ -1774,7 +1774,7 @@ namespace ProcessLayer | ||||||
|     	const CustomGCode::Item 								*custom_gcode, |     	const CustomGCode::Item 								*custom_gcode, | ||||||
|         // ID of the first extruder printing this layer.
 |         // ID of the first extruder printing this layer.
 | ||||||
|         unsigned int                                             first_extruder_id, |         unsigned int                                             first_extruder_id, | ||||||
| 		bool  											         single_material_print) | 		bool  											         single_extruder_printer) | ||||||
| 	{ | 	{ | ||||||
|         std::string gcode; |         std::string gcode; | ||||||
|          |          | ||||||
|  | @ -1783,30 +1783,38 @@ namespace ProcessLayer | ||||||
| 			assert(custom_gcode->gcode != ToolChangeCode); | 			assert(custom_gcode->gcode != ToolChangeCode); | ||||||
| 
 | 
 | ||||||
|             const std::string  &custom_code  = custom_gcode->gcode; |             const std::string  &custom_code  = custom_gcode->gcode; | ||||||
|  |             bool  				color_change = custom_code == ColorChangeCode; | ||||||
|  |             bool 				tool_change  = custom_code == ToolChangeCode; | ||||||
|  | 		    // Tool Change is applied as Color Change for a single extruder printer only.
 | ||||||
|  | 		    assert(! tool_change || single_extruder_printer); | ||||||
|  | 
 | ||||||
| 		    std::string pause_print_msg; | 		    std::string pause_print_msg; | ||||||
| 		    int m600_extruder_before_layer = -1; | 		    int m600_extruder_before_layer = -1; | ||||||
| 	        if (custom_code == ColorChangeCode && custom_gcode->extruder > 0) | 	        if (color_change && custom_gcode->extruder > 0) | ||||||
| 	            m600_extruder_before_layer = custom_gcode->extruder - 1; | 	            m600_extruder_before_layer = custom_gcode->extruder - 1; | ||||||
| 	        else if (custom_code == PausePrintCode) | 	        else if (custom_code == PausePrintCode) | ||||||
| 	            pause_print_msg = custom_gcode->color; | 	            pause_print_msg = custom_gcode->color; | ||||||
| 
 | 
 | ||||||
| 		    // we should add or not colorprint_change in respect to nozzle_diameter count instead of really used extruders count
 | 		    // we should add or not colorprint_change in respect to nozzle_diameter count instead of really used extruders count
 | ||||||
| 	        if (custom_code == ColorChangeCode) // color change
 | 	        if (color_change || tool_change) | ||||||
| 	        { | 	        { | ||||||
|  | 		        // Color Change or Tool Change as Color Change.
 | ||||||
| 	            // add tag for analyzer
 | 	            // add tag for analyzer
 | ||||||
| 	            gcode += "; " + GCodeAnalyzer::Color_Change_Tag + ",T" + std::to_string(m600_extruder_before_layer) + "\n"; | 	            gcode += "; " + GCodeAnalyzer::Color_Change_Tag + ",T" + std::to_string(m600_extruder_before_layer) + "\n"; | ||||||
| 	            // add tag for time estimator
 | 	            // add tag for time estimator
 | ||||||
| 	            gcode += "; " + GCodeTimeEstimator::Color_Change_Tag + "\n"; | 	            gcode += "; " + GCodeTimeEstimator::Color_Change_Tag + "\n"; | ||||||
| 
 | 
 | ||||||
| 	            if (!single_material_print && m600_extruder_before_layer >= 0 && first_extruder_id != m600_extruder_before_layer | 	            if (!single_extruder_printer && m600_extruder_before_layer >= 0 && first_extruder_id != m600_extruder_before_layer | ||||||
| 	                // && !MMU1
 | 	                // && !MMU1
 | ||||||
| 	                ) { | 	                ) { | ||||||
| 	                //! FIXME_in_fw show message during print pause
 | 	                //! FIXME_in_fw show message during print pause
 | ||||||
| 	                gcode += "M601\n"; // pause print
 | 	                gcode += "M601\n"; // pause print
 | ||||||
| 	                gcode += "M117 Change filament for Extruder " + std::to_string(m600_extruder_before_layer) + "\n"; | 	                gcode += "M117 Change filament for Extruder " + std::to_string(m600_extruder_before_layer) + "\n"; | ||||||
| 	            } | 	            } | ||||||
| 	            else  |                 else { | ||||||
| 	                gcode += custom_code + "\n"; |                     gcode += ColorChangeCode; | ||||||
|  |                     gcode += "\n"; | ||||||
|  |                 } | ||||||
| 	        }  | 	        }  | ||||||
| 	        else | 	        else | ||||||
| 	        { | 	        { | ||||||
|  |  | ||||||
|  | @ -130,7 +130,8 @@ ToolOrdering::ToolOrdering(const Print &print, unsigned int first_extruder, bool | ||||||
| 	// Do it only if all the objects were configured to be printed with a single extruder.
 | 	// Do it only if all the objects were configured to be printed with a single extruder.
 | ||||||
| 	std::vector<std::pair<double, unsigned int>> per_layer_extruder_switches; | 	std::vector<std::pair<double, unsigned int>> per_layer_extruder_switches; | ||||||
| 	if (auto num_extruders = unsigned(print.config().nozzle_diameter.size()); | 	if (auto num_extruders = unsigned(print.config().nozzle_diameter.size()); | ||||||
| 		num_extruders > 1 && print.object_extruders().size() == 1) { | 		num_extruders > 1 && print.object_extruders().size() == 1 && // the current Print's configuration is CustomGCode::MultiAsSingle
 | ||||||
|  | 		print.model().custom_gcode_per_print_z.mode == CustomGCode::MultiAsSingle) { | ||||||
| 		// Printing a single extruder platter on a printer with more than 1 extruder (or single-extruder multi-material).
 | 		// Printing a single extruder platter on a printer with more than 1 extruder (or single-extruder multi-material).
 | ||||||
| 		// There may be custom per-layer tool changes available at the model.
 | 		// There may be custom per-layer tool changes available at the model.
 | ||||||
| 		per_layer_extruder_switches = custom_tool_changes(print.model().custom_gcode_per_print_z, num_extruders); | 		per_layer_extruder_switches = custom_tool_changes(print.model().custom_gcode_per_print_z, num_extruders); | ||||||
|  | @ -466,11 +467,19 @@ void ToolOrdering::assign_custom_gcodes(const Print &print) | ||||||
| 	if (custom_gcode_per_print_z.gcodes.empty()) | 	if (custom_gcode_per_print_z.gcodes.empty()) | ||||||
| 		return; | 		return; | ||||||
| 
 | 
 | ||||||
| 	unsigned int 							 num_extruders = *std::max_element(m_all_printing_extruders.begin(), m_all_printing_extruders.end()) + 1; | 	auto 						num_extruders = unsigned(print.config().nozzle_diameter.size()); | ||||||
|  | 	CustomGCode::Mode 			mode          = | ||||||
|  | 		(num_extruders == 1) ? CustomGCode::SingleExtruder : | ||||||
|  | 		print.object_extruders().size() == 1 ? CustomGCode::MultiAsSingle : CustomGCode::MultiExtruder; | ||||||
|  | 	CustomGCode::Mode           model_mode    = print.model().custom_gcode_per_print_z.mode; | ||||||
| 	std::vector<unsigned char> 	extruder_printing_above(num_extruders, false); | 	std::vector<unsigned char> 	extruder_printing_above(num_extruders, false); | ||||||
| 	auto 						custom_gcode_it = custom_gcode_per_print_z.gcodes.rbegin(); | 	auto 						custom_gcode_it = custom_gcode_per_print_z.gcodes.rbegin(); | ||||||
|  | 	// Tool changes and color changes will be ignored, if the model's tool/color changes were entered in mm mode and the print is in non mm mode
 | ||||||
|  | 	// or vice versa.
 | ||||||
|  | 	bool 						ignore_tool_and_color_changes = (mode == CustomGCode::MultiExtruder) != (model_mode == CustomGCode::MultiExtruder); | ||||||
| 	// If printing on a single extruder machine, make the tool changes trigger color change (M600) events.
 | 	// 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; | 	bool 						tool_changes_as_color_changes = mode == CustomGCode::SingleExtruder && model_mode == CustomGCode::MultiAsSingle; | ||||||
|  | 
 | ||||||
| 	// From the last layer to the first one:
 | 	// From the last layer to the first one:
 | ||||||
| 	for (auto it_lt = m_layer_tools.rbegin(); it_lt != m_layer_tools.rend(); ++ it_lt) { | 	for (auto it_lt = m_layer_tools.rbegin(); it_lt != m_layer_tools.rend(); ++ it_lt) { | ||||||
| 		LayerTools < = *it_lt; | 		LayerTools < = *it_lt; | ||||||
|  | @ -490,9 +499,16 @@ void ToolOrdering::assign_custom_gcodes(const Print &print) | ||||||
| 			print_z_below = it_lt_below->print_z; | 			print_z_below = it_lt_below->print_z; | ||||||
| 		if (custom_gcode.print_z > print_z_below + 0.5 * EPSILON) { | 		if (custom_gcode.print_z > print_z_below + 0.5 * EPSILON) { | ||||||
| 			// The custom G-code applies to the current layer.
 | 			// The custom G-code applies to the current layer.
 | ||||||
| 			if ( tool_changes_as_color_changes || custom_gcode.gcode != ColorChangeCode ||  | 			bool color_change = custom_gcode.gcode == ColorChangeCode; | ||||||
|                 (custom_gcode.extruder <= int(num_extruders) && extruder_printing_above[unsigned(custom_gcode.extruder - 1)])) | 			bool tool_change  = custom_gcode.gcode == ToolChangeCode; | ||||||
|  | 			bool pause_or_custom_gcode = ! color_change && ! tool_change; | ||||||
|  | 			bool apply_color_change = ! ignore_tool_and_color_changes && | ||||||
| 				// If it is color change, it will actually be useful as the exturder above will print.
 | 				// If it is color change, it will actually be useful as the exturder above will print.
 | ||||||
|  | 				(color_change ?  | ||||||
|  | 					mode == CustomGCode::SingleExtruder ||  | ||||||
|  | 						(custom_gcode.extruder <= int(num_extruders) && extruder_printing_above[unsigned(custom_gcode.extruder - 1)]) : | ||||||
|  | 				 	tool_change && tool_changes_as_color_changes); | ||||||
|  | 			if (pause_or_custom_gcode || apply_color_change) | ||||||
|         		lt.custom_gcode = &custom_gcode; |         		lt.custom_gcode = &custom_gcode; | ||||||
| 			// Consume that custom G-code event.
 | 			// Consume that custom G-code event.
 | ||||||
| 			++ custom_gcode_it; | 			++ custom_gcode_it; | ||||||
|  |  | ||||||
|  | @ -709,7 +709,11 @@ Print::ApplyStatus Print::apply(const Model &model, DynamicPrintConfig new_full_ | ||||||
| 			model_object_status.emplace(model_object->id(), ModelObjectStatus::New); | 			model_object_status.emplace(model_object->id(), ModelObjectStatus::New); | ||||||
|     } else { |     } else { | ||||||
|         if (m_model.custom_gcode_per_print_z != model.custom_gcode_per_print_z) { |         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.gcodes, model.custom_gcode_per_print_z.gcodes) ? |             update_apply_status(num_extruders_changed ||  | ||||||
|  |             	// Tool change G-codes are applied as color changes for a single extruder printer, no need to invalidate tool ordering.
 | ||||||
|  |             	//FIXME The tool ordering may be invalidated unnecessarily if the custom_gcode_per_print_z.mode is not applicable
 | ||||||
|  |             	// to the active print / model state, and then it is reset, so it is being applicable, but empty, thus the effect is the same.
 | ||||||
|  |             	(num_extruders > 1 && 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.
 |             	// The Tool Ordering and the Wipe Tower are no more valid.
 | ||||||
|             	this->invalidate_steps({ psWipeTower, psGCodeExport }) : |             	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.
 |             	// There is no change in Tool Changes stored in custom_gcode_per_print_z, therefore there is no need to update Tool Ordering.
 | ||||||
|  |  | ||||||
|  | @ -5100,7 +5100,7 @@ void GLCanvas3D::_render_overlays() const | ||||||
| 
 | 
 | ||||||
| #if ENABLE_SHOW_SCENE_LABELS | #if ENABLE_SHOW_SCENE_LABELS | ||||||
|     const ConfigOptionBool* opt = dynamic_cast<const ConfigOptionBool*>(m_config->option("complete_objects")); |     const ConfigOptionBool* opt = dynamic_cast<const ConfigOptionBool*>(m_config->option("complete_objects")); | ||||||
|     bool sequential_print = (opt != nullptr) ? m_config->opt_bool("complete_objects") : false; |     bool sequential_print = opt != nullptr && opt->value; | ||||||
|     std::vector<const PrintInstance*> sorted_instances; |     std::vector<const PrintInstance*> sorted_instances; | ||||||
|     if (sequential_print) { |     if (sequential_print) { | ||||||
|         const Print* print = fff_print(); |         const Print* print = fff_print(); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bubnikv
						bubnikv