Ported reload_object() to XS

This commit is contained in:
Alessandro Ranellucci 2014-11-07 20:25:05 +01:00
parent 12ba7201c0
commit d645dabcff
4 changed files with 26 additions and 14 deletions

View file

@ -217,20 +217,6 @@ sub add_model_object {
$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 {
my $self = shift;

View file

@ -114,6 +114,30 @@ Print::delete_object(size_t idx)
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
Print::clear_regions()
{

View file

@ -154,6 +154,7 @@ class Print
PrintObject* add_object(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 reload_object(size_t idx);
// methods for handling regions
PrintRegion* get_region(size_t idx);

View file

@ -137,6 +137,7 @@ _constant()
BoundingBoxf3 *modobj_bbox)
%code%{ RETVAL = THIS->set_new_object(idx, model_object, *modobj_bbox); %};
void delete_object(int idx);
void reload_object(int idx);
size_t object_count()
%code%{ RETVAL = THIS->objects.size(); %};