Component:HandPoser: Difference between revisions

From Resonite Wiki
m Remove introduction header
add info
 
Line 1: Line 1:
{{stub}}
{{Infobox Component
{{Infobox Component
|Image=HandPoser.png
|Image=HandPoser.png
Line 13: Line 12:


<!--T:3-->
<!--T:3-->
== Usage ==
== Fields ==
{{Table ComponentFields
{{Table ComponentFields
|PoseSource|IFingerPoseSource| What the finger transform data is derived from.
|PoseSource|IFingerPoseSource| What the finger transform data is derived from.
Line 22: Line 21:
|HandUp|Float3| A unit vector pointing from the back of the hand outwards (alternatively phrased, this is pointing into the palm)
|HandUp|Float3| A unit vector pointing from the back of the hand outwards (alternatively phrased, this is pointing into the palm)
|HandRight|Float3| A unit vector pointing to the right of the hand, if the hand is facing down. This is roughly the direction of the thumb on the left hand, and the other side of the hand from the thumb on the right hand.
|HandRight|Float3| A unit vector pointing to the right of the hand, if the hand is facing down. This is roughly the direction of the thumb on the left hand, and the other side of the hand from the thumb on the right hand.
|Thumb|{{RootFieldType|(nested)|[[#Finger|Finger]]}}|TypeAdv7=true|
|Thumb|{{RootFieldType|(nested)|[[#Finger|Finger]]}}|TypeAdv7=true| The Thumb on an anthro hand.
|Index|{{RootFieldType|(nested)|[[#Finger|Finger]]}}|TypeAdv8=true|
|Index|{{RootFieldType|(nested)|[[#Finger|Finger]]}}|TypeAdv8=true| The Index on an anthro hand.
|Middle|{{RootFieldType|(nested)|[[#Finger|Finger]]}}|TypeAdv9=true|
|Middle|{{RootFieldType|(nested)|[[#Finger|Finger]]}}|TypeAdv9=true| The Middle on an anthro hand.
|Ring|{{RootFieldType|(nested)|[[#Finger|Finger]]}}|TypeAdv10=true|
|Ring|{{RootFieldType|(nested)|[[#Finger|Finger]]}}|TypeAdv10=true| The Ring on an anthro hand.
|Pinky|{{RootFieldType|(nested)|[[#Finger|Finger]]}}|TypeAdv11=true|
|Pinky|{{RootFieldType|(nested)|[[#Finger|Finger]]}}|TypeAdv11=true| The Pinky on an anthro hand.
|DebugFingers|Bool|
|DebugFingers|Bool| Whether to show visuals for debugging the fingers.
}}
 
== Sync Delegates ==
{{Table ComponentTriggers
|AssignFromRig()|[[Type:Action|Action]]|This initializes the driver based on the rig details.
|InitializeHand()|[[Type:Action|Action]]|This populates every numeric field and drive field in the component based on the populated Root slots. This should not be pressed when someone is inside the avatar or the hands may crumple.
}}
}}
{| class="wikitable mw-collapsible"
|+ Methods
|-
! Name
! Description
|-
| <code>AssignFromRig</code>
| This initializes the driver based on the rig details.
|-
| <code>InitializeHand</code>
| This populates every numeric field and drive field in the component based on the populated Root slots. This should not be pressed when someone is inside the avatar or the hands may crumple.
|}


== Finger ==
== Finger ==
{{Table TypeFields
{{Table TypeFields
|Metacarpal|{{RootFieldType|(nested)|[[#FingerSegment|FingerSegment]]}}|TypeAdv0=true|
|Metacarpal|{{RootFieldType|(nested)|[[#FingerSegment|FingerSegment]]}}|TypeAdv0=true| Usually inside of the palm and not actually inside the finger itself.
|Proximal|{{RootFieldType|(nested)|[[#FingerSegment|FingerSegment]]}}|TypeAdv1=true|
|Proximal|{{RootFieldType|(nested)|[[#FingerSegment|FingerSegment]]}}|TypeAdv1=true| The first finger segment of 3.
|Intermediate|{{RootFieldType|(nested)|[[#FingerSegment|FingerSegment]]}}|TypeAdv2=true|
|Intermediate|{{RootFieldType|(nested)|[[#FingerSegment|FingerSegment]]}}|TypeAdv2=true| The second finger segment of 3.
|Distal|{{RootFieldType|(nested)|[[#FingerSegment|FingerSegment]]}}|TypeAdv3=true|
|Distal|{{RootFieldType|(nested)|[[#FingerSegment|FingerSegment]]}}|TypeAdv3=true| The third finger segment of 3.
}}
}}


== FingerSegment ==
== FingerSegment ==
{{Table TypeFields
{{Table TypeFields
|CoordinateCompensation|FloatQ|
|CoordinateCompensation|FloatQ| The amount the bone is offset from the expected finger rotation by Resonite.
|Root|Slot|The slot representing this bone. Note that a human hand has no thumb intermediate bone, so this field will in general always be null.
|Root|Slot|The slot representing this bone. Note that a hand has no thumb intermediate bone. This is filled when the hand does have this finger segment.
|OriginalRotation|FloatQ|
|OriginalRotation|FloatQ| The resting rotation of the finger bone.
|RotationDrive|{{RootFieldType|FieldDrive`1|[[Type:FloatQ|FloatQ]]}}|TypeAdv3=true|
|RotationDrive|{{RootFieldType|FieldDrive`1|[[Type:FloatQ|FloatQ]]}}|TypeAdv3=true| The Rotation field of the slot <code>Slot</code> of this finger segement. Used to move the finger.
}}
}}


<!--T:4-->
<!--T:4-->
== Behavior ==
== Usage ==


This component forcibly assigns the rotation of each bound finger to a particular bone relative to the palm.
This component forcibly assigns the rotation of each bound finger to a particular bone relative to the palm.
Line 105: Line 98:
<!--T:6-->
<!--T:6-->
== Related Components ==
== Related Components ==
[[Component:AvatarHandDataAssigner]]
* [[Component:AvatarHandDataAssigner]]


[[Category:ComponentStubs]]
[[Category:Components:Users:Common Avatar System:Fingers{{#translation:}}|Hand Poser]]
[[Category:Components:Users:Common Avatar System:Fingers{{#translation:}}|Hand Poser]]
[[Category:Components{{#translation:}}|Hand Poser]]
[[Category:Components{{#translation:}}|Hand Poser]]
[[Category:Components With Nested Types{{#translation:}}|Hand Poser]]
[[Category:Components With Nested Types{{#translation:}}|Hand Poser]]

Latest revision as of 19:29, 22 December 2024

Component image 
Hand Poser component as seen in the Scene Inspector

This component modifies the rotation of the fingers of an avatar's hand based on a pose source. The HandPoser works with whatever data is avilable, either precise finger tracking like a LeapMotion, or course grained like a vive wand, where grip and trigger affect the main finger positions.

The HandPoser is made of five duplicate finger objects, each of which contains four duplicate bone objects. Each bone object contains a Coordinate Compensation, Root, OrigionalRotation, and RotationDrive. The below chart is difficult to read for this reason, but read it as: the same four fields, duplicated four times (one for each bone), duplicated five times (one for each finger).

Due to this pattern, the intermediate bone of the thumb should never be bound as a human thumb does not have an intermediate bone.

Fields

Fields
Name Type Description
persistent Bool Determines whether or not this item will be saved to the server.
UpdateOrder Int Controls the order in which this component is updated.
Enabled Bool Controls whether or not this component is enabled.
PoseSource IFingerPoseSource What the finger transform data is derived from.
Side Chirality Which hand this poser is representing
PoseMetacarpals Bool If metacarpals should be posed (this should normally be left as True)
HandRoot Slot The root of the hand (if null the slot the component is attached to is used)
HandForward Float3 A unit vector pointing forward from the wrist to the fingers.
HandUp Float3 A unit vector pointing from the back of the hand outwards (alternatively phrased, this is pointing into the palm)
HandRight Float3 A unit vector pointing to the right of the hand, if the hand is facing down. This is roughly the direction of the thumb on the left hand, and the other side of the hand from the thumb on the right hand.
Thumb direct Finger The Thumb on an anthro hand.
Index direct Finger The Index on an anthro hand.
Middle direct Finger The Middle on an anthro hand.
Ring direct Finger The Ring on an anthro hand.
Pinky direct Finger The Pinky on an anthro hand.
DebugFingers Bool Whether to show visuals for debugging the fingers.

Sync Delegates

Triggers
Method Name Method type and Arguments. Description
AssignFromRig() Action This initializes the driver based on the rig details.
InitializeHand() Action This populates every numeric field and drive field in the component based on the populated Root slots. This should not be pressed when someone is inside the avatar or the hands may crumple.

Finger

Fields
Name Type Description
Metacarpal direct FingerSegment Usually inside of the palm and not actually inside the finger itself.
Proximal direct FingerSegment The first finger segment of 3.
Intermediate direct FingerSegment The second finger segment of 3.
Distal direct FingerSegment The third finger segment of 3.

FingerSegment

Fields
Name Type Description
CoordinateCompensation FloatQ The amount the bone is offset from the expected finger rotation by Resonite.
Root Slot The slot representing this bone. Note that a hand has no thumb intermediate bone. This is filled when the hand does have this finger segment.
OriginalRotation FloatQ The resting rotation of the finger bone.
RotationDrive field drive of FloatQ The Rotation field of the slot Slot of this finger segement. Used to move the finger.

Usage

This component forcibly assigns the rotation of each bound finger to a particular bone relative to the palm. As an example of this, if you only assign a Distal bone, that bone will spin 270 degrees starting pointing forwards, curling to point out the direction of the palm, back towards the wrist, then pointing out the back of the hand.

It is often easiest to make changes to this component following this procedure:

  1. Have the avatar be unequipped
  2. Clear every RotationDrive field
  3. Assign the Root field of each bone in the hand to be driven, this list will not be complete and some roots will be null.
  4. Press InitializeHand at the bottom of the component (Note: This button only works once, to reset the button select another slot, then select the slot with the component again).
  5. Re-Equip the avatar and see if the hands initialized successfully.
  6. If a bone did not bind correctly, repeat.

Examples

A few common problems can occur with an avatar's hands, here are common solutions.

Fingertips Through the Palm

Some avatars have very long fingertips (distal bones), but the human hand is structured to have very short fingertips. For these avatars if the hand is fully closed the fingertips (or clawtips) may poke through the back of the avatars hands. To resolve this

One known fix for this is to follow the steps outlined in Behavior, but assign every Distal bone to the Intermediate slot (leaving the Indermediate unbound). This will result in the distal bones curling down to lay flat against the palm, instead of curling all theway through the hand.

Hook Index Finger

This is where the rest of the hand bones accept the index finger bend at the base of the palm, instead of the knuckle. The index finger metacarpal doesn't bend at all though, leading to a 'hooked' appearance when the hand is closed.

There are two main fixes here, if the avatar isn't fully imported then re-import with the thumb parented to the palm bone instead of the index metacarpal. Otherwise do the following:

  1. Reparent the thumb metacarpal to the palm in the inspector (This may not be needed, investigation is needed).
  2. Reassign the root fields for the entire hand following the procedure outlined in Behavior, the bindings will be incorrect.

Extra Finger Spread

Some avatars may end up with much more splayed fingers when inhabited by a user, the current proposed solution is to not bind the metacarpal bones (More investigation is needed into this solution).

Hand curls to look like cat claws

The first digit of the finger isn't curling when the hand is closed, making the hand look like a cat claw.

This is caused by the avatar's hand having more bones than Resonite expects, and the first bone in the hand is bound to the metacarpal, it needs to be bound to proximal instead, moving each corresponding bone one position down the finger. The thumb is likely not affected by this.

Related Components