Camera

Other topics

Remarks:

When not in VR mode, userHeight translates the camera up to approximate average height of human eye level. The injected camera has this set to 1.6 (meters). When entering VR, this height offset is removed such that we used absolute position returned from the VR headset. The offset is convenient for experiences that work both in and out of VR, as well as making experiences look decent from a desktop screen as opposed to clipping the ground if the headset was resting on the ground.

When exiting VR, the camera will restore its rotation to its rotation before it entered VR. This is so when we exit VR, the rotation of the camera is back to normal for a desktop screen.

Default camera

A camera situated at the average height of human eye level (1.6 meters or 1.75 yard or 5.25 feet).

<a-entity camera="userHeight: 1.6" look-controls></a-entity>

Changing the Active Camera

When the active property gets toggled, the component will notify the camera system to change the current camera used by the renderer:

var secondCameraEl = document.querySelector('#second-camera');
secondCameraEl.setAttribute('camera', 'active', true);

Fixing Entities to the Camera

To fix entities onto the camera such that they stay within view no matter where the user looks, you can attach those entities as a child of the camera. Use cases might be a heads-up display (HUD).

<a-entity camera look-controls>
  <a-entity geometry="primitive: plane; height: 0.2; width: 0.2" position="0 0 -1"
            material="color: gray; opacity: 0.5"></a-entity>
</a-entity>

Note that you should use HUDs sparingly as they cause irritation and eye strain in VR. Consider integrating menus into the fabric of the world itself. If you do create a HUD, make sure that the HUD is more in the center of the field of view such that the user does not have to strain their eyes to read it.

a-camera primitive

The camera primitive determines what the user sees. We can change the viewport by modifying the camera entity’s position and rotation.

Note that by default, the camera origin will be at 0 1.6 0 in desktop mode and 0 0 0 in VR mode. Read about the camera.userHeight property.

<a-scene>
  <a-box></a-box>
  <a-camera></a-camera>
</a-scene>

Manually Positioning the Camera

To position the camera, set the position on a wrapper . Don’t set the position directly on the camera primitive because controls will quickly override the set position:

<a-entity position="0 0 5">
  <a-camera></a-camera>
</a-entity>

Syntax:

  • <a-entity camera></a-entity>
  • <a-camera></a-camera>

Parameters:

PropertyDescription
activeWhether the camera is the active camera in a scene with more than one camera.
farCamera frustum far clipping plane.
fovField of view (in degrees).
nearCamera frustum near clipping plane.
userHeightHow much height to add to the camera when not in VR mode. The default camera has this set to 1.6 (meters, to represent average eye level.).
zoomZoom factor of the camera.

Contributors

Topic Id: 10181

Example Ids: 31214,31215,31216,31217,31218

This site is not affiliated with any of the contributors.