mirror of
				https://github.com/luanti-org/luanti.git
				synced 2025-10-25 21:55:25 +02:00 
			
		
		
		
	Fix touch input on Linux
The code relied on touch IDs being consecutive. This is true on Android, but not on Linux.
Therefore, touch input on Linux was broken since 53886dcdb5.
			
			
This commit is contained in:
		| @@ -278,7 +278,7 @@ bool GUIModalMenu::preprocessEvent(const SEvent &event) | ||||
| 		irr_ptr<GUIModalMenu> holder; | ||||
| 		holder.grab(this); // keep this alive until return (it might be dropped downstream [?])
 | ||||
| 
 | ||||
| 		if (event.TouchInput.ID == 0) { | ||||
| 		if (event.TouchInput.touchedCount == 1) { | ||||
| 			if (event.TouchInput.Event == ETIE_PRESSED_DOWN || event.TouchInput.Event == ETIE_MOVED) | ||||
| 				m_pointer = v2s32(event.TouchInput.X, event.TouchInput.Y); | ||||
| 			gui::IGUIElement *hovered = Environment->getRootGUIElement()->getElementFromPoint(core::position2d<s32>(m_pointer)); | ||||
| @@ -295,7 +295,7 @@ bool GUIModalMenu::preprocessEvent(const SEvent &event) | ||||
| 			if (event.TouchInput.Event == ETIE_LEFT_UP) | ||||
| 				leave(); | ||||
| 			return ret; | ||||
| 		} else if (event.TouchInput.ID == 1) { | ||||
| 		} else if (event.TouchInput.touchedCount == 2) { | ||||
| 			if (event.TouchInput.Event != ETIE_LEFT_UP) | ||||
| 				return true; // ignore
 | ||||
| 			auto focused = Environment->getFocus(); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user