mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 17:51:10 -06:00 
			
		
		
		
	Code cleaning for the 6ed9adaeff commit
				
					
				
			This commit is contained in:
		
							parent
							
								
									6ed9adaeff
								
							
						
					
					
						commit
						ba0ad954e8
					
				
					 3 changed files with 68 additions and 130 deletions
				
			
		|  | @ -893,15 +893,14 @@ void GLCanvas3D::LegendTexture::fill_color_print_legend_items(const GCodePreview | ||||||
|         return; |         return; | ||||||
| 
 | 
 | ||||||
|     std::vector<Model::CustomGCode> custom_gcode_per_height = wxGetApp().plater()->model().custom_gcode_per_height; |     std::vector<Model::CustomGCode> custom_gcode_per_height = wxGetApp().plater()->model().custom_gcode_per_height; | ||||||
|     if (custom_gcode_per_height.empty()) { |  | ||||||
|         cp_legend_items.push_back(I18N::translate_utf8(L("Default print color"))); |  | ||||||
|         return; |  | ||||||
|     } |  | ||||||
| 
 | 
 | ||||||
|     const int extruders_cnt = wxGetApp().extruders_edited_cnt(); |     const int extruders_cnt = wxGetApp().extruders_edited_cnt(); | ||||||
| 
 |  | ||||||
|     if (extruders_cnt == 1)  |     if (extruders_cnt == 1)  | ||||||
|     { |     { | ||||||
|  |         if (custom_gcode_per_height.empty()) { | ||||||
|  |             cp_legend_items.push_back(I18N::translate_utf8(L("Default print color"))); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|         std::vector<std::pair<double, double>> cp_values; |         std::vector<std::pair<double, double>> cp_values; | ||||||
|          |          | ||||||
|         std::vector<double> print_zs = canvas.get_current_print_zs(true); |         std::vector<double> print_zs = canvas.get_current_print_zs(true); | ||||||
|  | @ -4807,68 +4806,13 @@ void GLCanvas3D::_load_print_object_toolpaths(const PrintObject& print_object, c | ||||||
|                     return number_tools()-1; // last color item is a gray color for pause print or custom G-code 
 |                     return number_tools()-1; // last color item is a gray color for pause print or custom G-code 
 | ||||||
| 
 | 
 | ||||||
|                 // change tool (extruder) 
 |                 // change tool (extruder) 
 | ||||||
|                 if (code == "tool_change") { |                 if (code == "tool_change") | ||||||
|                     if (number_tools() == extruders_cnt+1) |                     return get_color_idx_for_tool_change(it, extruder); | ||||||
|                         return std::min<int>(extruders_cnt - 1, std::max<int>(it->extruder - 1, 0)); |  | ||||||
| 
 |  | ||||||
|                     auto it_n = it; |  | ||||||
|                     bool apply_color_change = false; |  | ||||||
|                     while (it_n != color_print_values->begin()) { |  | ||||||
|                         --it_n; |  | ||||||
|                         if (it_n->gcode == "M600" && it_n->extruder == it->extruder) { |  | ||||||
|                             apply_color_change = true; |  | ||||||
|                             break; |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|                     if (apply_color_change) |  | ||||||
|                     { |  | ||||||
|                         int shift = 0; |  | ||||||
|                         while (it_n != color_print_values->begin()) { |  | ||||||
|                             --it_n; |  | ||||||
|                             if (it_n->gcode == "M600") |  | ||||||
|                                 shift++; |  | ||||||
|                         } |  | ||||||
|                         return extruders_cnt + shift; |  | ||||||
|                     } |  | ||||||
|                      |  | ||||||
|                     return std::min<int>(extruders_cnt - 1, std::max<int>(it->extruder - 1, 0)); |  | ||||||
|                 } |  | ||||||
|                 // change color for current extruder
 |                 // change color for current extruder
 | ||||||
|                 if (code == "M600") { |                 if (code == "M600") { | ||||||
|                     if (it->extruder == extruder) { |                     int color_idx = get_color_idx_for_color_change(it, extruder); | ||||||
|                         int shift = 0; |                     if (color_idx >= 0) | ||||||
|                         while (it != color_print_values->begin()) { |                         return color_idx; | ||||||
|                             --it; |  | ||||||
|                             if (it->gcode == "M600") |  | ||||||
|                                 shift++; |  | ||||||
|                         } |  | ||||||
|                         return extruders_cnt + shift; |  | ||||||
|                     } |  | ||||||
|                      |  | ||||||
|                     if (is_single_material_print) |  | ||||||
|                     { |  | ||||||
|                         auto it_n = it; |  | ||||||
|                         bool apply_color_change = false; |  | ||||||
|                         while (it_n != color_print_values->begin()) { |  | ||||||
|                             --it_n; |  | ||||||
|                             if (it_n->gcode == "tool_change") { |  | ||||||
|                                 if (it_n->extruder == it->extruder) |  | ||||||
|                                     apply_color_change = true; |  | ||||||
|                                 break; |  | ||||||
|                             } |  | ||||||
|                         } |  | ||||||
| 
 |  | ||||||
|                         if (apply_color_change) |  | ||||||
|                         { |  | ||||||
|                             int shift = 0; |  | ||||||
|                             while (it != color_print_values->begin()) { |  | ||||||
|                                 --it; |  | ||||||
|                                 if (it->gcode == "M600") |  | ||||||
|                                     shift++; |  | ||||||
|                             } |  | ||||||
|                             return extruders_cnt + shift; |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|  | @ -4877,77 +4821,70 @@ void GLCanvas3D::_load_print_object_toolpaths(const PrintObject& print_object, c | ||||||
|             while (it != color_print_values->begin()) |             while (it != color_print_values->begin()) | ||||||
|             { |             { | ||||||
|                 --it; |                 --it; | ||||||
|                 const std::string& code = it->gcode; |  | ||||||
|                 // change color for current extruder
 |                 // change color for current extruder
 | ||||||
|                 if (code == "M600") |                 if (it->gcode == "M600") { | ||||||
|                 { |                     int color_idx = get_color_idx_for_color_change(it, extruder); | ||||||
|                     if (it->extruder == extruder) { |                     if (color_idx >= 0) | ||||||
|                         int shift = 0; |                         return color_idx; | ||||||
|                         while (it != color_print_values->begin()) { |  | ||||||
|                             --it; |  | ||||||
|                             if (it->gcode == "M600") |  | ||||||
|                                 shift++; |  | ||||||
|                         } |  | ||||||
|                         return extruders_cnt + shift; |  | ||||||
|                     } |  | ||||||
| 
 |  | ||||||
|                     if (is_single_material_print) |  | ||||||
|                     { |  | ||||||
|                         auto it_n = it; |  | ||||||
|                         bool apply_color_change = false; |  | ||||||
|                         while (it_n != color_print_values->begin()) { |  | ||||||
|                             --it_n; |  | ||||||
|                             if (it_n->gcode == "tool_change") { |  | ||||||
|                                 if (it_n->extruder == it->extruder) |  | ||||||
|                                     apply_color_change = true; |  | ||||||
|                                 break; |  | ||||||
|                             } |  | ||||||
|                         } |  | ||||||
| 
 |  | ||||||
|                         if (apply_color_change) |  | ||||||
|                         { |  | ||||||
|                             int shift = 0; |  | ||||||
|                             while (it != color_print_values->begin()) { |  | ||||||
|                                 --it; |  | ||||||
|                                 if (it->gcode == "M600") |  | ||||||
|                                     shift++; |  | ||||||
|                             } |  | ||||||
|                             return extruders_cnt + shift; |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|                 } |                 } | ||||||
|                 // change tool (extruder) 
 |                 // change tool (extruder) 
 | ||||||
|                 if (code == "tool_change") |                 if (it->gcode == "tool_change") | ||||||
|                 { |                     return get_color_idx_for_tool_change(it, extruder); | ||||||
|                     if (number_tools() == extruders_cnt + 1) |  | ||||||
|                         return std::min<int>(extruders_cnt - 1, std::max<int>(it->extruder - 1, 0)); |  | ||||||
| 
 |  | ||||||
|                     auto it_n = it; |  | ||||||
|                     bool apply_color_change = false; |  | ||||||
|                     while (it_n != color_print_values->begin()) { |  | ||||||
|                         --it_n; |  | ||||||
|                         if (it_n->gcode == "M600" && it_n->extruder == it->extruder) { |  | ||||||
|                             apply_color_change = true; |  | ||||||
|                             break; |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|                     if (apply_color_change) |  | ||||||
|                     { |  | ||||||
|                         int shift = 0; |  | ||||||
|                         while (it_n != color_print_values->begin()) { |  | ||||||
|                             --it_n; |  | ||||||
|                             if (it_n->gcode == "M600") |  | ||||||
|                                 shift++; |  | ||||||
|                         } |  | ||||||
|                         return extruders_cnt + shift; |  | ||||||
|                     } |  | ||||||
| 
 |  | ||||||
|                     return std::min<int>(extruders_cnt - 1, std::max<int>(it->extruder - 1, 0)); |  | ||||||
|                 } |  | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             return std::min<int>(extruders_cnt - 1, std::max<int>(extruder - 1, 0));; |             return std::min<int>(extruders_cnt - 1, std::max<int>(extruder - 1, 0));; | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|  |     private: | ||||||
|  |         int get_m600_color_idx(std::vector<Model::CustomGCode>::const_iterator it) const  | ||||||
|  |         { | ||||||
|  |             int shift = 0; | ||||||
|  |             while (it != color_print_values->begin()) { | ||||||
|  |                 --it; | ||||||
|  |                 if (it->gcode == "M600") | ||||||
|  |                     shift++; | ||||||
|  |             } | ||||||
|  |             return extruders_cnt + shift; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         int get_color_idx_for_tool_change(std::vector<Model::CustomGCode>::const_iterator it, const int extruder) const  | ||||||
|  |         { | ||||||
|  |             const int current_extruder = it->extruder == 0 ? extruder : it->extruder; | ||||||
|  |             if (number_tools() == extruders_cnt + 1) // there is no one "M600"
 | ||||||
|  |                 return std::min<int>(extruders_cnt - 1, std::max<int>(current_extruder - 1, 0)); | ||||||
|  | 
 | ||||||
|  |             auto it_n = it; | ||||||
|  |             while (it_n != color_print_values->begin()) { | ||||||
|  |                 --it_n; | ||||||
|  |                 if (it_n->gcode == "M600" && it_n->extruder == current_extruder) | ||||||
|  |                     return get_m600_color_idx(it_n); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             return std::min<int>(extruders_cnt - 1, std::max<int>(current_extruder - 1, 0)); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         int get_color_idx_for_color_change(std::vector<Model::CustomGCode>::const_iterator it, const int extruder) const  | ||||||
|  |         { | ||||||
|  |             if (extruders_cnt == 1) | ||||||
|  |                 return get_m600_color_idx(it); | ||||||
|  | 
 | ||||||
|  |             auto it_n = it; | ||||||
|  |             bool is_tool_change = false; | ||||||
|  |             while (it_n != color_print_values->begin()) { | ||||||
|  |                 --it_n; | ||||||
|  |                 if (it_n->gcode == "tool_change") { | ||||||
|  |                     is_tool_change = true; | ||||||
|  |                     if (it_n->extruder == it->extruder) | ||||||
|  |                         return get_m600_color_idx(it); | ||||||
|  |                     break; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             if (!is_tool_change && it->extruder == extruder) | ||||||
|  |                 return get_m600_color_idx(it); | ||||||
|  | 
 | ||||||
|  |             return -1; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|     } ctxt; |     } ctxt; | ||||||
| 
 | 
 | ||||||
|     ctxt.has_perimeters = print_object.is_step_done(posPerimeters); |     ctxt.has_perimeters = print_object.is_step_done(posPerimeters); | ||||||
|  |  | ||||||
|  | @ -641,6 +641,7 @@ void Preview::create_double_slider() | ||||||
| 
 | 
 | ||||||
|         evt.StopPropagation(); |         evt.StopPropagation(); | ||||||
|     }); |     }); | ||||||
|  |     m_extruder_selector->Disable(); | ||||||
| 
 | 
 | ||||||
|     auto sizer = new wxBoxSizer(wxVERTICAL); |     auto sizer = new wxBoxSizer(wxVERTICAL); | ||||||
|     sizer->Add(m_extruder_selector, 0, wxEXPAND, 0); |     sizer->Add(m_extruder_selector, 0, wxEXPAND, 0); | ||||||
|  |  | ||||||
|  | @ -3615,7 +3615,7 @@ void DoubleSlider::change_extruder(int extruder) | ||||||
|     // if on this Y doesn't exist tick
 |     // if on this Y doesn't exist tick
 | ||||||
|     if (m_ticks_.find(tick) == m_ticks_.end()) |     if (m_ticks_.find(tick) == m_ticks_.end()) | ||||||
|     {         |     {         | ||||||
|         m_ticks_.insert(TICK_CODE(tick, "tool_change", extruder, colors[extruder-1])); |         m_ticks_.insert(TICK_CODE(tick, "tool_change", extruder, extruder == 0 ? "" : colors[extruder-1])); | ||||||
| 
 | 
 | ||||||
|         wxPostEvent(this->GetParent(), wxCommandEvent(wxCUSTOMEVT_TICKSCHANGED)); |         wxPostEvent(this->GetParent(), wxCommandEvent(wxCUSTOMEVT_TICKSCHANGED)); | ||||||
|         Refresh(); |         Refresh(); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 YuSanka
						YuSanka