mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 01:31:14 -06:00 
			
		
		
		
	Fix up build and clear dev output
This commit is contained in:
		
							parent
							
								
									7e0199746e
								
							
						
					
					
						commit
						c187a5fb69
					
				
					 3 changed files with 26 additions and 54 deletions
				
			
		|  | @ -96,23 +96,6 @@ ToolOrdering::ToolOrdering(const Print &print, unsigned int first_extruder, bool | |||
|     this->collect_extruder_statistics(prime_multi_material); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| LayerTools& ToolOrdering::tools_for_layer(coordf_t print_z) | ||||
| { | ||||
|     auto it_layer_tools = std::lower_bound(m_layer_tools.begin(), m_layer_tools.end(), LayerTools(print_z - EPSILON)); | ||||
|     assert(it_layer_tools != m_layer_tools.end()); | ||||
|     coordf_t dist_min = std::abs(it_layer_tools->print_z - print_z); | ||||
| 	for (++ it_layer_tools; it_layer_tools != m_layer_tools.end(); ++it_layer_tools) { | ||||
|         coordf_t d = std::abs(it_layer_tools->print_z - print_z); | ||||
|         if (d >= dist_min) | ||||
|             break; | ||||
|         dist_min = d; | ||||
|     } | ||||
|     -- it_layer_tools; | ||||
|     assert(dist_min < EPSILON); | ||||
|     return *it_layer_tools; | ||||
| } | ||||
| 
 | ||||
| void ToolOrdering::initialize_layers(std::vector<coordf_t> &zs) | ||||
| { | ||||
|     sort_remove_duplicates(zs); | ||||
|  | @ -151,7 +134,7 @@ void ToolOrdering::collect_extruders(const PrintObject &object) | |||
|         LayerTools &layer_tools = this->tools_for_layer(layer->print_z); | ||||
|         // What extruders are required to print this object layer?
 | ||||
|         for (size_t region_id = 0; region_id < object.region_volumes.size(); ++ region_id) { | ||||
| 			const LayerRegion *layerm = (region_id < layer->regions().size()) ? layer->regions()[region_id] : nullptr; | ||||
|             const LayerRegion *layerm = (region_id < layer->regions().size()) ? layer->regions()[region_id] : nullptr; | ||||
|             if (layerm == nullptr) | ||||
|                 continue; | ||||
|             const PrintRegion ®ion = *object.print()->regions()[region_id]; | ||||
|  | @ -320,20 +303,20 @@ void ToolOrdering::fill_wipe_tower_partitions(const PrintConfig &config, coordf_ | |||
|                     LayerTools lt_new(0.5f * (lt.print_z + lt_object.print_z)); | ||||
|                     // Find the 1st layer above lt_new.
 | ||||
|                     for (j = i + 1; j < m_layer_tools.size() && m_layer_tools[j].print_z < lt_new.print_z - EPSILON; ++ j); | ||||
| 					if (std::abs(m_layer_tools[j].print_z - lt_new.print_z) < EPSILON) { | ||||
| 						m_layer_tools[j].has_wipe_tower = true; | ||||
| 					} else { | ||||
| 						LayerTools <_extra = *m_layer_tools.insert(m_layer_tools.begin() + j, lt_new); | ||||
|                     if (std::abs(m_layer_tools[j].print_z - lt_new.print_z) < EPSILON) { | ||||
|                         m_layer_tools[j].has_wipe_tower = true; | ||||
|                     } else { | ||||
|                         LayerTools <_extra = *m_layer_tools.insert(m_layer_tools.begin() + j, lt_new); | ||||
|                         LayerTools <_next  = m_layer_tools[j + 1]; | ||||
|                         assert(! m_layer_tools[j - 1].extruders.empty() && ! lt_next.extruders.empty()); | ||||
|                         // FIXME: Following assert tripped when running combine_infill.t. I decided to comment it out for now.
 | ||||
|                         // If it is a bug, it's likely not critical, because this code is unchanged for a long time. It might
 | ||||
|                         // still be worth looking into it more and decide if it is a bug or an obsolete assert.
 | ||||
|                         //assert(lt_prev.extruders.back() == lt_next.extruders.front());
 | ||||
| 						lt_extra.has_wipe_tower = true; | ||||
|                         lt_extra.has_wipe_tower = true; | ||||
|                         lt_extra.extruders.push_back(lt_next.extruders.front()); | ||||
| 						lt_extra.wipe_tower_partitions = lt_next.wipe_tower_partitions; | ||||
| 					} | ||||
|                         lt_extra.wipe_tower_partitions = lt_next.wipe_tower_partitions; | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|             break; | ||||
|  | @ -375,7 +358,7 @@ void ToolOrdering::collect_extruder_statistics(bool prime_multi_material) | |||
|         // Reorder m_all_printing_extruders in the sequence they will be primed, the last one will be m_first_printing_extruder.
 | ||||
|         // Then set m_first_printing_extruder to the 1st extruder primed.
 | ||||
|         m_all_printing_extruders.erase( | ||||
|             std::remove_if(m_all_printing_extruders.begin(), m_all_printing_extruders.end(),  | ||||
|             std::remove_if(m_all_printing_extruders.begin(), m_all_printing_extruders.end(), | ||||
|                 [ this ](const unsigned int eid) { return eid == m_first_printing_extruder; }), | ||||
|             m_all_printing_extruders.end()); | ||||
|         m_all_printing_extruders.emplace_back(m_first_printing_extruder); | ||||
|  | @ -623,6 +606,6 @@ const std::vector<int>* WipingExtrusions::get_extruder_overrides(const Extrusion | |||
| 
 | ||||
|     return &(entity_map_it->second); | ||||
| } | ||||
|      | ||||
| 
 | ||||
| 
 | ||||
| } // namespace Slic3r
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 tamasmeszaros
						tamasmeszaros