安全上下文
此特征只可用于
安全上下文
(HTTPS),在某些或所有
支持浏览器
.
只读
XRInputSourceEvent
property
frame
specifies an
XRFrame
object representing the event frame during which a
WebXR
user input occurred.
This may thus be an event which occurred in the past rather than a current or impending event.
let inputFrame = xrInputSourceEvent.frame;
XRFrame
indicating the event frame at which the user input event described by the object took place.
The event frame does not correspond to a visual frame as is delivered to the frame rendering callback function (see
Rendering and the WebXR frame rendering callback
for details on the callback). Instead, the
XRFrame
指定通过
frame
property is simply a method to provide access to the
getPose()
method, which you can use to get the relative positions of the objects in the scene at the time the event occurred.
However, since the event frame isn't an animation frame, there is no viewer pose available to represent the viewer's current point of view; the results of calling
getViewerPose()
will be an
XRViewerPose
with an empty
views
列表。
This code shows a handler for the
selectstart
event which gets the target ray's pose from the frame, mapping the pose representing the ray (
event.inputSource.targetRaySpace
) to the overall reference space
myRefSpace
.
Then, if the result isn't
null
, the target ray pose's transform is passed into a function called
myCheckAndHandleHit()
to see if the ray was pointing at anything when the select was triggered.
xrSession.onselectstart = event => {
let targetRayPose = event.frame.getPose(event.inputSource.targetRaySpace,
myRefSpace);
if (targetRayPose) {
checkAndHandleHit(targetRayPose.transform);
}
};
| 规范 | 状态 | 注释 |
|---|---|---|
|
WebXR 设备 API
The definition of 'XRInputSourceEvent.frame' in that specification. |
工作草案 | 初始定义。 |
| 桌面 | 移动 | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
frame
|
Chrome 79 | Edge 79 | Firefox 不支持 No | IE 不支持 No | Opera 不支持 No | Safari 不支持 No | WebView Android 不支持 No | Chrome Android 79 | Firefox Android 不支持 No | Opera Android 不支持 No | Safari iOS 不支持 No | Samsung Internet Android 11.2 |
完整支持
不支持
XRInputSourceEvent
frame
inputSource
Navigator.xr
WebGLRenderingContext.makeXRCompatible()
XR
XRBoundedReferenceSpace
XRFrame
XRInputSource
XRInputSourceArray
XRInputSourcesChangeEvent
XRPose
XRReferenceSpace
XRReferenceSpaceEvent
XRRenderState
XRRigidTransform
XRSession
XRSessionEvent
XRSpace
XRView
XRViewerPose
XRViewport
XRWebGLLayer