mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-10-24 01:01:15 -06:00
ConfigWizard: Add view mode setting page
This commit is contained in:
parent
c5a67ff931
commit
cb1ee5ce55
2 changed files with 57 additions and 1 deletions
|
@ -758,6 +758,43 @@ PageUpdate::PageUpdate(ConfigWizard *parent)
|
||||||
box_presets->Bind(wxEVT_CHECKBOX, [this](wxCommandEvent &event) { this->preset_update = event.IsChecked(); });
|
box_presets->Bind(wxEVT_CHECKBOX, [this](wxCommandEvent &event) { this->preset_update = event.IsChecked(); });
|
||||||
}
|
}
|
||||||
|
|
||||||
|
PageMode::PageMode(ConfigWizard *parent)
|
||||||
|
: ConfigWizardPage(parent, _(L("View mode")), _(L("View mode")))
|
||||||
|
{
|
||||||
|
append_text(_(L("PrusaSlicer's user interfaces comes in three variants:\nSimple, Advanced, and Expert.\n"
|
||||||
|
"The Simple mode shows only the most frequently used settings relevant for regular 3D printing. "
|
||||||
|
"The other two offer progressivly more specialized fine-tuning, "
|
||||||
|
"they are suitable for advanced and expert usiser, respectively. (FIXME: review this text)")));
|
||||||
|
|
||||||
|
radio_simple = new wxRadioButton(this, wxID_ANY, _(L("Simple mode")));
|
||||||
|
radio_advanced = new wxRadioButton(this, wxID_ANY, _(L("Advanced mode")));
|
||||||
|
radio_expert = new wxRadioButton(this, wxID_ANY, _(L("Expert mode")));
|
||||||
|
|
||||||
|
append(radio_simple);
|
||||||
|
append(radio_advanced);
|
||||||
|
append(radio_expert);
|
||||||
|
}
|
||||||
|
|
||||||
|
void PageMode::on_activate()
|
||||||
|
{
|
||||||
|
std::string mode { "simple" };
|
||||||
|
wxGetApp().app_config->get("", "view_mode", mode);
|
||||||
|
|
||||||
|
if (mode == "advanced") { radio_advanced->SetValue(true); }
|
||||||
|
else if (mode == "expert") { radio_expert->SetValue(true); }
|
||||||
|
else { radio_simple->SetValue(true); }
|
||||||
|
}
|
||||||
|
|
||||||
|
void PageMode::serialize_mode(AppConfig *app_config) const
|
||||||
|
{
|
||||||
|
const char *mode = "simple";
|
||||||
|
|
||||||
|
if (radio_advanced->GetValue()) { mode = "advanced"; }
|
||||||
|
if (radio_expert->GetValue()) { mode = "expert"; }
|
||||||
|
|
||||||
|
app_config->set("view_mode", mode);
|
||||||
|
}
|
||||||
|
|
||||||
PageVendors::PageVendors(ConfigWizard *parent)
|
PageVendors::PageVendors(ConfigWizard *parent)
|
||||||
: ConfigWizardPage(parent, _(L("Other Vendors")), _(L("Other Vendors")))
|
: ConfigWizardPage(parent, _(L("Other Vendors")), _(L("Other Vendors")))
|
||||||
{
|
{
|
||||||
|
@ -1300,6 +1337,7 @@ void ConfigWizard::priv::load_pages()
|
||||||
if (any_sla_selected) { index->add_page(page_sla_materials); }
|
if (any_sla_selected) { index->add_page(page_sla_materials); }
|
||||||
|
|
||||||
index->add_page(page_update);
|
index->add_page(page_update);
|
||||||
|
index->add_page(page_mode);
|
||||||
|
|
||||||
index->go_to(former_active); // Will restore the active item/page if possible
|
index->go_to(former_active); // Will restore the active item/page if possible
|
||||||
|
|
||||||
|
@ -1587,6 +1625,7 @@ void ConfigWizard::priv::apply_config(AppConfig *app_config, PresetBundle *prese
|
||||||
}
|
}
|
||||||
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");
|
||||||
|
page_mode->serialize_mode(app_config);
|
||||||
|
|
||||||
std::string preferred_model;
|
std::string preferred_model;
|
||||||
|
|
||||||
|
@ -1686,6 +1725,7 @@ ConfigWizard::ConfigWizard(wxWindow *parent)
|
||||||
|
|
||||||
p->add_page(p->page_custom = new PageCustom(this));
|
p->add_page(p->page_custom = new PageCustom(this));
|
||||||
p->add_page(p->page_update = new PageUpdate(this));
|
p->add_page(p->page_update = new PageUpdate(this));
|
||||||
|
p->add_page(p->page_mode = new PageMode(this));
|
||||||
p->add_page(p->page_firmware = new PageFirmware(this));
|
p->add_page(p->page_firmware = new PageFirmware(this));
|
||||||
p->add_page(p->page_bed = new PageBedShape(this));
|
p->add_page(p->page_bed = new PageBedShape(this));
|
||||||
p->add_page(p->page_diams = new PageDiameters(this));
|
p->add_page(p->page_diams = new PageDiameters(this));
|
||||||
|
@ -1751,6 +1791,7 @@ bool ConfigWizard::run(RunReason reason, StartPage start_page)
|
||||||
if (ShowModal() == wxID_OK) {
|
if (ShowModal() == wxID_OK) {
|
||||||
p->apply_config(app.app_config, app.preset_bundle, app.preset_updater);
|
p->apply_config(app.app_config, app.preset_bundle, app.preset_updater);
|
||||||
app.app_config->set_legacy_datadir(false);
|
app.app_config->set_legacy_datadir(false);
|
||||||
|
app.update_mode();
|
||||||
BOOST_LOG_TRIVIAL(info) << "ConfigWizard applied";
|
BOOST_LOG_TRIVIAL(info) << "ConfigWizard applied";
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
#include <wx/textctrl.h>
|
#include <wx/textctrl.h>
|
||||||
#include <wx/listbox.h>
|
#include <wx/listbox.h>
|
||||||
#include <wx/checklst.h>
|
#include <wx/checklst.h>
|
||||||
|
#include <wx/radiobut.h>
|
||||||
|
|
||||||
#include "libslic3r/PrintConfig.hpp"
|
#include "libslic3r/PrintConfig.hpp"
|
||||||
#include "slic3r/Utils/PresetUpdater.hpp"
|
#include "slic3r/Utils/PresetUpdater.hpp"
|
||||||
|
@ -290,6 +291,19 @@ struct PageUpdate: ConfigWizardPage
|
||||||
PageUpdate(ConfigWizard *parent);
|
PageUpdate(ConfigWizard *parent);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct PageMode: ConfigWizardPage
|
||||||
|
{
|
||||||
|
wxRadioButton *radio_simple;
|
||||||
|
wxRadioButton *radio_advanced;
|
||||||
|
wxRadioButton *radio_expert;
|
||||||
|
|
||||||
|
PageMode(ConfigWizard *parent);
|
||||||
|
|
||||||
|
void serialize_mode(AppConfig *app_config) const;
|
||||||
|
|
||||||
|
virtual void on_activate();
|
||||||
|
};
|
||||||
|
|
||||||
struct PageVendors: ConfigWizardPage
|
struct PageVendors: ConfigWizardPage
|
||||||
{
|
{
|
||||||
PageVendors(ConfigWizard *parent);
|
PageVendors(ConfigWizard *parent);
|
||||||
|
@ -424,7 +438,8 @@ struct ConfigWizard::priv
|
||||||
PageMaterials *page_sla_materials = nullptr;
|
PageMaterials *page_sla_materials = nullptr;
|
||||||
PageCustom *page_custom = nullptr;
|
PageCustom *page_custom = nullptr;
|
||||||
PageUpdate *page_update = nullptr;
|
PageUpdate *page_update = nullptr;
|
||||||
PageVendors *page_vendors = nullptr; // XXX: ?
|
PageMode *page_mode = nullptr;
|
||||||
|
PageVendors *page_vendors = nullptr;
|
||||||
Pages3rdparty pages_3rdparty;
|
Pages3rdparty pages_3rdparty;
|
||||||
|
|
||||||
// Custom setup pages
|
// Custom setup pages
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue