Gesture building blocks
You can define custom gestures using a set of building blocks:
|
Building block |
Description |
data:image/s3,"s3://crabby-images/ea1ce/ea1ce5b4ef57776000808af7f93648cf7fc63558" alt="" |
Joint data |
The positions and orientations of the joints and bones of a hand are the most fundamental building block of a gesture. The gesture recognizer reads this data automatically. You do not need to reference individual joints when defining a custom gesture. Instead, you specify the aspects of the desired finger shape. |
data:image/s3,"s3://crabby-images/62c0f/62c0f6e53ad170188cfb39db67f2df2b1ae9587d" alt="" |
Finger shape |
The overall shape of a finger. Finger shape is abstracted into five aspects that you can specify individually:
- Full Curl: the overall curve of the finger
- Base Curl: the bend of the first knuckle
- Tip Curl: the curve of the outer bones of the finger (not including the first knuckle, unless the finger is a thumb)
- Pinch: how close the finger is to pinching the thumb
- Spread: the splay angle between adjacent fingers
For example, the Full Curl value rates how curved the entire finger must be to perform the gesture, while the Base Curl value rates just the bend of the Metacarpophalangeal (MCP) joint. For a gesture to be recognized, the user's hand must be positioned to match the specified shapes of all referenced fingers within the required tolerance settings.
You define shape values and tolerances for one or more fingers in a Hand Shape asset. |
data:image/s3,"s3://crabby-images/a7e85/a7e85e5a77d4a4073131aebc6206eb2125c9681a" alt="" |
Orientation |
The orientation of the hand compared to one or more selected reference directions. For example, you can specify that the user's hand be faced toward or away from the user by setting the required orientation properties.
You can add one or more orientation conditions to Hand Pose assets and Static Hand Gesture components. |
data:image/s3,"s3://crabby-images/b0f3d/b0f3d21716187fd362e307e7274445dfd0ffe5c0" alt="" |
Hand shape |
Defined by the shape values of one or more fingers. For example, the "Spock" hand shape could be defined by setting the necessary Full Curl and Spread values of each finger.
Add a Hand Shape asset to your project with the menu: Assets > Create > XR > Hand Interactions > Hand Shape. |
data:image/s3,"s3://crabby-images/ce769/ce76940f62011fc0515b0de9eddad6e4bfdc4910" alt="" |
Hand pose |
A Hand Shape combined with an orientation. For example, an open hand facing the user is a different pose than the same hand shape turned away from the user.
Add a Hand Pose asset to your project with the menu: Assets > Create > XR > Hand Interactions > Hand Pose. |
data:image/s3,"s3://crabby-images/8404a/8404a9f6063b149e9a796806490b5b60fdeac496" alt="" |
Static Hand Gesture component |
The component you add to every scene in which you want a specific gesture to be detected. This component references either a Hand Shape or a Hand Pose asset to define how the user's hand must be held to trigger the gesture. You can also specify additional, target-relative Orientation conditions in this component. |
Refer to Add a custom gesture to a scene for instructions on defining a custom gesture and adding it to a scene.
Did you find this page useful? Please give it a rating:
Thanks for rating this page!
What kind of problem would you like to report?
Thanks for letting us know! This page has been marked for review based on your feedback.
If you have time, you can provide more information to help us fix the problem faster.
Provide more information
You've told us this page needs code samples. If you'd like to help us further, you could provide a code sample, or tell us about what kind of code sample you'd like to see:
You've told us there are code samples on this page which don't work. If you know how to fix it, or have something better we could use instead, please let us know:
You've told us there is information missing from this page. Please tell us more about what's missing:
You've told us there is incorrect information on this page. If you know what we should change to make it correct, please tell us:
You've told us this page has unclear or confusing information. Please tell us more about what you found unclear or confusing, or let us know how we could make it clearer:
You've told us there is a spelling or grammar error on this page. Please tell us what's wrong:
You've told us this page has a problem. Please tell us more about what's wrong:
Thank you for helping to make the Unity documentation better!
Your feedback has been submitted as a ticket for our documentation team to review.
We are not able to reply to every ticket submitted.