mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-10-24 09:11:23 -06:00
DoubleSlider:colored_band: Fixed get a correct color for extruder, when it's changed from Settings Tab
This commit is contained in:
parent
1399696b04
commit
3ffc565722
4 changed files with 22 additions and 8 deletions
|
@ -77,6 +77,7 @@ Control::Control( wxWindow *parent,
|
||||||
|
|
||||||
m_selection = ssUndef;
|
m_selection = ssUndef;
|
||||||
m_ticks.set_pause_print_msg(_utf8(L("Place bearings in slots and resume printing")));
|
m_ticks.set_pause_print_msg(_utf8(L("Place bearings in slots and resume printing")));
|
||||||
|
m_ticks.set_extruder_colors(&m_extruder_colors);
|
||||||
|
|
||||||
// slider events
|
// slider events
|
||||||
this->Bind(wxEVT_PAINT, &Control::OnPaint, this);
|
this->Bind(wxEVT_PAINT, &Control::OnPaint, this);
|
||||||
|
@ -351,6 +352,11 @@ void Control::SetModeAndOnlyExtruder(const bool is_one_extruder_printed_model, c
|
||||||
UseDefaultColors(m_mode == t_mode::SingleExtruder);
|
UseDefaultColors(m_mode == t_mode::SingleExtruder);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Control::SetExtruderColors( const std::vector<std::string>& extruder_colors)
|
||||||
|
{
|
||||||
|
m_extruder_colors = extruder_colors;
|
||||||
|
}
|
||||||
|
|
||||||
void Control::get_lower_and_higher_position(int& lower_pos, int& higher_pos)
|
void Control::get_lower_and_higher_position(int& lower_pos, int& higher_pos)
|
||||||
{
|
{
|
||||||
const double step = get_scroll_step();
|
const double step = get_scroll_step();
|
||||||
|
@ -677,7 +683,7 @@ std::string Control::get_color_for_tool_change_tick(std::set<TickCode>::const_it
|
||||||
return it_n->color;
|
return it_n->color;
|
||||||
}
|
}
|
||||||
|
|
||||||
return it->color;
|
return m_extruder_colors[current_extruder-1]; // return a color for a specific extruder from the colors list
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string Control::get_color_for_color_change_tick(std::set<TickCode>::const_iterator it) const
|
std::string Control::get_color_for_color_change_tick(std::set<TickCode>::const_iterator it) const
|
||||||
|
@ -690,7 +696,7 @@ std::string Control::get_color_for_color_change_tick(std::set<TickCode>::const_i
|
||||||
if (it_n->gcode == ToolChangeCode) {
|
if (it_n->gcode == ToolChangeCode) {
|
||||||
is_tool_change = true;
|
is_tool_change = true;
|
||||||
if (it_n->extruder == it->extruder)
|
if (it_n->extruder == it->extruder)
|
||||||
return it->color;
|
return m_extruder_colors[it->extruder-1]; // return a color for a specific extruder from the colors list
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -736,7 +742,7 @@ void Control::draw_colored_band(wxDC& dc)
|
||||||
}
|
}
|
||||||
|
|
||||||
const int default_color_idx = m_mode==t_mode::MultiAsSingle ? std::max<int>(m_only_extruder - 1, 0) : 0;
|
const int default_color_idx = m_mode==t_mode::MultiAsSingle ? std::max<int>(m_only_extruder - 1, 0) : 0;
|
||||||
draw_band(dc, wxColour(GUI::wxGetApp().plater()->get_extruder_colors_from_plater_config()[default_color_idx]), main_band);
|
draw_band(dc, wxColour(m_extruder_colors[default_color_idx]), main_band);
|
||||||
|
|
||||||
std::set<TickCode>::const_iterator tick_it = m_ticks.ticks.begin();
|
std::set<TickCode>::const_iterator tick_it = m_ticks.ticks.begin();
|
||||||
|
|
||||||
|
@ -1819,15 +1825,13 @@ void Control::edit_extruder_sequence()
|
||||||
int extruder = 0;
|
int extruder = 0;
|
||||||
const int extr_cnt = m_extruders_sequence.extruders.size();
|
const int extr_cnt = m_extruders_sequence.extruders.size();
|
||||||
|
|
||||||
std::vector<std::string> colors = GUI::wxGetApp().plater()->get_extruder_colors_from_plater_config();
|
|
||||||
|
|
||||||
while (tick <= m_max_value)
|
while (tick <= m_max_value)
|
||||||
{
|
{
|
||||||
const int cur_extruder = m_extruders_sequence.extruders[extruder];
|
const int cur_extruder = m_extruders_sequence.extruders[extruder];
|
||||||
|
|
||||||
bool meaningless_tick = tick == 0.0 && cur_extruder == extruder;
|
bool meaningless_tick = tick == 0.0 && cur_extruder == extruder;
|
||||||
if (!meaningless_tick)
|
if (!meaningless_tick)
|
||||||
m_ticks.ticks.emplace(TickCode{tick, ToolChangeCode, cur_extruder + 1, colors[cur_extruder]});
|
m_ticks.ticks.emplace(TickCode{tick, ToolChangeCode, cur_extruder + 1, m_extruder_colors[cur_extruder]});
|
||||||
|
|
||||||
extruder++;
|
extruder++;
|
||||||
if (extruder == extr_cnt)
|
if (extruder == extr_cnt)
|
||||||
|
@ -1942,8 +1946,7 @@ std::string TickCodeInfo::get_color_for_tick(TickCode tick, const std::string& c
|
||||||
return colors[m_default_color_idx % colors.size()];
|
return colors[m_default_color_idx % colors.size()];
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<std::string> colors = GUI::wxGetApp().plater()->get_extruder_colors_from_plater_config();
|
std::string color = (*m_colors)[extruder - 1];
|
||||||
std::string color = colors[extruder - 1];
|
|
||||||
|
|
||||||
if (code == ColorChangeCode)
|
if (code == ColorChangeCode)
|
||||||
{
|
{
|
||||||
|
|
|
@ -95,6 +95,8 @@ class TickCodeInfo
|
||||||
bool m_use_default_colors= false;
|
bool m_use_default_colors= false;
|
||||||
int m_default_color_idx = 0;
|
int m_default_color_idx = 0;
|
||||||
|
|
||||||
|
std::vector<std::string>* m_colors {nullptr};
|
||||||
|
|
||||||
std::string get_color_for_tick(TickCode tick, const std::string& code, const int extruder);
|
std::string get_color_for_tick(TickCode tick, const std::string& code, const int extruder);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
@ -122,6 +124,8 @@ public:
|
||||||
bool suppressed_plus () { return m_suppress_plus; }
|
bool suppressed_plus () { return m_suppress_plus; }
|
||||||
bool suppressed_minus() { return m_suppress_minus; }
|
bool suppressed_minus() { return m_suppress_minus; }
|
||||||
void set_default_colors(bool default_colors_on) { m_use_default_colors = default_colors_on; }
|
void set_default_colors(bool default_colors_on) { m_use_default_colors = default_colors_on; }
|
||||||
|
|
||||||
|
void set_extruder_colors(std::vector<std::string>* extruder_colors) { m_colors = extruder_colors; }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -209,6 +213,7 @@ public:
|
||||||
void SetManipulationMode(t_mode mode) { m_mode = mode; }
|
void SetManipulationMode(t_mode mode) { m_mode = mode; }
|
||||||
t_mode GetManipulationMode() const { return m_mode; }
|
t_mode GetManipulationMode() const { return m_mode; }
|
||||||
void SetModeAndOnlyExtruder(const bool is_one_extruder_printed_model, const int only_extruder);
|
void SetModeAndOnlyExtruder(const bool is_one_extruder_printed_model, const int only_extruder);
|
||||||
|
void SetExtruderColors(const std::vector<std::string>& extruder_colors);
|
||||||
|
|
||||||
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; }
|
||||||
|
@ -357,6 +362,8 @@ private:
|
||||||
std::vector<double> m_values;
|
std::vector<double> m_values;
|
||||||
TickCodeInfo m_ticks;
|
TickCodeInfo m_ticks;
|
||||||
|
|
||||||
|
std::vector<std::string> m_extruder_colors;
|
||||||
|
|
||||||
// control's view variables
|
// control's view variables
|
||||||
wxCoord SLIDER_MARGIN; // margin around slider
|
wxCoord SLIDER_MARGIN; // margin around slider
|
||||||
|
|
||||||
|
|
|
@ -705,6 +705,8 @@ void Preview::update_double_slider(const std::vector<double>& layers_z, bool kee
|
||||||
bool sla_print_technology = wxGetApp().plater()->printer_technology() == ptSLA;
|
bool sla_print_technology = wxGetApp().plater()->printer_technology() == ptSLA;
|
||||||
bool sequential_print = wxGetApp().preset_bundle->prints.get_edited_preset().config.opt_bool("complete_objects");
|
bool sequential_print = wxGetApp().preset_bundle->prints.get_edited_preset().config.opt_bool("complete_objects");
|
||||||
m_slider->SetDrawMode(sla_print_technology, sequential_print);
|
m_slider->SetDrawMode(sla_print_technology, sequential_print);
|
||||||
|
|
||||||
|
m_slider->SetExtruderColors(wxGetApp().plater()->get_extruder_colors_from_plater_config());
|
||||||
}
|
}
|
||||||
|
|
||||||
void Preview::update_double_slider_mode()
|
void Preview::update_double_slider_mode()
|
||||||
|
|
|
@ -131,8 +131,10 @@ void OptionsGroup::append_line(const Line& line, wxStaticText** full_Label/* = n
|
||||||
// Set sidetext width for a better alignment of options in line
|
// Set sidetext width for a better alignment of options in line
|
||||||
if (option_set.size() > 1) {
|
if (option_set.size() > 1) {
|
||||||
sidetext_width = Field::def_width_thinner();
|
sidetext_width = Field::def_width_thinner();
|
||||||
|
/* Temporary commented till UI-review will be completed
|
||||||
if (m_show_modified_btns) // means that options groups are in tabs
|
if (m_show_modified_btns) // means that options groups are in tabs
|
||||||
sublabel_width = Field::def_width();
|
sublabel_width = Field::def_width();
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
// add mode value for current line to m_options_mode
|
// add mode value for current line to m_options_mode
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue