This commit is contained in:
bubnikv 2019-02-21 11:41:04 +01:00
commit 22a15e7e25
4 changed files with 36 additions and 28 deletions

View file

@ -3,7 +3,7 @@ msgstr ""
"Project-Id-Version: \n" "Project-Id-Version: \n"
"Report-Msgid-Bugs-To: \n" "Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2019-01-17 13:39+0100\n" "POT-Creation-Date: 2019-01-17 13:39+0100\n"
"PO-Revision-Date: 2019-01-21 11:25+0100\n" "PO-Revision-Date: 2019-02-19 14:42+0100\n"
"Last-Translator: Oleksandra Iushchenko <yusanka@gmail.com>\n" "Last-Translator: Oleksandra Iushchenko <yusanka@gmail.com>\n"
"Language-Team: \n" "Language-Team: \n"
"Language: uk\n" "Language: uk\n"
@ -624,48 +624,48 @@ msgstr ""
#: src/slic3r/GUI/GLGizmo.cpp:2207 #: src/slic3r/GUI/GLGizmo.cpp:2207
msgid "Left mouse click - add point" msgid "Left mouse click - add point"
msgstr "" msgstr "Ліва кнопка миші - додати точку"
#: src/slic3r/GUI/GLGizmo.cpp:2208 #: src/slic3r/GUI/GLGizmo.cpp:2208
msgid "Right mouse click - remove point" msgid "Right mouse click - remove point"
msgstr "" msgstr "Права кнопка миші - видалити точку"
#: src/slic3r/GUI/GLGizmo.cpp:2211 #: src/slic3r/GUI/GLGizmo.cpp:2211
msgid "Generate points automatically" msgid "Generate points automatically"
msgstr "" msgstr "Генерувати точки автоматично"
#: src/slic3r/GUI/GLGizmo.cpp:2212 #: src/slic3r/GUI/GLGizmo.cpp:2212
msgid "Remove all points" msgid "Remove all points"
msgstr "" msgstr "Видалити всі точки"
#: src/slic3r/GUI/GLGizmo.cpp:2245 #: src/slic3r/GUI/GLGizmo.cpp:2245
msgid "SLA Support Points" msgid "SLA Support Points"
msgstr "" msgstr "Точки SLA підтримки"
#: src/slic3r/GUI/GLGizmo.cpp:2268 src/slic3r/GUI/GLGizmo.cpp:2468 #: src/slic3r/GUI/GLGizmo.cpp:2268 src/slic3r/GUI/GLGizmo.cpp:2468
msgid "Rotate lower part upwards" msgid "Rotate lower part upwards"
msgstr "" msgstr "Повернути нижню частину вгору"
#: src/slic3r/GUI/GLGizmo.cpp:2269 src/slic3r/GUI/GLGizmo.cpp:2470 #: src/slic3r/GUI/GLGizmo.cpp:2269 src/slic3r/GUI/GLGizmo.cpp:2470
msgid "Perform cut" msgid "Perform cut"
msgstr "" msgstr "Виконати розріз"
#: src/slic3r/GUI/GLGizmo.cpp:2276 #: src/slic3r/GUI/GLGizmo.cpp:2276
msgid "Cut object:" msgid "Cut object:"
msgstr "" msgstr "Розрізати об'єкт:"
#: src/slic3r/GUI/GLGizmo.cpp:2356 src/slic3r/GUI/GLGizmo.cpp:2461 #: src/slic3r/GUI/GLGizmo.cpp:2356 src/slic3r/GUI/GLGizmo.cpp:2461
#: src/libslic3r/PrintConfig.cpp:3016 #: src/libslic3r/PrintConfig.cpp:3016
msgid "Cut" msgid "Cut"
msgstr "" msgstr "Розрізати"
#: src/slic3r/GUI/GLGizmo.cpp:2466 #: src/slic3r/GUI/GLGizmo.cpp:2466
msgid "Keep upper part" msgid "Keep upper part"
msgstr "" msgstr "Залишити верхню частину"
#: src/slic3r/GUI/GLGizmo.cpp:2467 #: src/slic3r/GUI/GLGizmo.cpp:2467
msgid "Keep lower part" msgid "Keep lower part"
msgstr "" msgstr "Залишити нижню частину"
#: src/slic3r/GUI/GUI.cpp:242 #: src/slic3r/GUI/GUI.cpp:242
msgid "Notice" msgid "Notice"
@ -5636,7 +5636,7 @@ msgstr ""
#: src/libslic3r/PrintConfig.cpp:3017 #: src/libslic3r/PrintConfig.cpp:3017
msgid "Cut model at the given Z." msgid "Cut model at the given Z."
msgstr "" msgstr "Розрізати модель за заданим Z."
#: src/libslic3r/PrintConfig.cpp:3022 #: src/libslic3r/PrintConfig.cpp:3022
msgid "Dont arrange" msgid "Dont arrange"

View file

@ -669,6 +669,7 @@ void Tab::load_config(const DynamicPrintConfig& config)
bool modified = 0; bool modified = 0;
for(auto opt_key : m_config->diff(config)) { for(auto opt_key : m_config->diff(config)) {
m_config->set_key_value(opt_key, config.option(opt_key)->clone()); m_config->set_key_value(opt_key, config.option(opt_key)->clone());
m_dirty_options.emplace(opt_key);
modified = 1; modified = 1;
} }
if (modified) { if (modified) {
@ -751,17 +752,7 @@ void Tab::load_key_value(const std::string& opt_key, const boost::any& value, bo
void Tab::on_value_change(const std::string& opt_key, const boost::any& value) void Tab::on_value_change(const std::string& opt_key, const boost::any& value)
{ {
wxCommandEvent event(EVT_TAB_VALUE_CHANGED); m_dirty_options.erase(opt_key);
event.SetEventObject(this);
event.SetString(opt_key);
if (opt_key == "extruders_count")
{
int val = boost::any_cast<size_t>(value);
event.SetInt(val);
}
wxPostEvent(this, event);
ConfigOptionsGroup* og_freq_chng_params = wxGetApp().sidebar().og_freq_chng_params(supports_printer_technology(ptFFF)); ConfigOptionsGroup* og_freq_chng_params = wxGetApp().sidebar().og_freq_chng_params(supports_printer_technology(ptFFF));
if (opt_key == "fill_density" || opt_key == "supports_enable" || opt_key == "pad_enable") if (opt_key == "fill_density" || opt_key == "supports_enable" || opt_key == "pad_enable")
@ -788,6 +779,21 @@ void Tab::on_value_change(const std::string& opt_key, const boost::any& value)
update_wiping_button_visibility(); update_wiping_button_visibility();
update(); update();
// Post event to the Plater after updating of the all dirty options
// It helps to avoid needless schedule_background_processing
if (update_completed()) {
wxCommandEvent event(EVT_TAB_VALUE_CHANGED);
event.SetEventObject(this);
event.SetString(opt_key);
if (opt_key == "extruders_count")
{
const int val = boost::any_cast<size_t>(value);
event.SetInt(val);
}
wxPostEvent(this, event);
}
} }
// Show/hide the 'purging volumes' button // Show/hide the 'purging volumes' button
@ -1163,8 +1169,8 @@ void TabPrint::update()
// KillFocus() for the wxSpinCtrl use CallAfter function. So, // KillFocus() for the wxSpinCtrl use CallAfter function. So,
// to except the duplicate call of the update() after dialog->ShowModal(), // to except the duplicate call of the update() after dialog->ShowModal(),
// let check if this process is already started. // let check if this process is already started.
if (is_msg_dlg_already_exist) // if (is_msg_dlg_already_exist) // ! It looks like a fixed problem after start to using of a m_dirty_options
return; // return; // ! TODO Let delete this part of code after a common aplication testing
Freeze(); Freeze();
@ -1181,7 +1187,7 @@ void TabPrint::update()
"- no ensure_vertical_shell_thickness\n" "- no ensure_vertical_shell_thickness\n"
"\nShall I adjust those settings in order to enable Spiral Vase?")); "\nShall I adjust those settings in order to enable Spiral Vase?"));
auto dialog = new wxMessageDialog(parent(), msg_text, _(L("Spiral Vase")), wxICON_WARNING | wxYES | wxNO); auto dialog = new wxMessageDialog(parent(), msg_text, _(L("Spiral Vase")), wxICON_WARNING | wxYES | wxNO);
is_msg_dlg_already_exist = true; // is_msg_dlg_already_exist = true;
DynamicPrintConfig new_conf = *m_config; DynamicPrintConfig new_conf = *m_config;
if (dialog->ShowModal() == wxID_YES) { if (dialog->ShowModal() == wxID_YES) {
new_conf.set_key_value("perimeters", new ConfigOptionInt(1)); new_conf.set_key_value("perimeters", new ConfigOptionInt(1));
@ -1197,7 +1203,7 @@ void TabPrint::update()
} }
load_config(new_conf); load_config(new_conf);
on_value_change("fill_density", fill_density); on_value_change("fill_density", fill_density);
is_msg_dlg_already_exist = false; // is_msg_dlg_already_exist = false;
} }
if (m_config->opt_bool("wipe_tower") && m_config->opt_bool("support_material") && if (m_config->opt_bool("wipe_tower") && m_config->opt_bool("support_material") &&

View file

@ -204,6 +204,7 @@ protected:
void set_type(); void set_type();
int m_em_unit; int m_em_unit;
std::set<std::string> m_dirty_options = {};
public: public:
PresetBundle* m_preset_bundle; PresetBundle* m_preset_bundle;
@ -283,6 +284,7 @@ protected:
void update_frequently_changed_parameters(); void update_frequently_changed_parameters();
void fill_icon_descriptions(); void fill_icon_descriptions();
void set_tooltips_text(); void set_tooltips_text();
bool update_completed() const { return m_dirty_options.empty(); }
}; };
class TabPrint : public Tab class TabPrint : public Tab