PopupMenu displays a list of options. PopupMenu is the typical Control that displays a list of options. They are popular in toolbars or context menus. Adds a new checkable item with text [code]label[/code]. An [code]id[/code] can optionally be provided, as well as an accelerator ([code]accel[/code]). If no [code]id[/code] is provided, one will be created from the index. [b]Note:[/b] Checkable items just display a checkmark, but don't have any built-in checking behavior and must be checked/unchecked manually. Adds a new checkable item with text [code]label[/code] and icon [code]texture[/code]. An [code]id[/code] can optionally be provided, as well as an accelerator ([code]accel[/code]). If no [code]id[/code] is provided, one will be created from the index. [b]Note:[/b] Checkable items just display a checkmark, but don't have any built-in checking behavior and must be checked/unchecked manually. Adds a new item with text [code]label[/code] and icon [code]texture[/code]. An [code]id[/code] can optionally be provided, as well as an accelerator keybinding ([code]accel[/code]). If no [code]id[/code] is provided, one will be created from the index. Adds a new item with text [code]label[/code]. An [code]id[/code] can optionally be provided, as well as an accelerator keybinding ([code]accel[/code]). If no [code]id[/code] is provided, one will be created from the index. The same as [method add_check_item], but the inserted item will look as a radio button. [b]Note:[/b] This is purely cosmetic; you must add the logic for checking/unchecking items in radio groups. Adds a separator between items. Separators also occupy an index. Adds an item with a submenu. The submenu is the name of a child PopupMenu node that would be shown when the item is clicked. An id can optionally be provided, but if is isn't provided, one will be created from the index. Clear the popup menu, in effect removing all items. Returns the accelerator of the item at index [code]idx[/code]. Accelerators are special combinations of keys that activate the item, no matter which control is focused. Returns the amount of items. Returns the icon of the item at index [code]idx[/code]. Returns the id of the item at index [code]idx[/code]. Finds and return the index of the item containing a given [code]id[/code]. Returns the metadata of an item, which might be of any type. You can set it with [method set_item_metadata], which provides a simple way of assigning context data to items. Returns the submenu name of the item at index [code]idx[/code]. Returns the text of the item at index [code]idx[/code]. Returns [code]true[/code] if the item at index [code]idx[/code] is checkable in some way, i.e. if it has a checkbox or radio button. [b]Note:[/b] Checkable items just display a checkmark or radio button, but don't have any built-in checking behavior and must be checked/unchecked manually. Returns [code]true[/code] if the item at index [code]idx[/code] is checked. Returns [code]true[/code] if the item at index [code]idx[/code] is disabled. When it is disabled it can't be selected, or its action invoked. Returns [code]true[/code] if the item at index [code]idx[/code] has radio-button-style checkability. [b]Note:[/b] This is purely cosmetic; you must add the logic for checking/unchecking items in radio groups. Returns [code]true[/code] if the item is a separator. If it is, it will be displayed as a line. Removes the item at index [code]idx[/code] from the menu. [b]Note:[/b] The indices of items after the removed item will be shifted by one. Sets the accelerator of the item at index [code]idx[/code]. Accelerators are special combinations of keys that activate the item, no matter which control is focused. Sets whether the item at index [code]idx[/code] has a checkbox. [b]Note:[/b] Checkable items just display a checkmark, but don't have any built-in checking behavior and must be checked/unchecked manually. The same as [method set_item_as_checkable] but placing a radio button in case of enabling. If used for disabling, it's the same. Remember this is just cosmetic and you have to add the logic for checking/unchecking items in radio groups. Mark the item at index [code]idx[/code] as a separator, which means that it would be displayed as a line. Sets the checkstate status of the item at index [code]idx[/code]. Sets whether the item at index [code]idx[/code] is disabled or not. When it is disabled, it can't be selected and its action can't be invoked. Sets the [code]id[/code] of the item at index [code]idx[/code]. Sets the metadata of an item, which may be of any type. You can later get it with [method get_item_metadata], which provides a simple way of assigning context data to items. Sets the submenu of the item at index [code]idx[/code]. The submenu is the name of a child PopupMenu node that would be shown when the item is clicked. Sets the text of the item at index [code]idx[/code]. If [code]true[/code], allows to navigate [PopupMenu] with letter keys. Default value: [code]false[/code]. Sets the delay time for the submenu item to popup on mouse hovering. If the popup menu is added as a child of another (acting as a submenu), it will inherit the delay time of the parent menu item. Default value: [code]0.3[/code] seconds. Emitted when user navigated to an item of some [code]id[/code] using [code]ui_up[/code] or [code]ui_down[/code] action. Emitted when an item of some [code]id[/code] is pressed or its accelerator is activated. Emitted when an item of some [code]index[/code] is pressed or its accelerator is activated.