mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 10:11:10 -06:00 
			
		
		
		
	Added new tech ENABLE_LAYOUT_NO_RESTART -> Enable changing application layout without the need to restart it
This commit is contained in:
		
							parent
							
								
									0a7e2aa8da
								
							
						
					
					
						commit
						920d9677da
					
				
					 5 changed files with 269 additions and 9 deletions
				
			
		|  | @ -51,5 +51,8 @@ | ||||||
| // Enable error logging for OpenGL calls when SLIC3R_LOGLEVEL >= 5
 | // Enable error logging for OpenGL calls when SLIC3R_LOGLEVEL >= 5
 | ||||||
| #define ENABLE_OPENGL_ERROR_LOGGING (1 && ENABLE_2_3_0_ALPHA1) | #define ENABLE_OPENGL_ERROR_LOGGING (1 && ENABLE_2_3_0_ALPHA1) | ||||||
| 
 | 
 | ||||||
|  | // Enable changing application layout without the need to restart
 | ||||||
|  | #define ENABLE_LAYOUT_NO_RESTART (1 && ENABLE_2_3_0_ALPHA1) | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| #endif // _prusaslicer_technologies_h_
 | #endif // _prusaslicer_technologies_h_
 | ||||||
|  |  | ||||||
|  | @ -1059,17 +1059,33 @@ void GUI_App::add_config_menu(wxMenuBar *menu) | ||||||
|             break; |             break; | ||||||
|         case ConfigMenuPreferences: |         case ConfigMenuPreferences: | ||||||
|         { |         { | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  |             bool app_layout_changed = false; | ||||||
|  | #else | ||||||
|             bool recreate_app = false; |             bool recreate_app = false; | ||||||
|  | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
|             { |             { | ||||||
|                 // the dialog needs to be destroyed before the call to recreate_GUI()
 |                 // the dialog needs to be destroyed before the call to recreate_GUI()
 | ||||||
|                 // or sometimes the application crashes into wxDialogBase() destructor
 |                 // or sometimes the application crashes into wxDialogBase() destructor
 | ||||||
|                 // so we put it into an inner scope
 |                 // so we put it into an inner scope
 | ||||||
|                 PreferencesDialog dlg(mainframe); |                 PreferencesDialog dlg(mainframe); | ||||||
|                 dlg.ShowModal(); |                 dlg.ShowModal(); | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  |                 app_layout_changed = dlg.settings_layout_changed(); | ||||||
|  | #else | ||||||
|                 recreate_app = dlg.settings_layout_changed(); |                 recreate_app = dlg.settings_layout_changed(); | ||||||
|  | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
|             } |             } | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  |             if (app_layout_changed) | ||||||
|  |             { | ||||||
|  |                 mainframe->update_layout(); | ||||||
|  |                 mainframe->select_tab(0); | ||||||
|  |             } | ||||||
|  | #else | ||||||
|             if (recreate_app) |             if (recreate_app) | ||||||
|                 recreate_GUI(_L("Changing of the settings layout") + dots); |                 recreate_GUI(_L("Changing of the settings layout") + dots); | ||||||
|  | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|         case ConfigMenuLanguage: |         case ConfigMenuLanguage: | ||||||
|  |  | ||||||
|  | @ -46,6 +46,9 @@ MainFrame::MainFrame() : | ||||||
| DPIFrame(NULL, wxID_ANY, "", wxDefaultPosition, wxDefaultSize, wxDEFAULT_FRAME_STYLE, "mainframe"), | DPIFrame(NULL, wxID_ANY, "", wxDefaultPosition, wxDefaultSize, wxDEFAULT_FRAME_STYLE, "mainframe"), | ||||||
|     m_printhost_queue_dlg(new PrintHostQueueDialog(this)) |     m_printhost_queue_dlg(new PrintHostQueueDialog(this)) | ||||||
|     , m_recent_projects(9) |     , m_recent_projects(9) | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  |     , m_settings_dialog(this) | ||||||
|  | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
| { | { | ||||||
|     // Fonts were created by the DPIFrame constructor for the monitor, on which the window opened.
 |     // Fonts were created by the DPIFrame constructor for the monitor, on which the window opened.
 | ||||||
|     wxGetApp().update_fonts(this); |     wxGetApp().update_fonts(this); | ||||||
|  | @ -90,6 +93,7 @@ DPIFrame(NULL, wxID_ANY, "", wxDefaultPosition, wxDefaultSize, wxDEFAULT_FRAME_S | ||||||
| 
 | 
 | ||||||
|     m_loaded = true; |     m_loaded = true; | ||||||
| 
 | 
 | ||||||
|  | #if !ENABLE_LAYOUT_NO_RESTART | ||||||
| #ifdef __APPLE__ | #ifdef __APPLE__ | ||||||
|     // Using SetMinSize() on Mac messes up the window position in some cases
 |     // Using SetMinSize() on Mac messes up the window position in some cases
 | ||||||
|     // cf. https://groups.google.com/forum/#!topic/wx-users/yUKPBBfXWO0
 |     // cf. https://groups.google.com/forum/#!topic/wx-users/yUKPBBfXWO0
 | ||||||
|  | @ -103,8 +107,17 @@ DPIFrame(NULL, wxID_ANY, "", wxDefaultPosition, wxDefaultSize, wxDEFAULT_FRAME_S | ||||||
|         m_tabpanel->SetMinSize(size); |         m_tabpanel->SetMinSize(size); | ||||||
|     } |     } | ||||||
| #endif | #endif | ||||||
|  | #endif // !ENABLE_LAYOUT_NO_RESTART
 | ||||||
|  | 
 | ||||||
|     // initialize layout
 |     // initialize layout
 | ||||||
|     auto sizer = new wxBoxSizer(wxVERTICAL); |     auto sizer = new wxBoxSizer(wxVERTICAL); | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  |     SetSizer(sizer); | ||||||
|  |     // initialize layout from config
 | ||||||
|  |     update_layout(); | ||||||
|  |     sizer->SetSizeHints(this); | ||||||
|  |     Fit(); | ||||||
|  | #else | ||||||
|     if (m_plater && m_layout != slOld) |     if (m_plater && m_layout != slOld) | ||||||
|         sizer->Add(m_plater, 1, wxEXPAND); |         sizer->Add(m_plater, 1, wxEXPAND); | ||||||
| 
 | 
 | ||||||
|  | @ -114,6 +127,7 @@ DPIFrame(NULL, wxID_ANY, "", wxDefaultPosition, wxDefaultSize, wxDEFAULT_FRAME_S | ||||||
|     sizer->SetSizeHints(this); |     sizer->SetSizeHints(this); | ||||||
|     SetSizer(sizer); |     SetSizer(sizer); | ||||||
|     Fit(); |     Fit(); | ||||||
|  | #endif // !ENABLE_LAYOUT_NO_RESTART
 | ||||||
| 
 | 
 | ||||||
|     const wxSize min_size = wxGetApp().get_min_size(); //wxSize(76*wxGetApp().em_unit(), 49*wxGetApp().em_unit());
 |     const wxSize min_size = wxGetApp().get_min_size(); //wxSize(76*wxGetApp().em_unit(), 49*wxGetApp().em_unit());
 | ||||||
| #ifdef __APPLE__ | #ifdef __APPLE__ | ||||||
|  | @ -205,8 +219,12 @@ DPIFrame(NULL, wxID_ANY, "", wxDefaultPosition, wxDefaultSize, wxDEFAULT_FRAME_S | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     wxGetApp().persist_window_geometry(this, true); |     wxGetApp().persist_window_geometry(this, true); | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  |     wxGetApp().persist_window_geometry(&m_settings_dialog, true); | ||||||
|  | #else | ||||||
|     if (m_settings_dialog != nullptr) |     if (m_settings_dialog != nullptr) | ||||||
|         wxGetApp().persist_window_geometry(m_settings_dialog, true); |         wxGetApp().persist_window_geometry(m_settings_dialog, true); | ||||||
|  | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
| 
 | 
 | ||||||
|     update_ui_from_settings();    // FIXME (?)
 |     update_ui_from_settings();    // FIXME (?)
 | ||||||
| 
 | 
 | ||||||
|  | @ -214,6 +232,90 @@ DPIFrame(NULL, wxID_ANY, "", wxDefaultPosition, wxDefaultSize, wxDEFAULT_FRAME_S | ||||||
|         m_plater->show_action_buttons(true); |         m_plater->show_action_buttons(true); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  | void MainFrame::update_layout() | ||||||
|  | { | ||||||
|  |     ESettingsLayout layout = wxGetApp().app_config->get("old_settings_layout_mode") == "1" ? ESettingsLayout::Old : | ||||||
|  |         wxGetApp().app_config->get("new_settings_layout_mode") == "1" ? ESettingsLayout::New : | ||||||
|  |         wxGetApp().app_config->get("dlg_settings_layout_mode") == "1" ? ESettingsLayout::Dlg : ESettingsLayout::Old; | ||||||
|  | 
 | ||||||
|  |     if (m_layout == layout) | ||||||
|  |         return; | ||||||
|  | 
 | ||||||
|  |     wxBusyCursor busy; | ||||||
|  | 
 | ||||||
|  |     Freeze(); | ||||||
|  | 
 | ||||||
|  |     if (m_layout != ESettingsLayout::Unknown) { | ||||||
|  |         // Restore from previous settings
 | ||||||
|  |         if (m_layout == ESettingsLayout::Old) { | ||||||
|  |             m_plater->Reparent(this); | ||||||
|  |             m_tabpanel->RemovePage(m_tabpanel->FindPage(m_plater)); | ||||||
|  |             GetSizer()->Detach(m_tabpanel); | ||||||
|  |         } | ||||||
|  |         else { | ||||||
|  |             if (m_layout == ESettingsLayout::New) { | ||||||
|  |                 GetSizer()->Detach(m_plater); | ||||||
|  |                 GetSizer()->Detach(m_tabpanel); | ||||||
|  |                 m_tabpanel->DeletePage(m_tabpanel->FindPage(m_plater_page)); | ||||||
|  |             } | ||||||
|  |             else { | ||||||
|  |                 if (m_settings_dialog.IsShown()) | ||||||
|  |                     m_settings_dialog.Close(); | ||||||
|  | 
 | ||||||
|  |                 GetSizer()->Detach(m_plater); | ||||||
|  |                 m_settings_dialog.GetSizer()->Detach(m_tabpanel); | ||||||
|  |                 m_tabpanel->Reparent(this); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     m_layout = layout; | ||||||
|  | 
 | ||||||
|  |     // From the very beginning the Print settings should be selected
 | ||||||
|  |     m_last_selected_tab = m_layout == ESettingsLayout::Dlg ? 0 : 1; | ||||||
|  | 
 | ||||||
|  |     // Set new settings
 | ||||||
|  |     if (m_layout == ESettingsLayout::Old) { | ||||||
|  |         m_plater->Reparent(m_tabpanel); | ||||||
|  |         m_tabpanel->InsertPage(0, m_plater, _L("Plater")); | ||||||
|  |         GetSizer()->Add(m_tabpanel, 1, wxEXPAND); | ||||||
|  |         m_tabpanel->Show(); | ||||||
|  |     } | ||||||
|  |     else { | ||||||
|  |         if (m_layout == ESettingsLayout::New) { | ||||||
|  |             GetSizer()->Add(m_plater, 1, wxEXPAND); | ||||||
|  |             GetSizer()->Add(m_tabpanel, 1, wxEXPAND); | ||||||
|  |             m_plater_page = new wxPanel(m_tabpanel); | ||||||
|  |             m_tabpanel->InsertPage(0, m_plater_page, _L("Plater")); // empty panel just for Plater tab */
 | ||||||
|  |         } | ||||||
|  |         else { | ||||||
|  |             GetSizer()->Add(m_plater, 1, wxEXPAND); | ||||||
|  |             m_plater->Show(); | ||||||
|  |             m_tabpanel->Reparent(&m_settings_dialog); | ||||||
|  |             m_settings_dialog.GetSizer()->Add(m_tabpanel, 1, wxEXPAND); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | #ifdef __APPLE__ | ||||||
|  |     // Using SetMinSize() on Mac messes up the window position in some cases
 | ||||||
|  |     // cf. https://groups.google.com/forum/#!topic/wx-users/yUKPBBfXWO0
 | ||||||
|  |     // So, if we haven't possibility to set MinSize() for the MainFrame, 
 | ||||||
|  |     // set the MinSize() as a half of regular  for the m_plater and m_tabpanel, when settings layout is in slNew mode
 | ||||||
|  |     // Otherwise, MainFrame will be maximized by height
 | ||||||
|  |     if (m_layout == ESettingsLayout::New) { | ||||||
|  |         wxSize size = wxGetApp().get_min_size(); | ||||||
|  |         size.SetHeight(int(0.5 * size.GetHeight())); | ||||||
|  |         m_plater->SetMinSize(size); | ||||||
|  |         m_tabpanel->SetMinSize(size); | ||||||
|  |     } | ||||||
|  | #endif | ||||||
|  |      | ||||||
|  |     Layout(); | ||||||
|  |     Thaw(); | ||||||
|  | } | ||||||
|  | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
|  | 
 | ||||||
| // Called when closing the application and when switching the application language.
 | // Called when closing the application and when switching the application language.
 | ||||||
| void MainFrame::shutdown() | void MainFrame::shutdown() | ||||||
| { | { | ||||||
|  | @ -246,6 +348,11 @@ void MainFrame::shutdown() | ||||||
|     // In addition, there were some crashes due to the Paint events sent to already destructed windows.
 |     // In addition, there were some crashes due to the Paint events sent to already destructed windows.
 | ||||||
|     this->Show(false); |     this->Show(false); | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  |     if (m_settings_dialog.IsShown()) | ||||||
|  |         // call Close() to trigger call to lambda defined into GUI_App::persist_window_geometry()
 | ||||||
|  |         m_settings_dialog.Close(); | ||||||
|  | #else | ||||||
|     if (m_settings_dialog != nullptr) |     if (m_settings_dialog != nullptr) | ||||||
|     { |     { | ||||||
|         if (m_settings_dialog->IsShown()) |         if (m_settings_dialog->IsShown()) | ||||||
|  | @ -254,6 +361,7 @@ void MainFrame::shutdown() | ||||||
| 
 | 
 | ||||||
|         m_settings_dialog->Destroy(); |         m_settings_dialog->Destroy(); | ||||||
|     } |     } | ||||||
|  | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
| 
 | 
 | ||||||
| 	// Stop the background thread (Windows and Linux).
 | 	// Stop the background thread (Windows and Linux).
 | ||||||
| 	// Disconnect from a 3DConnextion driver (OSX).
 | 	// Disconnect from a 3DConnextion driver (OSX).
 | ||||||
|  | @ -312,6 +420,15 @@ void MainFrame::update_title() | ||||||
| 
 | 
 | ||||||
| void MainFrame::init_tabpanel() | void MainFrame::init_tabpanel() | ||||||
| { | { | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  |     // wxNB_NOPAGETHEME: Disable Windows Vista theme for the Notebook background. The theme performance is terrible on Windows 10
 | ||||||
|  |     // with multiple high resolution displays connected.
 | ||||||
|  |     m_tabpanel = new wxNotebook(this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxNB_TOP | wxTAB_TRAVERSAL | wxNB_NOPAGETHEME); | ||||||
|  | #ifndef __WXOSX__ // Don't call SetFont under OSX to avoid name cutting in ObjectList
 | ||||||
|  |     m_tabpanel->SetFont(Slic3r::GUI::wxGetApp().normal_font()); | ||||||
|  | #endif | ||||||
|  |     m_settings_dialog.set_tabpanel(m_tabpanel); | ||||||
|  | #else | ||||||
|     m_layout = wxGetApp().app_config->get("old_settings_layout_mode") == "1" ? slOld : |     m_layout = wxGetApp().app_config->get("old_settings_layout_mode") == "1" ? slOld : | ||||||
|         wxGetApp().app_config->get("new_settings_layout_mode") == "1" ? slNew : |         wxGetApp().app_config->get("new_settings_layout_mode") == "1" ? slNew : | ||||||
|         wxGetApp().app_config->get("dlg_settings_layout_mode") == "1" ? slDlg : slOld; |         wxGetApp().app_config->get("dlg_settings_layout_mode") == "1" ? slDlg : slOld; | ||||||
|  | @ -331,6 +448,7 @@ void MainFrame::init_tabpanel() | ||||||
|         m_tabpanel->SetFont(Slic3r::GUI::wxGetApp().normal_font()); |         m_tabpanel->SetFont(Slic3r::GUI::wxGetApp().normal_font()); | ||||||
| #endif | #endif | ||||||
|     } |     } | ||||||
|  | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
| 
 | 
 | ||||||
|     m_tabpanel->Bind(wxEVT_NOTEBOOK_PAGE_CHANGED, [this](wxEvent&) { |     m_tabpanel->Bind(wxEVT_NOTEBOOK_PAGE_CHANGED, [this](wxEvent&) { | ||||||
|         wxWindow* panel = m_tabpanel->GetCurrentPage(); |         wxWindow* panel = m_tabpanel->GetCurrentPage(); | ||||||
|  | @ -351,6 +469,9 @@ void MainFrame::init_tabpanel() | ||||||
|             select_tab(0); // select Plater
 |             select_tab(0); // select Plater
 | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  |     m_plater = new Plater(this, this); | ||||||
|  | #else | ||||||
|     if (m_layout == slOld) { |     if (m_layout == slOld) { | ||||||
|         m_plater = new Plater(m_tabpanel, this); |         m_plater = new Plater(m_tabpanel, this); | ||||||
|         m_tabpanel->AddPage(m_plater, _L("Plater")); |         m_tabpanel->AddPage(m_plater, _L("Plater")); | ||||||
|  | @ -360,6 +481,7 @@ void MainFrame::init_tabpanel() | ||||||
|         if (m_layout == slNew) |         if (m_layout == slNew) | ||||||
|             m_tabpanel->AddPage(new wxPanel(m_tabpanel), _L("Plater")); // empty panel just for Plater tab
 |             m_tabpanel->AddPage(new wxPanel(m_tabpanel), _L("Plater")); // empty panel just for Plater tab
 | ||||||
|     } |     } | ||||||
|  | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
|     wxGetApp().plater_ = m_plater; |     wxGetApp().plater_ = m_plater; | ||||||
| 
 | 
 | ||||||
|     wxGetApp().obj_list()->create_popup_menus(); |     wxGetApp().obj_list()->create_popup_menus(); | ||||||
|  | @ -501,6 +623,18 @@ bool MainFrame::can_slice() const | ||||||
| 
 | 
 | ||||||
| bool MainFrame::can_change_view() const | bool MainFrame::can_change_view() const | ||||||
| { | { | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  |     switch (m_layout) | ||||||
|  |     { | ||||||
|  |     default:                   { return false; } | ||||||
|  |     case ESettingsLayout::New: { return m_plater->IsShown(); } | ||||||
|  |     case ESettingsLayout::Dlg: { return true; } | ||||||
|  |     case ESettingsLayout::Old: {  | ||||||
|  |         int page_id = m_tabpanel->GetSelection(); | ||||||
|  |         return page_id != wxNOT_FOUND && dynamic_cast<const Slic3r::GUI::Plater*>(m_tabpanel->GetPage((size_t)page_id)) != nullptr; | ||||||
|  |     } | ||||||
|  |     } | ||||||
|  | #else | ||||||
|     if (m_layout == slNew) |     if (m_layout == slNew) | ||||||
|         return m_plater->IsShown(); |         return m_plater->IsShown(); | ||||||
|     if (m_layout == slDlg) |     if (m_layout == slDlg) | ||||||
|  | @ -508,6 +642,7 @@ bool MainFrame::can_change_view() const | ||||||
|     // slOld layout mode
 |     // slOld layout mode
 | ||||||
|     int page_id = m_tabpanel->GetSelection(); |     int page_id = m_tabpanel->GetSelection(); | ||||||
|     return page_id != wxNOT_FOUND && dynamic_cast<const Slic3r::GUI::Plater*>(m_tabpanel->GetPage((size_t)page_id)) != nullptr; |     return page_id != wxNOT_FOUND && dynamic_cast<const Slic3r::GUI::Plater*>(m_tabpanel->GetPage((size_t)page_id)) != nullptr; | ||||||
|  | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool MainFrame::can_select() const | bool MainFrame::can_select() const | ||||||
|  | @ -549,7 +684,11 @@ void MainFrame::on_dpi_changed(const wxRect &suggested_rect) | ||||||
|     wxGetApp().plater()->msw_rescale(); |     wxGetApp().plater()->msw_rescale(); | ||||||
| 
 | 
 | ||||||
|     // update Tabs
 |     // update Tabs
 | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  |     if (m_layout != ESettingsLayout::Dlg) // Update tabs later, from the SettingsDialog, when the Settings are in the separated dialog
 | ||||||
|  | #else | ||||||
|     if (m_layout != slDlg) // Update tabs later, from the SettingsDialog, when the Settings are in the separated dialog
 |     if (m_layout != slDlg) // Update tabs later, from the SettingsDialog, when the Settings are in the separated dialog
 | ||||||
|  | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
|         for (auto tab : wxGetApp().tabs_list) |         for (auto tab : wxGetApp().tabs_list) | ||||||
|             tab->msw_rescale(); |             tab->msw_rescale(); | ||||||
| 
 | 
 | ||||||
|  | @ -1311,15 +1450,41 @@ void MainFrame::load_config(const DynamicPrintConfig& config) | ||||||
| 
 | 
 | ||||||
| void MainFrame::select_tab(size_t tab/* = size_t(-1)*/) | void MainFrame::select_tab(size_t tab/* = size_t(-1)*/) | ||||||
| { | { | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  |     if (m_layout == ESettingsLayout::Dlg) { | ||||||
|  | #else | ||||||
|     if (m_layout == slDlg) { |     if (m_layout == slDlg) { | ||||||
|  | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
|         if (tab==0) { |         if (tab==0) { | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  |             if (m_settings_dialog.IsShown()) | ||||||
|  |                 this->SetFocus(); | ||||||
|  | #else | ||||||
|             if (m_settings_dialog->IsShown()) |             if (m_settings_dialog->IsShown()) | ||||||
|                 this->SetFocus(); |                 this->SetFocus(); | ||||||
|  | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
|             // plater should be focused for correct navigation inside search window
 |             // plater should be focused for correct navigation inside search window
 | ||||||
|             if (m_plater->canvas3D()->is_search_pressed()) |             if (m_plater->canvas3D()->is_search_pressed()) | ||||||
|                 m_plater->SetFocus(); |                 m_plater->SetFocus(); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  |         // Show/Activate Settings Dialog
 | ||||||
|  | #ifdef __WXOSX__ // Don't call SetFont under OSX to avoid name cutting in ObjectList
 | ||||||
|  |         if (m_settings_dialog.IsShown()) | ||||||
|  |             m_settings_dialog.Hide(); | ||||||
|  | 
 | ||||||
|  |         m_tabpanel->Show(); | ||||||
|  |         m_settings_dialog.Show(); | ||||||
|  | #else | ||||||
|  |         if (m_settings_dialog.IsShown()) | ||||||
|  |             m_settings_dialog.SetFocus(); | ||||||
|  |         else { | ||||||
|  |             m_tabpanel->Show(); | ||||||
|  |             m_settings_dialog.Show(); | ||||||
|  |         } | ||||||
|  | #endif | ||||||
|  | #else | ||||||
|         // Show/Activate Settings Dialog
 |         // Show/Activate Settings Dialog
 | ||||||
|         if (m_settings_dialog->IsShown()) |         if (m_settings_dialog->IsShown()) | ||||||
| #ifdef __WXOSX__ // Don't call SetFont under OSX to avoid name cutting in ObjectList
 | #ifdef __WXOSX__ // Don't call SetFont under OSX to avoid name cutting in ObjectList
 | ||||||
|  | @ -1329,8 +1494,13 @@ void MainFrame::select_tab(size_t tab/* = size_t(-1)*/) | ||||||
|         else |         else | ||||||
| #endif | #endif | ||||||
|         m_settings_dialog->Show(); |         m_settings_dialog->Show(); | ||||||
|  | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
|     } |     } | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  |     else if (m_layout == ESettingsLayout::New) { | ||||||
|  | #else | ||||||
|     else if (m_layout == slNew) { |     else if (m_layout == slNew) { | ||||||
|  | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
|         m_plater->Show(tab == 0); |         m_plater->Show(tab == 0); | ||||||
|         m_tabpanel->Show(tab != 0); |         m_tabpanel->Show(tab != 0); | ||||||
| 
 | 
 | ||||||
|  | @ -1341,7 +1511,11 @@ void MainFrame::select_tab(size_t tab/* = size_t(-1)*/) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // when tab == -1, it means we should to show the last selected tab
 |     // when tab == -1, it means we should to show the last selected tab
 | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  |     m_tabpanel->SetSelection(tab == (size_t)(-1) ? m_last_selected_tab : (m_layout == ESettingsLayout::Dlg && tab != 0) ? tab - 1 : tab); | ||||||
|  | #else | ||||||
|     m_tabpanel->SetSelection(tab == (size_t)(-1) ? m_last_selected_tab : (m_layout == slDlg && tab != 0) ? tab-1 : tab); |     m_tabpanel->SetSelection(tab == (size_t)(-1) ? m_last_selected_tab : (m_layout == slDlg && tab != 0) ? tab-1 : tab); | ||||||
|  | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // Set a camera direction, zoom to all objects.
 | // Set a camera direction, zoom to all objects.
 | ||||||
|  | @ -1452,14 +1626,12 @@ std::string MainFrame::get_dir_name(const wxString &full_name) const | ||||||
| // ----------------------------------------------------------------------------
 | // ----------------------------------------------------------------------------
 | ||||||
| 
 | 
 | ||||||
| SettingsDialog::SettingsDialog(MainFrame* mainframe) | SettingsDialog::SettingsDialog(MainFrame* mainframe) | ||||||
| : DPIDialog(nullptr, wxID_ANY, wxString(SLIC3R_APP_NAME) + " - " + _L("Settings"), wxDefaultPosition, wxDefaultSize, | : DPIDialog(mainframe, wxID_ANY, wxString(SLIC3R_APP_NAME) + " - " + _L("Settings"), wxDefaultPosition, wxDefaultSize, | ||||||
|     wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER | wxMINIMIZE_BOX | wxMAXIMIZE_BOX | wxDIALOG_NO_PARENT, "settings_dialog"), |         wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER | wxMINIMIZE_BOX | wxMAXIMIZE_BOX, "settings_dialog"), | ||||||
|     m_main_frame(mainframe) |     m_main_frame(mainframe) | ||||||
| { | { | ||||||
|     this->SetFont(wxGetApp().normal_font()); |     this->SetFont(wxGetApp().normal_font()); | ||||||
| 
 |     this->SetBackgroundColour(wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOW)); | ||||||
|     wxColour bgr_clr = wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOW); |  | ||||||
|     this->SetBackgroundColour(bgr_clr); |  | ||||||
| 
 | 
 | ||||||
|     // Load the icon either from the exe, or from the ico file.
 |     // Load the icon either from the exe, or from the ico file.
 | ||||||
| #if _WIN32 | #if _WIN32 | ||||||
|  | @ -1472,6 +1644,7 @@ SettingsDialog::SettingsDialog(MainFrame* mainframe) | ||||||
|     SetIcon(wxIcon(var("PrusaSlicer_128px.png"), wxBITMAP_TYPE_PNG)); |     SetIcon(wxIcon(var("PrusaSlicer_128px.png"), wxBITMAP_TYPE_PNG)); | ||||||
| #endif // _WIN32
 | #endif // _WIN32
 | ||||||
| 
 | 
 | ||||||
|  | #if !ENABLE_LAYOUT_NO_RESTART | ||||||
|     // wxNB_NOPAGETHEME: Disable Windows Vista theme for the Notebook background. The theme performance is terrible on Windows 10
 |     // wxNB_NOPAGETHEME: Disable Windows Vista theme for the Notebook background. The theme performance is terrible on Windows 10
 | ||||||
|     // with multiple high resolution displays connected.
 |     // with multiple high resolution displays connected.
 | ||||||
|     m_tabpanel = new wxNotebook(this, wxID_ANY, wxDefaultPosition, wxGetApp().get_min_size(), wxNB_TOP | wxTAB_TRAVERSAL | wxNB_NOPAGETHEME); |     m_tabpanel = new wxNotebook(this, wxID_ANY, wxDefaultPosition, wxGetApp().get_min_size(), wxNB_TOP | wxTAB_TRAVERSAL | wxNB_NOPAGETHEME); | ||||||
|  | @ -1496,10 +1669,45 @@ SettingsDialog::SettingsDialog(MainFrame* mainframe) | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     }); |     }); | ||||||
|  | #endif // !ENABLE_LAYOUT_NO_RESTART
 | ||||||
|  | 
 | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  |     this->Bind(wxEVT_SHOW, [this](wxShowEvent& evt) { | ||||||
|  | 
 | ||||||
|  |         auto key_up_handker = [this](wxKeyEvent& evt) { | ||||||
|  |             if ((evt.GetModifiers() & wxMOD_CONTROL) != 0) { | ||||||
|  |                 switch (evt.GetKeyCode()) { | ||||||
|  |                 case '1': { m_main_frame->select_tab(0); break; } | ||||||
|  |                 case '2': { m_main_frame->select_tab(1); break; } | ||||||
|  |                 case '3': { m_main_frame->select_tab(2); break; } | ||||||
|  |                 case '4': { m_main_frame->select_tab(3); break; } | ||||||
|  | #ifdef __APPLE__ | ||||||
|  |                 case 'f': | ||||||
|  | #else /* __APPLE__ */ | ||||||
|  |                 case WXK_CONTROL_F: | ||||||
|  | #endif /* __APPLE__ */ | ||||||
|  |                 case 'F': { m_main_frame->plater()->search(false); break; } | ||||||
|  |                 default:break; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         if (evt.IsShown()) { | ||||||
|  |             if (m_tabpanel != nullptr) | ||||||
|  |                 m_tabpanel->Bind(wxEVT_KEY_UP, key_up_handker); | ||||||
|  |         } | ||||||
|  |         else { | ||||||
|  |             if (m_tabpanel != nullptr) | ||||||
|  |                 m_tabpanel->Unbind(wxEVT_KEY_UP, key_up_handker); | ||||||
|  |         } | ||||||
|  |         }); | ||||||
|  | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
| 
 | 
 | ||||||
|     // initialize layout
 |     // initialize layout
 | ||||||
|     auto sizer = new wxBoxSizer(wxVERTICAL); |     auto sizer = new wxBoxSizer(wxVERTICAL); | ||||||
|  | #if !ENABLE_LAYOUT_NO_RESTART | ||||||
|     sizer->Add(m_tabpanel, 1, wxEXPAND); |     sizer->Add(m_tabpanel, 1, wxEXPAND); | ||||||
|  | #endif // !ENABLE_LAYOUT_NO_RESTART
 | ||||||
|     sizer->SetSizeHints(this); |     sizer->SetSizeHints(this); | ||||||
|     SetSizer(sizer); |     SetSizer(sizer); | ||||||
|     Fit(); |     Fit(); | ||||||
|  | @ -1513,7 +1721,13 @@ SettingsDialog::SettingsDialog(MainFrame* mainframe) | ||||||
|     SetMinSize(min_size); |     SetMinSize(min_size); | ||||||
|     SetSize(GetMinSize()); |     SetSize(GetMinSize()); | ||||||
| #endif | #endif | ||||||
|  | //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||||
|  | //#if !ENABLE_LAYOUT_NO_RESTART
 | ||||||
|  | //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||||
|     Layout(); |     Layout(); | ||||||
|  | //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||||
|  | //#endif // !ENABLE_LAYOUT_NO_RESTART
 | ||||||
|  | //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void SettingsDialog::on_dpi_changed(const wxRect& suggested_rect) | void SettingsDialog::on_dpi_changed(const wxRect& suggested_rect) | ||||||
|  |  | ||||||
|  | @ -55,7 +55,11 @@ class SettingsDialog : public DPIDialog | ||||||
| public: | public: | ||||||
|     SettingsDialog(MainFrame* mainframe); |     SettingsDialog(MainFrame* mainframe); | ||||||
|     ~SettingsDialog() {} |     ~SettingsDialog() {} | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  |     void set_tabpanel(wxNotebook* tabpanel) { m_tabpanel = tabpanel; } | ||||||
|  | #else | ||||||
|     wxNotebook* get_tabpanel() { return m_tabpanel; } |     wxNotebook* get_tabpanel() { return m_tabpanel; } | ||||||
|  | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
| 
 | 
 | ||||||
| protected: | protected: | ||||||
|     void on_dpi_changed(const wxRect& suggested_rect) override; |     void on_dpi_changed(const wxRect& suggested_rect) override; | ||||||
|  | @ -114,11 +118,23 @@ class MainFrame : public DPIFrame | ||||||
| 
 | 
 | ||||||
|     wxFileHistory m_recent_projects; |     wxFileHistory m_recent_projects; | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  |     enum class ESettingsLayout | ||||||
|  |     { | ||||||
|  |         Unknown, | ||||||
|  |         Old, | ||||||
|  |         New, | ||||||
|  |         Dlg, | ||||||
|  |     }; | ||||||
|  |      | ||||||
|  |     ESettingsLayout m_layout{ ESettingsLayout::Unknown }; | ||||||
|  | #else | ||||||
|     enum SettingsLayout { |     enum SettingsLayout { | ||||||
|         slOld = 0, |         slOld = 0, | ||||||
|         slNew, |         slNew, | ||||||
|         slDlg, |         slDlg, | ||||||
|     }               m_layout; |     }               m_layout; | ||||||
|  | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
| 
 | 
 | ||||||
| protected: | protected: | ||||||
|     virtual void on_dpi_changed(const wxRect &suggested_rect); |     virtual void on_dpi_changed(const wxRect &suggested_rect); | ||||||
|  | @ -128,6 +144,10 @@ public: | ||||||
|     MainFrame(); |     MainFrame(); | ||||||
|     ~MainFrame() = default; |     ~MainFrame() = default; | ||||||
| 
 | 
 | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  |     void update_layout(); | ||||||
|  | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
|  | 
 | ||||||
| 	// Called when closing the application and when switching the application language.
 | 	// Called when closing the application and when switching the application language.
 | ||||||
| 	void 		shutdown(); | 	void 		shutdown(); | ||||||
| 
 | 
 | ||||||
|  | @ -169,7 +189,12 @@ public: | ||||||
| 
 | 
 | ||||||
|     Plater*             m_plater { nullptr }; |     Plater*             m_plater { nullptr }; | ||||||
|     wxNotebook*         m_tabpanel { nullptr }; |     wxNotebook*         m_tabpanel { nullptr }; | ||||||
|  | #if ENABLE_LAYOUT_NO_RESTART | ||||||
|  |     SettingsDialog      m_settings_dialog; | ||||||
|  |     wxWindow*           m_plater_page{ nullptr }; | ||||||
|  | #else | ||||||
|     SettingsDialog*     m_settings_dialog { nullptr }; |     SettingsDialog*     m_settings_dialog { nullptr }; | ||||||
|  | #endif // ENABLE_LAYOUT_NO_RESTART
 | ||||||
|     wxProgressDialog*   m_progress_dialog { nullptr }; |     wxProgressDialog*   m_progress_dialog { nullptr }; | ||||||
|     std::shared_ptr<ProgressStatusBar>  m_statusbar; |     std::shared_ptr<ProgressStatusBar>  m_statusbar; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -234,6 +234,7 @@ void PreferencesDialog::accept() | ||||||
| 	    } | 	    } | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | #if !ENABLE_LAYOUT_NO_RESTART | ||||||
| 	if (m_settings_layout_changed) { | 	if (m_settings_layout_changed) { | ||||||
| 		// the dialog needs to be destroyed before the call to recreate_gui()
 | 		// the dialog needs to be destroyed before the call to recreate_gui()
 | ||||||
| 		// or sometimes the application crashes into wxDialogBase() destructor
 | 		// or sometimes the application crashes into wxDialogBase() destructor
 | ||||||
|  | @ -255,6 +256,7 @@ void PreferencesDialog::accept() | ||||||
| 			return; | 			return; | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  | #endif // !ENABLE_LAYOUT_NO_RESTART
 | ||||||
| 
 | 
 | ||||||
| 	for (std::map<std::string, std::string>::iterator it = m_values.begin(); it != m_values.end(); ++it) | 	for (std::map<std::string, std::string>::iterator it = m_values.begin(); it != m_values.end(); ++it) | ||||||
| 		app_config->set(it->first, it->second); | 		app_config->set(it->first, it->second); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 enricoturri1966
						enricoturri1966