Code cleaning - removed unused state from DoubleSlider

This commit is contained in:
YuSanka 2019-11-28 08:38:28 +01:00
parent 322c0230c3
commit c87feb9870
3 changed files with 16 additions and 27 deletions

View file

@ -697,11 +697,7 @@ void Preview::update_double_slider(const std::vector<double>& layers_z, bool kee
bool color_print_enable = (wxGetApp().plater()->printer_technology() == ptFFF); bool color_print_enable = (wxGetApp().plater()->printer_technology() == ptFFF);
m_slider->EnableTickManipulation(color_print_enable); m_slider->EnableTickManipulation(color_print_enable);
if (color_print_enable && wxGetApp().extruders_edited_cnt() > 1) { m_slider->SetManipulationState(wxGetApp().extruders_edited_cnt());
m_slider->SetExtruderID(0);
}
else
m_slider->SetExtruderID(-1);
} }
void Preview::reset_double_slider() void Preview::reset_double_slider()

View file

@ -2561,7 +2561,7 @@ void DoubleSlider::SetTicksValues(const std::vector<t_custom_code>& heights)
m_ticks_.insert(TICK_CODE(it-m_values.begin(), h.gcode, h.extruder, h.color)); m_ticks_.insert(TICK_CODE(it-m_values.begin(), h.gcode, h.extruder, h.color));
} }
if (!was_empty && m_ticks_.empty() && m_state != msMultiExtruder) if (!was_empty && m_ticks_.empty())
// Switch to the "Feature type"/"Tool" from the very beginning of a new object slicing after deleting of the old one // Switch to the "Feature type"/"Tool" from the very beginning of a new object slicing after deleting of the old one
wxPostEvent(this->GetParent(), wxCommandEvent(wxCUSTOMEVT_TICKSCHANGED)); wxPostEvent(this->GetParent(), wxCommandEvent(wxCUSTOMEVT_TICKSCHANGED));
@ -2847,15 +2847,15 @@ void DoubleSlider::draw_colored_band(wxDC& dc)
for (auto tick : m_ticks_) for (auto tick : m_ticks_)
{ {
if ( (m_state == msSingleExtruder && tick.gcode != Slic3r::ColorChangeCode) || if ( (m_state == msSingleExtruder && tick.gcode != Slic3r::ColorChangeCode) ||
(m_state == msMultiExtruderWholePrint && tick.gcode != Slic3r::ExtruderChangeCode) ) (m_state == msMultiExtruder && tick.gcode != Slic3r::ExtruderChangeCode) )
continue; continue;
const wxCoord pos = get_position_from_value(tick.tick); const wxCoord pos = get_position_from_value(tick.tick);
is_horizontal() ? main_band.SetLeft(SLIDER_MARGIN + pos) : is_horizontal() ? main_band.SetLeft(SLIDER_MARGIN + pos) :
main_band.SetBottom(pos - 1); main_band.SetBottom(pos - 1);
clr = (m_state == msMultiExtruderWholePrint && tick.color.empty()) ? bg_clr : clr = (m_state == msMultiExtruder && tick.color.empty()) ? bg_clr :
m_state == msMultiExtruderWholePrint ? wxColour(colors[std::min<int>(colors_cnt - 1, tick.extruder-1)]) : wxColour(tick.color); m_state == msMultiExtruder ? wxColour(colors[std::min<int>(colors_cnt - 1, tick.extruder-1)]) : wxColour(tick.color);
draw_band(dc, clr, main_band); draw_band(dc, clr, main_band);
i++; i++;
} }
@ -2900,7 +2900,7 @@ void DoubleSlider::draw_revert_icon(wxDC& dc)
void DoubleSlider::draw_cog_icon(wxDC& dc) void DoubleSlider::draw_cog_icon(wxDC& dc)
{ {
if (m_state != msMultiExtruderWholePrint) if (m_state != msMultiExtruder)
return; return;
int width, height; int width, height;
@ -3016,7 +3016,7 @@ void DoubleSlider::OnLeftDown(wxMouseEvent& event)
m_ticks_.clear(); m_ticks_.clear();
wxPostEvent(this->GetParent(), wxCommandEvent(wxCUSTOMEVT_TICKSCHANGED)); wxPostEvent(this->GetParent(), wxCommandEvent(wxCUSTOMEVT_TICKSCHANGED));
} }
else if (is_point_in_rect(pos, m_rect_cog_icon) && m_state == msMultiExtruderWholePrint) { else if (is_point_in_rect(pos, m_rect_cog_icon) && m_state == msMultiExtruder) {
// show dialog for set extruder sequence // show dialog for set extruder sequence
m_edit_extruder_sequence = true; m_edit_extruder_sequence = true;
} }
@ -3160,7 +3160,7 @@ void DoubleSlider::OnLeftUp(wxMouseEvent& event)
if (m_show_context_menu) if (m_show_context_menu)
{ {
if (m_state == msMultiExtruderWholePrint) if (m_state == msMultiExtruder)
{ {
wxMenu menu; wxMenu menu;
const int extruders_cnt = Slic3r::GUI::wxGetApp().extruders_edited_cnt(); const int extruders_cnt = Slic3r::GUI::wxGetApp().extruders_edited_cnt();
@ -3279,7 +3279,7 @@ void DoubleSlider::action_tick(const TicksAction action)
if (m_suppress_add_code) if (m_suppress_add_code)
return; return;
m_suppress_add_code = true; m_suppress_add_code = true;
if (m_state != msMultiExtruderWholePrint) if (m_state != msMultiExtruder)
add_code(Slic3r::ColorChangeCode); add_code(Slic3r::ColorChangeCode);
m_suppress_add_code = false; m_suppress_add_code = false;
return; return;
@ -3423,7 +3423,7 @@ void DoubleSlider::OnRightUp(wxMouseEvent& event)
if (m_show_context_menu) { if (m_show_context_menu) {
wxMenu menu; wxMenu menu;
if (m_state == msMultiExtruderWholePrint) if (m_state == msMultiExtruder)
{ {
const int extruders_cnt = Slic3r::GUI::wxGetApp().extruders_edited_cnt(); const int extruders_cnt = Slic3r::GUI::wxGetApp().extruders_edited_cnt();
if (extruders_cnt > 1) if (extruders_cnt > 1)
@ -3457,7 +3457,6 @@ void DoubleSlider::OnRightUp(wxMouseEvent& event)
append_menu_item(&menu, wxID_ANY, _(L("Add color change")) + " (M600)", "", append_menu_item(&menu, wxID_ANY, _(L("Add color change")) + " (M600)", "",
[this](wxCommandEvent&) { add_code(Slic3r::ColorChangeCode); }, "colorchange_add_off.png", &menu); [this](wxCommandEvent&) { add_code(Slic3r::ColorChangeCode); }, "colorchange_add_off.png", &menu);
if (m_state != msMultiExtruder)
append_menu_item(&menu, wxID_ANY, _(L("Add pause print")) + " (M601)", "", append_menu_item(&menu, wxID_ANY, _(L("Add pause print")) + " (M601)", "",
[this](wxCommandEvent&) { add_code(Slic3r::PausePrintCode); }, "pause_print", &menu); [this](wxCommandEvent&) { add_code(Slic3r::PausePrintCode); }, "pause_print", &menu);
@ -3584,14 +3583,12 @@ void DoubleSlider::add_code(std::string code, int selected_extruder/* = -1*/)
} }
int extruder = 1; int extruder = 1;
if (m_state == msMultiExtruderWholePrint) { if (m_state == msMultiExtruder) {
if (code == Slic3r::ColorChangeCode && selected_extruder >= 0) if (code == Slic3r::ColorChangeCode && selected_extruder >= 0)
extruder = selected_extruder; extruder = selected_extruder;
else else
extruder = get_extruder_for_tick(m_selection == ssLower ? m_lower_value : m_higher_value); extruder = get_extruder_for_tick(m_selection == ssLower ? m_lower_value : m_higher_value);
} }
else if (m_state == msMultiExtruder && m_current_extruder > 0)
extruder = m_current_extruder;
m_ticks_.insert(TICK_CODE(tick, code, extruder, color)); m_ticks_.insert(TICK_CODE(tick, code, extruder, color));

View file

@ -819,18 +819,15 @@ public:
enum ManipulationState { enum ManipulationState {
msSingleExtruder, // single extruder printer preset is selected msSingleExtruder, // single extruder printer preset is selected
msMultiExtruder, // multiple extruder printer preset is selected msMultiExtruder // multiple extruder printer preset is selected, and "Whole print" is selected
msMultiExtruderWholePrint // multiple extruder printer preset is selected, and "Whole print" is selected
}; };
void SetManipulationState(ManipulationState state) { void SetManipulationState(ManipulationState state) {
m_state = state; m_state = state;
} }
ManipulationState GetManipulationState() const { return m_state; } void SetManipulationState(int extruders_cnt) {
void SetExtruderID(int extruder) { m_state = extruders_cnt ==1 ? msSingleExtruder : msMultiExtruder;
m_current_extruder = extruder;
m_state = extruder < 0 ? msSingleExtruder :
extruder > 0 ? msMultiExtruder : msMultiExtruderWholePrint;
} }
ManipulationState GetManipulationState() const { return m_state; }
bool is_horizontal() const { return m_style == wxSL_HORIZONTAL; } bool is_horizontal() const { return m_style == wxSL_HORIZONTAL; }
bool is_one_layer() const { return m_is_one_layer; } bool is_one_layer() const { return m_is_one_layer; }
@ -928,7 +925,6 @@ private:
ManipulationState m_state = msSingleExtruder; ManipulationState m_state = msSingleExtruder;
std::string m_custom_gcode = ""; std::string m_custom_gcode = "";
std::string m_pause_print_msg; std::string m_pause_print_msg;
int m_current_extruder = -1;
wxRect m_rect_lower_thumb; wxRect m_rect_lower_thumb;
wxRect m_rect_higher_thumb; wxRect m_rect_higher_thumb;