pub struct Menu { /* private fields */ }Expand description
A root menu that can be added to a Window on Windows and Linux and used as the app global menu on macOS.
Implementations§
Source§impl Menu
impl Menu
Sourcepub fn with_items(items: &[&dyn IsMenuItem]) -> Result<Menu, Error>
pub fn with_items(items: &[&dyn IsMenuItem]) -> Result<Menu, Error>
Creates a new menu with given items. It calls Menu::new and Menu::append_items internally.
Sourcepub fn with_id_and_items<I>(
id: I,
items: &[&dyn IsMenuItem],
) -> Result<Menu, Error>
pub fn with_id_and_items<I>( id: I, items: &[&dyn IsMenuItem], ) -> Result<Menu, Error>
Creates a new menu with the specified id and given items. It calls Menu::new and Menu::append_items internally.
Sourcepub fn append_items(&self, items: &[&dyn IsMenuItem]) -> Result<(), Error>
pub fn append_items(&self, items: &[&dyn IsMenuItem]) -> Result<(), Error>
Add menu items to the end of this menu. It calls Menu::append in a loop internally.
§Platform-spcific:
- macOS: Only
Submenucan be added to the menu
Sourcepub fn prepend_items(&self, items: &[&dyn IsMenuItem]) -> Result<(), Error>
pub fn prepend_items(&self, items: &[&dyn IsMenuItem]) -> Result<(), Error>
Add menu items to the beginning of this menu. It calls Menu::insert_items with position of 0 internally.
§Platform-spcific:
- macOS: Only
Submenucan be added to the menu
Sourcepub fn insert_items(
&self,
items: &[&dyn IsMenuItem],
position: usize,
) -> Result<(), Error>
pub fn insert_items( &self, items: &[&dyn IsMenuItem], position: usize, ) -> Result<(), Error>
Sourcepub fn remove(&self, item: &dyn IsMenuItem) -> Result<(), Error>
pub fn remove(&self, item: &dyn IsMenuItem) -> Result<(), Error>
Remove a menu item from this menu.
Sourcepub fn remove_at(&self, position: usize) -> Option<MenuItemKind>
pub fn remove_at(&self, position: usize) -> Option<MenuItemKind>
Remove the menu item at the specified position from this menu and returns it.
Sourcepub fn items(&self) -> Vec<MenuItemKind>
pub fn items(&self) -> Vec<MenuItemKind>
Returns a list of menu items that has been added to this menu.
Sourcepub fn init_for_gtk_window<W, C>(
&self,
window: &W,
container: Option<&C>,
) -> Result<(), Error>
pub fn init_for_gtk_window<W, C>( &self, window: &W, container: Option<&C>, ) -> Result<(), Error>
Adds this menu to a gtk::Window
container: this is an optional paramter to specify a container for thegtk::MenuBar, it is highly recommended to pass a container, otherwise the menubar will be added directly to the window, which is usually not the desired behavior. If using agtk::Boxas a container, it is added usingBox::pack_start(menubar, false, false, 0)then reordered to be the first child ofgtk::BoxusingBox::reorder_child(menubar, 0).
§Example:
let window = gtk::Window::builder().build();
let vbox = gtk::Box::new(gtk::Orientation::Vertical, 0);
let menu = muda::Menu::new();
// -- snip, add your menu items --
menu.init_for_gtk_window(&window, Some(&vbox));
// then proceed to add your widgets to the `vbox`§Panics:
Panics if the gtk event loop hasn’t been initialized on the thread.
Sourcepub fn remove_for_gtk_window<W>(&self, window: &W) -> Result<(), Error>
pub fn remove_for_gtk_window<W>(&self, window: &W) -> Result<(), Error>
Removes this menu from a gtk::Window
Sourcepub fn hide_for_gtk_window<W>(&self, window: &W) -> Result<(), Error>
pub fn hide_for_gtk_window<W>(&self, window: &W) -> Result<(), Error>
Hides this menu from a gtk::Window
Sourcepub fn show_for_gtk_window<W>(&self, window: &W) -> Result<(), Error>
pub fn show_for_gtk_window<W>(&self, window: &W) -> Result<(), Error>
Shows this menu on a gtk::Window
Sourcepub fn is_visible_on_gtk_window<W>(&self, window: &W) -> bool
pub fn is_visible_on_gtk_window<W>(&self, window: &W) -> bool
Returns whether this menu visible on a gtk::Window
Returns the gtk::MenuBar that is associated with this window if it exists.
This is useful to get information about the menubar for example its height.
Trait Implementations§
Source§impl ContextMenu for Menu
impl ContextMenu for Menu
gtk::Window Read moreMenu, and returns None if it wasn’t.Menu, and panics if it wasn’t.Submenu, and returns None if it wasn’t.Submenu, and panics if it wasn’t.