|  | @@ -129,13 +129,22 @@ void AndroidInputHandler::process_key_event(int p_physical_keycode, int p_unicod
 | 
											
												
													
														|  |  	Input::get_singleton()->parse_input_event(ev);
 |  |  	Input::get_singleton()->parse_input_event(ev);
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -void AndroidInputHandler::_parse_all_touch(bool p_pressed, bool p_double_tap) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +void AndroidInputHandler::_cancel_all_touch() {
 | 
											
												
													
														|  | 
 |  | +	_parse_all_touch(false, false, true);
 | 
											
												
													
														|  | 
 |  | +	touch.clear();
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +void AndroidInputHandler::_parse_all_touch(bool p_pressed, bool p_double_tap, bool reset_index) {
 | 
											
												
													
														|  |  	if (touch.size()) {
 |  |  	if (touch.size()) {
 | 
											
												
													
														|  |  		//end all if exist
 |  |  		//end all if exist
 | 
											
												
													
														|  |  		for (int i = 0; i < touch.size(); i++) {
 |  |  		for (int i = 0; i < touch.size(); i++) {
 | 
											
												
													
														|  |  			Ref<InputEventScreenTouch> ev;
 |  |  			Ref<InputEventScreenTouch> ev;
 | 
											
												
													
														|  |  			ev.instantiate();
 |  |  			ev.instantiate();
 | 
											
												
													
														|  | -			ev->set_index(touch[i].id);
 |  | 
 | 
											
												
													
														|  | 
 |  | +			if (reset_index) {
 | 
											
												
													
														|  | 
 |  | +				ev->set_index(-1);
 | 
											
												
													
														|  | 
 |  | +			} else {
 | 
											
												
													
														|  | 
 |  | +				ev->set_index(touch[i].id);
 | 
											
												
													
														|  | 
 |  | +			}
 | 
											
												
													
														|  |  			ev->set_pressed(p_pressed);
 |  |  			ev->set_pressed(p_pressed);
 | 
											
												
													
														|  |  			ev->set_position(touch[i].pos);
 |  |  			ev->set_position(touch[i].pos);
 | 
											
												
													
														|  |  			ev->set_double_tap(p_double_tap);
 |  |  			ev->set_double_tap(p_double_tap);
 | 
											
										
											
												
													
														|  | @@ -196,7 +205,9 @@ void AndroidInputHandler::process_touch_event(int p_event, int p_pointer, const
 | 
											
												
													
														|  |  			}
 |  |  			}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  		} break;
 |  |  		} break;
 | 
											
												
													
														|  | -		case AMOTION_EVENT_ACTION_CANCEL:
 |  | 
 | 
											
												
													
														|  | 
 |  | +		case AMOTION_EVENT_ACTION_CANCEL: {
 | 
											
												
													
														|  | 
 |  | +			_cancel_all_touch();
 | 
											
												
													
														|  | 
 |  | +		} break;
 | 
											
												
													
														|  |  		case AMOTION_EVENT_ACTION_UP: { //release
 |  |  		case AMOTION_EVENT_ACTION_UP: { //release
 | 
											
												
													
														|  |  			_release_all_touch();
 |  |  			_release_all_touch();
 | 
											
												
													
														|  |  		} break;
 |  |  		} break;
 | 
											
										
											
												
													
														|  | @@ -236,6 +247,12 @@ void AndroidInputHandler::process_touch_event(int p_event, int p_pointer, const
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +void AndroidInputHandler::_cancel_mouse_event_info(bool p_source_mouse_relative) {
 | 
											
												
													
														|  | 
 |  | +	buttons_state = BitField<MouseButtonMask>();
 | 
											
												
													
														|  | 
 |  | +	_parse_mouse_event_info(BitField<MouseButtonMask>(), false, false, p_source_mouse_relative);
 | 
											
												
													
														|  | 
 |  | +	mouse_event_info.valid = false;
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |  void AndroidInputHandler::_parse_mouse_event_info(BitField<MouseButtonMask> event_buttons_mask, bool p_pressed, bool p_double_click, bool p_source_mouse_relative) {
 |  |  void AndroidInputHandler::_parse_mouse_event_info(BitField<MouseButtonMask> event_buttons_mask, bool p_pressed, bool p_double_click, bool p_source_mouse_relative) {
 | 
											
												
													
														|  |  	if (!mouse_event_info.valid) {
 |  |  	if (!mouse_event_info.valid) {
 | 
											
												
													
														|  |  		return;
 |  |  		return;
 | 
											
										
											
												
													
														|  | @@ -296,8 +313,11 @@ void AndroidInputHandler::process_mouse_event(int p_event_action, int p_event_an
 | 
											
												
													
														|  |  			_parse_mouse_event_info(event_buttons_mask, true, p_double_click, p_source_mouse_relative);
 |  |  			_parse_mouse_event_info(event_buttons_mask, true, p_double_click, p_source_mouse_relative);
 | 
											
												
													
														|  |  		} break;
 |  |  		} break;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +		case AMOTION_EVENT_ACTION_CANCEL: {
 | 
											
												
													
														|  | 
 |  | +			_cancel_mouse_event_info(p_source_mouse_relative);
 | 
											
												
													
														|  | 
 |  | +		} break;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |  		case AMOTION_EVENT_ACTION_UP:
 |  |  		case AMOTION_EVENT_ACTION_UP:
 | 
											
												
													
														|  | -		case AMOTION_EVENT_ACTION_CANCEL:
 |  | 
 | 
											
												
													
														|  |  		case AMOTION_EVENT_ACTION_BUTTON_RELEASE: {
 |  |  		case AMOTION_EVENT_ACTION_BUTTON_RELEASE: {
 | 
											
												
													
														|  |  			_release_mouse_event_info(p_source_mouse_relative);
 |  |  			_release_mouse_event_info(p_source_mouse_relative);
 | 
											
												
													
														|  |  		} break;
 |  |  		} break;
 |