mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	Fix of wipe into object
The bug was introduced in 15eedef. lower_bound_by_predicate implementation returns first item that does not satisfy the predicate, not last item that does.
			
			
This commit is contained in:
		
							parent
							
								
									57c0a313a4
								
							
						
					
					
						commit
						8be3d074fd
					
				
					 1 changed files with 4 additions and 4 deletions
				
			
		|  | @ -150,15 +150,15 @@ public: | |||
|     Layer* 			get_layer(int idx) 		 { return m_layers[idx]; } | ||||
|     // Get a layer exactly at print_z.
 | ||||
|     const Layer*	get_layer_at_printz(coordf_t print_z) const { | ||||
|     	auto it = Slic3r::lower_bound_by_predicate(m_layers.begin(), m_layers.end(), [print_z](const Layer *layer) { return layer->print_z < print_z; }); | ||||
|         auto it = Slic3r::lower_bound_by_predicate(m_layers.begin(), m_layers.end(), [print_z](const Layer *layer) { return layer->print_z < print_z; }); | ||||
| 		return (it == m_layers.end() || (*it)->print_z != print_z) ? nullptr : *it; | ||||
| 	} | ||||
|     Layer*			get_layer_at_printz(coordf_t print_z) { return const_cast<Layer*>(std::as_const(*this).get_layer_at_printz(print_z)); } | ||||
|     // Get a layer approximately at print_z.
 | ||||
|     const Layer*	get_layer_at_printz(coordf_t print_z, coordf_t epsilon) const { | ||||
|         coordf_t limit = print_z + epsilon; | ||||
|     	auto it = Slic3r::lower_bound_by_predicate(m_layers.begin(), m_layers.end(), [limit](const Layer *layer) { return layer->print_z < limit; }); | ||||
| 		return (it == m_layers.end() || (*it)->print_z < print_z - epsilon) ? nullptr : *it; | ||||
|         coordf_t limit = print_z - epsilon; | ||||
|         auto it = Slic3r::lower_bound_by_predicate(m_layers.begin(), m_layers.end(), [limit](const Layer *layer) { return layer->print_z < limit; }); | ||||
|         return (it == m_layers.end() || (*it)->print_z > print_z + epsilon) ? nullptr : *it; | ||||
| 	} | ||||
|     Layer*			get_layer_at_printz(coordf_t print_z, coordf_t epsilon) { return const_cast<Layer*>(std::as_const(*this).get_layer_at_printz(print_z, epsilon)); } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lukas Matena
						Lukas Matena