mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 01:31:14 -06:00 
			
		
		
		
	Add method for bridge addition with Head parameter to fill the bridge_id
This commit is contained in:
		
							parent
							
								
									3f698c4ccf
								
							
						
					
					
						commit
						95e22d8fd4
					
				
					 2 changed files with 25 additions and 7 deletions
				
			
		|  | @ -208,6 +208,11 @@ struct Bridge { | ||||||
|            const Vec3d &j2, |            const Vec3d &j2, | ||||||
|            double       r_mm  = 0.8, |            double       r_mm  = 0.8, | ||||||
|            size_t       steps = 45); |            size_t       steps = 45); | ||||||
|  |      | ||||||
|  |     Bridge(const Head  &h, | ||||||
|  |            const Vec3d &j2, | ||||||
|  |            size_t       steps = 45) | ||||||
|  |         : Bridge{h.junction_point(), j2, h.r_back_mm, steps} {} | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| // A bridge that spans from model surface to model surface with small connecting
 | // A bridge that spans from model surface to model surface with small connecting
 | ||||||
|  | @ -378,9 +383,23 @@ public: | ||||||
|         return m_junctions.back(); |         return m_junctions.back(); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     template<class...Args> const Bridge& add_bridge(Args&&... args) |     template<class...Args> const Bridge&  | ||||||
|  |     add_bridge(const Vec3d &sp, const Vec3d &ep, double r, size_t steps = 45) | ||||||
|     { |     { | ||||||
|         return _add_bridge(m_bridges, std::forward<Args>(args)...); |         return _add_bridge(m_bridges, sp, ep, r, steps); | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     template<class...Args>  | ||||||
|  |     const Bridge& add_bridge(const Head &h, const Vec3d &endp, size_t steps = 45) | ||||||
|  |     { | ||||||
|  |         std::lock_guard<Mutex> lk(m_mutex); | ||||||
|  |         m_bridges.emplace_back(h, endp, steps); | ||||||
|  |         m_bridges.back().id = long(m_bridges.size() - 1); | ||||||
|  |          | ||||||
|  |         assert(h.id >= 0 && h.id < m_head_indices.size()); | ||||||
|  |         m_heads[m_head_indices[size_t(h.id)]].bridge_id = m_bridges.back().id; | ||||||
|  |         m_meshcache_valid = false; | ||||||
|  |         return m_bridges.back(); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     template<class...Args> const Bridge& add_crossbridge(Args&&... args) |     template<class...Args> const Bridge& add_crossbridge(Args&&... args) | ||||||
|  |  | ||||||
|  | @ -582,7 +582,7 @@ void SupportTreeBuildsteps::create_ground_pillar(const Vec3d &jp, | ||||||
|         // the ground level only.
 |         // the ground level only.
 | ||||||
|          |          | ||||||
|         normal_mode     = false; |         normal_mode     = false; | ||||||
|         double mind       = min_dist - dist; |         double mind     = min_dist - dist; | ||||||
|         double azimuth  = std::atan2(sourcedir(Y), sourcedir(X)); |         double azimuth  = std::atan2(sourcedir(Y), sourcedir(X)); | ||||||
|         double sinpolar = std::sin(PI - m_cfg.bridge_slope); |         double sinpolar = std::sin(PI - m_cfg.bridge_slope); | ||||||
|         double cospolar = std::cos(PI - m_cfg.bridge_slope); |         double cospolar = std::cos(PI - m_cfg.bridge_slope); | ||||||
|  | @ -964,12 +964,11 @@ void SupportTreeBuildsteps::routing_to_model() | ||||||
|     auto routedown = [this](Head& head, const Vec3d& dir, double dist) |     auto routedown = [this](Head& head, const Vec3d& dir, double dist) | ||||||
|     { |     { | ||||||
|         head.transform(); |         head.transform(); | ||||||
|         Vec3d hjp = head.junction_point(); |         Vec3d endp = head.junction_point() + dist * dir; | ||||||
|         Vec3d endp = hjp + dist * dir; |         m_builder.add_bridge(head, endp); | ||||||
|         m_builder.add_bridge(hjp, endp, head.r_back_mm); |  | ||||||
|         m_builder.add_junction(endp, head.r_back_mm); |         m_builder.add_junction(endp, head.r_back_mm); | ||||||
|          |          | ||||||
|         this->create_ground_pillar(endp, dir, head.r_back_mm, head.id); |         this->create_ground_pillar(endp, dir, head.r_back_mm); | ||||||
|     }; |     }; | ||||||
|      |      | ||||||
|     std::vector<unsigned> modelpillars; |     std::vector<unsigned> modelpillars; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 tamasmeszaros
						tamasmeszaros