mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 01:31:14 -06:00 
			
		
		
		
	Removed mutable members from class Selection
This commit is contained in:
		
							parent
							
								
									a393df59d7
								
							
						
					
					
						commit
						4c464b35f9
					
				
					 2 changed files with 45 additions and 57 deletions
				
			
		|  | @ -1102,39 +1102,32 @@ void Selection::erase() | |||
| 
 | ||||
|     if (is_single_full_object()) | ||||
|         wxGetApp().obj_list()->delete_from_model_and_list(ItemType::itObject, get_object_idx(), 0); | ||||
|     else if (is_multiple_full_object()) | ||||
|     { | ||||
|     else if (is_multiple_full_object()) { | ||||
|         std::vector<ItemForDelete> items; | ||||
|         items.reserve(m_cache.content.size()); | ||||
|         for (ObjectIdxsToInstanceIdxsMap::iterator it = m_cache.content.begin(); it != m_cache.content.end(); ++it) | ||||
|         { | ||||
|         for (ObjectIdxsToInstanceIdxsMap::iterator it = m_cache.content.begin(); it != m_cache.content.end(); ++it) { | ||||
|             items.emplace_back(ItemType::itObject, it->first, 0); | ||||
|         } | ||||
|         wxGetApp().obj_list()->delete_from_model_and_list(items); | ||||
|     } | ||||
|     else if (is_multiple_full_instance()) | ||||
|     { | ||||
|     else if (is_multiple_full_instance()) { | ||||
|         std::set<std::pair<int, int>> instances_idxs; | ||||
|         for (ObjectIdxsToInstanceIdxsMap::iterator obj_it = m_cache.content.begin(); obj_it != m_cache.content.end(); ++obj_it) | ||||
|         { | ||||
|             for (InstanceIdxsList::reverse_iterator inst_it = obj_it->second.rbegin(); inst_it != obj_it->second.rend(); ++inst_it) | ||||
|             { | ||||
|         for (ObjectIdxsToInstanceIdxsMap::iterator obj_it = m_cache.content.begin(); obj_it != m_cache.content.end(); ++obj_it) { | ||||
|             for (InstanceIdxsList::reverse_iterator inst_it = obj_it->second.rbegin(); inst_it != obj_it->second.rend(); ++inst_it) { | ||||
|                 instances_idxs.insert(std::make_pair(obj_it->first, *inst_it)); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         std::vector<ItemForDelete> items; | ||||
|         items.reserve(instances_idxs.size()); | ||||
|         for (const std::pair<int, int>& i : instances_idxs) | ||||
|         { | ||||
|         for (const std::pair<int, int>& i : instances_idxs) { | ||||
|             items.emplace_back(ItemType::itInstance, i.first, i.second); | ||||
|         } | ||||
|         wxGetApp().obj_list()->delete_from_model_and_list(items); | ||||
|     } | ||||
|     else if (is_single_full_instance()) | ||||
|         wxGetApp().obj_list()->delete_from_model_and_list(ItemType::itInstance, get_object_idx(), get_instance_idx()); | ||||
|     else if (is_mixed()) | ||||
|     { | ||||
|     else if (is_mixed()) { | ||||
|         std::set<ItemForDelete> items_set; | ||||
|         std::map<int, int> volumes_in_obj; | ||||
| 
 | ||||
|  | @ -1186,11 +1179,9 @@ void Selection::erase() | |||
| 
 | ||||
|         wxGetApp().obj_list()->delete_from_model_and_list(items); | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|     else { | ||||
|         std::set<std::pair<int, int>> volumes_idxs; | ||||
|         for (unsigned int i : m_list) | ||||
|         { | ||||
|         for (unsigned int i : m_list) { | ||||
|             const GLVolume* v = (*m_volumes)[i]; | ||||
|             // Only remove volumes associated with ModelVolumes from the object list.
 | ||||
|             // Temporary meshes (SLA supports or pads) are not managed by the object list.
 | ||||
|  | @ -1200,8 +1191,7 @@ void Selection::erase() | |||
| 
 | ||||
|         std::vector<ItemForDelete> items; | ||||
|         items.reserve(volumes_idxs.size()); | ||||
|         for (const std::pair<int, int>& v : volumes_idxs) | ||||
|         { | ||||
|         for (const std::pair<int, int>& v : volumes_idxs) { | ||||
|             items.emplace_back(ItemType::itVolume, v.first, v.second); | ||||
|         } | ||||
| 
 | ||||
|  | @ -1214,7 +1204,7 @@ void Selection::render(float scale_factor) const | |||
|     if (!m_valid || is_empty()) | ||||
|         return; | ||||
| 
 | ||||
|     m_scale_factor = scale_factor; | ||||
|     *const_cast<float*>(&m_scale_factor) = scale_factor; | ||||
| 
 | ||||
|     // render cumulative bounding box of selected volumes
 | ||||
|     render_selected_volumes(); | ||||
|  | @ -1224,7 +1214,7 @@ void Selection::render(float scale_factor) const | |||
| #if ENABLE_RENDER_SELECTION_CENTER | ||||
| void Selection::render_center(bool gizmo_is_dragging) const | ||||
| { | ||||
|     if (!m_valid || is_empty() || (m_quadric == nullptr)) | ||||
|     if (!m_valid || is_empty() || m_quadric == nullptr) | ||||
|         return; | ||||
| 
 | ||||
|     Vec3d center = gizmo_is_dragging ? m_cache.dragging_center : get_bounding_box().center(); | ||||
|  | @ -1250,8 +1240,7 @@ void Selection::render_sidebar_hints(const std::string& sidebar_field) const | |||
| 
 | ||||
|     GLShaderProgram* shader = nullptr; | ||||
| 
 | ||||
|     if (!boost::starts_with(sidebar_field, "layer")) | ||||
|     { | ||||
|     if (!boost::starts_with(sidebar_field, "layer")) { | ||||
|         shader = wxGetApp().get_shader("gouraud_light"); | ||||
|         if (shader == nullptr) | ||||
|             return; | ||||
|  | @ -1735,18 +1724,16 @@ void Selection::do_remove_volume(unsigned int volume_idx) | |||
| 
 | ||||
| void Selection::do_remove_instance(unsigned int object_idx, unsigned int instance_idx) | ||||
| { | ||||
|     for (unsigned int i = 0; i < (unsigned int)m_volumes->size(); ++i) | ||||
|     { | ||||
|     for (unsigned int i = 0; i < (unsigned int)m_volumes->size(); ++i) { | ||||
|         GLVolume* v = (*m_volumes)[i]; | ||||
|         if ((v->object_idx() == (int)object_idx) && (v->instance_idx() == (int)instance_idx)) | ||||
|         if (v->object_idx() == (int)object_idx && v->instance_idx() == (int)instance_idx) | ||||
|             do_remove_volume(i); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| void Selection::do_remove_object(unsigned int object_idx) | ||||
| { | ||||
|     for (unsigned int i = 0; i < (unsigned int)m_volumes->size(); ++i) | ||||
|     { | ||||
|     for (unsigned int i = 0; i < (unsigned int)m_volumes->size(); ++i) { | ||||
|         GLVolume* v = (*m_volumes)[i]; | ||||
|         if (v->object_idx() == (int)object_idx) | ||||
|             do_remove_volume(i); | ||||
|  | @ -1755,20 +1742,20 @@ void Selection::do_remove_object(unsigned int object_idx) | |||
| 
 | ||||
| void Selection::calc_bounding_box() const | ||||
| { | ||||
|     m_bounding_box = BoundingBoxf3(); | ||||
|     if (m_valid) | ||||
|     { | ||||
|         for (unsigned int i : m_list) | ||||
|         { | ||||
|             m_bounding_box.merge((*m_volumes)[i]->transformed_convex_hull_bounding_box()); | ||||
|     BoundingBoxf3* bounding_box = const_cast<BoundingBoxf3*>(&m_bounding_box); | ||||
|     *bounding_box = BoundingBoxf3(); | ||||
|     if (m_valid) { | ||||
|         for (unsigned int i : m_list) { | ||||
|             bounding_box->merge((*m_volumes)[i]->transformed_convex_hull_bounding_box()); | ||||
|         } | ||||
|     } | ||||
| 	m_bounding_box_dirty = false; | ||||
|     *const_cast<bool*>(&m_bounding_box_dirty) = false; | ||||
| } | ||||
| 
 | ||||
| void Selection::calc_unscaled_instance_bounding_box() const | ||||
| { | ||||
| 	m_unscaled_instance_bounding_box = BoundingBoxf3(); | ||||
|     BoundingBoxf3* unscaled_instance_bounding_box = const_cast<BoundingBoxf3*>(&m_unscaled_instance_bounding_box); | ||||
|     *unscaled_instance_bounding_box = BoundingBoxf3(); | ||||
|     if (m_valid) { | ||||
|         for (unsigned int i : m_list) { | ||||
|             const GLVolume& volume = *(*m_volumes)[i]; | ||||
|  | @ -1776,15 +1763,16 @@ void Selection::calc_unscaled_instance_bounding_box() const | |||
|                 continue; | ||||
|             Transform3d trafo = volume.get_instance_transformation().get_matrix(false, false, true, false) * volume.get_volume_transformation().get_matrix(); | ||||
|             trafo.translation()(2) += volume.get_sla_shift_z(); | ||||
| 			m_unscaled_instance_bounding_box.merge(volume.transformed_convex_hull_bounding_box(trafo)); | ||||
|             unscaled_instance_bounding_box->merge(volume.transformed_convex_hull_bounding_box(trafo)); | ||||
|         } | ||||
|     } | ||||
| 	m_unscaled_instance_bounding_box_dirty = false; | ||||
|     *const_cast<bool*>(&m_unscaled_instance_bounding_box_dirty) = false; | ||||
| } | ||||
| 
 | ||||
| void Selection::calc_scaled_instance_bounding_box() const | ||||
| { | ||||
|     m_scaled_instance_bounding_box = BoundingBoxf3(); | ||||
|     BoundingBoxf3* scaled_instance_bounding_box = const_cast<BoundingBoxf3*>(&m_scaled_instance_bounding_box); | ||||
|     *scaled_instance_bounding_box = BoundingBoxf3(); | ||||
|     if (m_valid) { | ||||
|         for (unsigned int i : m_list) { | ||||
|             const GLVolume& volume = *(*m_volumes)[i]; | ||||
|  | @ -1792,10 +1780,10 @@ void Selection::calc_scaled_instance_bounding_box() const | |||
|                 continue; | ||||
|             Transform3d trafo = volume.get_instance_transformation().get_matrix(false, false, false, false) * volume.get_volume_transformation().get_matrix(); | ||||
|             trafo.translation()(2) += volume.get_sla_shift_z(); | ||||
|             m_scaled_instance_bounding_box.merge(volume.transformed_convex_hull_bounding_box(trafo)); | ||||
|             scaled_instance_bounding_box->merge(volume.transformed_convex_hull_bounding_box(trafo)); | ||||
|         } | ||||
|     } | ||||
|     m_scaled_instance_bounding_box_dirty = false; | ||||
|     *const_cast<bool*>(&m_scaled_instance_bounding_box_dirty) = false; | ||||
| } | ||||
| 
 | ||||
| void Selection::render_selected_volumes() const | ||||
|  |  | |||
|  | @ -206,14 +206,14 @@ private: | |||
|     IndicesList m_list; | ||||
|     Cache m_cache; | ||||
|     Clipboard m_clipboard; | ||||
|     mutable BoundingBoxf3 m_bounding_box; | ||||
|     mutable bool m_bounding_box_dirty; | ||||
|     BoundingBoxf3 m_bounding_box; | ||||
|     bool m_bounding_box_dirty; | ||||
|     // Bounding box of a selection, with no instance scaling applied. This bounding box
 | ||||
|     // is useful for absolute scaling of tilted objects in world coordinate space.
 | ||||
|     mutable BoundingBoxf3 m_unscaled_instance_bounding_box; | ||||
|     mutable bool m_unscaled_instance_bounding_box_dirty; | ||||
|     mutable BoundingBoxf3 m_scaled_instance_bounding_box; | ||||
|     mutable bool m_scaled_instance_bounding_box_dirty; | ||||
|     BoundingBoxf3 m_unscaled_instance_bounding_box; | ||||
|     bool m_unscaled_instance_bounding_box_dirty; | ||||
|     BoundingBoxf3 m_scaled_instance_bounding_box; | ||||
|     bool m_scaled_instance_bounding_box_dirty; | ||||
| 
 | ||||
| #if ENABLE_RENDER_SELECTION_CENTER | ||||
|     GLUquadricObj* m_quadric; | ||||
|  | @ -222,7 +222,7 @@ private: | |||
|     GLModel m_arrow; | ||||
|     GLModel m_curved_arrow; | ||||
| 
 | ||||
|     mutable float m_scale_factor; | ||||
|     float m_scale_factor; | ||||
| 
 | ||||
| public: | ||||
|     Selection(); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 enricoturri1966
						enricoturri1966