Update volumes on 3DScene, after adding of part for unprintable object

This commit is contained in:
YuSanka 2019-08-16 13:14:51 +02:00
parent 8fce511806
commit dac301e3b6
3 changed files with 25 additions and 17 deletions

View File

@ -1319,9 +1319,7 @@ void GLCanvas3D::toggle_model_objects_visibility(bool visible, const ModelObject
_set_warning_texture(WarningTexture::SomethingNotShown, false); _set_warning_texture(WarningTexture::SomethingNotShown, false);
} }
void GLCanvas3D::update_instance_printable_state_for_objects(std::vector<size_t>& object_idxs) void GLCanvas3D::update_instance_printable_state_for_object(const size_t obj_idx)
{
for (size_t obj_idx : object_idxs)
{ {
ModelObject* model_object = m_model->objects[obj_idx]; ModelObject* model_object = m_model->objects[obj_idx];
for (int inst_idx = 0; inst_idx < model_object->instances.size(); inst_idx++) for (int inst_idx = 0; inst_idx < model_object->instances.size(); inst_idx++)
@ -1335,6 +1333,11 @@ void GLCanvas3D::update_instance_printable_state_for_objects(std::vector<size_t>
} }
} }
} }
void GLCanvas3D::update_instance_printable_state_for_objects(std::vector<size_t>& object_idxs)
{
for (size_t obj_idx : object_idxs)
update_instance_printable_state_for_object(obj_idx);
} }
void GLCanvas3D::set_config(const DynamicPrintConfig* config) void GLCanvas3D::set_config(const DynamicPrintConfig* config)

View File

@ -482,6 +482,7 @@ public:
void toggle_sla_auxiliaries_visibility(bool visible, const ModelObject* mo = nullptr, int instance_idx = -1); void toggle_sla_auxiliaries_visibility(bool visible, const ModelObject* mo = nullptr, int instance_idx = -1);
void toggle_model_objects_visibility(bool visible, const ModelObject* mo = nullptr, int instance_idx = -1); void toggle_model_objects_visibility(bool visible, const ModelObject* mo = nullptr, int instance_idx = -1);
void update_instance_printable_state_for_object(size_t obj_idx);
void update_instance_printable_state_for_objects(std::vector<size_t>& object_idxs); void update_instance_printable_state_for_objects(std::vector<size_t>& object_idxs);
void set_config(const DynamicPrintConfig* config); void set_config(const DynamicPrintConfig* config);

View File

@ -1616,6 +1616,9 @@ void ObjectList::load_subobject(ModelVolumeType type)
changed_object(obj_idx); changed_object(obj_idx);
if (type == ModelVolumeType::MODEL_PART)
// update printable state on canvas
wxGetApp().plater()->canvas3D()->update_instance_printable_state_for_object((size_t)obj_idx);
wxDataViewItem sel_item; wxDataViewItem sel_item;
for (const auto& volume : volumes_info ) for (const auto& volume : volumes_info )
@ -1739,6 +1742,9 @@ void ObjectList::load_generic_subobject(const std::string& type_name, const Mode
new_volume->config.set_key_value("extruder", new ConfigOptionInt(0)); new_volume->config.set_key_value("extruder", new ConfigOptionInt(0));
changed_object(obj_idx); changed_object(obj_idx);
if (type == ModelVolumeType::MODEL_PART)
// update printable state on canvas
wxGetApp().plater()->canvas3D()->update_instance_printable_state_for_object((size_t)obj_idx);
const auto object_item = m_objects_model->GetTopParent(GetSelection()); const auto object_item = m_objects_model->GetTopParent(GetSelection());
select_item(m_objects_model->AddVolumeChild(object_item, name, type, select_item(m_objects_model->AddVolumeChild(object_item, name, type,
@ -3351,9 +3357,8 @@ void ObjectList::instances_to_separated_object(const int obj_idx, const std::set
delete_instance_from_list(obj_idx, *it); delete_instance_from_list(obj_idx, *it);
} }
std::vector<size_t> object_idxs = { new_obj_indx };
// update printable state for new volumes on canvas3D // update printable state for new volumes on canvas3D
wxGetApp().plater()->canvas3D()->update_instance_printable_state_for_objects(object_idxs); wxGetApp().plater()->canvas3D()->update_instance_printable_state_for_object(new_obj_indx);
} }
void ObjectList::instances_to_separated_objects(const int obj_idx) void ObjectList::instances_to_separated_objects(const int obj_idx)
@ -3684,8 +3689,7 @@ void ObjectList::toggle_printable_state(wxDataViewItem item)
inst->printable = printable; inst->printable = printable;
// update printable state on canvas // update printable state on canvas
std::vector<size_t> obj_idxs = {(size_t)obj_idx}; wxGetApp().plater()->canvas3D()->update_instance_printable_state_for_object((size_t)obj_idx);
wxGetApp().plater()->canvas3D()->update_instance_printable_state_for_objects(obj_idxs);
// update printable state in ObjectList // update printable state in ObjectList
m_objects_model->SetObjectPrintableState(printable ? piPrintable : piUnprintable , item); m_objects_model->SetObjectPrintableState(printable ? piPrintable : piUnprintable , item);