[MenuBar] Store and use global menu item indices.
This commit is contained in:
parent
bf8dd73e9d
commit
a759d97a51
2 changed files with 28 additions and 19 deletions
|
@ -251,10 +251,13 @@ String MenuBar::bind_global_menu() {
|
||||||
String submenu_name = popups[i]->bind_global_menu();
|
String submenu_name = popups[i]->bind_global_menu();
|
||||||
if (!popups[i]->is_system_menu()) {
|
if (!popups[i]->is_system_menu()) {
|
||||||
int index = ds->global_menu_add_submenu_item("_main", menu_cache[i].name, submenu_name, global_start_idx + i);
|
int index = ds->global_menu_add_submenu_item("_main", menu_cache[i].name, submenu_name, global_start_idx + i);
|
||||||
|
menu_cache.write[i].global_index = index;
|
||||||
ds->global_menu_set_item_tag("_main", index, global_menu_name + "#" + itos(i));
|
ds->global_menu_set_item_tag("_main", index, global_menu_name + "#" + itos(i));
|
||||||
ds->global_menu_set_item_hidden("_main", index, menu_cache[i].hidden);
|
ds->global_menu_set_item_hidden("_main", index, menu_cache[i].hidden);
|
||||||
ds->global_menu_set_item_disabled("_main", index, menu_cache[i].disabled);
|
ds->global_menu_set_item_disabled("_main", index, menu_cache[i].disabled);
|
||||||
ds->global_menu_set_item_tooltip("_main", index, menu_cache[i].tooltip);
|
ds->global_menu_set_item_tooltip("_main", index, menu_cache[i].tooltip);
|
||||||
|
} else {
|
||||||
|
menu_cache.write[i].global_index = -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -267,12 +270,14 @@ void MenuBar::unbind_global_menu() {
|
||||||
}
|
}
|
||||||
|
|
||||||
DisplayServer *ds = DisplayServer::get_singleton();
|
DisplayServer *ds = DisplayServer::get_singleton();
|
||||||
int global_start = _find_global_start_index();
|
|
||||||
Vector<PopupMenu *> popups = _get_popups();
|
Vector<PopupMenu *> popups = _get_popups();
|
||||||
for (int i = menu_cache.size() - 1; i >= 0; i--) {
|
for (int i = menu_cache.size() - 1; i >= 0; i--) {
|
||||||
if (!popups[i]->is_system_menu()) {
|
if (!popups[i]->is_system_menu()) {
|
||||||
popups[i]->unbind_global_menu();
|
popups[i]->unbind_global_menu();
|
||||||
ds->global_menu_remove_item("_main", global_start + i);
|
if (menu_cache[i].global_index >= 0) {
|
||||||
|
ds->global_menu_remove_item("_main", menu_cache[i].global_index);
|
||||||
|
}
|
||||||
|
menu_cache.write[i].global_index = -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -300,11 +305,10 @@ void MenuBar::_notification(int p_what) {
|
||||||
case NOTIFICATION_TRANSLATION_CHANGED: {
|
case NOTIFICATION_TRANSLATION_CHANGED: {
|
||||||
DisplayServer *ds = DisplayServer::get_singleton();
|
DisplayServer *ds = DisplayServer::get_singleton();
|
||||||
bool is_global = !global_menu_name.is_empty();
|
bool is_global = !global_menu_name.is_empty();
|
||||||
int global_start = _find_global_start_index();
|
|
||||||
for (int i = 0; i < menu_cache.size(); i++) {
|
for (int i = 0; i < menu_cache.size(); i++) {
|
||||||
shape(menu_cache.write[i]);
|
shape(menu_cache.write[i]);
|
||||||
if (is_global) {
|
if (is_global && menu_cache[i].global_index >= 0) {
|
||||||
ds->global_menu_set_item_text("_main", global_start + i, atr(menu_cache[i].name));
|
ds->global_menu_set_item_text("_main", menu_cache[i].global_index, atr(menu_cache[i].name));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} break;
|
} break;
|
||||||
|
@ -505,15 +509,14 @@ void MenuBar::shape(Menu &p_menu) {
|
||||||
void MenuBar::_refresh_menu_names() {
|
void MenuBar::_refresh_menu_names() {
|
||||||
DisplayServer *ds = DisplayServer::get_singleton();
|
DisplayServer *ds = DisplayServer::get_singleton();
|
||||||
bool is_global = !global_menu_name.is_empty();
|
bool is_global = !global_menu_name.is_empty();
|
||||||
int global_start = _find_global_start_index();
|
|
||||||
|
|
||||||
Vector<PopupMenu *> popups = _get_popups();
|
Vector<PopupMenu *> popups = _get_popups();
|
||||||
for (int i = 0; i < popups.size(); i++) {
|
for (int i = 0; i < popups.size(); i++) {
|
||||||
if (!popups[i]->has_meta("_menu_name") && String(popups[i]->get_name()) != get_menu_title(i)) {
|
if (!popups[i]->has_meta("_menu_name") && String(popups[i]->get_name()) != get_menu_title(i)) {
|
||||||
menu_cache.write[i].name = popups[i]->get_name();
|
menu_cache.write[i].name = popups[i]->get_name();
|
||||||
shape(menu_cache.write[i]);
|
shape(menu_cache.write[i]);
|
||||||
if (is_global) {
|
if (is_global && menu_cache[i].global_index >= 0) {
|
||||||
ds->global_menu_set_item_text("_main", global_start + i, atr(menu_cache[i].name));
|
ds->global_menu_set_item_text("_main", menu_cache[i].global_index, atr(menu_cache[i].name));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -564,6 +567,7 @@ void MenuBar::add_child_notify(Node *p_child) {
|
||||||
String submenu_name = pm->bind_global_menu();
|
String submenu_name = pm->bind_global_menu();
|
||||||
if (!pm->is_system_menu()) {
|
if (!pm->is_system_menu()) {
|
||||||
int index = DisplayServer::get_singleton()->global_menu_add_submenu_item("_main", atr(menu.name), submenu_name, _find_global_start_index() + menu_cache.size() - 1);
|
int index = DisplayServer::get_singleton()->global_menu_add_submenu_item("_main", atr(menu.name), submenu_name, _find_global_start_index() + menu_cache.size() - 1);
|
||||||
|
menu_cache.write[menu_cache.size() - 1].global_index = index;
|
||||||
DisplayServer::get_singleton()->global_menu_set_item_tag("_main", index, global_menu_name + "#" + itos(menu_cache.size() - 1));
|
DisplayServer::get_singleton()->global_menu_set_item_tag("_main", index, global_menu_name + "#" + itos(menu_cache.size() - 1));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -595,12 +599,13 @@ void MenuBar::move_child_notify(Node *p_child) {
|
||||||
if (!global_menu_name.is_empty()) {
|
if (!global_menu_name.is_empty()) {
|
||||||
if (!pm->is_system_menu()) {
|
if (!pm->is_system_menu()) {
|
||||||
int global_start = _find_global_start_index();
|
int global_start = _find_global_start_index();
|
||||||
if (old_idx != -1) {
|
if (menu.global_index >= 0) {
|
||||||
DisplayServer::get_singleton()->global_menu_remove_item("_main", global_start + old_idx);
|
DisplayServer::get_singleton()->global_menu_remove_item("_main", menu.global_index);
|
||||||
}
|
}
|
||||||
if (new_idx != -1) {
|
if (new_idx != -1) {
|
||||||
String submenu_name = pm->bind_global_menu();
|
String submenu_name = pm->bind_global_menu();
|
||||||
int index = DisplayServer::get_singleton()->global_menu_add_submenu_item("_main", atr(menu.name), submenu_name, global_start + new_idx);
|
int index = DisplayServer::get_singleton()->global_menu_add_submenu_item("_main", atr(menu.name), submenu_name, global_start + new_idx);
|
||||||
|
menu_cache.write[new_idx].global_index = index;
|
||||||
DisplayServer::get_singleton()->global_menu_set_item_tag("_main", index, global_menu_name + "#" + itos(new_idx));
|
DisplayServer::get_singleton()->global_menu_set_item_tag("_main", index, global_menu_name + "#" + itos(new_idx));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -622,7 +627,10 @@ void MenuBar::remove_child_notify(Node *p_child) {
|
||||||
if (!global_menu_name.is_empty()) {
|
if (!global_menu_name.is_empty()) {
|
||||||
if (!pm->is_system_menu()) {
|
if (!pm->is_system_menu()) {
|
||||||
pm->unbind_global_menu();
|
pm->unbind_global_menu();
|
||||||
DisplayServer::get_singleton()->global_menu_remove_item("_main", _find_global_start_index() + idx);
|
if (menu_cache[idx].global_index >= 0) {
|
||||||
|
DisplayServer::get_singleton()->global_menu_remove_item("_main", menu_cache[idx].global_index);
|
||||||
|
menu_cache.write[idx].global_index = -1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -818,8 +826,8 @@ void MenuBar::set_menu_title(int p_menu, const String &p_title) {
|
||||||
}
|
}
|
||||||
menu_cache.write[p_menu].name = p_title;
|
menu_cache.write[p_menu].name = p_title;
|
||||||
shape(menu_cache.write[p_menu]);
|
shape(menu_cache.write[p_menu]);
|
||||||
if (!global_menu_name.is_empty()) {
|
if (!global_menu_name.is_empty() && menu_cache[p_menu].global_index >= 0) {
|
||||||
DisplayServer::get_singleton()->global_menu_set_item_text("_main", _find_global_start_index() + p_menu, atr(menu_cache[p_menu].name));
|
DisplayServer::get_singleton()->global_menu_set_item_text("_main", menu_cache[p_menu].global_index, atr(menu_cache[p_menu].name));
|
||||||
}
|
}
|
||||||
update_minimum_size();
|
update_minimum_size();
|
||||||
}
|
}
|
||||||
|
@ -834,8 +842,8 @@ void MenuBar::set_menu_tooltip(int p_menu, const String &p_tooltip) {
|
||||||
PopupMenu *pm = get_menu_popup(p_menu);
|
PopupMenu *pm = get_menu_popup(p_menu);
|
||||||
pm->set_meta("_menu_tooltip", p_tooltip);
|
pm->set_meta("_menu_tooltip", p_tooltip);
|
||||||
menu_cache.write[p_menu].tooltip = p_tooltip;
|
menu_cache.write[p_menu].tooltip = p_tooltip;
|
||||||
if (!global_menu_name.is_empty()) {
|
if (!global_menu_name.is_empty() && menu_cache[p_menu].global_index >= 0) {
|
||||||
DisplayServer::get_singleton()->global_menu_set_item_tooltip("_main", _find_global_start_index() + p_menu, p_tooltip);
|
DisplayServer::get_singleton()->global_menu_set_item_tooltip("_main", menu_cache[p_menu].global_index, p_tooltip);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -847,8 +855,8 @@ String MenuBar::get_menu_tooltip(int p_menu) const {
|
||||||
void MenuBar::set_menu_disabled(int p_menu, bool p_disabled) {
|
void MenuBar::set_menu_disabled(int p_menu, bool p_disabled) {
|
||||||
ERR_FAIL_INDEX(p_menu, menu_cache.size());
|
ERR_FAIL_INDEX(p_menu, menu_cache.size());
|
||||||
menu_cache.write[p_menu].disabled = p_disabled;
|
menu_cache.write[p_menu].disabled = p_disabled;
|
||||||
if (!global_menu_name.is_empty()) {
|
if (!global_menu_name.is_empty() && menu_cache[p_menu].global_index >= 0) {
|
||||||
DisplayServer::get_singleton()->global_menu_set_item_disabled("_main", _find_global_start_index() + p_menu, p_disabled);
|
DisplayServer::get_singleton()->global_menu_set_item_disabled("_main", menu_cache[p_menu].global_index, p_disabled);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -860,8 +868,8 @@ bool MenuBar::is_menu_disabled(int p_menu) const {
|
||||||
void MenuBar::set_menu_hidden(int p_menu, bool p_hidden) {
|
void MenuBar::set_menu_hidden(int p_menu, bool p_hidden) {
|
||||||
ERR_FAIL_INDEX(p_menu, menu_cache.size());
|
ERR_FAIL_INDEX(p_menu, menu_cache.size());
|
||||||
menu_cache.write[p_menu].hidden = p_hidden;
|
menu_cache.write[p_menu].hidden = p_hidden;
|
||||||
if (!global_menu_name.is_empty()) {
|
if (!global_menu_name.is_empty() && menu_cache[p_menu].global_index >= 0) {
|
||||||
DisplayServer::get_singleton()->global_menu_set_item_hidden("_main", _find_global_start_index() + p_menu, p_hidden);
|
DisplayServer::get_singleton()->global_menu_set_item_hidden("_main", menu_cache[p_menu].global_index, p_hidden);
|
||||||
}
|
}
|
||||||
update_minimum_size();
|
update_minimum_size();
|
||||||
}
|
}
|
||||||
|
|
|
@ -55,6 +55,7 @@ class MenuBar : public Control {
|
||||||
Ref<TextLine> text_buf;
|
Ref<TextLine> text_buf;
|
||||||
bool hidden = false;
|
bool hidden = false;
|
||||||
bool disabled = false;
|
bool disabled = false;
|
||||||
|
int global_index = -1;
|
||||||
|
|
||||||
Menu(const String &p_name) {
|
Menu(const String &p_name) {
|
||||||
name = p_name;
|
name = p_name;
|
||||||
|
|
Loading…
Reference in a new issue