mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-22 16:21:24 -06:00 
			
		
		
		
	Implemented reload of original mesh volume in case the SLA hollowing
step is no more valid.
This commit is contained in:
		
							parent
							
								
									9ef65b23d8
								
							
						
					
					
						commit
						f28d0ebc18
					
				
					 2 changed files with 72 additions and 59 deletions
				
			
		|  | @ -314,32 +314,37 @@ public: | ||||||
|     std::pair<size_t, size_t> geometry_id; |     std::pair<size_t, size_t> geometry_id; | ||||||
|     // An ID containing the extruder ID (used to select color).
 |     // An ID containing the extruder ID (used to select color).
 | ||||||
|     int                 	extruder_id; |     int                 	extruder_id; | ||||||
|  | 
 | ||||||
|  |     // Various boolean flags.
 | ||||||
|  |     struct { | ||||||
| 	    // Is this object selected?
 | 	    // Is this object selected?
 | ||||||
|     bool                selected; | 	    bool                selected : 1; | ||||||
| 	    // Is this object disabled from selection?
 | 	    // Is this object disabled from selection?
 | ||||||
|     bool                disabled; | 	    bool                disabled : 1; | ||||||
| 	    // Is this object printable?
 | 	    // Is this object printable?
 | ||||||
|     bool                printable; | 	    bool                printable : 1; | ||||||
| 	    // Whether or not this volume is active for rendering
 | 	    // Whether or not this volume is active for rendering
 | ||||||
|     bool                is_active; | 	    bool                is_active : 1; | ||||||
| 	    // Whether or not to use this volume when applying zoom_to_volumes()
 | 	    // Whether or not to use this volume when applying zoom_to_volumes()
 | ||||||
|     bool                zoom_to_volumes; | 	    bool                zoom_to_volumes : 1; | ||||||
| 	    // Wheter or not this volume is enabled for outside print volume detection in shader.
 | 	    // Wheter or not this volume is enabled for outside print volume detection in shader.
 | ||||||
|     bool                shader_outside_printer_detection_enabled; | 	    bool                shader_outside_printer_detection_enabled : 1; | ||||||
| 	    // Wheter or not this volume is outside print volume.
 | 	    // Wheter or not this volume is outside print volume.
 | ||||||
|     bool                is_outside; | 	    bool                is_outside : 1; | ||||||
|  | 	    // Wheter or not this volume has been generated from a modifier
 | ||||||
|  | 	    bool                is_modifier : 1; | ||||||
|  | 	    // Wheter or not this volume has been generated from the wipe tower
 | ||||||
|  | 	    bool                is_wipe_tower : 1; | ||||||
|  | 	    // Wheter or not this volume has been generated from an extrusion path
 | ||||||
|  | 	    bool                is_extrusion_path : 1; | ||||||
|  | 	    // Wheter or not to always render this volume using its own alpha 
 | ||||||
|  | 	    bool                force_transparent : 1; | ||||||
|  | 	    // Whether or not always use the volume's own color (not using SELECTED/HOVER/DISABLED/OUTSIDE)
 | ||||||
|  | 	    bool                force_native_color : 1; | ||||||
|  | 	}; | ||||||
|  | 
 | ||||||
|     // Is mouse or rectangle selection over this object to select/deselect it ?
 |     // Is mouse or rectangle selection over this object to select/deselect it ?
 | ||||||
|     EHoverState         	hover; |     EHoverState         	hover; | ||||||
|     // Wheter or not this volume has been generated from a modifier
 |  | ||||||
|     bool                is_modifier; |  | ||||||
|     // Wheter or not this volume has been generated from the wipe tower
 |  | ||||||
|     bool                is_wipe_tower; |  | ||||||
|     // Wheter or not this volume has been generated from an extrusion path
 |  | ||||||
|     bool                is_extrusion_path; |  | ||||||
|     // Wheter or not to always render this volume using its own alpha 
 |  | ||||||
|     bool                force_transparent; |  | ||||||
|     // Whether or not always use the volume's own color (not using SELECTED/HOVER/DISABLED/OUTSIDE)
 |  | ||||||
|     bool                force_native_color; |  | ||||||
| 
 | 
 | ||||||
|     // Interleaved triangles & normals with indexed triangles & quads.
 |     // Interleaved triangles & normals with indexed triangles & quads.
 | ||||||
|     GLIndexedVertexArray        indexed_vertex_array; |     GLIndexedVertexArray        indexed_vertex_array; | ||||||
|  |  | ||||||
|  | @ -2143,8 +2143,6 @@ void GLCanvas3D::reload_scene(bool refresh_immediately, bool force_full_scene_re | ||||||
|             const ModelObject *model_object = print_object->model_object(); |             const ModelObject *model_object = print_object->model_object(); | ||||||
|             // Find an index of the ModelObject
 |             // Find an index of the ModelObject
 | ||||||
|             int object_idx; |             int object_idx; | ||||||
| 			if (std::all_of(state.step.begin(), state.step.end(), [](const PrintStateBase::StateWithTimeStamp &state){ return state.state != PrintStateBase::DONE; })) |  | ||||||
| 				continue; |  | ||||||
|             // There may be new SLA volumes added to the scene for this print_object.
 |             // There may be new SLA volumes added to the scene for this print_object.
 | ||||||
|             // Find the object index of this print_object in the Model::objects list.
 |             // Find the object index of this print_object in the Model::objects list.
 | ||||||
|             auto it = std::find(sla_print->model().objects.begin(), sla_print->model().objects.end(), model_object); |             auto it = std::find(sla_print->model().objects.begin(), sla_print->model().objects.end(), model_object); | ||||||
|  | @ -2163,23 +2161,34 @@ void GLCanvas3D::reload_scene(bool refresh_immediately, bool force_full_scene_re | ||||||
|                 assert(it != model_object->instances.end()); |                 assert(it != model_object->instances.end()); | ||||||
|                 int instance_idx = it - model_object->instances.begin(); |                 int instance_idx = it - model_object->instances.begin(); | ||||||
|                 for (size_t istep = 0; istep < sla_steps.size(); ++ istep) |                 for (size_t istep = 0; istep < sla_steps.size(); ++ istep) | ||||||
|                     if (state.step[istep].state == PrintStateBase::DONE) { |  | ||||||
|                     if (sla_steps[istep] == slaposHollowing) { |                     if (sla_steps[istep] == slaposHollowing) { | ||||||
|                             // Check whether there is a main object mesh, which we may update with the hollowed mesh.
 |                     	// Hollowing is a special case, where the mesh from the backend is being loaded into the 1st volume of an instance,
 | ||||||
|  |                     	// not into its own GLVolume.
 | ||||||
|  |                         // There shall always be such a GLVolume allocated.
 | ||||||
|                         ModelVolumeState key(model_object->volumes.front()->id(), instance.instance_id); |                         ModelVolumeState key(model_object->volumes.front()->id(), instance.instance_id); | ||||||
|                         auto it = std::lower_bound(model_volume_state.begin(), model_volume_state.end(), key, model_volume_state_lower); |                         auto it = std::lower_bound(model_volume_state.begin(), model_volume_state.end(), key, model_volume_state_lower); | ||||||
|                         assert(it != model_volume_state.end() && it->geometry_id == key.geometry_id); |                         assert(it != model_volume_state.end() && it->geometry_id == key.geometry_id); | ||||||
|                         assert(!it->new_geometry()); |                         assert(!it->new_geometry()); | ||||||
|                             GLVolume& volume = *m_volumes.volumes[it->volume_idx]; |                         GLVolume &volume = *m_volumes.volumes[it->volume_idx]; | ||||||
|                             TriangleMesh mesh = print_object->get_mesh(slaposHollowing); |                         if (! volume.offsets.empty() && state.step[istep].timestamp != volume.offsets.front()) { | ||||||
|                             if (!mesh.empty()) { |                         	// The backend either produced a new hollowed mesh, or it invalidated the one that the front end has seen.
 | ||||||
|                                 Transform3d t = sla_print->sla_trafo(*m_model->objects[volume.object_idx()]); |  | ||||||
|                                 mesh.transform(t.inverse()); |  | ||||||
|                             volume.indexed_vertex_array.release_geometry(); |                             volume.indexed_vertex_array.release_geometry(); | ||||||
|  |                         	if (state.step[istep].state == PrintStateBase::DONE) { | ||||||
|  | 	                            TriangleMesh mesh = print_object->get_mesh(slaposHollowing); | ||||||
|  | 	                            assert(! mesh.empty()); | ||||||
|  |                                 mesh.transform(sla_print->sla_trafo(*m_model->objects[volume.object_idx()]).inverse()); | ||||||
|                                 volume.indexed_vertex_array.load_mesh(mesh); |                                 volume.indexed_vertex_array.load_mesh(mesh); | ||||||
|  | 	                        } else { | ||||||
|  | 	                        	// Reload the original volume.
 | ||||||
|  |                                 volume.indexed_vertex_array.load_mesh(m_model->objects[volume.object_idx()]->volumes[volume.volume_idx()]->mesh()); | ||||||
|  | 	                        } | ||||||
|                             volume.finalize_geometry(true); |                             volume.finalize_geometry(true); | ||||||
| 	                    } | 	                    } | ||||||
|                         } else { |                     	//FIXME it is an ugly hack to write the timestamp into the "offsets" field to not have to add another member variable
 | ||||||
|  |                     	// to the GLVolume. We should refactor GLVolume significantly, so that the GLVolume will not contain member variables
 | ||||||
|  |                     	// of various concenrs (model vs. 3D print path).
 | ||||||
|  |                     	volume.offsets = { state.step[istep].timestamp }; | ||||||
|  |                     } else if (state.step[istep].state == PrintStateBase::DONE) { | ||||||
|                         // Check whether there is an existing auxiliary volume to be updated, or a new auxiliary volume to be created.
 |                         // Check whether there is an existing auxiliary volume to be updated, or a new auxiliary volume to be created.
 | ||||||
| 						ModelVolumeState key(state.step[istep].timestamp, instance.instance_id.id); | 						ModelVolumeState key(state.step[istep].timestamp, instance.instance_id.id); | ||||||
| 						auto it = std::lower_bound(aux_volume_state.begin(), aux_volume_state.end(), key, model_volume_state_lower); | 						auto it = std::lower_bound(aux_volume_state.begin(), aux_volume_state.end(), key, model_volume_state_lower); | ||||||
|  | @ -2198,7 +2207,6 @@ void GLCanvas3D::reload_scene(bool refresh_immediately, bool force_full_scene_re | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|             } |             } | ||||||
|             } |  | ||||||
| 
 | 
 | ||||||
|             for (size_t istep = 0; istep < sla_steps.size(); ++istep) |             for (size_t istep = 0; istep < sla_steps.size(); ++istep) | ||||||
|                 if (!instances[istep].empty()) |                 if (!instances[istep].empty()) | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bubnikv
						bubnikv