XRSession: squeezestart event
Limited availability
This feature is not Baseline because it does not work in some of the most widely-used browsers.
Experimental: This is an experimental technology
Check the Browser compatibility table carefully before using this in production.
Secure context: This feature is available only in secure contexts (HTTPS), in some or all supporting browsers.
The WebXR event squeezestart
is sent to an XRSession
when the user begins a primary squeeze action on one of its input sources.
Primary squeeze actions are actions which are meant to represent gripping or squeezing using your hands, and may be simulated using triggers on hand controllers.
Syntax
Use the event name in methods like addEventListener()
, or set an event handler property.
addEventListener("squeezestart", (event) => {});
onsqueezestart = (event) => {};
Event type
An XRInputSourceEvent
. Inherits from Event
.
Event properties
In addition to the properties listed below, properties from the parent interface, Event
, are available.
frame
Read only-
An
XRFrame
object providing the needed information about the event frame during which the event occurred. This frame may have been rendered in the past rather than being a current frame. Because this is an event frame, not an animation frame, you cannot callXRFrame.getViewerPose()
on it; instead, usegetPose()
. inputSource
Read only-
An
XRInputSource
object indicating which input source generated the input event.
Description
Trigger
Triggered when users begin squeezing the controller, making a hand gesture that mimes grabbing something, or using (squeezing) a trigger.
Use cases
The squeezestart
event is sent indicating that the user has begun a squeeze action.
If the primary squeeze action ends successfully, the session is sent a squeeze
event.
A squeezeend
event is sent to indicate that the squeeze action is no longer underway. This is sent whether the squeeze action succeeded or not.
Examples
The following example uses addEventListener()
to establish handlers for the squeeze events: squeezestart
, squeezeend
, and squeeze
. This snippet is the core of an event handler to allow the user to grab objects in the scene and move them around.
In this case, a single function is used to handle all three events, allowing them to share certain code that's the same regardless of which of the three events is received. Only after completing those tasks does the onSqueezeEvent()
function below dispatch the action out to a specialized function to handle things.
After checking to ensure that the received event is a tracked-pointer
event (the only kind we handle here), the target ray's pose is obtained using getPose()
.
If the target ray pose was fetched successfully, the code then uses the value of Event
property type
to route control to an appropriate function to handle the event which arrived:
- For
squeezestart
events, amyBeginTracking()
function is called with the target ray pose'smatrix
. ThemyBeginTracking()
function would presumably start the presentation of the object-dragging process, using the transform to perform a hit test, determining which object to pick up.myBeginTracking()
returns an object representing the object the user has begun to drag. - Upon receiving a
squeeze
event, themyDropObject()
function is called with the target object, and the current target ray pose transform as inputs. This places the object into its new position in the world and triggers any effects that may arise, like scheduling an animation of a splash if dropped in water, etc. - The
squeezeend
event results in amyStopTracking()
function being called with the object being dragged and the final target ray pose's transform.
xrSession.addEventListener("squeezestart", onSqueezeEvent);
xrSession.addEventListener("squeeze", onSqueezeEvent);
xrSession.addEventListener("squeezeend", onSqueezeEvent);
function onSqueezeEvent(event) {
let source = event.inputSource;
let targetObj = null;
if (source.targetRayMode !== "tracked-pointer") {
return;
}
let targetRayPose = event.frame.getPose(source.targetRaySpace, myRefSpace);
if (!targetRayPose) {
return;
}
switch (event.type) {
case "squeezestart":
targetObj = myBeginTracking(targetRayPose.matrix);
break;
case "squeeze":
myDropObject(targetObj, targetRayPose.matrix);
break;
case "squeezeend":
myStopTracking(targetObj, targetRayPose.matrix);
break;
}
}
You can also set up a handler for these events by setting the XRSession
object's event handler properties to a function that handles the event:
xrSession.onsqueezestart = onSqueezeEvent;
xrSession.onsqueeze = onSqueezeEvent;
xrSession.onsqueezeend = onSqueezeEvent;
Specifications
Specification |
---|
WebXR Device API # eventdef-xrsession-squeezestart |
WebXR Device API # dom-xrsession-onsqueezestart |
Browser compatibility
BCD tables only load in the browser