mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	Arrange is accounting for the wipe tower now
This commit is contained in:
		
							parent
							
								
									5f226c5d7f
								
							
						
					
					
						commit
						e9a53e49db
					
				
					 7 changed files with 114 additions and 25 deletions
				
			
		|  | @ -1869,7 +1869,13 @@ std::vector<size_t> Plater::priv::load_model_objects(const ModelObjectPtrs &mode | |||
|     Polyline bed; bed.points.reserve(bedpoints.size()); | ||||
|     for(auto& v : bedpoints) bed.append(Point::new_scale(v(0), v(1))); | ||||
| 
 | ||||
|     arr::find_new_position(model, new_instances, min_obj_distance, bed); | ||||
|     arr::WipeTowerInfo wti = view3D->get_canvas3d()->get_wipe_tower_info(); | ||||
| 
 | ||||
|     arr::find_new_position(model, new_instances, min_obj_distance, bed, wti); | ||||
| 
 | ||||
|     // it remains to move the wipe tower:
 | ||||
|     view3D->get_canvas3d()->arrange_wipe_tower(wti); | ||||
| 
 | ||||
| #endif /* AUTOPLACEMENT_ON_LOAD */ | ||||
| 
 | ||||
|     if (scaled_down) { | ||||
|  | @ -2126,6 +2132,8 @@ void Plater::priv::arrange() | |||
| 
 | ||||
|     statusfn(0, arrangestr); | ||||
| 
 | ||||
|     arr::WipeTowerInfo wti = view3D->get_canvas3d()->get_wipe_tower_info(); | ||||
| 
 | ||||
|     try { | ||||
|         arr::BedShapeHint hint; | ||||
| 
 | ||||
|  | @ -2133,6 +2141,7 @@ void Plater::priv::arrange() | |||
|         hint.type = arr::BedShapeType::WHO_KNOWS; | ||||
| 
 | ||||
|         arr::arrange(model, | ||||
|                      wti, | ||||
|                      min_obj_distance, | ||||
|                      bed, | ||||
|                      hint, | ||||
|  | @ -2144,6 +2153,9 @@ void Plater::priv::arrange() | |||
|                                    "Some geometries may be invalid.")); | ||||
|     } | ||||
| 
 | ||||
|     // it remains to move the wipe tower:
 | ||||
|     view3D->get_canvas3d()->arrange_wipe_tower(wti); | ||||
| 
 | ||||
|     statusfn(0, L("Arranging done.")); | ||||
|     statusbar()->set_range(prev_range); | ||||
|     statusbar()->set_cancel_callback(); // remove cancel button
 | ||||
|  | @ -2246,7 +2258,8 @@ void Plater::priv::sla_optimize_rotation() { | |||
|         oi->set_rotation(rt); | ||||
|     } | ||||
| 
 | ||||
|     arr::find_new_position(model, o->instances, coord_t(mindist/SCALING_FACTOR), bed); | ||||
|     arr::WipeTowerInfo wti; // useless in SLA context
 | ||||
|     arr::find_new_position(model, o->instances, coord_t(mindist/SCALING_FACTOR), bed, wti); | ||||
| 
 | ||||
|     // Correct the z offset of the object which was corrupted be the rotation
 | ||||
|     o->ensure_on_bed(); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lukas Matena
						Lukas Matena