瀏覽代碼

Fix crash in Tree when moving using Joypad

Fabio Alessandrelli 7 年之前
父節點
當前提交
e355a8fc4c
共有 1 個文件被更改,包括 3 次插入2 次删除
  1. 3 2
      scene/gui/tree.cpp

+ 3 - 2
scene/gui/tree.cpp

@@ -2183,6 +2183,7 @@ void Tree::_gui_input(Ref<InputEvent> p_event) {
 
 
 	Ref<InputEventKey> k = p_event;
 	Ref<InputEventKey> k = p_event;
 
 
+	bool is_command = k.is_valid() && k->get_command();
 	if (p_event->is_action("ui_right") && p_event->is_pressed()) {
 	if (p_event->is_action("ui_right") && p_event->is_pressed()) {
 
 
 		if (!cursor_can_exit_tree) accept_event();
 		if (!cursor_can_exit_tree) accept_event();
@@ -2219,13 +2220,13 @@ void Tree::_gui_input(Ref<InputEvent> p_event) {
 			_go_left();
 			_go_left();
 		}
 		}
 
 
-	} else if (p_event->is_action("ui_up") && p_event->is_pressed() && !k->get_command()) {
+	} else if (p_event->is_action("ui_up") && p_event->is_pressed() && !is_command) {
 
 
 		if (!cursor_can_exit_tree) accept_event();
 		if (!cursor_can_exit_tree) accept_event();
 
 
 		_go_up();
 		_go_up();
 
 
-	} else if (p_event->is_action("ui_down") && p_event->is_pressed() && !k->get_command()) {
+	} else if (p_event->is_action("ui_down") && p_event->is_pressed() && !is_command) {
 
 
 		if (!cursor_can_exit_tree) accept_event();
 		if (!cursor_can_exit_tree) accept_event();