mirror of
				https://git.mirrors.martin98.com/https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-21 04:21:09 +08:00 
			
		
		
		
	Merged new methods for handling menus with icons,
merged "Use submenus for listing options in dropdown menu." #3905 thanks @alexrj Adapted the "Use submenus" code to sort the menus in the same order as they appear in the parameter tabs.
This commit is contained in:
		
							parent
							
								
									632bf56f29
								
							
						
					
					
						commit
						3b54b68b59
					
				| @ -36,9 +36,8 @@ use Slic3r::GUI::Tab; | |||||||
| our $have_OpenGL = eval "use Slic3r::GUI::3DScene; 1"; | our $have_OpenGL = eval "use Slic3r::GUI::3DScene; 1"; | ||||||
| our $have_LWP    = eval "use LWP::UserAgent; 1"; | our $have_LWP    = eval "use LWP::UserAgent; 1"; | ||||||
| 
 | 
 | ||||||
| use Wx 0.9901 qw(:bitmap :dialog :icon :id :misc :systemsettings :toplevelwindow | use Wx 0.9901 qw(:bitmap :dialog :icon :id :misc :systemsettings :toplevelwindow :filedialog :font); | ||||||
|     :filedialog :font); | use Wx::Event qw(EVT_IDLE EVT_COMMAND EVT_MENU); | ||||||
| use Wx::Event qw(EVT_IDLE EVT_COMMAND); |  | ||||||
| use base 'Wx::App'; | use base 'Wx::App'; | ||||||
| 
 | 
 | ||||||
| use constant FILE_WILDCARDS => { | use constant FILE_WILDCARDS => { | ||||||
| @ -404,6 +403,39 @@ sub scan_serial_ports { | |||||||
|     return grep !/Bluetooth|FireFly/, @ports; |     return grep !/Bluetooth|FireFly/, @ports; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | sub append_menu_item { | ||||||
|  |     my ($self, $menu, $string, $description, $cb, $id, $icon, $kind) = @_; | ||||||
|  |      | ||||||
|  |     $id //= &Wx::NewId(); | ||||||
|  |     my $item = Wx::MenuItem->new($menu, $id, $string, $description // '', $kind // 0); | ||||||
|  |     $self->set_menu_item_icon($item, $icon); | ||||||
|  |     $menu->Append($item); | ||||||
|  |      | ||||||
|  |     EVT_MENU($self, $id, $cb); | ||||||
|  |     return $item; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | sub append_submenu { | ||||||
|  |     my ($self, $menu, $string, $description, $submenu, $id, $icon) = @_; | ||||||
|  |      | ||||||
|  |     $id //= &Wx::NewId(); | ||||||
|  |     my $item = Wx::MenuItem->new($menu, $id, $string, $description // ''); | ||||||
|  |     $self->set_menu_item_icon($item, $icon); | ||||||
|  |     $item->SetSubMenu($submenu); | ||||||
|  |     $menu->Append($item); | ||||||
|  |      | ||||||
|  |     return $item; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | sub set_menu_item_icon { | ||||||
|  |     my ($self, $menuItem, $icon) = @_; | ||||||
|  |      | ||||||
|  |     # SetBitmap was not available on OS X before Wx 0.9927 | ||||||
|  |     if ($icon && $menuItem->can('SetBitmap')) { | ||||||
|  |         $menuItem->SetBitmap(Wx::Bitmap->new($Slic3r::var->($icon), wxBITMAP_TYPE_PNG)); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| sub save_window_pos { | sub save_window_pos { | ||||||
|     my ($self, $window, $name) = @_; |     my ($self, $window, $name) = @_; | ||||||
|      |      | ||||||
|  | |||||||
| @ -16,6 +16,18 @@ use constant ICON_MATERIAL      => 0; | |||||||
| use constant ICON_SOLIDMESH     => 1; | use constant ICON_SOLIDMESH     => 1; | ||||||
| use constant ICON_MODIFIERMESH  => 2; | use constant ICON_MODIFIERMESH  => 2; | ||||||
| 
 | 
 | ||||||
|  | my %icons = ( | ||||||
|  |     'Advanced'              => 'wand.png', | ||||||
|  |     'Extruders'             => 'funnel.png', | ||||||
|  |     'Extrusion Width'       => 'funnel.png', | ||||||
|  |     'Infill'                => 'infill.png', | ||||||
|  |     'Layers and Perimeters' => 'layers.png', | ||||||
|  |     'Skirt and brim'        => 'box.png', | ||||||
|  |     'Speed'                 => 'time.png', | ||||||
|  |     'Speed > Acceleration'  => 'time.png', | ||||||
|  |     'Support material'      => 'building.png', | ||||||
|  | ); | ||||||
|  | 
 | ||||||
| sub new { | sub new { | ||||||
|     my $class = shift; |     my $class = shift; | ||||||
|     my ($parent, %params) = @_; |     my ($parent, %params) = @_; | ||||||
| @ -39,14 +51,29 @@ sub new { | |||||||
|             wxDefaultPosition, wxDefaultSize, Wx::wxBORDER_NONE); |             wxDefaultPosition, wxDefaultSize, Wx::wxBORDER_NONE); | ||||||
|         EVT_LEFT_DOWN($btn, sub { |         EVT_LEFT_DOWN($btn, sub { | ||||||
|             my $menu = Wx::Menu->new; |             my $menu = Wx::Menu->new; | ||||||
|  |             # create category submenus | ||||||
|  |             my %categories = ();  # category => submenu | ||||||
|             foreach my $opt_key (@{$self->{options}}) { |             foreach my $opt_key (@{$self->{options}}) { | ||||||
|                 my $id = &Wx::NewId(); |                 if (my $cat = $Slic3r::Config::Options->{$opt_key}{category}) { | ||||||
|                 $menu->Append($id, $self->{option_labels}{$opt_key}); |                     $categories{$cat} //= Wx::Menu->new; | ||||||
|                 EVT_MENU($menu, $id, sub { |                 } | ||||||
|  |             } | ||||||
|  |             # append submenus to main menu | ||||||
|  |             my @categories = ('Layers and Perimeters', 'Infill', 'Support material', 'Speed', 'Extruders', 'Extrusion Width', 'Advanced'); | ||||||
|  |             #foreach my $cat (sort keys %categories) { | ||||||
|  |             foreach my $cat (@categories) { | ||||||
|  |                 wxTheApp->append_submenu($menu, $cat, "", $categories{$cat}, undef, $icons{$cat}); | ||||||
|  |             } | ||||||
|  |             # append options to submenus | ||||||
|  |             foreach my $opt_key (@{$self->{options}}) { | ||||||
|  |                 my $cat = $Slic3r::Config::Options->{$opt_key}{category} or next; | ||||||
|  |                 my $cb = sub { | ||||||
|                     $self->{config}->set($opt_key, $self->{default_config}->get($opt_key)); |                     $self->{config}->set($opt_key, $self->{default_config}->get($opt_key)); | ||||||
|                     $self->update_optgroup; |                     $self->update_optgroup; | ||||||
|                     $self->{on_change}->() if $self->{on_change}; |                     $self->{on_change}->($opt_key) if $self->{on_change}; | ||||||
|                 }); |                 }; | ||||||
|  |                 wxTheApp->append_menu_item($categories{$cat}, $self->{option_labels}{$opt_key}, | ||||||
|  |                     $Slic3r::Config::Options->{$opt_key}{tooltip}, $cb); | ||||||
|             } |             } | ||||||
|             $self->PopupMenu($menu, $btn->GetPosition); |             $self->PopupMenu($menu, $btn->GetPosition); | ||||||
|             $menu->Destroy; |             $menu->Destroy; | ||||||
| @ -79,11 +106,8 @@ sub set_config { | |||||||
| 
 | 
 | ||||||
| sub set_opt_keys { | sub set_opt_keys { | ||||||
|     my ($self, $opt_keys) = @_; |     my ($self, $opt_keys) = @_; | ||||||
|      |  | ||||||
|     # sort options by category+label |     # sort options by category+label | ||||||
|     $self->{option_labels} = { |     $self->{option_labels} = { map { $_ => $Slic3r::Config::Options->{$_}{full_label} // $Slic3r::Config::Options->{$_}{label} } @$opt_keys }; | ||||||
|         map { $_ => sprintf('%s > %s', $Slic3r::Config::Options->{$_}{category}, $Slic3r::Config::Options->{$_}{full_label} // $Slic3r::Config::Options->{$_}{label}) } @$opt_keys |  | ||||||
|     }; |  | ||||||
|     $self->{options} = [ sort { $self->{option_labels}{$a} cmp $self->{option_labels}{$b} } @$opt_keys ]; |     $self->{options} = [ sort { $self->{option_labels}{$a} cmp $self->{option_labels}{$b} } @$opt_keys ]; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										
											BIN
										
									
								
								var/wand.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								var/wand.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 570 B | 
| @ -1127,7 +1127,7 @@ PrintConfigDef::PrintConfigDef() | |||||||
| 
 | 
 | ||||||
|     def = this->add("seam_position", coEnum); |     def = this->add("seam_position", coEnum); | ||||||
|     def->label = "Seam position"; |     def->label = "Seam position"; | ||||||
|     def->category = "Layers and perimeters"; |     def->category = "Layers and Perimeters"; | ||||||
|     def->tooltip = "Position of perimeters starting points."; |     def->tooltip = "Position of perimeters starting points."; | ||||||
|     def->cli = "seam-position=s"; |     def->cli = "seam-position=s"; | ||||||
|     def->enum_keys_map = ConfigOptionEnum<SeamPosition>::get_enum_values(); |     def->enum_keys_map = ConfigOptionEnum<SeamPosition>::get_enum_values(); | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 bubnikv
						bubnikv