mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 10:11:10 -06:00 
			
		
		
		
	Merge branch 'et_reload_from_disk' of https://github.com/prusa3d/PrusaSlicer into dev
This commit is contained in:
		
						commit
						22ab022088
					
				
					 1 changed files with 32 additions and 17 deletions
				
			
		|  | @ -1936,6 +1936,7 @@ private: | |||
|                                                               * */ | ||||
|     std::string m_last_fff_printer_profile_name; | ||||
|     std::string m_last_sla_printer_profile_name; | ||||
|     bool m_update_objects_list_on_loading{ true }; | ||||
| }; | ||||
| 
 | ||||
| const std::regex Plater::priv::pattern_bundle(".*[.](amf|amf[.]xml|zip[.]amf|3mf|prusa)", std::regex::icase); | ||||
|  | @ -2460,8 +2461,11 @@ std::vector<size_t> Plater::priv::load_model_objects(const ModelObjectPtrs &mode | |||
|             _(L("Object too large?"))); | ||||
|     } | ||||
| 
 | ||||
|     for (const size_t idx : obj_idxs) { | ||||
|         wxGetApp().obj_list()->add_object_to_list(idx); | ||||
|     if (m_update_objects_list_on_loading) | ||||
|     { | ||||
|         for (const size_t idx : obj_idxs) { | ||||
|             wxGetApp().obj_list()->add_object_to_list(idx); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     update(); | ||||
|  | @ -3095,6 +3099,9 @@ void Plater::priv::reload_from_disk() | |||
|     // disable render to avoid to show intermediate states
 | ||||
|     view3D->get_canvas3d()->enable_render(false); | ||||
| 
 | ||||
|     // disable update of objects list while loading to avoid to show intermediate states
 | ||||
|     m_update_objects_list_on_loading = false; | ||||
| 
 | ||||
|     const auto new_idxs = load_files(input_paths, true, false); | ||||
|     if (new_idxs.empty()) | ||||
|     { | ||||
|  | @ -3103,33 +3110,43 @@ void Plater::priv::reload_from_disk() | |||
|         return; | ||||
|     } | ||||
| 
 | ||||
|     for (const auto idx : new_idxs) { | ||||
|     for (const auto idx : new_idxs) | ||||
|     { | ||||
|         ModelObject *object = model.objects[idx]; | ||||
|         object->config.apply(object_orig->config); | ||||
| 
 | ||||
|         object->clear_instances(); | ||||
|         for (const ModelInstance *instance : object_orig->instances) { | ||||
|         for (const ModelInstance *instance : object_orig->instances) | ||||
|         { | ||||
|             object->add_instance(*instance); | ||||
|         } | ||||
| 
 | ||||
|         if (object->volumes.size() == object_orig->volumes.size()) { | ||||
|             for (size_t i = 0; i < object->volumes.size(); i++) { | ||||
|         for (const ModelVolume* v : object_orig->volumes) | ||||
|         { | ||||
|             if (v->is_modifier()) | ||||
|                 object->add_volume(*v); | ||||
|         } | ||||
| 
 | ||||
|         if (object->volumes.size() == object_orig->volumes.size()) | ||||
|         { | ||||
|             for (size_t i = 0; i < object->volumes.size(); i++) | ||||
|             { | ||||
|                 object->volumes[i]->config.apply(object_orig->volumes[i]->config); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         if (object->instances.size() > 1) | ||||
|         { | ||||
|             sidebar->obj_list()->increase_object_instances(idx, object->instances.size()); | ||||
|             for (int i = 0; i < (int)object->instances.size(); ++i) | ||||
|             { | ||||
|                 sidebar->obj_list()->update_printable_state((int)idx, i); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         // XXX: Restore more: layer_height_ranges, layer_height_profile (?)
 | ||||
|     } | ||||
| 
 | ||||
|     // re-enable update of objects list
 | ||||
|     m_update_objects_list_on_loading = true; | ||||
| 
 | ||||
|     // puts the new objects into the list
 | ||||
|     for (const auto idx : new_idxs) | ||||
|     { | ||||
|         wxGetApp().obj_list()->add_object_to_list(idx); | ||||
|     } | ||||
| 
 | ||||
|     remove(obj_orig_idx); | ||||
| 
 | ||||
|     // new GLVolumes have been created at this point, so update their printable state
 | ||||
|  | @ -3148,8 +3165,6 @@ void Plater::priv::reload_from_disk() | |||
|     { | ||||
|         selection.add_instance((unsigned int)idx - 1, instance_idx, false); | ||||
|     } | ||||
| 
 | ||||
|     wxGetApp().obj_list()->update_and_show_object_settings_item(); | ||||
| } | ||||
| 
 | ||||
| void Plater::priv::fix_through_netfabb(const int obj_idx, const int vol_idx/* = -1*/) | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Enrico Turri
						Enrico Turri