mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 02:01:12 -06:00 
			
		
		
		
	Added separate icon for the SLA printer presets
DoubleSlider: + fixed bug with un-hidden tooltip when OneLayerLock is on + MultiAsSingle mode : Show context menu on Cog icon after L/RButtonClick
This commit is contained in:
		
							parent
							
								
									b8c898bf40
								
							
						
					
					
						commit
						10ade4192c
					
				
					 6 changed files with 86 additions and 16 deletions
				
			
		
							
								
								
									
										14
									
								
								resources/icons/sla_printer.svg
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								resources/icons/sla_printer.svg
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,14 @@ | |||
| <?xml version="1.0" encoding="utf-8"?> | ||||
| <!-- Generator: Adobe Illustrator 24.0.3, SVG Export Plug-In . SVG Version: 6.00 Build 0)  --> | ||||
| <svg version="1.0" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" | ||||
| 	 viewBox="0 0 16 16" enable-background="new 0 0 16 16" xml:space="preserve"> | ||||
| <g id="sla"> | ||||
| 	<rect x="3" y="11" fill="#808080" width="1" height="4"/> | ||||
| 	<rect x="12" y="11" fill="#808080" width="1" height="4"/> | ||||
| 	<rect x="7.5" y="6.5" transform="matrix(-1.836970e-16 1 -1 -1.836970e-16 19.5 3.5)" fill="#808080" width="1" height="10"/> | ||||
| 	<rect x="7.5" y="9.5" transform="matrix(-1.836970e-16 1 -1 -1.836970e-16 22.5 6.5)" fill="#808080" width="1" height="10"/> | ||||
| 	<rect x="10.5" y="11.5" transform="matrix(-1.836970e-16 1 -1 -1.836970e-16 24.5 1.5)" fill="#808080" width="2" height="3"/> | ||||
| 	<rect x="3.5" y="11.5" transform="matrix(-1.836970e-16 1 -1 -1.836970e-16 17.5 8.5)" fill="#808080" width="2" height="3"/> | ||||
| 	<rect x="3" y="1" fill="#ED6B21" width="10" height="10"/> | ||||
| </g> | ||||
| </svg> | ||||
| After Width: | Height: | Size: 1 KiB | 
							
								
								
									
										14
									
								
								resources/icons/white/sla_printer.svg
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								resources/icons/white/sla_printer.svg
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,14 @@ | |||
| <?xml version="1.0" encoding="utf-8"?> | ||||
| <!-- Generator: Adobe Illustrator 24.0.3, SVG Export Plug-In . SVG Version: 6.00 Build 0)  --> | ||||
| <svg version="1.0" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" | ||||
| 	 viewBox="0 0 16 16" enable-background="new 0 0 16 16" xml:space="preserve"> | ||||
| <g id="sla"> | ||||
| 	<rect x="3" y="11" fill="#FFFFFF" width="1" height="4"/> | ||||
| 	<rect x="12" y="11" fill="#FFFFFF" width="1" height="4"/> | ||||
| 	<rect x="7.5" y="6.5" transform="matrix(-1.836970e-16 1 -1 -1.836970e-16 19.5 3.5)" fill="#FFFFFF" width="1" height="10"/> | ||||
| 	<rect x="7.5" y="9.5" transform="matrix(-1.836970e-16 1 -1 -1.836970e-16 22.5 6.5)" fill="#FFFFFF" width="1" height="10"/> | ||||
| 	<rect x="10.5" y="11.5" transform="matrix(-1.836970e-16 1 -1 -1.836970e-16 24.5 1.5)" fill="#FFFFFF" width="2" height="3"/> | ||||
| 	<rect x="3.5" y="11.5" transform="matrix(-1.836970e-16 1 -1 -1.836970e-16 17.5 8.5)" fill="#FFFFFF" width="2" height="3"/> | ||||
| 	<rect x="3" y="1" fill="#ED6B21" width="10" height="10"/> | ||||
| </g> | ||||
| </svg> | ||||
| After Width: | Height: | Size: 1 KiB | 
|  | @ -1032,7 +1032,11 @@ void Control::OnMotion(wxMouseEvent& event) | |||
|     const wxPoint pos = event.GetLogicalPosition(wxClientDC(this)); | ||||
|     int tick = -1; | ||||
| 
 | ||||
|     if (!m_is_left_down && !m_is_one_layer) | ||||
|     /* Note: Checking "!m_is_one_layer" is commented now because of 
 | ||||
|      * it looks like unnecessary and cause a tooltip "One layer" showing when OneLayerLock is on | ||||
|      * #ysFIXME : Delete it after testing | ||||
|      *  */ | ||||
|     if (!m_is_left_down/* && !m_is_one_layer*/)  | ||||
|     { | ||||
|         if (is_point_in_rect(pos, m_rect_one_layer_icon)) | ||||
|             m_focus = fiOneLayerIcon; | ||||
|  | @ -1166,6 +1170,9 @@ void Control::OnLeftUp(wxMouseEvent& event) | |||
|         add_current_tick(); | ||||
|         break; | ||||
|     case maCogIconClick : | ||||
|         if (m_mode == t_mode::MultiAsSingle) | ||||
|             show_cog_icon_context_menu(); | ||||
|         else | ||||
|             jump_to_print_z(); | ||||
|         break; | ||||
|     case maOneLayerIconClick: | ||||
|  |  | |||
|  | @ -703,7 +703,7 @@ Field* ConfigOptionsGroup::get_fieldc(const t_config_option_key& opt_key, int op | |||
| void ogStaticText::SetText(const wxString& value, bool wrap/* = true*/) | ||||
| { | ||||
| 	SetLabel(value); | ||||
|     if (wrap) Wrap(40 * wxGetApp().em_unit()); | ||||
|     if (wrap) Wrap(60 * wxGetApp().em_unit()); | ||||
| 	GetParent()->Layout(); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -1061,7 +1061,15 @@ void PresetCollection::update_plater_ui(GUI::PresetComboBox *ui) | |||
|         const Preset &preset = this->m_presets[i]; | ||||
|         if (! preset.is_visible || (! preset.is_compatible && i != m_idx_selected)) | ||||
|             continue; | ||||
| 
 | ||||
|         std::string   bitmap_key = ""; | ||||
|         // !!! Temporary solution, till refactoring: create and use "sla_printer" icon instead of m_bitmap_main_frame
 | ||||
|         wxBitmap main_bmp = m_bitmap_main_frame ? *m_bitmap_main_frame : wxNullBitmap; | ||||
|         if (m_type == Preset::TYPE_PRINTER && preset.printer_technology()==ptSLA ) { | ||||
|             bitmap_key = "sla_printer"; | ||||
|             main_bmp = create_scaled_bitmap("sla_printer"); | ||||
|         } | ||||
| 
 | ||||
|         // If the filament preset is not compatible and there is a "red flag" icon loaded, show it left
 | ||||
|         // to the filament color image.
 | ||||
|         if (wide_icons) | ||||
|  | @ -1076,7 +1084,7 @@ void PresetCollection::update_plater_ui(GUI::PresetComboBox *ui) | |||
|                 bmps.emplace_back(preset.is_compatible ? m_bitmap_cache->mkclear(icon_width, icon_height) : *m_bitmap_incompatible); | ||||
|             // Paint the color bars.
 | ||||
|             bmps.emplace_back(m_bitmap_cache->mkclear(thin_space_icon_width, icon_height)); | ||||
|             bmps.emplace_back(*m_bitmap_main_frame); | ||||
|             bmps.emplace_back(main_bmp); | ||||
|             // Paint a lock at the system presets.
 | ||||
|             bmps.emplace_back(m_bitmap_cache->mkclear(wide_space_icon_width, icon_height)); | ||||
|             bmps.emplace_back((preset.is_system || preset.is_default) ? *m_bitmap_lock : m_bitmap_cache->mkclear(icon_width, icon_height)); | ||||
|  | @ -1086,7 +1094,7 @@ void PresetCollection::update_plater_ui(GUI::PresetComboBox *ui) | |||
|         const std::string name = preset.alias.empty() ? preset.name : preset.alias; | ||||
|         if (preset.is_default || preset.is_system) { | ||||
|             ui->Append(wxString::FromUTF8((/*preset.*/name + (preset.is_dirty ? g_suffix_modified : "")).c_str()), | ||||
|                 (bmp == 0) ? (m_bitmap_main_frame ? *m_bitmap_main_frame : wxNullBitmap) : *bmp); | ||||
|                 (bmp == 0) ? main_bmp : *bmp); | ||||
|             if (i == m_idx_selected || | ||||
|                 // just in case: mark selected_preset_item as a first added element
 | ||||
|                 selected_preset_item == INT_MAX) { | ||||
|  | @ -1116,13 +1124,13 @@ void PresetCollection::update_plater_ui(GUI::PresetComboBox *ui) | |||
|                 selected_preset_item = ui->GetCount() - 1; | ||||
|         } | ||||
|     } | ||||
|     if (m_type == Preset::TYPE_PRINTER) { | ||||
|     if (m_type == Preset::TYPE_PRINTER || m_type == Preset::TYPE_SLA_MATERIAL) { | ||||
|         std::string   bitmap_key = ""; | ||||
|         // If the filament preset is not compatible and there is a "red flag" icon loaded, show it left
 | ||||
|         // to the filament color image.
 | ||||
|         if (wide_icons) | ||||
|             bitmap_key += "wide,"; | ||||
|         bitmap_key += "add_printer"; | ||||
|         bitmap_key += "edit_preset_list"; | ||||
|         wxBitmap     *bmp = m_bitmap_cache->find(bitmap_key); | ||||
|         if (bmp == nullptr) { | ||||
|             // Create the bitmap with color bars.
 | ||||
|  | @ -1135,12 +1143,14 @@ void PresetCollection::update_plater_ui(GUI::PresetComboBox *ui) | |||
|             bmps.emplace_back(*m_bitmap_main_frame); | ||||
|             // Paint a lock at the system presets.
 | ||||
|             bmps.emplace_back(m_bitmap_cache->mkclear(wide_space_icon_width, icon_height)); | ||||
|             bmps.emplace_back(m_bitmap_add ? *m_bitmap_add : wxNullBitmap); | ||||
| //            bmps.emplace_back(m_bitmap_add ? *m_bitmap_add : wxNullBitmap);
 | ||||
|             bmps.emplace_back(create_scaled_bitmap("edit_uni")); | ||||
|             bmp = m_bitmap_cache->insert(bitmap_key, bmps); | ||||
|         } | ||||
|         ui->set_label_marker(ui->Append(PresetCollection::separator(L("Add a new printer")), *bmp), GUI::PresetComboBox::LABEL_ITEM_WIZARD_PRINTERS); | ||||
|     } else if (m_type == Preset::TYPE_SLA_MATERIAL) { | ||||
|         ui->set_label_marker(ui->Append(PresetCollection::separator(L("Add/Remove materials")), wxNullBitmap), GUI::PresetComboBox::LABEL_ITEM_WIZARD_MATERIALS); | ||||
|         if (m_type == Preset::TYPE_SLA_MATERIAL) | ||||
|             ui->set_label_marker(ui->Append(PresetCollection::separator(L("Add/Remove materials")), *bmp), GUI::PresetComboBox::LABEL_ITEM_WIZARD_MATERIALS); | ||||
|         else | ||||
|             ui->set_label_marker(ui->Append(PresetCollection::separator(L("Add/Remove printers")), *bmp), GUI::PresetComboBox::LABEL_ITEM_WIZARD_PRINTERS); | ||||
|     } | ||||
| 
 | ||||
|     /* But, if selected_preset_item is still equal to INT_MAX, it means that
 | ||||
|  | @ -1185,6 +1195,14 @@ size_t PresetCollection::update_tab_ui(wxBitmapComboBox *ui, bool show_incompati | |||
|         if (! preset.is_visible || (! show_incompatible && ! preset.is_compatible && i != m_idx_selected)) | ||||
|             continue; | ||||
|         std::string   bitmap_key = "tab"; | ||||
| 
 | ||||
|         // !!! Temporary solution, till refactoring: create and use "sla_printer" icon instead of m_bitmap_main_frame
 | ||||
|         wxBitmap main_bmp = m_bitmap_main_frame ? *m_bitmap_main_frame : wxNullBitmap; | ||||
|         if (m_type == Preset::TYPE_PRINTER && preset.printer_technology() == ptSLA) { | ||||
|             bitmap_key = "sla_printer"; | ||||
|             main_bmp = create_scaled_bitmap("sla_printer"); | ||||
|         } | ||||
| 
 | ||||
|         bitmap_key += preset.is_compatible ? ",cmpt" : ",ncmpt"; | ||||
|         bitmap_key += (preset.is_system || preset.is_default) ? ",syst" : ",nsyst"; | ||||
|         wxBitmap     *bmp = m_bitmap_cache->find(bitmap_key); | ||||
|  | @ -1192,7 +1210,7 @@ size_t PresetCollection::update_tab_ui(wxBitmapComboBox *ui, bool show_incompati | |||
|             // Create the bitmap with color bars.
 | ||||
|             std::vector<wxBitmap> bmps; | ||||
|             const wxBitmap* tmp_bmp = preset.is_compatible ? m_bitmap_compatible : m_bitmap_incompatible; | ||||
|             bmps.emplace_back((tmp_bmp == 0) ? (m_bitmap_main_frame ? *m_bitmap_main_frame : wxNullBitmap) : *tmp_bmp); | ||||
|             bmps.emplace_back((tmp_bmp == 0) ? main_bmp : *tmp_bmp); | ||||
|             // Paint a lock at the system presets.
 | ||||
|             bmps.emplace_back((preset.is_system || preset.is_default) ? *m_bitmap_lock : m_bitmap_cache->mkclear(icon_width, icon_height)); | ||||
|             bmp = m_bitmap_cache->insert(bitmap_key, bmps); | ||||
|  | @ -1200,7 +1218,7 @@ size_t PresetCollection::update_tab_ui(wxBitmapComboBox *ui, bool show_incompati | |||
| 
 | ||||
|         if (preset.is_default || preset.is_system) { | ||||
|             ui->Append(wxString::FromUTF8((preset.name + (preset.is_dirty ? g_suffix_modified : "")).c_str()), | ||||
|                 (bmp == 0) ? (m_bitmap_main_frame ? *m_bitmap_main_frame : wxNullBitmap) : *bmp); | ||||
|                 (bmp == 0) ? main_bmp : *bmp); | ||||
|             if (i == m_idx_selected || | ||||
|                 // just in case: mark selected_preset_item as a first added element
 | ||||
|                 selected_preset_item == INT_MAX) | ||||
|  | @ -1227,12 +1245,13 @@ size_t PresetCollection::update_tab_ui(wxBitmapComboBox *ui, bool show_incompati | |||
|         } | ||||
|     } | ||||
|     if (m_type == Preset::TYPE_PRINTER) { | ||||
|         wxBitmap *bmp = m_bitmap_cache->find("add_printer_tab"); | ||||
|         wxBitmap *bmp = m_bitmap_cache->find("edit_printer_list"); | ||||
|         if (bmp == nullptr) { | ||||
|             // Create the bitmap with color bars.
 | ||||
|             std::vector<wxBitmap> bmps; | ||||
|             bmps.emplace_back(*m_bitmap_main_frame); | ||||
|             bmps.emplace_back(m_bitmap_add ? *m_bitmap_add : wxNullBitmap); | ||||
| //            bmps.emplace_back(m_bitmap_add ? *m_bitmap_add : wxNullBitmap);
 | ||||
|             bmps.emplace_back(create_scaled_bitmap("edit_uni")); | ||||
|             bmp = m_bitmap_cache->insert("add_printer_tab", bmps); | ||||
|         } | ||||
|         ui->Append(PresetCollection::separator("Add a new printer"), *bmp); | ||||
|  |  | |||
|  | @ -1678,7 +1678,23 @@ void PresetBundle::update_plater_filament_ui(unsigned int idx_extruder, GUI::Pre | |||
| 		} | ||||
| 	} | ||||
| 
 | ||||
|     ui->set_label_marker(ui->Append(PresetCollection::separator(L("Add/Remove filaments")), wxNullBitmap), GUI::PresetComboBox::LABEL_ITEM_WIZARD_FILAMENTS); | ||||
|     std::string   bitmap_key = ""; | ||||
|     if (wide_icons) | ||||
|         bitmap_key += "wide,"; | ||||
|     bitmap_key += "edit_preset_list"; | ||||
|     wxBitmap* bmp = m_bitmapCache->find(bitmap_key); | ||||
|     if (bmp == nullptr) { | ||||
|         // Create the bitmap with color bars.
 | ||||
|         std::vector<wxBitmap> bmps; | ||||
|         if (wide_icons) | ||||
|             // Paint a red flag for incompatible presets.
 | ||||
|             bmps.emplace_back(m_bitmapCache->mkclear(normal_icon_width, icon_height)); | ||||
|         // Paint the color bars + a lock at the system presets.
 | ||||
|         bmps.emplace_back(m_bitmapCache->mkclear(wide_icon_width+space_icon_width, icon_height)); | ||||
|         bmps.emplace_back(create_scaled_bitmap("edit_uni")); | ||||
|         bmp = m_bitmapCache->insert(bitmap_key, bmps); | ||||
|     } | ||||
|     ui->set_label_marker(ui->Append(PresetCollection::separator(L("Add/Remove filaments")), *bmp), GUI::PresetComboBox::LABEL_ITEM_WIZARD_FILAMENTS); | ||||
| 
 | ||||
|     /* But, if selected_preset_item is still equal to INT_MAX, it means that
 | ||||
|      * there is no presets added to the list. | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 YuSanka
						YuSanka