Background
VirtualGrasp not only provides solutions to grasp interaction, but also for push interactions.
Button push as an action in real world is very simple process due to the very physical laws existing in the nature. When the same problem is ported into VR, a realistic button push behavior requires some tedius steps that often needs complex setup of physical properties on both button and the hand.
VirtualGrasp provides a solution to make push interaction setup easier and intuitive through object articulation, without relying on physical simulations.
Below we will explain how to setup push interaction without adding any physical properties on an object – push without physics,
Push Without Physics
From Object Selection to Push Without Physics
When push is done with physics, the selection of object is straightforward – by contact and apply force. When push is done without physics, there need to be a way to decide which object is to be pushed. VirtualGrasp does this through checking the geometric relation between a push agent and the object to be pushed. To allow VR developers to be able to specify for example “This button can not be pushed from below”, push direction is added to the object to specify the preferred approach direction by the push agent for pushing this object.
Given that
- the push agent has been assigned (through set interaction affordance as INDEX_PUSHABLE), and
- push direction is added to the object to be pushed,
the decision on which of the pushable objects is selected for pushing is done by considering:
- how close is the push agent to the pushable object and
- how aligned is the push agent’s approach direction with the preferred approach direction.
For example image above shows the push direction transform added to the red button. The blue arrow (zaxis of this transform) specifies the approach direction. So when index finger is approaching from bottom to the button, opposite to the blue arrow, the object will not be selected for push.
Once an object is selected, a push on the object will be triggered when the finger tip touches the pushing surface. The pushable object’s movement is then controlled by sensor controlled finger tip position through joint articulation. In other words, the finger tip is “dragging” the object to move to the allowed direction by joint articulation setup. This way an object (like a button) can be “pushed down”, or “slided” on a surface as shown on the rectangular button with planar joint (see pad with planar joint buttons).
How to Setup Push Without Physics
Through VirtualGrasp’s object articulation feature, a VR developer can setup a pushable object with various behaviors simulating real world’s button object in any game engine. And this setup does not require the developer to add any physical components (such as RigidBody or Colliders) to either objects or hands in the game engine.
Using Unity game engine as an example, to create a pushable button, you add the component VG_Articulation to the object, and the parameters shown in below image create a button that can be pushed by index finger, and will bounce alternatively to the two discrete states when push is released (see affordances):
- Since button is moving along a single axis linearly, we select the joint type to be PRISMATIC.
- For PRISMATIC joint, we need to provide anchor which specifies the joint axis along which object moves.
- For PRISMATIC joint, we also need to provide joint limit, i.e. a linear movement range between 0 and 0.014 meter.
- Since the pushable button’s movement direction (by anchor) is same as the direction we want hand to approach for pushing, so we don’t need to specify a different push direction.
- For push without physics, you need to select interaction affordance as INDEX_PUSHABLE.
- To let object bounce back alternatively to two stages when push is release, you need to set the state affordance to be TWO_STAGE.
- To let object bounce back NOT to the lower boundary of the joint limit (min = 0), but to slightly lower position, we set two discrete states with first value 0.004 (>min).
Why the finger penetrates?
Some complaints have arrised from VG users about the finger penetrating through pushing surface of an object. The foundamental reason is on the mechanism of how object is pushed for VG’s non-physical pushing setup. To explain more explicitly, the object is not pushed by force in physical setup but rather moved because it is “dragged” by the position of the sensor controlled finger tip, therefore the finger tip could go through the pushing surface. In next version we will introduce a proxy hand which will be forced to stay on the pushing surface.