mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-30 20:21:12 -06:00 
			
		
		
		
	Fixing issues in Print / PrintObject / PrintRegion reporting
a list of printing extruders.
This commit is contained in:
		
							parent
							
								
									ded2019765
								
							
						
					
					
						commit
						40d313961e
					
				
					 2 changed files with 34 additions and 10 deletions
				
			
		|  | @ -262,8 +262,14 @@ std::vector<unsigned int> Print::object_extruders() const | |||
| { | ||||
|     std::vector<unsigned int> extruders; | ||||
|     extruders.reserve(m_regions.size() * 3); | ||||
|     for (const PrintRegion *region : m_regions) | ||||
|         region->collect_object_printing_extruders(extruders); | ||||
|     std::vector<unsigned char> region_used(m_regions.size(), false); | ||||
|     for (const PrintObject *object : m_objects) | ||||
| 		for (const std::vector<std::pair<t_layer_height_range, int>> &volumes_per_region : object->region_volumes) | ||||
|         	if (! volumes_per_region.empty()) | ||||
|         		region_used[&volumes_per_region - &object->region_volumes.front()] = true; | ||||
|     for (size_t idx_region = 0; idx_region < m_regions.size(); ++ idx_region) | ||||
|     	if (region_used[idx_region]) | ||||
|         	m_regions[idx_region]->collect_object_printing_extruders(extruders); | ||||
|     sort_remove_duplicates(extruders); | ||||
|     return extruders; | ||||
| } | ||||
|  | @ -273,17 +279,24 @@ std::vector<unsigned int> Print::support_material_extruders() const | |||
| { | ||||
|     std::vector<unsigned int> extruders; | ||||
|     bool support_uses_current_extruder = false; | ||||
|     auto num_extruders = (unsigned int)m_config.nozzle_diameter.size(); | ||||
| 
 | ||||
|     for (PrintObject *object : m_objects) { | ||||
|         if (object->has_support_material()) { | ||||
|         	assert(object->config().support_material_extruder >= 0); | ||||
|             if (object->config().support_material_extruder == 0) | ||||
|                 support_uses_current_extruder = true; | ||||
|             else | ||||
|                 extruders.push_back(object->config().support_material_extruder - 1); | ||||
|             else { | ||||
|             	unsigned int i = (unsigned int)object->config().support_material_extruder - 1; | ||||
|                 extruders.emplace_back((i >= num_extruders) ? 0 : i); | ||||
|             } | ||||
|         	assert(object->config().support_material_interface_extruder >= 0); | ||||
|             if (object->config().support_material_interface_extruder == 0) | ||||
|                 support_uses_current_extruder = true; | ||||
|             else | ||||
|                 extruders.push_back(object->config().support_material_interface_extruder - 1); | ||||
|             else { | ||||
|             	unsigned int i = (unsigned int)object->config().support_material_interface_extruder - 1; | ||||
|                 extruders.emplace_back((i >= num_extruders) ? 0 : i); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -46,7 +46,7 @@ Flow PrintRegion::flow(FlowRole role, double layer_height, bool bridge, bool fir | |||
|     } | ||||
|     double nozzle_diameter = m_print->config().nozzle_diameter.get_at(extruder-1); | ||||
|      | ||||
|     return Flow::new_from_config_width(role, config_width, nozzle_diameter, layer_height, bridge ? (float)m_config.bridge_flow_ratio : 0.0); | ||||
|     return Flow::new_from_config_width(role, config_width, (float)nozzle_diameter, (float)layer_height, bridge ? (float)m_config.bridge_flow_ratio : 0.0f); | ||||
| } | ||||
| 
 | ||||
| coordf_t PrintRegion::nozzle_dmr_avg(const PrintConfig &print_config) const | ||||
|  | @ -64,16 +64,27 @@ coordf_t PrintRegion::bridging_height_avg(const PrintConfig &print_config) const | |||
| void PrintRegion::collect_object_printing_extruders(const PrintConfig &print_config, const PrintRegionConfig ®ion_config, std::vector<unsigned int> &object_extruders) | ||||
| { | ||||
|     // These checks reflect the same logic used in the GUI for enabling/disabling extruder selection fields.
 | ||||
|     auto num_extruders = (int)print_config.nozzle_diameter.size(); | ||||
|     auto emplace_extruder = [num_extruders, &object_extruders](int extruder_id) { | ||||
|     	int i = std::max(0, extruder_id - 1); | ||||
|         object_extruders.emplace_back((i >= num_extruders) ? 0 : i); | ||||
|     }; | ||||
|     if (region_config.perimeters.value > 0 || print_config.brim_width.value > 0) | ||||
|         object_extruders.emplace_back(region_config.perimeter_extruder - 1); | ||||
|     	emplace_extruder(region_config.perimeter_extruder); | ||||
|     if (region_config.fill_density.value > 0) | ||||
|         object_extruders.emplace_back(region_config.infill_extruder - 1); | ||||
|     	emplace_extruder(region_config.infill_extruder); | ||||
|     if (region_config.top_solid_layers.value > 0 || region_config.bottom_solid_layers.value > 0) | ||||
|         object_extruders.emplace_back(region_config.solid_infill_extruder - 1); | ||||
|     	emplace_extruder(region_config.solid_infill_extruder); | ||||
| } | ||||
| 
 | ||||
| void PrintRegion::collect_object_printing_extruders(std::vector<unsigned int> &object_extruders) const | ||||
| { | ||||
|     auto num_extruders = (int)print()->config().nozzle_diameter.size(); | ||||
|     // PrintRegion, if used by some PrintObject, shall have all the extruders set to an existing printer extruder.
 | ||||
|     // If not, then there must be something wrong with the Print::apply() function.
 | ||||
|     assert(this->config().perimeter_extruder    <= num_extruders); | ||||
|     assert(this->config().infill_extruder       <= num_extruders); | ||||
|     assert(this->config().solid_infill_extruder <= num_extruders); | ||||
|     collect_object_printing_extruders(print()->config(), this->config(), object_extruders); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bubnikv
						bubnikv