mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	Merge remote-tracking branch 'origin/master' into ys_ftn_improvements
This commit is contained in:
		
						commit
						88fc45797c
					
				
					 16 changed files with 161 additions and 70 deletions
				
			
		|  | @ -149,7 +149,10 @@ set(SLIC3R_GUI_SOURCES | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| if (APPLE) | if (APPLE) | ||||||
|     list(APPEND SLIC3R_GUI_SOURCES Utils/RetinaHelperImpl.mm) |     list(APPEND SLIC3R_GUI_SOURCES | ||||||
|  |             Utils/RetinaHelperImpl.mm | ||||||
|  |             Utils/MacDarkMode.mm | ||||||
|  |         ) | ||||||
| endif () | endif () | ||||||
| 
 | 
 | ||||||
| add_library(libslic3r_gui STATIC ${SLIC3R_GUI_SOURCES}) | add_library(libslic3r_gui STATIC ${SLIC3R_GUI_SOURCES}) | ||||||
|  |  | ||||||
|  | @ -8,6 +8,7 @@ | ||||||
| 
 | 
 | ||||||
| #include "GUI_App.hpp" | #include "GUI_App.hpp" | ||||||
| #include "PresetBundle.hpp" | #include "PresetBundle.hpp" | ||||||
|  | #include "Gizmos/GLGizmoBase.hpp" | ||||||
| 
 | 
 | ||||||
| #include <GL/glew.h> | #include <GL/glew.h> | ||||||
| 
 | 
 | ||||||
|  | @ -232,7 +233,7 @@ void Bed3D::Axes::render() const | ||||||
|     glsafe(::glEnable(GL_LIGHTING)); |     glsafe(::glEnable(GL_LIGHTING)); | ||||||
| 
 | 
 | ||||||
|     // x axis
 |     // x axis
 | ||||||
|     glsafe(::glColor3f(1.0f, 0.0f, 0.0f)); |     glsafe(::glColor3fv(AXES_COLOR[0])); | ||||||
|     glsafe(::glPushMatrix()); |     glsafe(::glPushMatrix()); | ||||||
|     glsafe(::glTranslated(origin(0), origin(1), origin(2))); |     glsafe(::glTranslated(origin(0), origin(1), origin(2))); | ||||||
|     glsafe(::glRotated(90.0, 0.0, 1.0, 0.0)); |     glsafe(::glRotated(90.0, 0.0, 1.0, 0.0)); | ||||||
|  | @ -240,7 +241,7 @@ void Bed3D::Axes::render() const | ||||||
|     glsafe(::glPopMatrix()); |     glsafe(::glPopMatrix()); | ||||||
| 
 | 
 | ||||||
|     // y axis
 |     // y axis
 | ||||||
|     glsafe(::glColor3f(0.0f, 1.0f, 0.0f)); |     glsafe(::glColor3fv(AXES_COLOR[1])); | ||||||
|     glsafe(::glPushMatrix()); |     glsafe(::glPushMatrix()); | ||||||
|     glsafe(::glTranslated(origin(0), origin(1), origin(2))); |     glsafe(::glTranslated(origin(0), origin(1), origin(2))); | ||||||
|     glsafe(::glRotated(-90.0, 1.0, 0.0, 0.0)); |     glsafe(::glRotated(-90.0, 1.0, 0.0, 0.0)); | ||||||
|  | @ -248,7 +249,7 @@ void Bed3D::Axes::render() const | ||||||
|     glsafe(::glPopMatrix()); |     glsafe(::glPopMatrix()); | ||||||
| 
 | 
 | ||||||
|     // z axis
 |     // z axis
 | ||||||
|     glsafe(::glColor3f(0.0f, 0.0f, 1.0f)); |     glsafe(::glColor3fv(AXES_COLOR[2])); | ||||||
|     glsafe(::glPushMatrix()); |     glsafe(::glPushMatrix()); | ||||||
|     glsafe(::glTranslated(origin(0), origin(1), origin(2))); |     glsafe(::glTranslated(origin(0), origin(1), origin(2))); | ||||||
|     render_axis(length(2)); |     render_axis(length(2)); | ||||||
|  |  | ||||||
|  | @ -649,12 +649,6 @@ void PageTemperatures::apply_custom_config(DynamicPrintConfig &config) | ||||||
| 
 | 
 | ||||||
| ConfigWizardIndex::ConfigWizardIndex(wxWindow *parent) | ConfigWizardIndex::ConfigWizardIndex(wxWindow *parent) | ||||||
|     : wxPanel(parent) |     : wxPanel(parent) | ||||||
|     /* #ys_FIXME_delete_after_testing by VK
 |  | ||||||
|     , bg(GUI::from_u8(Slic3r::var("Slic3r_192px_transparent.png")), wxBITMAP_TYPE_PNG) |  | ||||||
|     , bullet_black(GUI::from_u8(Slic3r::var("bullet_black.png")), wxBITMAP_TYPE_PNG) |  | ||||||
|     , bullet_blue(GUI::from_u8(Slic3r::var("bullet_blue.png")), wxBITMAP_TYPE_PNG) |  | ||||||
|     , bullet_white(GUI::from_u8(Slic3r::var("bullet_white.png")), wxBITMAP_TYPE_PNG) |  | ||||||
|     */ |  | ||||||
|     , bg(ScalableBitmap(parent, "Slic3r_192px_transparent.png", 192)) |     , bg(ScalableBitmap(parent, "Slic3r_192px_transparent.png", 192)) | ||||||
|     , bullet_black(ScalableBitmap(parent, "bullet_black.png")) |     , bullet_black(ScalableBitmap(parent, "bullet_black.png")) | ||||||
|     , bullet_blue(ScalableBitmap(parent, "bullet_blue.png")) |     , bullet_blue(ScalableBitmap(parent, "bullet_blue.png")) | ||||||
|  | @ -675,9 +669,6 @@ ConfigWizardIndex::ConfigWizardIndex(wxWindow *parent) | ||||||
|     // In some cases it didn't work at all. And so wxStaticBitmap is used here instead,
 |     // In some cases it didn't work at all. And so wxStaticBitmap is used here instead,
 | ||||||
|     // because it has all the platform quirks figured out.
 |     // because it has all the platform quirks figured out.
 | ||||||
|     auto *sizer = new wxBoxSizer(wxVERTICAL); |     auto *sizer = new wxBoxSizer(wxVERTICAL); | ||||||
|     /* #ys_FIXME_delete_after_testing by VK
 |  | ||||||
|     auto *logo = new wxStaticBitmap(this, wxID_ANY, bg); |  | ||||||
|     */ |  | ||||||
|     logo = new wxStaticBitmap(this, wxID_ANY, bg.bmp()); |     logo = new wxStaticBitmap(this, wxID_ANY, bg.bmp()); | ||||||
|     sizer->AddStretchSpacer(); |     sizer->AddStretchSpacer(); | ||||||
|     sizer->Add(logo); |     sizer->Add(logo); | ||||||
|  | @ -786,10 +777,6 @@ void ConfigWizardIndex::on_paint(wxPaintEvent & evt) | ||||||
| 
 | 
 | ||||||
|     wxPaintDC dc(this); |     wxPaintDC dc(this); | ||||||
| 
 | 
 | ||||||
|     /* #ys_FIXME_delete_after_testing by VK
 |  | ||||||
|     const auto bullet_w = bullet_black.GetSize().GetWidth(); |  | ||||||
|     const auto bullet_h = bullet_black.GetSize().GetHeight(); |  | ||||||
|     */ |  | ||||||
|     const auto bullet_w = bullet_black.bmp().GetSize().GetWidth(); |     const auto bullet_w = bullet_black.bmp().GetSize().GetWidth(); | ||||||
|     const auto bullet_h = bullet_black.bmp().GetSize().GetHeight(); |     const auto bullet_h = bullet_black.bmp().GetSize().GetHeight(); | ||||||
|     const int yoff_icon = bullet_h < em_h ? (em_h - bullet_h) / 2 : 0; |     const int yoff_icon = bullet_h < em_h ? (em_h - bullet_h) / 2 : 0; | ||||||
|  | @ -804,12 +791,6 @@ void ConfigWizardIndex::on_paint(wxPaintEvent & evt) | ||||||
|         unsigned x = em_w/2 + item.indent * em_w; |         unsigned x = em_w/2 + item.indent * em_w; | ||||||
| 
 | 
 | ||||||
|         if (i == item_active || item_hover >= 0 && i == (size_t)item_hover) { |         if (i == item_active || item_hover >= 0 && i == (size_t)item_hover) { | ||||||
|             /*#ys_FIXME_delete_after_testing by VK
 |  | ||||||
|             dc.DrawBitmap(bullet_blue,  x, y + yoff_icon, false); |  | ||||||
|         } |  | ||||||
|         else if (i < item_active)  { dc.DrawBitmap(bullet_black, x, y + yoff_icon, false); } |  | ||||||
|         else if (i > item_active)  { dc.DrawBitmap(bullet_white, x, y + yoff_icon, false); } |  | ||||||
|             */ |  | ||||||
|             dc.DrawBitmap(bullet_blue.bmp(), x, y + yoff_icon, false); |             dc.DrawBitmap(bullet_blue.bmp(), x, y + yoff_icon, false); | ||||||
|         } |         } | ||||||
|         else if (i < item_active)  { dc.DrawBitmap(bullet_black.bmp(), x, y + yoff_icon, false); } |         else if (i < item_active)  { dc.DrawBitmap(bullet_black.bmp(), x, y + yoff_icon, false); } | ||||||
|  | @ -848,6 +829,10 @@ void ConfigWizardIndex::on_mouse_move(wxMouseEvent &evt) | ||||||
| 
 | 
 | ||||||
| void ConfigWizardIndex::msw_rescale() | void ConfigWizardIndex::msw_rescale() | ||||||
| { | { | ||||||
|  |     const wxSize size = GetTextExtent("m"); | ||||||
|  |     em_w = size.x; | ||||||
|  |     em_h = size.y; | ||||||
|  | 
 | ||||||
|     bg.msw_rescale(); |     bg.msw_rescale(); | ||||||
|     SetMinSize(bg.bmp().GetSize()); |     SetMinSize(bg.bmp().GetSize()); | ||||||
|     logo->SetBitmap(bg.bmp()); |     logo->SetBitmap(bg.bmp()); | ||||||
|  | @ -897,6 +882,29 @@ void ConfigWizard::priv::load_pages(bool custom_setup) | ||||||
|     q->Layout(); |     q->Layout(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void ConfigWizard::priv::init_dialog_size() | ||||||
|  | { | ||||||
|  |     // Clamp the Wizard size based on screen dimensions
 | ||||||
|  | 
 | ||||||
|  |     const auto idx = wxDisplay::GetFromWindow(q); | ||||||
|  |     wxDisplay display(idx != wxNOT_FOUND ? idx : 0u); | ||||||
|  | 
 | ||||||
|  |     const auto disp_rect = display.GetClientArea(); | ||||||
|  |     wxRect window_rect( | ||||||
|  |         disp_rect.x + disp_rect.width / 20, | ||||||
|  |         disp_rect.y + disp_rect.height / 20, | ||||||
|  |         9*disp_rect.width / 10, | ||||||
|  |         9*disp_rect.height / 10); | ||||||
|  | 
 | ||||||
|  |     const int width_hint = index->GetSize().GetWidth() + page_fff->get_width() + 30 * em();    // XXX: magic constant, I found no better solution
 | ||||||
|  |     if (width_hint < window_rect.width) { | ||||||
|  |         window_rect.x += (window_rect.width - width_hint) / 2; | ||||||
|  |         window_rect.width = width_hint; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     q->SetSize(window_rect); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| bool ConfigWizard::priv::check_first_variant() const | bool ConfigWizard::priv::check_first_variant() const | ||||||
| { | { | ||||||
|     return run_reason == RR_DATA_EMPTY || run_reason == RR_DATA_LEGACY; |     return run_reason == RR_DATA_EMPTY || run_reason == RR_DATA_LEGACY; | ||||||
|  | @ -982,11 +990,12 @@ void ConfigWizard::priv::apply_config(AppConfig *app_config, PresetBundle *prese | ||||||
| 
 | 
 | ||||||
|         size_t size_sum = 0; |         size_t size_sum = 0; | ||||||
|         for (const auto &model : vendor->second) { size_sum += model.second.size(); } |         for (const auto &model : vendor->second) { size_sum += model.second.size(); } | ||||||
|         if (size_sum == 0) { continue; } |  | ||||||
| 
 | 
 | ||||||
|  |         if (size_sum > 0) { | ||||||
|             // This vendor needs to be installed
 |             // This vendor needs to be installed
 | ||||||
|             install_bundles.emplace_back(vendor_rsrc.second); |             install_bundles.emplace_back(vendor_rsrc.second); | ||||||
|         } |         } | ||||||
|  |     } | ||||||
| 
 | 
 | ||||||
|     // Decide whether to create snapshot based on run_reason and the reset profile checkbox
 |     // Decide whether to create snapshot based on run_reason and the reset profile checkbox
 | ||||||
|     bool snapshot = true; |     bool snapshot = true; | ||||||
|  | @ -1011,9 +1020,26 @@ void ConfigWizard::priv::apply_config(AppConfig *app_config, PresetBundle *prese | ||||||
|     app_config->set_vendors(appconfig_vendors); |     app_config->set_vendors(appconfig_vendors); | ||||||
|     app_config->set("version_check", page_update->version_check ? "1" : "0"); |     app_config->set("version_check", page_update->version_check ? "1" : "0"); | ||||||
|     app_config->set("preset_update", page_update->preset_update ? "1" : "0"); |     app_config->set("preset_update", page_update->preset_update ? "1" : "0"); | ||||||
|     app_config->reset_selections(); |  | ||||||
|     preset_bundle->load_presets(*app_config); |  | ||||||
| 
 | 
 | ||||||
|  |     std::string preferred_model; | ||||||
|  | 
 | ||||||
|  |     // Figure out the default pre-selected printer based on the seletions in the picker.
 | ||||||
|  |     // The default is the first selected printer model (one with at least 1 variant selected).
 | ||||||
|  |     // The default is only applied by load_presets() if the user doesn't have a (visible) printer
 | ||||||
|  |     // selected already.
 | ||||||
|  |     const auto vendor_prusa = vendors.find("PrusaResearch"); | ||||||
|  |     const auto config_prusa = enabled_vendors.find("PrusaResearch"); | ||||||
|  |     if (vendor_prusa != vendors.end() && config_prusa != enabled_vendors.end()) { | ||||||
|  |         for (const auto &model : vendor_prusa->second.models) { | ||||||
|  |             const auto model_it = config_prusa->second.find(model.id); | ||||||
|  |             if (model_it != config_prusa->second.end() && model_it->second.size() > 0) { | ||||||
|  |                 preferred_model = model.id; | ||||||
|  |                 break; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     preset_bundle->load_presets(*app_config, preferred_model); | ||||||
| 
 | 
 | ||||||
|     if (page_custom->custom_wanted()) { |     if (page_custom->custom_wanted()) { | ||||||
|         page_firmware->apply_custom_config(*custom_config); |         page_firmware->apply_custom_config(*custom_config); | ||||||
|  | @ -1107,25 +1133,7 @@ ConfigWizard::ConfigWizard(wxWindow *parent, RunReason reason) | ||||||
|     p->hscroll->SetScrollRate(30, 30); |     p->hscroll->SetScrollRate(30, 30); | ||||||
| 
 | 
 | ||||||
|     on_window_geometry(this, [this]() { |     on_window_geometry(this, [this]() { | ||||||
|         // Clamp the Wizard size based on screen dimensions
 |         p->init_dialog_size(); | ||||||
| 
 |  | ||||||
|         const auto idx = wxDisplay::GetFromWindow(this); |  | ||||||
|         wxDisplay display(idx != wxNOT_FOUND ? idx : 0u); |  | ||||||
| 
 |  | ||||||
|         const auto disp_rect = display.GetClientArea(); |  | ||||||
|         wxRect window_rect( |  | ||||||
|             disp_rect.x + disp_rect.width / 20, |  | ||||||
|             disp_rect.y + disp_rect.height / 20, |  | ||||||
|             9*disp_rect.width / 10, |  | ||||||
|             9*disp_rect.height / 10); |  | ||||||
| 
 |  | ||||||
|         const int width_hint = p->index->GetSize().GetWidth() + p->page_fff->get_width() + 30 * p->em();    // XXX: magic constant, I found no better solution
 |  | ||||||
|         if (width_hint < window_rect.width) { |  | ||||||
|             window_rect.x += (window_rect.width - width_hint) / 2; |  | ||||||
|             window_rect.width = width_hint; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         SetSize(window_rect); |  | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     p->btn_prev->Bind(wxEVT_BUTTON, [this](const wxCommandEvent &) { this->p->index->go_prev(); }); |     p->btn_prev->Bind(wxEVT_BUTTON, [this](const wxCommandEvent &) { this->p->index->go_prev(); }); | ||||||
|  | @ -1194,7 +1202,7 @@ void ConfigWizard::on_dpi_changed(const wxRect &suggested_rect) | ||||||
|     for (auto printer_picker: p->page_fff->printer_pickers) |     for (auto printer_picker: p->page_fff->printer_pickers) | ||||||
|         msw_buttons_rescale(this, em, printer_picker->get_button_indexes()); |         msw_buttons_rescale(this, em, printer_picker->get_button_indexes()); | ||||||
| 
 | 
 | ||||||
|     // FIXME VK SetSize(???)
 |     p->init_dialog_size(); | ||||||
| 
 | 
 | ||||||
|     Refresh(); |     Refresh(); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -292,6 +292,7 @@ struct ConfigWizard::priv | ||||||
|     priv(ConfigWizard *q) : q(q) {} |     priv(ConfigWizard *q) : q(q) {} | ||||||
| 
 | 
 | ||||||
|     void load_pages(bool custom_setup); |     void load_pages(bool custom_setup); | ||||||
|  |     void init_dialog_size(); | ||||||
| 
 | 
 | ||||||
|     bool check_first_variant() const; |     bool check_first_variant() const; | ||||||
|     void load_vendors(); |     void load_vendors(); | ||||||
|  |  | ||||||
|  | @ -5001,6 +5001,10 @@ bool GLCanvas3D::_travel_paths_by_tool(const GCodePreviewData& preview_data, con | ||||||
|     // creates a new volume for each tool
 |     // creates a new volume for each tool
 | ||||||
|     for (Tool& tool : tools) |     for (Tool& tool : tools) | ||||||
|     { |     { | ||||||
|  |         // tool.value could be invalid (as it was with https://github.com/prusa3d/Slic3r/issues/2179), we better check
 | ||||||
|  |         if (tool.value >= tool_colors.size()) | ||||||
|  |             continue; | ||||||
|  | 
 | ||||||
|         GLVolume* volume = new GLVolume(tool_colors.data() + tool.value * 4); |         GLVolume* volume = new GLVolume(tool_colors.data() + tool.value * 4); | ||||||
|         if (volume == nullptr) |         if (volume == nullptr) | ||||||
|             return false; |             return false; | ||||||
|  | @ -5015,7 +5019,7 @@ bool GLCanvas3D::_travel_paths_by_tool(const GCodePreviewData& preview_data, con | ||||||
|     for (const GCodePreviewData::Travel::Polyline& polyline : preview_data.travel.polylines) |     for (const GCodePreviewData::Travel::Polyline& polyline : preview_data.travel.polylines) | ||||||
|     { |     { | ||||||
|         ToolsList::iterator tool = std::find(tools.begin(), tools.end(), Tool(polyline.extruder_id)); |         ToolsList::iterator tool = std::find(tools.begin(), tools.end(), Tool(polyline.extruder_id)); | ||||||
|         if (tool != tools.end()) |         if (tool != tools.end() && tool->volume != nullptr) | ||||||
|         { |         { | ||||||
|             tool->volume->print_zs.push_back(unscale<double>(polyline.polyline.bounding_box().min(2))); |             tool->volume->print_zs.push_back(unscale<double>(polyline.polyline.bounding_box().min(2))); | ||||||
|             tool->volume->offsets.push_back(tool->volume->indexed_vertex_array.quad_indices.size()); |             tool->volume->offsets.push_back(tool->volume->indexed_vertex_array.quad_indices.size()); | ||||||
|  |  | ||||||
|  | @ -125,9 +125,6 @@ void config_wizard(int reason) | ||||||
|     if (! wxGetApp().check_unsaved_changes()) |     if (! wxGetApp().check_unsaved_changes()) | ||||||
|     	return; |     	return; | ||||||
| 
 | 
 | ||||||
|     // save selected preset before config wizard running
 |  | ||||||
|     const auto printer_preset_name = wxGetApp().preset_bundle->printers.get_edited_preset().name; |  | ||||||
| 
 |  | ||||||
| 	try { | 	try { | ||||||
| 		ConfigWizard wizard(nullptr, static_cast<ConfigWizard::RunReason>(reason)); | 		ConfigWizard wizard(nullptr, static_cast<ConfigWizard::RunReason>(reason)); | ||||||
|         wizard.run(wxGetApp().preset_bundle, wxGetApp().preset_updater); |         wizard.run(wxGetApp().preset_bundle, wxGetApp().preset_updater); | ||||||
|  | @ -136,10 +133,8 @@ void config_wizard(int reason) | ||||||
| 		show_error(nullptr, e.what()); | 		show_error(nullptr, e.what()); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|     // select old(before config wizard running) preset
 | 	wxGetApp().load_current_presets(); | ||||||
| 	wxGetApp().get_tab(Preset::TYPE_PRINTER)->select_preset(printer_preset_name);  | 
 | ||||||
|     // If old preset if invisible now, then first visible preset will be selected
 |  | ||||||
|     // So, let control the case if multi-part object is on the scene and first visible preset is SLA
 |  | ||||||
|     if (wxGetApp().preset_bundle->printers.get_edited_preset().printer_technology() == ptSLA && |     if (wxGetApp().preset_bundle->printers.get_edited_preset().printer_technology() == ptSLA && | ||||||
|         wxGetApp().obj_list()->has_multi_part_objects()) |         wxGetApp().obj_list()->has_multi_part_objects()) | ||||||
|     { |     { | ||||||
|  |  | ||||||
|  | @ -34,6 +34,7 @@ | ||||||
| 
 | 
 | ||||||
| #include "../Utils/PresetUpdater.hpp" | #include "../Utils/PresetUpdater.hpp" | ||||||
| #include "../Utils/PrintHost.hpp" | #include "../Utils/PrintHost.hpp" | ||||||
|  | #include "../Utils/MacDarkMode.hpp" | ||||||
| #include "ConfigWizard.hpp" | #include "ConfigWizard.hpp" | ||||||
| #include "slic3r/Config/Snapshot.hpp" | #include "slic3r/Config/Snapshot.hpp" | ||||||
| #include "ConfigSnapshotDialog.hpp" | #include "ConfigSnapshotDialog.hpp" | ||||||
|  | @ -284,10 +285,24 @@ unsigned GUI_App::get_colour_approx_luma(const wxColour &colour) | ||||||
|         )); |         )); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | bool GUI_App::dark_mode() | ||||||
|  | { | ||||||
|  |     const unsigned luma = get_colour_approx_luma(wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOW)); | ||||||
|  |     return luma < 128; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | bool GUI_App::dark_mode_menus() | ||||||
|  | { | ||||||
|  | #if __APPLE__ | ||||||
|  |     return mac_dark_mode(); | ||||||
|  | #else | ||||||
|  |     return dark_mode(); | ||||||
|  | #endif | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void GUI_App::init_label_colours() | void GUI_App::init_label_colours() | ||||||
| { | { | ||||||
|     auto luma = get_colour_approx_luma(wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOW)); |     if (dark_mode()) { | ||||||
|     if (luma >= 128) { |  | ||||||
|         m_color_label_modified = wxColour(252, 77, 1); |         m_color_label_modified = wxColour(252, 77, 1); | ||||||
|         m_color_label_sys = wxColour(26, 132, 57); |         m_color_label_sys = wxColour(26, 132, 57); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -94,7 +94,9 @@ public: | ||||||
| 
 | 
 | ||||||
|     GUI_App(); |     GUI_App(); | ||||||
| 
 | 
 | ||||||
|     unsigned        get_colour_approx_luma(const wxColour &colour); |     static unsigned get_colour_approx_luma(const wxColour &colour); | ||||||
|  |     static bool     dark_mode(); | ||||||
|  |     static bool     dark_mode_menus(); | ||||||
|     void            init_label_colours(); |     void            init_label_colours(); | ||||||
|     void            update_label_colours_from_appconfig(); |     void            update_label_colours_from_appconfig(); | ||||||
|     void            init_fonts(); |     void            init_fonts(); | ||||||
|  |  | ||||||
|  | @ -23,7 +23,7 @@ namespace GUI { | ||||||
| static const float DEFAULT_BASE_COLOR[3] = { 0.625f, 0.625f, 0.625f }; | static const float DEFAULT_BASE_COLOR[3] = { 0.625f, 0.625f, 0.625f }; | ||||||
| static const float DEFAULT_DRAG_COLOR[3] = { 1.0f, 1.0f, 1.0f }; | static const float DEFAULT_DRAG_COLOR[3] = { 1.0f, 1.0f, 1.0f }; | ||||||
| static const float DEFAULT_HIGHLIGHT_COLOR[3] = { 1.0f, 0.38f, 0.0f }; | static const float DEFAULT_HIGHLIGHT_COLOR[3] = { 1.0f, 0.38f, 0.0f }; | ||||||
| static const float AXES_COLOR[3][3] = { { 1.0f, 0.0f, 0.0f }, { 0.0f, 1.0f, 0.0f }, { 0.0f, 0.0f, 1.0f } }; | static const float AXES_COLOR[3][3] = { { 0.75f, 0.0f, 0.0f }, { 0.0f, 0.75f, 0.0f }, { 0.0f, 0.0f, 0.75f } }; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1330,4 +1330,15 @@ const Preset& PrinterPresetCollection::default_preset_for(const DynamicPrintConf | ||||||
| 	return this->default_preset((opt_printer_technology == nullptr || opt_printer_technology->value == ptFFF) ? 0 : 1); | 	return this->default_preset((opt_printer_technology == nullptr || opt_printer_technology->value == ptFFF) ? 0 : 1); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | const Preset* PrinterPresetCollection::find_by_model_id(const std::string &model_id) const | ||||||
|  | { | ||||||
|  |     if (model_id.empty()) { return nullptr; } | ||||||
|  | 
 | ||||||
|  |     const auto it = std::find_if(cbegin(), cend(), [&](const Preset &preset) { | ||||||
|  |         return preset.config.opt_string("printer_model") == model_id; | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  |     return it != cend() ? &*it : nullptr; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| } // namespace Slic3r
 | } // namespace Slic3r
 | ||||||
|  |  | ||||||
|  | @ -312,7 +312,7 @@ public: | ||||||
|     const Preset&   get_edited_preset() const   { return m_edited_preset; } |     const Preset&   get_edited_preset() const   { return m_edited_preset; } | ||||||
| 
 | 
 | ||||||
| 	// used to update preset_choice from Tab
 | 	// used to update preset_choice from Tab
 | ||||||
| 	const std::deque<Preset>&	get_presets()	{ return m_presets; } | 	const std::deque<Preset>&	get_presets() const	{ return m_presets; } | ||||||
| 	int						get_idx_selected()	{ return m_idx_selected; } | 	int						get_idx_selected()	{ return m_idx_selected; } | ||||||
| 	static const std::string&	get_suffix_modified(); | 	static const std::string&	get_suffix_modified(); | ||||||
| 
 | 
 | ||||||
|  | @ -503,6 +503,8 @@ public: | ||||||
|     PrinterPresetCollection(Preset::Type type, const std::vector<std::string> &keys, const Slic3r::StaticPrintConfig &defaults, const std::string &default_name = "- default -") : |     PrinterPresetCollection(Preset::Type type, const std::vector<std::string> &keys, const Slic3r::StaticPrintConfig &defaults, const std::string &default_name = "- default -") : | ||||||
| 		PresetCollection(type, keys, defaults, default_name) {} | 		PresetCollection(type, keys, defaults, default_name) {} | ||||||
|     const Preset&   default_preset_for(const DynamicPrintConfig &config) const override; |     const Preset&   default_preset_for(const DynamicPrintConfig &config) const override; | ||||||
|  | 
 | ||||||
|  |     const Preset*   find_by_model_id(const std::string &model_id) const; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| } // namespace Slic3r
 | } // namespace Slic3r
 | ||||||
|  |  | ||||||
|  | @ -191,7 +191,7 @@ void PresetBundle::setup_directories() | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void PresetBundle::load_presets(const AppConfig &config) | void PresetBundle::load_presets(const AppConfig &config, const std::string &preferred_model_id) | ||||||
| { | { | ||||||
|     // First load the vendor specific system presets.
 |     // First load the vendor specific system presets.
 | ||||||
|     std::string errors_cummulative = this->load_system_presets(); |     std::string errors_cummulative = this->load_system_presets(); | ||||||
|  | @ -234,7 +234,7 @@ void PresetBundle::load_presets(const AppConfig &config) | ||||||
|     if (! errors_cummulative.empty()) |     if (! errors_cummulative.empty()) | ||||||
|         throw std::runtime_error(errors_cummulative); |         throw std::runtime_error(errors_cummulative); | ||||||
| 
 | 
 | ||||||
|     this->load_selections(config); |     this->load_selections(config, preferred_model_id); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // Load system presets into this PresetBundle.
 | // Load system presets into this PresetBundle.
 | ||||||
|  | @ -324,7 +324,7 @@ void PresetBundle::load_installed_printers(const AppConfig &config) | ||||||
| 
 | 
 | ||||||
| // Load selections (current print, current filaments, current printer) from config.ini
 | // Load selections (current print, current filaments, current printer) from config.ini
 | ||||||
| // This is done on application start up or after updates are applied.
 | // This is done on application start up or after updates are applied.
 | ||||||
| void PresetBundle::load_selections(const AppConfig &config) | void PresetBundle::load_selections(const AppConfig &config, const std::string &preferred_model_id) | ||||||
| { | { | ||||||
| 	// Update visibility of presets based on application vendor / model / variant configuration.
 | 	// Update visibility of presets based on application vendor / model / variant configuration.
 | ||||||
| 	this->load_installed_printers(config); | 	this->load_installed_printers(config); | ||||||
|  | @ -336,11 +336,21 @@ void PresetBundle::load_selections(const AppConfig &config) | ||||||
|     std::string initial_sla_material_profile_name = remove_ini_suffix(config.get("presets", "sla_material")); |     std::string initial_sla_material_profile_name = remove_ini_suffix(config.get("presets", "sla_material")); | ||||||
| 	std::string initial_printer_profile_name      = remove_ini_suffix(config.get("presets", "printer")); | 	std::string initial_printer_profile_name      = remove_ini_suffix(config.get("presets", "printer")); | ||||||
| 
 | 
 | ||||||
| 	// Activate print / filament / printer profiles from the config.
 |     // Activate print / filament / printer profiles from either the config,
 | ||||||
|  |     // or from the preferred_model_id suggestion passed in by ConfigWizard.
 | ||||||
|     // If the printer profile enumerated by the config are not visible, select an alternate preset.
 |     // If the printer profile enumerated by the config are not visible, select an alternate preset.
 | ||||||
|     // Do not select alternate profiles for the print / filament profiles as those presets
 |     // Do not select alternate profiles for the print / filament profiles as those presets
 | ||||||
|     // will be selected by the following call of this->update_compatible(true).
 |     // will be selected by the following call of this->update_compatible(true).
 | ||||||
|  | 
 | ||||||
|  |     const Preset *initial_printer = printers.find_preset(initial_printer_profile_name); | ||||||
|  |     const Preset *preferred_printer = printers.find_by_model_id(preferred_model_id); | ||||||
|  | 
 | ||||||
|  |     if (preferred_printer != nullptr && (initial_printer == nullptr || !initial_printer->is_visible)) { | ||||||
|  |         printers.select_preset_by_name(preferred_printer->name, true); | ||||||
|  |     } else { | ||||||
|         printers.select_preset_by_name(initial_printer_profile_name, true); |         printers.select_preset_by_name(initial_printer_profile_name, true); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     PrinterTechnology printer_technology = printers.get_selected_preset().printer_technology(); |     PrinterTechnology printer_technology = printers.get_selected_preset().printer_technology(); | ||||||
|     if (printer_technology == ptFFF) { |     if (printer_technology == ptFFF) { | ||||||
|         prints.select_preset_by_name_strict(initial_print_profile_name); |         prints.select_preset_by_name_strict(initial_print_profile_name); | ||||||
|  |  | ||||||
|  | @ -31,7 +31,7 @@ public: | ||||||
|     // Load ini files of all types (print, filament, printer) from Slic3r::data_dir() / presets.
 |     // Load ini files of all types (print, filament, printer) from Slic3r::data_dir() / presets.
 | ||||||
|     // Load selections (current print, current filaments, current printer) from config.ini
 |     // Load selections (current print, current filaments, current printer) from config.ini
 | ||||||
|     // This is done just once on application start up.
 |     // This is done just once on application start up.
 | ||||||
|     void            load_presets(const AppConfig &config); |     void            load_presets(const AppConfig &config, const std::string &preferred_model_id = ""); | ||||||
| 
 | 
 | ||||||
|     // Export selections (current print, current filaments, current printer) into config.ini
 |     // Export selections (current print, current filaments, current printer) into config.ini
 | ||||||
|     void            export_selections(AppConfig &config); |     void            export_selections(AppConfig &config); | ||||||
|  | @ -143,7 +143,7 @@ private: | ||||||
| 
 | 
 | ||||||
|     // Load selections (current print, current filaments, current printer) from config.ini
 |     // Load selections (current print, current filaments, current printer) from config.ini
 | ||||||
|     // This is done just once on application start up.
 |     // This is done just once on application start up.
 | ||||||
|     void                        load_selections(const AppConfig &config); |     void                        load_selections(const AppConfig &config, const std::string &preferred_model_id = ""); | ||||||
| 
 | 
 | ||||||
|     // Load print, filament & printer presets from a config. If it is an external config, then the name is extracted from the external path.
 |     // Load print, filament & printer presets from a config. If it is an external config, then the name is extracted from the external path.
 | ||||||
|     // and the external config is just referenced, not stored into user profile directory.
 |     // and the external config is just referenced, not stored into user profile directory.
 | ||||||
|  |  | ||||||
|  | @ -2413,7 +2413,9 @@ void ModeButton::SetState(const bool state) | ||||||
| 
 | 
 | ||||||
| void ModeButton::focus_button(const bool focus) | void ModeButton::focus_button(const bool focus) | ||||||
| { | { | ||||||
|     const wxFont& new_font = focus ? Slic3r::GUI::wxGetApp().bold_font() : Slic3r::GUI::wxGetApp().normal_font(); |     const wxFont& new_font = focus ?  | ||||||
|  |                              Slic3r::GUI::wxGetApp().bold_font() :  | ||||||
|  |                              Slic3r::GUI::wxGetApp().normal_font(); | ||||||
| 
 | 
 | ||||||
|     SetFont(new_font); |     SetFont(new_font); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
							
								
								
									
										15
									
								
								src/slic3r/Utils/MacDarkMode.hpp
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								src/slic3r/Utils/MacDarkMode.hpp
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,15 @@ | ||||||
|  | #ifndef slic3r_MacDarkMode_hpp_ | ||||||
|  | #define slic3r_MacDarkMode_hpp_ | ||||||
|  | 
 | ||||||
|  | namespace Slic3r { | ||||||
|  | namespace GUI { | ||||||
|  | 
 | ||||||
|  | #if __APPLE__ | ||||||
|  | extern bool mac_dark_mode(); | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | } // namespace GUI
 | ||||||
|  | } // namespace Slic3r
 | ||||||
|  | 
 | ||||||
|  | #endif // MacDarkMode_h
 | ||||||
							
								
								
									
										22
									
								
								src/slic3r/Utils/MacDarkMode.mm
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								src/slic3r/Utils/MacDarkMode.mm
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,22 @@ | ||||||
|  | #import "MacDarkMode.hpp" | ||||||
|  | 
 | ||||||
|  | #import <Foundation/Foundation.h> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | @implementation MacDarkMode | ||||||
|  | 
 | ||||||
|  | namespace Slic3r { | ||||||
|  | namespace GUI { | ||||||
|  | 
 | ||||||
|  | bool mac_dark_mode() | ||||||
|  | { | ||||||
|  |     NSString *style = [[NSUserDefaults standardUserDefaults] stringForKey:@"AppleInterfaceStyle"]; | ||||||
|  |     return style && [style isEqualToString:@"Dark"]; | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | @end | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 YuSanka
						YuSanka