mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-22 00:01:09 -06:00 
			
		
		
		
	Ported reload_object() to XS
This commit is contained in:
		
							parent
							
								
									12ba7201c0
								
							
						
					
					
						commit
						d645dabcff
					
				
					 4 changed files with 26 additions and 14 deletions
				
			
		|  | @ -217,20 +217,6 @@ sub add_model_object { | ||||||
|     $o->config->apply_dynamic($object_config); |     $o->config->apply_dynamic($object_config); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| sub reload_object { |  | ||||||
|     my ($self, $obj_idx) = @_; |  | ||||||
|      |  | ||||||
|     # TODO: this method should check whether the per-object config and per-material configs |  | ||||||
|     # have changed in such a way that regions need to be rearranged or we can just apply |  | ||||||
|     # the diff and invalidate something.  Same logic as apply_config() |  | ||||||
|     # For now we just re-add all objects since we haven't implemented this incremental logic yet. |  | ||||||
|     # This should also check whether object volumes (parts) have changed. |  | ||||||
|      |  | ||||||
|     my @models_objects = map $_->model_object, @{$self->objects}; |  | ||||||
|     $self->clear_objects; |  | ||||||
|     $self->add_model_object($_) for @models_objects; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| sub validate { | sub validate { | ||||||
|     my $self = shift; |     my $self = shift; | ||||||
|      |      | ||||||
|  |  | ||||||
|  | @ -114,6 +114,30 @@ Print::delete_object(size_t idx) | ||||||
|     this->state.invalidate(psBrim); |     this->state.invalidate(psBrim); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void | ||||||
|  | Print::reload_object(size_t idx) | ||||||
|  | { | ||||||
|  |     /* TODO: this method should check whether the per-object config and per-material configs
 | ||||||
|  |         have changed in such a way that regions need to be rearranged or we can just apply | ||||||
|  |         the diff and invalidate something.  Same logic as apply_config() | ||||||
|  |         For now we just re-add all objects since we haven't implemented this incremental logic yet. | ||||||
|  |         This should also check whether object volumes (parts) have changed. */ | ||||||
|  |      | ||||||
|  |     // collect all current model objects
 | ||||||
|  |     ModelObjectPtrs model_objects; | ||||||
|  |     for (PrintObjectPtrs::iterator it = this->objects.begin(); it != this->objects.end(); ++it) { | ||||||
|  |         model_objects.push_back(it->model_object()); | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     // remove our print objects
 | ||||||
|  |     this->clear_object(); | ||||||
|  |      | ||||||
|  |     // re-add model objects
 | ||||||
|  |     for (ModelObjectPtrs::iterator it = model_objects.begin(); it != model_objects.end(); ++it) { | ||||||
|  |         this->add_model_object(*it); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void | void | ||||||
| Print::clear_regions() | Print::clear_regions() | ||||||
| { | { | ||||||
|  |  | ||||||
|  | @ -154,6 +154,7 @@ class Print | ||||||
|     PrintObject* add_object(ModelObject *model_object, const BoundingBoxf3 &modobj_bbox); |     PrintObject* add_object(ModelObject *model_object, const BoundingBoxf3 &modobj_bbox); | ||||||
|     PrintObject* set_new_object(size_t idx, ModelObject *model_object, const BoundingBoxf3 &modobj_bbox); |     PrintObject* set_new_object(size_t idx, ModelObject *model_object, const BoundingBoxf3 &modobj_bbox); | ||||||
|     void delete_object(size_t idx); |     void delete_object(size_t idx); | ||||||
|  |     void reload_object(size_t idx); | ||||||
| 
 | 
 | ||||||
|     // methods for handling regions
 |     // methods for handling regions
 | ||||||
|     PrintRegion* get_region(size_t idx); |     PrintRegion* get_region(size_t idx); | ||||||
|  |  | ||||||
|  | @ -137,6 +137,7 @@ _constant() | ||||||
|         BoundingBoxf3 *modobj_bbox) |         BoundingBoxf3 *modobj_bbox) | ||||||
|         %code%{ RETVAL = THIS->set_new_object(idx, model_object, *modobj_bbox); %}; |         %code%{ RETVAL = THIS->set_new_object(idx, model_object, *modobj_bbox); %}; | ||||||
|     void delete_object(int idx); |     void delete_object(int idx); | ||||||
|  |     void reload_object(int idx); | ||||||
|     size_t object_count() |     size_t object_count() | ||||||
|         %code%{ RETVAL = THIS->objects.size(); %}; |         %code%{ RETVAL = THIS->objects.size(); %}; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Alessandro Ranellucci
						Alessandro Ranellucci