@babylonjs/core
Version:
Getting started? Play directly with the Babylon.js API using our [playground](https://playground.babylonjs.com/). It also contains a lot of samples to learn how to use it.
37 lines • 1.79 kB
JavaScript
import { Camera } from "../../Cameras/camera.js";
import { DeviceOrientationCamera } from "../../Cameras/deviceOrientationCamera.js";
import { VRCameraMetrics } from "./vrCameraMetrics.js";
import { Vector3 } from "../../Maths/math.vector.js";
import { Node } from "../../node.js";
import { _SetVrRigMode } from "../RigModes/vrRigMode.js";
Node.AddNodeConstructor("VRDeviceOrientationFreeCamera", (name, scene) => {
return () => new VRDeviceOrientationFreeCamera(name, Vector3.Zero(), scene);
});
/**
* Camera used to simulate VR rendering (based on FreeCamera)
* @see https://doc.babylonjs.com/features/featuresDeepDive/cameras/camera_introduction#vr-device-orientation-cameras
*/
export class VRDeviceOrientationFreeCamera extends DeviceOrientationCamera {
/**
* Creates a new VRDeviceOrientationFreeCamera
* @param name defines camera name
* @param position defines the start position of the camera
* @param scene defines the scene the camera belongs to
* @param compensateDistortion defines if the camera needs to compensate the lens distortion
* @param vrCameraMetrics defines the vr metrics associated to the camera
*/
constructor(name, position, scene, compensateDistortion = true, vrCameraMetrics = VRCameraMetrics.GetDefault()) {
super(name, position, scene);
this._setRigMode = (rigParams) => _SetVrRigMode(this, rigParams);
vrCameraMetrics.compensateDistortion = compensateDistortion;
this.setCameraRigMode(Camera.RIG_MODE_VR, { vrCameraMetrics: vrCameraMetrics });
}
/**
* Gets camera class name
* @returns VRDeviceOrientationFreeCamera
*/
getClassName() {
return "VRDeviceOrientationFreeCamera";
}
}
//# sourceMappingURL=vrDeviceOrientationFreeCamera.js.map