mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-10-23 16:51:21 -06:00
ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK - Fixed inconsistencies for splitted and cutted objects
This commit is contained in:
parent
455f36119a
commit
a1c0a29af2
4 changed files with 13 additions and 32 deletions
|
@ -1116,7 +1116,7 @@ ModelObjectPtrs ModelObject::cut(size_t instance, coordf_t z, bool keep_upper, b
|
||||||
upper->sla_drain_holes.clear();
|
upper->sla_drain_holes.clear();
|
||||||
upper->sla_points_status = sla::PointsStatus::NoPoints;
|
upper->sla_points_status = sla::PointsStatus::NoPoints;
|
||||||
upper->clear_volumes();
|
upper->clear_volumes();
|
||||||
upper->input_file = "";
|
upper->input_file.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (keep_lower) {
|
if (keep_lower) {
|
||||||
|
@ -1125,7 +1125,7 @@ ModelObjectPtrs ModelObject::cut(size_t instance, coordf_t z, bool keep_upper, b
|
||||||
lower->sla_drain_holes.clear();
|
lower->sla_drain_holes.clear();
|
||||||
lower->sla_points_status = sla::PointsStatus::NoPoints;
|
lower->sla_points_status = sla::PointsStatus::NoPoints;
|
||||||
lower->clear_volumes();
|
lower->clear_volumes();
|
||||||
lower->input_file = "";
|
lower->input_file.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Because transformations are going to be applied to meshes directly,
|
// Because transformations are going to be applied to meshes directly,
|
||||||
|
|
|
@ -1651,14 +1651,9 @@ void ObjectList::append_menu_item_export_stl(wxMenu* menu) const
|
||||||
|
|
||||||
void ObjectList::append_menu_item_reload_from_disk(wxMenu* menu) const
|
void ObjectList::append_menu_item_reload_from_disk(wxMenu* menu) const
|
||||||
{
|
{
|
||||||
#if ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
|
||||||
append_menu_item(menu, wxID_ANY, _(L("Reload from disk")), _(L("Reload the selected volumes from disk")),
|
|
||||||
[this](wxCommandEvent&) { wxGetApp().plater()->reload_from_disk(); }, "", menu);
|
|
||||||
#else
|
|
||||||
append_menu_item(menu, wxID_ANY, _(L("Reload from disk")), _(L("Reload the selected volumes from disk")),
|
append_menu_item(menu, wxID_ANY, _(L("Reload from disk")), _(L("Reload the selected volumes from disk")),
|
||||||
[this](wxCommandEvent&) { wxGetApp().plater()->reload_from_disk(); }, "", menu,
|
[this](wxCommandEvent&) { wxGetApp().plater()->reload_from_disk(); }, "", menu,
|
||||||
[]() { return wxGetApp().plater()->can_reload_from_disk(); }, wxGetApp().plater());
|
[]() { return wxGetApp().plater()->can_reload_from_disk(); }, wxGetApp().plater());
|
||||||
#endif // ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ObjectList::append_menu_item_change_extruder(wxMenu* menu) const
|
void ObjectList::append_menu_item_change_extruder(wxMenu* menu) const
|
||||||
|
@ -2275,6 +2270,10 @@ void ObjectList::split()
|
||||||
add_settings_item(vol_item, &volume->config);
|
add_settings_item(vol_item, &volume->config);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
||||||
|
model_object->input_file.clear();
|
||||||
|
#endif // ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
||||||
|
|
||||||
if (parent == item)
|
if (parent == item)
|
||||||
Expand(parent);
|
Expand(parent);
|
||||||
|
|
||||||
|
@ -3928,15 +3927,10 @@ void ObjectList::show_multi_selection_menu()
|
||||||
_(L("Select extruder number for selected objects and/or parts")),
|
_(L("Select extruder number for selected objects and/or parts")),
|
||||||
[this](wxCommandEvent&) { extruder_selection(); }, "", menu);
|
[this](wxCommandEvent&) { extruder_selection(); }, "", menu);
|
||||||
|
|
||||||
#if ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
|
||||||
append_menu_item(menu, wxID_ANY, _(L("Reload from disk")), _(L("Reload the selected volumes from disk")),
|
|
||||||
[this](wxCommandEvent&) { wxGetApp().plater()->reload_from_disk(); }, "", menu);
|
|
||||||
#else
|
|
||||||
append_menu_item(menu, wxID_ANY, _(L("Reload from disk")), _(L("Reload the selected volumes from disk")),
|
append_menu_item(menu, wxID_ANY, _(L("Reload from disk")), _(L("Reload the selected volumes from disk")),
|
||||||
[this](wxCommandEvent&) { wxGetApp().plater()->reload_from_disk(); }, "", menu, []() {
|
[this](wxCommandEvent&) { wxGetApp().plater()->reload_from_disk(); }, "", menu, []() {
|
||||||
return wxGetApp().plater()->can_reload_from_disk();
|
return wxGetApp().plater()->can_reload_from_disk();
|
||||||
}, wxGetApp().plater());
|
}, wxGetApp().plater());
|
||||||
#endif // ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
|
||||||
|
|
||||||
wxGetApp().plater()->PopupMenu(menu);
|
wxGetApp().plater()->PopupMenu(menu);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1923,9 +1923,7 @@ struct Plater::priv
|
||||||
bool can_fix_through_netfabb() const;
|
bool can_fix_through_netfabb() const;
|
||||||
bool can_set_instance_to_object() const;
|
bool can_set_instance_to_object() const;
|
||||||
bool can_mirror() const;
|
bool can_mirror() const;
|
||||||
#if !ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
|
||||||
bool can_reload_from_disk() const;
|
bool can_reload_from_disk() const;
|
||||||
#endif // !ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
|
||||||
|
|
||||||
#if ENABLE_THUMBNAIL_GENERATOR
|
#if ENABLE_THUMBNAIL_GENERATOR
|
||||||
void generate_thumbnail(ThumbnailData& data, unsigned int w, unsigned int h, bool printable_only, bool parts_only, bool show_bed, bool transparent_background);
|
void generate_thumbnail(ThumbnailData& data, unsigned int w, unsigned int h, bool printable_only, bool parts_only, bool show_bed, bool transparent_background);
|
||||||
|
@ -3259,7 +3257,7 @@ void Plater::priv::reload_from_disk()
|
||||||
missing_input_paths.push_back(volume->source.input_file);
|
missing_input_paths.push_back(volume->source.input_file);
|
||||||
}
|
}
|
||||||
#if ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
#if ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
||||||
else if (!volume->name.empty())
|
else if (!object->input_file.empty() && !volume->name.empty())
|
||||||
missing_input_paths.push_back(volume->name);
|
missing_input_paths.push_back(volume->name);
|
||||||
#endif // ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
#endif // ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
||||||
}
|
}
|
||||||
|
@ -3942,13 +3940,8 @@ bool Plater::priv::init_common_menu(wxMenu* menu, const bool is_part/* = false*/
|
||||||
append_menu_item(menu, wxID_ANY, _(L("Delete")) + "\tDel", _(L("Remove the selected object")),
|
append_menu_item(menu, wxID_ANY, _(L("Delete")) + "\tDel", _(L("Remove the selected object")),
|
||||||
[this](wxCommandEvent&) { q->remove_selected(); }, "delete", nullptr, [this]() { return can_delete(); }, q);
|
[this](wxCommandEvent&) { q->remove_selected(); }, "delete", nullptr, [this]() { return can_delete(); }, q);
|
||||||
|
|
||||||
#if ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
|
||||||
append_menu_item(menu, wxID_ANY, _(L("Reload from disk")), _(L("Reload the selected volumes from disk")),
|
|
||||||
[this](wxCommandEvent&) { q->reload_from_disk(); }, "", menu);
|
|
||||||
#else
|
|
||||||
append_menu_item(menu, wxID_ANY, _(L("Reload from disk")), _(L("Reload the selected volumes from disk")),
|
append_menu_item(menu, wxID_ANY, _(L("Reload from disk")), _(L("Reload the selected volumes from disk")),
|
||||||
[this](wxCommandEvent&) { q->reload_from_disk(); }, "", menu, [this]() { return can_reload_from_disk(); }, q);
|
[this](wxCommandEvent&) { q->reload_from_disk(); }, "", menu, [this]() { return can_reload_from_disk(); }, q);
|
||||||
#endif // ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
|
||||||
|
|
||||||
sidebar->obj_list()->append_menu_item_export_stl(menu);
|
sidebar->obj_list()->append_menu_item_export_stl(menu);
|
||||||
}
|
}
|
||||||
|
@ -3976,13 +3969,8 @@ bool Plater::priv::init_common_menu(wxMenu* menu, const bool is_part/* = false*/
|
||||||
wxMenuItem* menu_item_printable = sidebar->obj_list()->append_menu_item_printable(menu, q);
|
wxMenuItem* menu_item_printable = sidebar->obj_list()->append_menu_item_printable(menu, q);
|
||||||
menu->AppendSeparator();
|
menu->AppendSeparator();
|
||||||
|
|
||||||
#if ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
|
||||||
append_menu_item(menu, wxID_ANY, _(L("Reload from disk")), _(L("Reload the selected object from disk")),
|
|
||||||
[this](wxCommandEvent&) { reload_from_disk(); }, "", nullptr);
|
|
||||||
#else
|
|
||||||
append_menu_item(menu, wxID_ANY, _(L("Reload from disk")), _(L("Reload the selected object from disk")),
|
append_menu_item(menu, wxID_ANY, _(L("Reload from disk")), _(L("Reload the selected object from disk")),
|
||||||
[this](wxCommandEvent&) { reload_from_disk(); }, "", nullptr, [this]() { return can_reload_from_disk(); }, q);
|
[this](wxCommandEvent&) { reload_from_disk(); }, "", nullptr, [this]() { return can_reload_from_disk(); }, q);
|
||||||
#endif // ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
|
||||||
|
|
||||||
append_menu_item(menu, wxID_ANY, _(L("Export as STL")) + dots, _(L("Export the selected object as STL file")),
|
append_menu_item(menu, wxID_ANY, _(L("Export as STL")) + dots, _(L("Export the selected object as STL file")),
|
||||||
[this](wxCommandEvent&) { q->export_stl(false, true); }, "", nullptr,
|
[this](wxCommandEvent&) { q->export_stl(false, true); }, "", nullptr,
|
||||||
|
@ -4162,7 +4150,6 @@ bool Plater::priv::can_mirror() const
|
||||||
return get_selection().is_from_single_instance();
|
return get_selection().is_from_single_instance();
|
||||||
}
|
}
|
||||||
|
|
||||||
#if !ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
|
||||||
bool Plater::priv::can_reload_from_disk() const
|
bool Plater::priv::can_reload_from_disk() const
|
||||||
{
|
{
|
||||||
// struct to hold selected ModelVolumes by their indices
|
// struct to hold selected ModelVolumes by their indices
|
||||||
|
@ -4199,16 +4186,20 @@ bool Plater::priv::can_reload_from_disk() const
|
||||||
std::vector<fs::path> paths;
|
std::vector<fs::path> paths;
|
||||||
for (const SelectedVolume& v : selected_volumes)
|
for (const SelectedVolume& v : selected_volumes)
|
||||||
{
|
{
|
||||||
const ModelVolume* volume = model.objects[v.object_idx]->volumes[v.volume_idx];
|
const ModelObject* object = model.objects[v.object_idx];
|
||||||
|
const ModelVolume* volume = object->volumes[v.volume_idx];
|
||||||
if (!volume->source.input_file.empty())
|
if (!volume->source.input_file.empty())
|
||||||
paths.push_back(volume->source.input_file);
|
paths.push_back(volume->source.input_file);
|
||||||
|
#if ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
||||||
|
else if (!object->input_file.empty() && !volume->name.empty())
|
||||||
|
paths.push_back(volume->name);
|
||||||
|
#endif // ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
||||||
}
|
}
|
||||||
std::sort(paths.begin(), paths.end());
|
std::sort(paths.begin(), paths.end());
|
||||||
paths.erase(std::unique(paths.begin(), paths.end()), paths.end());
|
paths.erase(std::unique(paths.begin(), paths.end()), paths.end());
|
||||||
|
|
||||||
return !paths.empty();
|
return !paths.empty();
|
||||||
}
|
}
|
||||||
#endif // !ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
|
||||||
|
|
||||||
void Plater::priv::set_bed_shape(const Pointfs& shape, const std::string& custom_texture, const std::string& custom_model)
|
void Plater::priv::set_bed_shape(const Pointfs& shape, const std::string& custom_texture, const std::string& custom_model)
|
||||||
{
|
{
|
||||||
|
@ -5709,9 +5700,7 @@ bool Plater::can_copy_to_clipboard() const
|
||||||
|
|
||||||
bool Plater::can_undo() const { return p->undo_redo_stack().has_undo_snapshot(); }
|
bool Plater::can_undo() const { return p->undo_redo_stack().has_undo_snapshot(); }
|
||||||
bool Plater::can_redo() const { return p->undo_redo_stack().has_redo_snapshot(); }
|
bool Plater::can_redo() const { return p->undo_redo_stack().has_redo_snapshot(); }
|
||||||
#if !ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
|
||||||
bool Plater::can_reload_from_disk() const { return p->can_reload_from_disk(); }
|
bool Plater::can_reload_from_disk() const { return p->can_reload_from_disk(); }
|
||||||
#endif // !ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
|
||||||
const UndoRedo::Stack& Plater::undo_redo_stack_main() const { return p->undo_redo_stack_main(); }
|
const UndoRedo::Stack& Plater::undo_redo_stack_main() const { return p->undo_redo_stack_main(); }
|
||||||
void Plater::enter_gizmos_stack() { p->enter_gizmos_stack(); }
|
void Plater::enter_gizmos_stack() { p->enter_gizmos_stack(); }
|
||||||
void Plater::leave_gizmos_stack() { p->leave_gizmos_stack(); }
|
void Plater::leave_gizmos_stack() { p->leave_gizmos_stack(); }
|
||||||
|
|
|
@ -277,9 +277,7 @@ public:
|
||||||
bool can_copy_to_clipboard() const;
|
bool can_copy_to_clipboard() const;
|
||||||
bool can_undo() const;
|
bool can_undo() const;
|
||||||
bool can_redo() const;
|
bool can_redo() const;
|
||||||
#if !ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
|
||||||
bool can_reload_from_disk() const;
|
bool can_reload_from_disk() const;
|
||||||
#endif // !ENABLE_BACKWARD_COMPATIBLE_RELOAD_FROM_DISK
|
|
||||||
|
|
||||||
void msw_rescale();
|
void msw_rescale();
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue