diff --git a/src/slic3r/GUI/GUI_App.cpp b/src/slic3r/GUI/GUI_App.cpp index 87f58aa1af..595a968bd2 100644 --- a/src/slic3r/GUI/GUI_App.cpp +++ b/src/slic3r/GUI/GUI_App.cpp @@ -466,7 +466,7 @@ void GUI_App::update_ui_from_settings() mainframe->update_ui_from_settings(); } -void GUI_App::persist_window_geometry(wxTopLevelWindow *window) +void GUI_App::persist_window_geometry(wxTopLevelWindow *window, bool default_maximized) { const std::string name = into_u8(window->GetName()); @@ -475,7 +475,7 @@ void GUI_App::persist_window_geometry(wxTopLevelWindow *window) event.Skip(); }); - window_pos_restore(window, name); + window_pos_restore(window, name, default_maximized); on_window_geometry(window, [=]() { window_pos_sanitize(window); @@ -883,15 +883,21 @@ void GUI_App::window_pos_save(wxTopLevelWindow* window, const std::string &name) app_config->save(); } -void GUI_App::window_pos_restore(wxTopLevelWindow* window, const std::string &name) +void GUI_App::window_pos_restore(wxTopLevelWindow* window, const std::string &name, bool default_maximized) { if (name.empty()) { return; } const auto config_key = (boost::format("window_%1%") % name).str(); - if (! app_config->has(config_key)) { return; } + if (! app_config->has(config_key)) { + window->Maximize(default_maximized); + return; + } auto metrics = WindowMetrics::deserialize(app_config->get(config_key)); - if (! metrics) { return; } + if (! metrics) { + window->Maximize(default_maximized); + return; + } window->SetSize(metrics->get_rect()); window->Maximize(metrics->get_maximized()); diff --git a/src/slic3r/GUI/GUI_App.hpp b/src/slic3r/GUI/GUI_App.hpp index 5ee0c15095..3a6a443f06 100644 --- a/src/slic3r/GUI/GUI_App.hpp +++ b/src/slic3r/GUI/GUI_App.hpp @@ -124,7 +124,7 @@ public: const std::string& err); // void notify(/*message*/); - void persist_window_geometry(wxTopLevelWindow *window); + void persist_window_geometry(wxTopLevelWindow *window, bool default_maximized = false); void update_ui_from_settings(); bool select_language(wxArrayString & names, wxArrayLong & identifiers); @@ -176,7 +176,7 @@ public: private: bool on_init_inner(); void window_pos_save(wxTopLevelWindow* window, const std::string &name); - void window_pos_restore(wxTopLevelWindow* window, const std::string &name); + void window_pos_restore(wxTopLevelWindow* window, const std::string &name, bool default_maximized = false); void window_pos_sanitize(wxTopLevelWindow* window); }; DECLARE_APP(GUI_App) diff --git a/src/slic3r/GUI/MainFrame.cpp b/src/slic3r/GUI/MainFrame.cpp index 571b57235f..3e3642af52 100644 --- a/src/slic3r/GUI/MainFrame.cpp +++ b/src/slic3r/GUI/MainFrame.cpp @@ -129,7 +129,7 @@ DPIFrame(NULL, wxID_ANY, SLIC3R_BUILD, wxDefaultPosition, wxDefaultSize, wxDEFAU event.Skip(); }); - wxGetApp().persist_window_geometry(this); + wxGetApp().persist_window_geometry(this, true); update_ui_from_settings(); // FIXME (?) }