Secure contextThis feature is available only in secure contexts (HTTPS), in some or all supporting browsers.
The WebXR event select
is sent to an XRSession
when one of the session's input sources has completed a primary action. Examples of comon kinds of primary action are users pressing triggers or buttons, tapping a touchpad, speaking a command, or performing a recognizable gesture when using a video tracking system or handheld controller with an accelerometer.
Bubbles | Yes |
Cancelable | No |
Interface | XRInputSourceEvent
|
Event handler property | onselect
|
For details on how the selectstart
, select
, and selectend
events work, and how you should react to them, see Primary actions in Inputs and input sources.
Examples
The following example uses addEventListener()
to set up a handler for the select
event. The handler fetches the pose representing the target ray for tracked-pointer
inputs and sends the pose's transform to a function called myHandleSelectWithRay()
.
xrSession.addEventListener("select", event => {
if (event.inputSource.targetRayMode == "tracked-pointer") {
let targetRayPose = event.frame.getPose(event.inputSource.targetRaySpace,
myRefSpace);
if (targetRayPose) {
myHandleSelectWithRay(targetRayPose.transform);
}
}
});
You can of course also set up a handler for select
events by setting the XRSession
object's onselect
event handler property to a function that handles the event:
xrSession.onselect = event => {
if (event.inputSource.targetRayMode == "tracked-pointer") {
let targetRayPose = event.frame.getPose(event.inputSource.targetRaySpace,
myRefSpace);
if (targetRayPose) {
myHandleSelectWithRay(targetRayPose.transform);
}
}
};
Specifications
Specification | Status | Comment |
---|---|---|
WebXR Device APIThe definition of 'select event' in that specification. | Working Draft | Initial definition. |
Browser compatibility
Update compatibility data on GitHub
Desktop | Mobile | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
select event
|
Chrome
Full support 79 |
Edge
Full support 79 |
Firefox
No support No |
IE
No support No |
Opera
No support No |
Safari
No support No |
WebView Android
No support No |
Chrome Android
Full support 79 |
Firefox Android
No support No |
Opera Android
No support No |
Safari iOS
No support No |
Samsung Internet Android
Full support 11.2 |
Legend
- Full support
- Full support
- No support
- No support
XRSession: select event by Mozilla Contributors is licensed under CC-BY-SA 2.5.