XRFrame: getDepthInformation() method
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 getDepthInformation()
method of the XRFrame
interface returns an XRCPUDepthInformation
object containing CPU depth information for the active and animated frame.
Syntax
js
getDepthInformation(view)
Parameters
Return value
An XRCPUDepthInformation
object.
Exceptions
NotSupportedError
DOMException
-
Thrown if
"depth-sensing"
is not in the list of enabled features for thisXRSession
. InvalidStateError
DOMException
-
Thrown if:
- the
XRFrame
is not active nor animated. Obtaining depth information is only valid within therequestAnimationFrame()
callback. - the session's
depthUsage
is not"cpu-optimized"
.
- the
Examples
Obtaining CPU depth information
js
// Make sure to request a session with depth-sensing enabled
const session = navigator.xr.requestSession("immersive-ar", {
requiredFeatures: ["depth-sensing"],
depthSensing: {
usagePreference: ["cpu-optimized", "gpu-optimized"],
formatPreference: ["luminance-alpha", "float32"],
},
});
// …
// Obtain depth information in an active and animated frame
function rafCallback(time, frame) {
session.requestAnimationFrame(rafCallback);
const pose = frame.getViewerPose(referenceSpace);
if (pose) {
for (const view of pose.views) {
const depthInformation = frame.getDepthInformation(view);
if (depthInformation) {
// Do something with the depth information
renderDepth(depthInformation);
}
}
}
}
Specifications
Specification |
---|
WebXR Depth Sensing Module # dom-xrframe-getdepthinformation |
Browser compatibility
BCD tables only load in the browser