IndieGame/client/Packages/com.unity.ugui@1.0.0/Documentation~/script-TouchInputModule.md

36 lines
1.5 KiB
Markdown
Raw Normal View History

2024-10-11 10:12:15 +08:00
# Touch Input Module
**Note: TouchInputModule is obsolete. Touch input is now handled in [StandaloneInputModule](script-StandaloneInputModule.md).**
This module is designed to work with touch devices. It sends pointer events for touching and dragging in response to user input. The module supports multitouch.
The module uses the scene configured Raycasters to calculate what element is currently being touched over. A raycast is issued for each current touch.
## Properties
|**_Property:_** |**_Function:_** |
|:---|:---|
|__Force Module Active__ | Forces this module to be active. |
## Details
The flow for the module is as follows:
- For each touch event
- If it is a new press
- Send PointerEnter event (sent to every object up the hierarchy that can handle it)
- Send PointerPress event
- Cache the drag handler (first element in the hierarchy that can handle it)
- Send BeginDrag event to the drag handler
- Set the 'Pressed' object as Selected in the event system
- If this is a continuing press
- Process movement
- Send DragEvent to the cached drag handler
- Handle PointerEnter and PointerExit events if touch moves between objects
- If this is a release
- Send PointerUp event to the object that received the PointerPress
- If the current hover object is the same as the PointerPress object send a PointerClick event
- Send a Drop event if there was a drag handler cached
- Send a EndDrag event to the cached drag handler