Creates an ARView with a VRDisplay and a THREE.WebGLRenderer. Handles the pass through camera differences between ARCore and ARKit platforms, and renders the camera behind your scene.
Renders the pass through camera. Usually called on every frame in a render loop before rendering other objects in the scene.
Creates an ARAnchorManager with a VRDisplay. Allows the adding of THREE.Object3Ds to be tracked and updated accurately as scene understanding improves via anchors. Extends EventTarget
, so subscribe to events via:
anchorManager.addEventListener('anchorsupdated', e => {
e.anchors.forEach(obj => console.log('updated', obj));
});
Currently there's only the anchorsupdated
event has an anchors
property containing an array
of all updated THREE.Object3Ds when an anchor update occurs.
Takes a THREE.Object3D and sets an anchor at its current position. If anchor is updated, the
object will be updated accordingly, and a anchorsupdated
event will be fired on the ARAnchorManager. Returns the ARAnchorManager.
Removes the anchor from THREE.Object3D and will no longer be updated when an anchor changes. Returns a boolean indicating if the object was being tracked initially.
Creates a THREE.Mesh reticle to render via hit tests with the VRDisplay.
Performs a hit test at x
and y
normalized coordinates and lerps the reticle
to the position. Usually called every frame to perform a hit test and cause the reticle
to "trace" along surfaces for placing additional objects.
A subclass of THREE.PerspectiveCamera, used to create a perspective camera that matches
your device's perspective and keep the projection matrix in sync with a device. Use
this camera to render your three.js objects ontop of an AR see through camera. If a vrDisplay
is not provided, or not an AR-capable display, falls back to a regular THREE.PerspectiveCamera
with supplied values. Only the projectionMatrix
is updated if using an AR-capable device,
and the fov
, aspect
, near
, far
properties are not applicable.
If given a VRDisplay in constructor, generates the projection matrix from the API to match the native camera intrinsics. To use the cached projection matrix, just access the projectionMatrix
property instead.
Creates an ARDebug panel to display hit and pose information. Use getElement()
to return the element managed by the ARDebug panel to inject into your content. Optionally takes THREE.Scene scene
, needed for rendering of planes via showPlanes: true
.
config
is defined with defaults as follows:
config = {
showPoseStatus: true,
showLastHit: true,
showPlanes: false,
};
Opens the ARDebug panel.
Closes the ARDebug panel.
Returns the HTMLElement for the debug panel to inject into the content.
Not a constructor but an object storing several utility functions listed below.
Returns a promise that resolves to a VRDisplay with AR capabilities or null if device is unsupported.
Takes a VRDisplay instance and returns a boolean whether or not this is considered an AR display. Will most likely be featured-based in the future.
Takes a VRDisplay instance and returns a boolean whether or not this is a Tango-backed/ARCore Android device.
Takes a VRDisplay instance and returns a boolean whether or not this is an ARKit-based iOS device.
Takes configuration to load an OBJ model, and optionally a path for an MTL material and returns a promise resolving to a THREE.Group loaded with the appropriate material. Can be used on downloaded models from Poly.
config
takes the following properties:
objPath
: path to the OBJ model. Required.mtlPath
: path to the MTL material. Optional.OBJLoader
: A constructor for THREE's OBJLoader. Defaults towindow.THREE.OBJLoader
. Useful to specify when in an ES6 module environment.MTLLoader
: A constructor for THREE's MTLLoader. Defaults towindow.THREE.MTLLoader
. Useful to specify when in an ES6 module environment.
Takes a THREE.Object3D and a VRHit object from a VRDisplay.prototype.hitTest
call, and
positions, and optionally orients, the object to the hit's model matrix. Optionally can use
easing to lerp between the object's current transform to the hit's transform.
Generates an element and injects into the DOM a message notifying the user that their browser does not support prototype AR features. See examples of common usage.