mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	WIP: Merged commits from stable between 1.41.2-beta and 1.42.2 final.
Changes in SupportMaterial.cpp, TriangleMesh.cpp and 01_trianglemesh.t are yet to be merged. WIP: Refactoring of layer height editing. Removed layer_height_ranges from PrintObject, as the Print/PrintObject now hold their copies of Model/ModelObject.
This commit is contained in:
		
							parent
							
								
									2ed77aadde
								
							
						
					
					
						commit
						52db7b055a
					
				
					 12 changed files with 231 additions and 40 deletions
				
			
		|  | @ -187,6 +187,24 @@ public: | |||
|             m_map.emplace(std::make_pair(Vec2crd(pt->x()>>m_grid_log2, pt->y()>>m_grid_log2), std::move(value))); | ||||
|     } | ||||
| 
 | ||||
|     // Erase a data point equal to value. (ValueType has to declare the operator==).
 | ||||
|     // Returns true if the data point equal to value was found and removed.
 | ||||
|     bool erase(const ValueType &value) { | ||||
|         const Point *pt = m_point_accessor(value); | ||||
|         if (pt != nullptr) { | ||||
|             // Range of fragment starts around grid_corner, close to pt.
 | ||||
|             auto range = m_map.equal_range(Point(pt->x>>m_grid_log2, pt->y>>m_grid_log2)); | ||||
|             // Remove the first item.
 | ||||
|             for (auto it = range.first; it != range.second; ++ it) { | ||||
|                 if (it->second == value) { | ||||
|                     m_map.erase(it); | ||||
|                     return true; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         return false; | ||||
|     } | ||||
| 
 | ||||
|     // Return a pair of <ValueType*, distance_squared>
 | ||||
|     std::pair<const ValueType*, double> find(const Vec2crd &pt) { | ||||
|         // Iterate over 4 closest grid cells around pt,
 | ||||
|  | @ -214,7 +232,7 @@ public: | |||
|                 } | ||||
|             } | ||||
|         } | ||||
|         return (value_min != nullptr && dist_min < coordf_t(m_search_radius * m_search_radius)) ?  | ||||
|         return (value_min != nullptr && dist_min < coordf_t(m_search_radius) * coordf_t(m_search_radius)) ?  | ||||
|             std::make_pair(value_min, dist_min) :  | ||||
|             std::make_pair(nullptr, std::numeric_limits<double>::max()); | ||||
|     } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bubnikv
						bubnikv