Merge pull request #61102 from okla/3.x
[3.x] Make various improvements to OptionButton
This commit is contained in:
commit
281c5c9a56
3 changed files with 33 additions and 16 deletions
|
@ -97,7 +97,7 @@
|
||||||
<method name="get_selected_id" qualifiers="const">
|
<method name="get_selected_id" qualifiers="const">
|
||||||
<return type="int" />
|
<return type="int" />
|
||||||
<description>
|
<description>
|
||||||
Returns the ID of the selected item, or [code]0[/code] if no item is selected.
|
Returns the ID of the selected item, or [code]-1[/code] if no item is selected.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="get_selected_metadata" qualifiers="const">
|
<method name="get_selected_metadata" qualifiers="const">
|
||||||
|
@ -125,6 +125,7 @@
|
||||||
<argument index="0" name="idx" type="int" />
|
<argument index="0" name="idx" type="int" />
|
||||||
<description>
|
<description>
|
||||||
Selects an item by index and makes it the current item. This will work even if the item is disabled.
|
Selects an item by index and makes it the current item. This will work even if the item is disabled.
|
||||||
|
Passing [code]-1[/code] as the index deselects any currently selected item.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="set_item_disabled">
|
<method name="set_item_disabled">
|
||||||
|
|
|
@ -32,6 +32,8 @@
|
||||||
#include "core/os/input.h"
|
#include "core/os/input.h"
|
||||||
#include "core/print_string.h"
|
#include "core/print_string.h"
|
||||||
|
|
||||||
|
static const int NONE_SELECTED = -1;
|
||||||
|
|
||||||
Size2 OptionButton::get_minimum_size() const {
|
Size2 OptionButton::get_minimum_size() const {
|
||||||
Size2 minsize = Button::get_minimum_size();
|
Size2 minsize = Button::get_minimum_size();
|
||||||
|
|
||||||
|
@ -173,6 +175,10 @@ Ref<Texture> OptionButton::get_item_icon(int p_idx) const {
|
||||||
}
|
}
|
||||||
|
|
||||||
int OptionButton::get_item_id(int p_idx) const {
|
int OptionButton::get_item_id(int p_idx) const {
|
||||||
|
if (p_idx == NONE_SELECTED) {
|
||||||
|
return NONE_SELECTED;
|
||||||
|
}
|
||||||
|
|
||||||
return popup->get_item_id(p_idx);
|
return popup->get_item_id(p_idx);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -203,17 +209,23 @@ void OptionButton::add_separator() {
|
||||||
void OptionButton::clear() {
|
void OptionButton::clear() {
|
||||||
popup->clear();
|
popup->clear();
|
||||||
set_text("");
|
set_text("");
|
||||||
current = -1;
|
current = NONE_SELECTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
void OptionButton::_select(int p_which, bool p_emit) {
|
void OptionButton::_select(int p_which, bool p_emit) {
|
||||||
if (p_which < 0) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (p_which == current) {
|
if (p_which == current) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (p_which == NONE_SELECTED) {
|
||||||
|
for (int i = 0; i < popup->get_item_count(); i++) {
|
||||||
|
popup->set_item_checked(i, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
current = NONE_SELECTED;
|
||||||
|
set_text("");
|
||||||
|
set_icon(NULL);
|
||||||
|
} else {
|
||||||
ERR_FAIL_INDEX(p_which, popup->get_item_count());
|
ERR_FAIL_INDEX(p_which, popup->get_item_count());
|
||||||
|
|
||||||
for (int i = 0; i < popup->get_item_count(); i++) {
|
for (int i = 0; i < popup->get_item_count(); i++) {
|
||||||
|
@ -223,6 +235,7 @@ void OptionButton::_select(int p_which, bool p_emit) {
|
||||||
current = p_which;
|
current = p_which;
|
||||||
set_text(popup->get_item_text(current));
|
set_text(popup->get_item_text(current));
|
||||||
set_icon(popup->get_item_icon(current));
|
set_icon(popup->get_item_icon(current));
|
||||||
|
}
|
||||||
|
|
||||||
if (is_inside_tree() && p_emit) {
|
if (is_inside_tree() && p_emit) {
|
||||||
emit_signal("item_selected", current);
|
emit_signal("item_selected", current);
|
||||||
|
@ -230,7 +243,7 @@ void OptionButton::_select(int p_which, bool p_emit) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void OptionButton::_select_int(int p_which) {
|
void OptionButton::_select_int(int p_which) {
|
||||||
if (p_which < 0 || p_which >= popup->get_item_count()) {
|
if (p_which < NONE_SELECTED || p_which >= popup->get_item_count()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
_select(p_which, false);
|
_select(p_which, false);
|
||||||
|
@ -261,6 +274,9 @@ Variant OptionButton::get_selected_metadata() const {
|
||||||
|
|
||||||
void OptionButton::remove_item(int p_idx) {
|
void OptionButton::remove_item(int p_idx) {
|
||||||
popup->remove_item(p_idx);
|
popup->remove_item(p_idx);
|
||||||
|
if (current == p_idx) {
|
||||||
|
_select(NONE_SELECTED);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
PopupMenu *OptionButton::get_popup() const {
|
PopupMenu *OptionButton::get_popup() const {
|
||||||
|
|
|
@ -666,7 +666,7 @@ void PopupMenu::_notification(int p_what) {
|
||||||
#define ITEM_SETUP_WITH_ACCEL(p_label, p_id, p_accel) \
|
#define ITEM_SETUP_WITH_ACCEL(p_label, p_id, p_accel) \
|
||||||
item.text = p_label; \
|
item.text = p_label; \
|
||||||
item.xl_text = tr(p_label); \
|
item.xl_text = tr(p_label); \
|
||||||
item.id = p_id == -1 ? items.size() : p_id; \
|
item.id = p_id == -1 ? items.size() - 1 : p_id; \
|
||||||
item.accel = p_accel;
|
item.accel = p_accel;
|
||||||
|
|
||||||
void PopupMenu::add_item(const String &p_label, int p_id, uint32_t p_accel) {
|
void PopupMenu::add_item(const String &p_label, int p_id, uint32_t p_accel) {
|
||||||
|
@ -739,7 +739,7 @@ void PopupMenu::add_multistate_item(const String &p_label, int p_max_states, int
|
||||||
_ref_shortcut(p_shortcut); \
|
_ref_shortcut(p_shortcut); \
|
||||||
item.text = p_shortcut->get_name(); \
|
item.text = p_shortcut->get_name(); \
|
||||||
item.xl_text = tr(item.text); \
|
item.xl_text = tr(item.text); \
|
||||||
item.id = p_id == -1 ? items.size() : p_id; \
|
item.id = p_id == -1 ? items.size() - 1 : p_id; \
|
||||||
item.shortcut = p_shortcut; \
|
item.shortcut = p_shortcut; \
|
||||||
item.shortcut_is_global = p_global;
|
item.shortcut_is_global = p_global;
|
||||||
|
|
||||||
|
@ -802,7 +802,7 @@ void PopupMenu::add_submenu_item(const String &p_label, const String &p_submenu,
|
||||||
Item item;
|
Item item;
|
||||||
item.text = p_label;
|
item.text = p_label;
|
||||||
item.xl_text = tr(p_label);
|
item.xl_text = tr(p_label);
|
||||||
item.id = p_id == -1 ? items.size() : p_id;
|
item.id = p_id == -1 ? items.size() - 1 : p_id;
|
||||||
item.submenu = p_submenu;
|
item.submenu = p_submenu;
|
||||||
items.push_back(item);
|
items.push_back(item);
|
||||||
update();
|
update();
|
||||||
|
|
Loading…
Reference in a new issue