mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-07-24 07:03:59 -06:00
Modifiers are moving now
This commit is contained in:
parent
fb9ba1a55c
commit
99082bfe67
5 changed files with 213 additions and 52 deletions
|
@ -887,6 +887,8 @@ void add_expert_mode_part( wxWindow* parent, wxBoxSizer* sizer,
|
||||||
{
|
{
|
||||||
set_event_object_selection_changed(event_object_selection_changed);
|
set_event_object_selection_changed(event_object_selection_changed);
|
||||||
set_event_object_settings_changed(event_object_settings_changed);
|
set_event_object_settings_changed(event_object_settings_changed);
|
||||||
|
init_mesh_icons();
|
||||||
|
|
||||||
wxWindowUpdateLocker noUpdates(parent);
|
wxWindowUpdateLocker noUpdates(parent);
|
||||||
|
|
||||||
add_collapsible_panes(parent, sizer);
|
add_collapsible_panes(parent, sizer);
|
||||||
|
|
|
@ -23,9 +23,17 @@ wxDataViewCtrl *m_objects_ctrl = nullptr;
|
||||||
PrusaObjectDataViewModel *m_objects_model = nullptr;
|
PrusaObjectDataViewModel *m_objects_model = nullptr;
|
||||||
wxCollapsiblePane *m_collpane_settings = nullptr;
|
wxCollapsiblePane *m_collpane_settings = nullptr;
|
||||||
|
|
||||||
wxSlider* mover_x = nullptr;
|
wxIcon m_icon_modifiermesh;
|
||||||
wxSlider* mover_y = nullptr;
|
wxIcon m_icon_solidmesh;
|
||||||
wxSlider* mover_z = nullptr;
|
|
||||||
|
wxSlider* m_mover_x = nullptr;
|
||||||
|
wxSlider* m_mover_y = nullptr;
|
||||||
|
wxSlider* m_mover_z = nullptr;
|
||||||
|
wxButton* m_btn_move_up = nullptr;
|
||||||
|
wxButton* m_btn_move_down = nullptr;
|
||||||
|
Point3 m_move_options;
|
||||||
|
Point3 m_last_coords;
|
||||||
|
int m_selected_object_id = -1;
|
||||||
|
|
||||||
bool g_prevent_list_events = false; // We use this flag to avoid circular event handling Select()
|
bool g_prevent_list_events = false; // We use this flag to avoid circular event handling Select()
|
||||||
// happens to fire a wxEVT_LIST_ITEM_SELECTED on OSX, whose event handler
|
// happens to fire a wxEVT_LIST_ITEM_SELECTED on OSX, whose event handler
|
||||||
|
@ -45,6 +53,11 @@ void set_event_object_settings_changed(const int& event){
|
||||||
m_event_object_settings_changed = event;
|
m_event_object_settings_changed = event;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void init_mesh_icons(){
|
||||||
|
m_icon_modifiermesh = wxIcon(Slic3r::GUI::from_u8(Slic3r::var("plugin.png")), wxBITMAP_TYPE_PNG);
|
||||||
|
m_icon_solidmesh = wxIcon(Slic3r::GUI::from_u8(Slic3r::var("package.png")), wxBITMAP_TYPE_PNG);
|
||||||
|
}
|
||||||
|
|
||||||
bool is_parts_changed(){return m_parts_changed;}
|
bool is_parts_changed(){return m_parts_changed;}
|
||||||
bool is_part_settings_changed(){ return m_part_settings_changed; }
|
bool is_part_settings_changed(){ return m_part_settings_changed; }
|
||||||
|
|
||||||
|
@ -96,6 +109,7 @@ wxBoxSizer* content_objects_list(wxWindow *win)
|
||||||
obj_idx = m_objects_model->GetIdByItem(parent); // TODO Temporary decision for sub-objects selection
|
obj_idx = m_objects_model->GetIdByItem(parent); // TODO Temporary decision for sub-objects selection
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
m_selected_object_id = obj_idx;
|
||||||
|
|
||||||
if (m_event_object_selection_changed > 0) {
|
if (m_event_object_selection_changed > 0) {
|
||||||
wxCommandEvent event(m_event_object_selection_changed);
|
wxCommandEvent event(m_event_object_selection_changed);
|
||||||
|
@ -107,29 +121,7 @@ wxBoxSizer* content_objects_list(wxWindow *win)
|
||||||
if (obj_idx < 0) return;
|
if (obj_idx < 0) return;
|
||||||
|
|
||||||
// m_objects_ctrl->SetSize(m_objects_ctrl->GetBestSize()); // TODO override GetBestSize(), than use it
|
// m_objects_ctrl->SetSize(m_objects_ctrl->GetBestSize()); // TODO override GetBestSize(), than use it
|
||||||
|
part_selection_changed();
|
||||||
auto show_obj_sizer = m_objects_model->GetParent(item) == wxDataViewItem(0);
|
|
||||||
m_sizer_object_buttons->Show(show_obj_sizer);
|
|
||||||
m_sizer_part_buttons->Show(!show_obj_sizer);
|
|
||||||
m_sizer_object_movers->Show(!show_obj_sizer);
|
|
||||||
|
|
||||||
if (!show_obj_sizer)
|
|
||||||
{
|
|
||||||
auto bb_size = m_objects[obj_idx]->bounding_box().size();
|
|
||||||
int scale = 10; //??
|
|
||||||
|
|
||||||
mover_x->SetMin(-bb_size.x * 4*scale);
|
|
||||||
mover_x->SetMax( bb_size.x * 4*scale);
|
|
||||||
|
|
||||||
mover_y->SetMin(-bb_size.y * 4*scale);
|
|
||||||
mover_y->SetMax( bb_size.y * 4*scale);
|
|
||||||
|
|
||||||
mover_z->SetMin(-bb_size.z * 4 * scale);
|
|
||||||
mover_z->SetMax( bb_size.z * 4 * scale);
|
|
||||||
}
|
|
||||||
|
|
||||||
m_collpane_settings->SetLabelText((show_obj_sizer ? _(L("Object Settings")) : _(L("Part Settings"))) + ":");
|
|
||||||
m_collpane_settings->Show(true);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
m_objects_ctrl->Bind(wxEVT_KEY_DOWN, [](wxKeyEvent& event)
|
m_objects_ctrl->Bind(wxEVT_KEY_DOWN, [](wxKeyEvent& event)
|
||||||
|
@ -152,8 +144,8 @@ wxBoxSizer* content_edit_object_buttons(wxWindow* win)
|
||||||
auto btn_load_lambda_modifier = new wxButton(win, wxID_ANY, /*Load */"generic" + dots, wxDefaultPosition, wxDefaultSize, wxBU_EXACTFIT | wxNO_BORDER/*wxBU_LEFT*/);
|
auto btn_load_lambda_modifier = new wxButton(win, wxID_ANY, /*Load */"generic" + dots, wxDefaultPosition, wxDefaultSize, wxBU_EXACTFIT | wxNO_BORDER/*wxBU_LEFT*/);
|
||||||
auto btn_delete = new wxButton(win, wxID_ANY, "Delete"/*" part"*/, wxDefaultPosition, wxDefaultSize, wxBU_EXACTFIT | wxNO_BORDER/*wxBU_LEFT*/);
|
auto btn_delete = new wxButton(win, wxID_ANY, "Delete"/*" part"*/, wxDefaultPosition, wxDefaultSize, wxBU_EXACTFIT | wxNO_BORDER/*wxBU_LEFT*/);
|
||||||
auto btn_split = new wxButton(win, wxID_ANY, "Split"/*" part"*/, wxDefaultPosition, wxDefaultSize, wxBU_EXACTFIT | wxNO_BORDER/*wxBU_LEFT*/);
|
auto btn_split = new wxButton(win, wxID_ANY, "Split"/*" part"*/, wxDefaultPosition, wxDefaultSize, wxBU_EXACTFIT | wxNO_BORDER/*wxBU_LEFT*/);
|
||||||
auto btn_move_up = new wxButton(win, wxID_ANY, "", wxDefaultPosition, wxDefaultSize/*wxSize(30, -1)*/, wxBU_LEFT);
|
m_btn_move_up = new wxButton(win, wxID_ANY, "", wxDefaultPosition, wxDefaultSize/*wxSize(30, -1)*/, wxBU_LEFT);
|
||||||
auto btn_move_down = new wxButton(win, wxID_ANY, "", wxDefaultPosition, wxDefaultSize/*wxSize(30, -1)*/, wxBU_LEFT);
|
m_btn_move_down = new wxButton(win, wxID_ANY, "", wxDefaultPosition, wxDefaultSize/*wxSize(30, -1)*/, wxBU_LEFT);
|
||||||
|
|
||||||
//*** button's functions
|
//*** button's functions
|
||||||
btn_load_part->Bind(wxEVT_BUTTON, [win](wxEvent&)
|
btn_load_part->Bind(wxEVT_BUTTON, [win](wxEvent&)
|
||||||
|
@ -176,18 +168,19 @@ wxBoxSizer* content_edit_object_buttons(wxWindow* win)
|
||||||
auto item = m_objects_ctrl->GetSelection();
|
auto item = m_objects_ctrl->GetSelection();
|
||||||
if (!item) return;
|
if (!item) return;
|
||||||
m_objects_ctrl->Select(m_objects_model->Delete(item));
|
m_objects_ctrl->Select(m_objects_model->Delete(item));
|
||||||
|
parts_changed(m_selected_object_id);
|
||||||
});
|
});
|
||||||
//***
|
//***
|
||||||
|
|
||||||
btn_move_up->SetMinSize(wxSize(20, -1));
|
m_btn_move_up->SetMinSize(wxSize(20, -1));
|
||||||
btn_move_down->SetMinSize(wxSize(20, -1));
|
m_btn_move_down->SetMinSize(wxSize(20, -1));
|
||||||
btn_load_part->SetBitmap(wxBitmap(from_u8(Slic3r::var("brick_add.png")), wxBITMAP_TYPE_PNG));
|
btn_load_part->SetBitmap(wxBitmap(from_u8(Slic3r::var("brick_add.png")), wxBITMAP_TYPE_PNG));
|
||||||
btn_load_modifier->SetBitmap(wxBitmap(from_u8(Slic3r::var("brick_add.png")), wxBITMAP_TYPE_PNG));
|
btn_load_modifier->SetBitmap(wxBitmap(from_u8(Slic3r::var("brick_add.png")), wxBITMAP_TYPE_PNG));
|
||||||
btn_load_lambda_modifier->SetBitmap(wxBitmap(from_u8(Slic3r::var("brick_add.png")), wxBITMAP_TYPE_PNG));
|
btn_load_lambda_modifier->SetBitmap(wxBitmap(from_u8(Slic3r::var("brick_add.png")), wxBITMAP_TYPE_PNG));
|
||||||
btn_delete->SetBitmap(wxBitmap(from_u8(Slic3r::var("brick_delete.png")), wxBITMAP_TYPE_PNG));
|
btn_delete->SetBitmap(wxBitmap(from_u8(Slic3r::var("brick_delete.png")), wxBITMAP_TYPE_PNG));
|
||||||
btn_split->SetBitmap(wxBitmap(from_u8(Slic3r::var("shape_ungroup.png")), wxBITMAP_TYPE_PNG));
|
btn_split->SetBitmap(wxBitmap(from_u8(Slic3r::var("shape_ungroup.png")), wxBITMAP_TYPE_PNG));
|
||||||
btn_move_up->SetBitmap(wxBitmap(from_u8(Slic3r::var("bullet_arrow_up.png")), wxBITMAP_TYPE_PNG));
|
m_btn_move_up->SetBitmap(wxBitmap(from_u8(Slic3r::var("bullet_arrow_up.png")), wxBITMAP_TYPE_PNG));
|
||||||
btn_move_down->SetBitmap(wxBitmap(from_u8(Slic3r::var("bullet_arrow_down.png")), wxBITMAP_TYPE_PNG));
|
m_btn_move_down->SetBitmap(wxBitmap(from_u8(Slic3r::var("bullet_arrow_down.png")), wxBITMAP_TYPE_PNG));
|
||||||
|
|
||||||
m_sizer_object_buttons = new wxGridSizer(1, 3, 0, 0);
|
m_sizer_object_buttons = new wxGridSizer(1, 3, 0, 0);
|
||||||
m_sizer_object_buttons->Add(btn_load_part, 0, wxEXPAND);
|
m_sizer_object_buttons->Add(btn_load_part, 0, wxEXPAND);
|
||||||
|
@ -200,8 +193,8 @@ wxBoxSizer* content_edit_object_buttons(wxWindow* win)
|
||||||
m_sizer_part_buttons->Add(btn_split, 0, wxEXPAND);
|
m_sizer_part_buttons->Add(btn_split, 0, wxEXPAND);
|
||||||
{
|
{
|
||||||
auto up_down_sizer = new wxGridSizer(1, 2, 0, 0);
|
auto up_down_sizer = new wxGridSizer(1, 2, 0, 0);
|
||||||
up_down_sizer->Add(btn_move_up, 1, wxEXPAND);
|
up_down_sizer->Add(m_btn_move_up, 1, wxEXPAND);
|
||||||
up_down_sizer->Add(btn_move_down, 1, wxEXPAND);
|
up_down_sizer->Add(m_btn_move_down, 1, wxEXPAND);
|
||||||
m_sizer_part_buttons->Add(up_down_sizer, 0, wxEXPAND);
|
m_sizer_part_buttons->Add(up_down_sizer, 0, wxEXPAND);
|
||||||
}
|
}
|
||||||
m_sizer_part_buttons->Show(false);
|
m_sizer_part_buttons->Show(false);
|
||||||
|
@ -211,19 +204,58 @@ wxBoxSizer* content_edit_object_buttons(wxWindow* win)
|
||||||
btn_load_lambda_modifier->SetFont(Slic3r::GUI::small_font());
|
btn_load_lambda_modifier->SetFont(Slic3r::GUI::small_font());
|
||||||
btn_delete->SetFont(Slic3r::GUI::small_font());
|
btn_delete->SetFont(Slic3r::GUI::small_font());
|
||||||
btn_split->SetFont(Slic3r::GUI::small_font());
|
btn_split->SetFont(Slic3r::GUI::small_font());
|
||||||
btn_move_up->SetFont(Slic3r::GUI::small_font());
|
m_btn_move_up->SetFont(Slic3r::GUI::small_font());
|
||||||
btn_move_down->SetFont(Slic3r::GUI::small_font());
|
m_btn_move_down->SetFont(Slic3r::GUI::small_font());
|
||||||
|
|
||||||
sizer->Add(m_sizer_object_buttons, 0, wxEXPAND | wxLEFT, 20);
|
sizer->Add(m_sizer_object_buttons, 0, wxEXPAND | wxLEFT, 20);
|
||||||
sizer->Add(m_sizer_part_buttons, 0, wxEXPAND | wxLEFT, 20);
|
sizer->Add(m_sizer_part_buttons, 0, wxEXPAND | wxLEFT, 20);
|
||||||
return sizer;
|
return sizer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void update_after_moving()
|
||||||
|
{
|
||||||
|
auto item = m_objects_ctrl->GetSelection();
|
||||||
|
if (!item || m_selected_object_id<0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
auto volume_id = m_objects_model->GetVolumeIdByItem(item);
|
||||||
|
if (volume_id < 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
Point3 m = m_move_options;
|
||||||
|
Point3 l = m_last_coords;
|
||||||
|
|
||||||
|
auto d = Pointf3(m.x - l.x, m.y - l.y, m.z - l.z);
|
||||||
|
auto volume = m_objects[m_selected_object_id]->volumes[volume_id];
|
||||||
|
volume->mesh.translate(d.x,d.y,d.z);
|
||||||
|
m_last_coords = m;
|
||||||
|
|
||||||
|
m_parts_changed = true;
|
||||||
|
parts_changed(m_selected_object_id);
|
||||||
|
}
|
||||||
|
|
||||||
wxSizer* object_movers(wxWindow *win)
|
wxSizer* object_movers(wxWindow *win)
|
||||||
{
|
{
|
||||||
// DynamicPrintConfig* config = &get_preset_bundle()->/*full_config();//*/printers.get_edited_preset().config; // TODO get config from Model_volume
|
// DynamicPrintConfig* config = &get_preset_bundle()->/*full_config();//*/printers.get_edited_preset().config; // TODO get config from Model_volume
|
||||||
std::shared_ptr<ConfigOptionsGroup> optgroup = std::make_shared<ConfigOptionsGroup>(win, "Move"/*, config*/);
|
std::shared_ptr<ConfigOptionsGroup> optgroup = std::make_shared<ConfigOptionsGroup>(win, "Move"/*, config*/);
|
||||||
optgroup->label_width = 20;
|
optgroup->label_width = 20;
|
||||||
|
optgroup->m_on_change = [](t_config_option_key opt_key, boost::any value){
|
||||||
|
int val = boost::any_cast<int>(value);
|
||||||
|
bool update = false;
|
||||||
|
if (opt_key == "x" && m_move_options.x != val){
|
||||||
|
update = true;
|
||||||
|
m_move_options.x = val;
|
||||||
|
}
|
||||||
|
else if (opt_key == "y" && m_move_options.y != val){
|
||||||
|
update = true;
|
||||||
|
m_move_options.y = val;
|
||||||
|
}
|
||||||
|
else if (opt_key == "z" && m_move_options.z != val){
|
||||||
|
update = true;
|
||||||
|
m_move_options.z = val;
|
||||||
|
}
|
||||||
|
if (update) update_after_moving();
|
||||||
|
};
|
||||||
|
|
||||||
ConfigOptionDef def;
|
ConfigOptionDef def;
|
||||||
def.label = L("X");
|
def.label = L("X");
|
||||||
|
@ -234,21 +266,26 @@ wxSizer* object_movers(wxWindow *win)
|
||||||
Option option = Option(def, "x");
|
Option option = Option(def, "x");
|
||||||
option.opt.full_width = true;
|
option.opt.full_width = true;
|
||||||
optgroup->append_single_option_line(option);
|
optgroup->append_single_option_line(option);
|
||||||
mover_x = dynamic_cast<wxSlider*>(optgroup->get_field("x")->getWindow());
|
m_mover_x = dynamic_cast<wxSlider*>(optgroup->get_field("x")->getWindow());
|
||||||
|
|
||||||
def.label = L("Y");
|
def.label = L("Y");
|
||||||
option = Option(def, "y");
|
option = Option(def, "y");
|
||||||
optgroup->append_single_option_line(option);
|
optgroup->append_single_option_line(option);
|
||||||
mover_y = dynamic_cast<wxSlider*>(optgroup->get_field("y")->getWindow());
|
m_mover_y = dynamic_cast<wxSlider*>(optgroup->get_field("y")->getWindow());
|
||||||
|
|
||||||
def.label = L("Z");
|
def.label = L("Z");
|
||||||
option = Option(def, "z");
|
option = Option(def, "z");
|
||||||
optgroup->append_single_option_line(option);
|
optgroup->append_single_option_line(option);
|
||||||
mover_z = dynamic_cast<wxSlider*>(optgroup->get_field("z")->getWindow());
|
m_mover_z = dynamic_cast<wxSlider*>(optgroup->get_field("z")->getWindow());
|
||||||
|
|
||||||
get_optgroups().push_back(optgroup); // ogObjectMovers
|
get_optgroups().push_back(optgroup); // ogObjectMovers
|
||||||
|
|
||||||
m_sizer_object_movers = optgroup->sizer;
|
m_sizer_object_movers = optgroup->sizer;
|
||||||
m_sizer_object_movers->Show(false);
|
m_sizer_object_movers->Show(false);
|
||||||
|
|
||||||
|
m_move_options = Point3(0, 0, 0);
|
||||||
|
m_last_coords = Point3(0, 0, 0);
|
||||||
|
|
||||||
return optgroup->sizer;
|
return optgroup->sizer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -512,10 +549,9 @@ void on_btn_load(wxWindow* parent, bool is_modifier /*= false*/, bool is_lambda/
|
||||||
|
|
||||||
parts_changed(obj_idx);
|
parts_changed(obj_idx);
|
||||||
|
|
||||||
const std::string icon_name = is_modifier ? "plugin.png" : "package.png";
|
|
||||||
auto icon = wxIcon(Slic3r::GUI::from_u8(Slic3r::var(icon_name)), wxBITMAP_TYPE_PNG);
|
|
||||||
for (int i = 0; i < part_names.size(); ++i)
|
for (int i = 0; i < part_names.size(); ++i)
|
||||||
m_objects_ctrl->Select(m_objects_model->AddChild(item, part_names.Item(i), icon));
|
m_objects_ctrl->Select( m_objects_model->AddChild(item, part_names.Item(i),
|
||||||
|
is_modifier ? m_icon_modifiermesh : m_icon_solidmesh));
|
||||||
}
|
}
|
||||||
|
|
||||||
void parts_changed(int obj_idx)
|
void parts_changed(int obj_idx)
|
||||||
|
@ -530,5 +566,100 @@ void parts_changed(int obj_idx)
|
||||||
get_main_frame()->ProcessWindowEvent(e);
|
get_main_frame()->ProcessWindowEvent(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void part_selection_changed()
|
||||||
|
{
|
||||||
|
m_move_options = Point3(0, 0, 0);
|
||||||
|
m_last_coords = Point3(0, 0, 0);
|
||||||
|
// reset move sliders
|
||||||
|
std::vector<std::string> opt_keys = {"x", "y", "z"};
|
||||||
|
auto og = get_optgroup(ogObjectMovers);
|
||||||
|
for (auto opt_key: opt_keys)
|
||||||
|
og->set_value(opt_key, int(0));
|
||||||
|
|
||||||
|
auto item = m_objects_ctrl->GetSelection();
|
||||||
|
if (!item || m_selected_object_id < 0){
|
||||||
|
m_sizer_object_buttons->Show(false);
|
||||||
|
m_sizer_part_buttons->Show(false);
|
||||||
|
m_sizer_object_movers->Show(false);
|
||||||
|
m_collpane_settings->Show(false);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_collpane_settings->Show(true);
|
||||||
|
|
||||||
|
auto volume_id = m_objects_model->GetVolumeIdByItem(item);
|
||||||
|
if (volume_id < 0){
|
||||||
|
m_sizer_object_buttons->Show(true);
|
||||||
|
m_sizer_part_buttons->Show(false);
|
||||||
|
m_sizer_object_movers->Show(false);
|
||||||
|
m_collpane_settings->SetLabelText(_(L("Object Settings")) + ":");
|
||||||
|
|
||||||
|
// elsif($itemData->{type} eq 'object') {
|
||||||
|
// # select nothing in 3D preview
|
||||||
|
//
|
||||||
|
// # attach object config to settings panel
|
||||||
|
// $self->{optgroup_movers}->disable;
|
||||||
|
// $self->{staticbox}->SetLabel('Object Settings');
|
||||||
|
// @opt_keys = (map @{$_->get_keys}, Slic3r::Config::PrintObject->new, Slic3r::Config::PrintRegion->new);
|
||||||
|
// $config = $self->{model_object}->config;
|
||||||
|
// }
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_collpane_settings->SetLabelText(_(L("Part Settings")) + ":");
|
||||||
|
|
||||||
|
m_sizer_object_buttons->Show(false);
|
||||||
|
m_sizer_part_buttons->Show(true);
|
||||||
|
m_sizer_object_movers->Show(true);
|
||||||
|
|
||||||
|
auto bb_size = m_objects[m_selected_object_id]->bounding_box().size();
|
||||||
|
int scale = 10; //??
|
||||||
|
|
||||||
|
m_mover_x->SetMin(-bb_size.x * 4 * scale);
|
||||||
|
m_mover_x->SetMax(bb_size.x * 4 * scale);
|
||||||
|
|
||||||
|
m_mover_y->SetMin(-bb_size.y * 4 * scale);
|
||||||
|
m_mover_y->SetMax(bb_size.y * 4 * scale);
|
||||||
|
|
||||||
|
m_mover_z->SetMin(-bb_size.z * 4 * scale);
|
||||||
|
m_mover_z->SetMax(bb_size.z * 4 * scale);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// my ($config, @opt_keys);
|
||||||
|
m_btn_move_up->Enable(volume_id > 0);
|
||||||
|
m_btn_move_down->Enable(volume_id + 1 < m_objects[m_selected_object_id]->volumes.size());
|
||||||
|
|
||||||
|
// attach volume config to settings panel
|
||||||
|
auto volume = m_objects[m_selected_object_id]->volumes[volume_id];
|
||||||
|
|
||||||
|
if (volume->modifier)
|
||||||
|
og->enable();
|
||||||
|
else
|
||||||
|
og->disable();
|
||||||
|
|
||||||
|
// auto config = volume->config;
|
||||||
|
|
||||||
|
// get default values
|
||||||
|
// @opt_keys = @{Slic3r::Config::PrintRegion->new->get_keys};
|
||||||
|
// }
|
||||||
|
/*
|
||||||
|
# get default values
|
||||||
|
my $default_config = Slic3r::Config::new_from_defaults_keys(\@opt_keys);
|
||||||
|
|
||||||
|
# append default extruder
|
||||||
|
push @opt_keys, 'extruder';
|
||||||
|
$default_config->set('extruder', 0);
|
||||||
|
$config->set_ifndef('extruder', 0);
|
||||||
|
$self->{settings_panel}->set_default_config($default_config);
|
||||||
|
$self->{settings_panel}->set_config($config);
|
||||||
|
$self->{settings_panel}->set_opt_keys(\@opt_keys);
|
||||||
|
$self->{settings_panel}->set_fixed_options([qw(extruder)]);
|
||||||
|
$self->{settings_panel}->enable;
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
|
||||||
} //namespace GUI
|
} //namespace GUI
|
||||||
} //namespace Slic3r
|
} //namespace Slic3r
|
|
@ -57,6 +57,7 @@ void unselect_objects();
|
||||||
// Select current object in the list on c++ side
|
// Select current object in the list on c++ side
|
||||||
void select_current_object(int idx);
|
void select_current_object(int idx);
|
||||||
|
|
||||||
|
void init_mesh_icons();
|
||||||
void set_event_object_selection_changed(const int& event);
|
void set_event_object_selection_changed(const int& event);
|
||||||
void set_event_object_settings_changed (const int& event);
|
void set_event_object_settings_changed (const int& event);
|
||||||
|
|
||||||
|
@ -72,6 +73,7 @@ void load_lambda(wxWindow* parent, ModelObject* model_object,
|
||||||
void on_btn_load(wxWindow* parent, bool is_modifier = false, bool is_lambda = false);
|
void on_btn_load(wxWindow* parent, bool is_modifier = false, bool is_lambda = false);
|
||||||
|
|
||||||
void parts_changed(int obj_idx);
|
void parts_changed(int obj_idx);
|
||||||
|
void part_selection_changed();
|
||||||
} //namespace GUI
|
} //namespace GUI
|
||||||
} //namespace Slic3r
|
} //namespace Slic3r
|
||||||
#endif //slic3r_GUI_ObjectParts_hpp_
|
#endif //slic3r_GUI_ObjectParts_hpp_
|
|
@ -376,14 +376,15 @@ wxDataViewItem PrusaObjectDataViewModel::AddChild( const wxDataViewItem &parent_
|
||||||
if (root->GetChildren().Count() == 0)
|
if (root->GetChildren().Count() == 0)
|
||||||
{
|
{
|
||||||
auto icon_solid_mesh = wxIcon(Slic3r::GUI::from_u8(Slic3r::var("package.png")), wxBITMAP_TYPE_PNG);
|
auto icon_solid_mesh = wxIcon(Slic3r::GUI::from_u8(Slic3r::var("package.png")), wxBITMAP_TYPE_PNG);
|
||||||
auto node = new PrusaObjectDataViewModelNode(root, root->m_name, icon_solid_mesh);
|
auto node = new PrusaObjectDataViewModelNode(root, root->m_name, icon_solid_mesh, 0);
|
||||||
root->Append(node);
|
root->Append(node);
|
||||||
// notify control
|
// notify control
|
||||||
wxDataViewItem child((void*)node);
|
wxDataViewItem child((void*)node);
|
||||||
ItemAdded(parent_item, child);
|
ItemAdded(parent_item, child);
|
||||||
}
|
}
|
||||||
|
|
||||||
auto node = new PrusaObjectDataViewModelNode(root, name, icon);
|
auto volume_id = root->GetChildCount();
|
||||||
|
auto node = new PrusaObjectDataViewModelNode(root, name, icon, volume_id);
|
||||||
root->Append(node);
|
root->Append(node);
|
||||||
// notify control
|
// notify control
|
||||||
wxDataViewItem child((void*)node);
|
wxDataViewItem child((void*)node);
|
||||||
|
@ -470,6 +471,16 @@ int PrusaObjectDataViewModel::GetIdByItem(wxDataViewItem& item)
|
||||||
return it - m_objects.begin();
|
return it - m_objects.begin();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int PrusaObjectDataViewModel::GetVolumeIdByItem(wxDataViewItem& item)
|
||||||
|
{
|
||||||
|
wxASSERT(item.IsOk());
|
||||||
|
|
||||||
|
PrusaObjectDataViewModelNode *node = (PrusaObjectDataViewModelNode*)item.GetID();
|
||||||
|
if (!node) // happens if item.IsOk()==false
|
||||||
|
return -1;
|
||||||
|
return node->GetVolumeId();
|
||||||
|
}
|
||||||
|
|
||||||
wxString PrusaObjectDataViewModel::GetName(const wxDataViewItem &item) const
|
wxString PrusaObjectDataViewModel::GetName(const wxDataViewItem &item) const
|
||||||
{
|
{
|
||||||
PrusaObjectDataViewModelNode *node = (PrusaObjectDataViewModelNode*)item.GetID();
|
PrusaObjectDataViewModelNode *node = (PrusaObjectDataViewModelNode*)item.GetID();
|
||||||
|
|
|
@ -153,7 +153,7 @@ WX_DEFINE_ARRAY_PTR(PrusaObjectDataViewModelNode*, MyObjectTreeModelNodePtrArray
|
||||||
|
|
||||||
class PrusaObjectDataViewModelNode
|
class PrusaObjectDataViewModelNode
|
||||||
{
|
{
|
||||||
PrusaObjectDataViewModelNode* m_parent;
|
PrusaObjectDataViewModelNode* m_parent;
|
||||||
MyObjectTreeModelNodePtrArray m_children;
|
MyObjectTreeModelNodePtrArray m_children;
|
||||||
public:
|
public:
|
||||||
PrusaObjectDataViewModelNode(const wxString &name, int instances_count=1, int scale=100) {
|
PrusaObjectDataViewModelNode(const wxString &name, int instances_count=1, int scale=100) {
|
||||||
|
@ -161,20 +161,21 @@ public:
|
||||||
m_name = name;
|
m_name = name;
|
||||||
m_copy = wxString::Format("%d", instances_count);
|
m_copy = wxString::Format("%d", instances_count);
|
||||||
m_scale = wxString::Format("%d%%", scale);
|
m_scale = wxString::Format("%d%%", scale);
|
||||||
|
m_type = "object";
|
||||||
|
m_volume_id = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
PrusaObjectDataViewModelNode( PrusaObjectDataViewModelNode* parent,
|
PrusaObjectDataViewModelNode( PrusaObjectDataViewModelNode* parent,
|
||||||
const wxString& sub_obj) {
|
const wxString& sub_obj,
|
||||||
|
const wxIcon& icon,
|
||||||
|
int volume_id=-1) {
|
||||||
m_parent = parent;
|
m_parent = parent;
|
||||||
m_name = sub_obj;
|
m_name = sub_obj;
|
||||||
m_copy = wxEmptyString;
|
m_copy = wxEmptyString;
|
||||||
m_scale = wxEmptyString;
|
m_scale = wxEmptyString;
|
||||||
}
|
m_icon = icon;
|
||||||
|
m_type = "volume";
|
||||||
PrusaObjectDataViewModelNode(PrusaObjectDataViewModelNode* parent,
|
m_volume_id = volume_id;
|
||||||
const wxString& sub_obj, const wxIcon& icon):
|
|
||||||
PrusaObjectDataViewModelNode(parent, sub_obj){
|
|
||||||
m_icon = icon;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
~PrusaObjectDataViewModelNode()
|
~PrusaObjectDataViewModelNode()
|
||||||
|
@ -192,6 +193,8 @@ public:
|
||||||
wxIcon m_icon;
|
wxIcon m_icon;
|
||||||
wxString m_copy;
|
wxString m_copy;
|
||||||
wxString m_scale;
|
wxString m_scale;
|
||||||
|
std::string m_type;
|
||||||
|
int m_volume_id;
|
||||||
bool m_container = false;
|
bool m_container = false;
|
||||||
|
|
||||||
bool IsContainer() const
|
bool IsContainer() const
|
||||||
|
@ -265,6 +268,17 @@ public:
|
||||||
{
|
{
|
||||||
m_icon = icon;
|
m_icon = icon;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void SetType(const std::string& type){
|
||||||
|
m_type = type;
|
||||||
|
}
|
||||||
|
const std::string& GetType(){
|
||||||
|
return m_type;
|
||||||
|
}
|
||||||
|
|
||||||
|
const int GetVolumeId(){
|
||||||
|
return m_volume_id;
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
@ -291,6 +305,7 @@ public:
|
||||||
void DeleteAll();
|
void DeleteAll();
|
||||||
wxDataViewItem GetItemById(int obj_idx);
|
wxDataViewItem GetItemById(int obj_idx);
|
||||||
int GetIdByItem(wxDataViewItem& item);
|
int GetIdByItem(wxDataViewItem& item);
|
||||||
|
int GetVolumeIdByItem(wxDataViewItem& item);
|
||||||
bool IsEmpty() { return m_objects.empty(); }
|
bool IsEmpty() { return m_objects.empty(); }
|
||||||
|
|
||||||
// helper method for wxLog
|
// helper method for wxLog
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue