mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 01:31:14 -06:00 
			
		
		
		
	ConfigWizard: Cap width on large screens
This commit is contained in:
		
							parent
							
								
									5a2a39c3ab
								
							
						
					
					
						commit
						94dc86ec72
					
				
					 2 changed files with 33 additions and 33 deletions
				
			
		|  | @ -1,6 +1,7 @@ | ||||||
| #include "ConfigWizard_private.hpp" | #include "ConfigWizard_private.hpp" | ||||||
| 
 | 
 | ||||||
| #include <algorithm> | #include <algorithm> | ||||||
|  | #include <numeric> | ||||||
| #include <utility> | #include <utility> | ||||||
| #include <unordered_map> | #include <unordered_map> | ||||||
| #include <boost/format.hpp> | #include <boost/format.hpp> | ||||||
|  | @ -58,6 +59,7 @@ wxDEFINE_EVENT(EVT_PRINTER_PICK, PrinterPickerEvent); | ||||||
| PrinterPicker::PrinterPicker(wxWindow *parent, const VendorProfile &vendor, wxString title, size_t max_cols, const AppConfig &appconfig_vendors, const ModelFilter &filter) | PrinterPicker::PrinterPicker(wxWindow *parent, const VendorProfile &vendor, wxString title, size_t max_cols, const AppConfig &appconfig_vendors, const ModelFilter &filter) | ||||||
|     : wxPanel(parent) |     : wxPanel(parent) | ||||||
|     , vendor_id(vendor.id) |     , vendor_id(vendor.id) | ||||||
|  |     , width(0) | ||||||
| { | { | ||||||
|     const auto &models = vendor.models; |     const auto &models = vendor.models; | ||||||
| 
 | 
 | ||||||
|  | @ -73,6 +75,9 @@ PrinterPicker::PrinterPicker(wxWindow *parent, const VendorProfile &vendor, wxSt | ||||||
|     std::vector<wxStaticBitmap*> bitmaps; |     std::vector<wxStaticBitmap*> bitmaps; | ||||||
|     std::vector<wxPanel*> variants_panels; |     std::vector<wxPanel*> variants_panels; | ||||||
| 
 | 
 | ||||||
|  |     int max_row_width = 0; | ||||||
|  |     int current_row_width = 0; | ||||||
|  | 
 | ||||||
|     for (const auto &model : models) { |     for (const auto &model : models) { | ||||||
|         if (! filter(model)) { continue; } |         if (! filter(model)) { continue; } | ||||||
| 
 | 
 | ||||||
|  | @ -80,7 +85,15 @@ PrinterPicker::PrinterPicker(wxWindow *parent, const VendorProfile &vendor, wxSt | ||||||
| 
 | 
 | ||||||
|         auto *title = new wxStaticText(this, wxID_ANY, model.name, wxDefaultPosition, wxDefaultSize, wxALIGN_LEFT); |         auto *title = new wxStaticText(this, wxID_ANY, model.name, wxDefaultPosition, wxDefaultSize, wxALIGN_LEFT); | ||||||
|         title->SetFont(font_name); |         title->SetFont(font_name); | ||||||
|         title->Wrap(std::max((int)MODEL_MIN_WRAP, bitmap.GetWidth())); |         const int wrap_width = std::max((int)MODEL_MIN_WRAP, bitmap.GetWidth()); | ||||||
|  |         title->Wrap(wrap_width); | ||||||
|  | 
 | ||||||
|  |         current_row_width += wrap_width; | ||||||
|  |         if (titles.size() % max_cols == max_cols - 1) { | ||||||
|  |             max_row_width = std::max(max_row_width, current_row_width); | ||||||
|  |             current_row_width = 0; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         titles.push_back(title); |         titles.push_back(title); | ||||||
| 
 | 
 | ||||||
|         auto *bitmap_widget = new wxStaticBitmap(this, wxID_ANY, bitmap); |         auto *bitmap_widget = new wxStaticBitmap(this, wxID_ANY, bitmap); | ||||||
|  | @ -120,6 +133,8 @@ PrinterPicker::PrinterPicker(wxWindow *parent, const VendorProfile &vendor, wxSt | ||||||
|         variants_panels.push_back(variants_panel); |         variants_panels.push_back(variants_panel); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     width = std::max(max_row_width, current_row_width); | ||||||
|  | 
 | ||||||
|     const size_t cols = std::min(max_cols, titles.size()); |     const size_t cols = std::min(max_cols, titles.size()); | ||||||
| 
 | 
 | ||||||
|     auto *printer_grid = new wxFlexGridSizer(cols, 0, 20); |     auto *printer_grid = new wxFlexGridSizer(cols, 0, 20); | ||||||
|  | @ -332,6 +347,12 @@ void PagePrinters::select_all(bool select) | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | int PagePrinters::get_width() const | ||||||
|  | { | ||||||
|  |     return std::accumulate(printer_pickers.begin(), printer_pickers.end(), 0, | ||||||
|  |         [](int acc, const PrinterPicker *picker) { return std::max(acc, picker->get_width()); }); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| const char *PageCustom::default_profile_name = "My Settings"; | const char *PageCustom::default_profile_name = "My Settings"; | ||||||
| 
 | 
 | ||||||
|  | @ -1019,27 +1040,6 @@ ConfigWizard::ConfigWizard(wxWindow *parent, RunReason reason) | ||||||
|     // We can now enable scrolling on hscroll
 |     // We can now enable scrolling on hscroll
 | ||||||
|     p->hscroll->SetScrollRate(30, 30); |     p->hscroll->SetScrollRate(30, 30); | ||||||
| 
 | 
 | ||||||
|     // XXX: set size right away on windows, create util function
 |  | ||||||
|     // Bind(wxEVT_CREATE, [this](wxWindowCreateEvent &event) {
 |  | ||||||
|     //     CallAfter([this]() {
 |  | ||||||
|     //         // Clamp the Wizard size based on screen dimensions
 |  | ||||||
|     //         // Note: Using EVT_SHOW + CallAfter because any sooner than this
 |  | ||||||
|     //         // on some Linux boxes wxDisplay::GetFromWindow() returns 0 no matter what.
 |  | ||||||
| 
 |  | ||||||
|     //         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);
 |  | ||||||
| 
 |  | ||||||
|     //         SetSize(window_rect);
 |  | ||||||
|     //     });
 |  | ||||||
|     // });
 |  | ||||||
| 
 |  | ||||||
|     on_window_geometry(this, [this]() { |     on_window_geometry(this, [this]() { | ||||||
|         // Clamp the Wizard size based on screen dimensions
 |         // Clamp the Wizard size based on screen dimensions
 | ||||||
| 
 | 
 | ||||||
|  | @ -1053,6 +1053,12 @@ ConfigWizard::ConfigWizard(wxWindow *parent, RunReason reason) | ||||||
|             9*disp_rect.width / 10, |             9*disp_rect.width / 10, | ||||||
|             9*disp_rect.height / 10); |             9*disp_rect.height / 10); | ||||||
| 
 | 
 | ||||||
|  |         const int width_hint = p->index->GetSize().GetWidth() + p->page_fff->get_width() + 300;    // 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); |         SetSize(window_rect); | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -67,6 +67,10 @@ struct PrinterPicker: wxPanel | ||||||
|     void select_all(bool select); |     void select_all(bool select); | ||||||
|     void select_one(size_t i, bool select); |     void select_one(size_t i, bool select); | ||||||
|     void on_checkbox(const Checkbox *cbox, bool checked); |     void on_checkbox(const Checkbox *cbox, bool checked); | ||||||
|  | 
 | ||||||
|  |     int get_width() const { return width; } | ||||||
|  | private: | ||||||
|  |     int width; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| struct ConfigWizardPage: wxPanel | struct ConfigWizardPage: wxPanel | ||||||
|  | @ -116,6 +120,7 @@ struct PagePrinters: ConfigWizardPage | ||||||
|     PagePrinters(ConfigWizard *parent, wxString title, wxString shortname, const VendorProfile &vendor, unsigned indent, Technology technology); |     PagePrinters(ConfigWizard *parent, wxString title, wxString shortname, const VendorProfile &vendor, unsigned indent, Technology technology); | ||||||
| 
 | 
 | ||||||
|     void select_all(bool select); |     void select_all(bool select); | ||||||
|  |     int get_width() const; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| struct PageCustom: ConfigWizardPage | struct PageCustom: ConfigWizardPage | ||||||
|  | @ -206,23 +211,13 @@ public: | ||||||
| 
 | 
 | ||||||
|     void clear(); |     void clear(); | ||||||
| 
 | 
 | ||||||
|     // XXX
 |  | ||||||
|     // void load_items(ConfigWizardPage *firstpage);
 |  | ||||||
|     // void set_active(ConfigWizardPage *page);
 |  | ||||||
| private: | private: | ||||||
|     // enum {
 |  | ||||||
|     //  // Units in em
 |  | ||||||
|     //  MARGIN = 1,
 |  | ||||||
|     //  SPACING = 1,
 |  | ||||||
|     // };
 |  | ||||||
| 
 |  | ||||||
|     struct Item |     struct Item | ||||||
|     { |     { | ||||||
|         wxString label; |         wxString label; | ||||||
|         unsigned indent; |         unsigned indent; | ||||||
|         ConfigWizardPage *page;     // nullptr page => label-only item
 |         ConfigWizardPage *page;     // nullptr page => label-only item
 | ||||||
| 
 | 
 | ||||||
|         // bool operator==(const wxString &label) const { return this->label == label; }
 |  | ||||||
|         bool operator==(ConfigWizardPage *page) const { return this->page == page; } |         bool operator==(ConfigWizardPage *page) const { return this->page == page; } | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|  | @ -235,7 +230,6 @@ private: | ||||||
|     const wxBitmap bullet_white; |     const wxBitmap bullet_white; | ||||||
| 
 | 
 | ||||||
|     std::vector<Item> items; |     std::vector<Item> items; | ||||||
|     // std::vector<Item>::const_iterator item_active;
 |  | ||||||
|     size_t item_active; |     size_t item_active; | ||||||
|     ssize_t item_hover; |     ssize_t item_hover; | ||||||
|     size_t last_page; |     size_t last_page; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Vojtech Kral
						Vojtech Kral