diff --git a/index.html b/index.html
index 842b6e6..27bba4d 100644
--- a/index.html
+++ b/index.html
@@ -40,6 +40,17 @@
CardiVR
+
+
+
+
+
+
+
+
+
+
+
diff --git a/libraries/cardboard-vr-display.js b/libraries/cardboard-vr-display.js
index f451349..b2efbf1 100644
--- a/libraries/cardboard-vr-display.js
+++ b/libraries/cardboard-vr-display.js
@@ -80,7 +80,11 @@
* THE SOFTWARE.
*/
-var MainFunc = (function () { 'use strict';
+(function (global, factory) {
+ typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
+ typeof define === 'function' && define.amd ? define(factory) :
+ (global.CardboardVRDisplay = factory());
+}(this, (function () { 'use strict';
var asyncGenerator = function () {
function AwaitValue(value) {
@@ -3462,6 +3466,4 @@ CardboardVRDisplay.VRDisplay = VRDisplay;
return CardboardVRDisplay;
-})();
-
-export default MainFunc;
\ No newline at end of file
+})));
diff --git a/src/main.js b/src/main.js
index 723e546..bbe04be 100644
--- a/src/main.js
+++ b/src/main.js
@@ -2,8 +2,6 @@
* @author crazyh / https://github.com/crazyh2
*/
-import * as THREE from "../libraries/three.module.min.js";
-import CardboardVRDisplay from "../libraries/cardboard-vr-display.js";
import { Render } from "./world/render.js";
class Main {
diff --git a/src/screens/main/SettingsMenu.js b/src/screens/main/SettingsMenu.js
index 00080ae..2b7dde0 100644
--- a/src/screens/main/SettingsMenu.js
+++ b/src/screens/main/SettingsMenu.js
@@ -2,7 +2,6 @@
* @author crazyh / https://github.com/crazyh2
*/
-import * as THREE from "../../../libraries/three.module.min.js";
import { Screen } from "../screen.js";
class SettingsMenu extends Screen {
diff --git a/src/screens/main/appsMenu.js b/src/screens/main/appsMenu.js
index 263dbc3..fe63553 100644
--- a/src/screens/main/appsMenu.js
+++ b/src/screens/main/appsMenu.js
@@ -2,7 +2,6 @@
* @author crazyh / https://github.com/crazyh2
*/
-import * as THREE from "../../../libraries/three.module.min.js";
import { Screen } from "../screen.js";
class AppsMenu extends Screen {
diff --git a/src/screens/main/mainMenu.js b/src/screens/main/mainMenu.js
index 2936f18..6d07986 100644
--- a/src/screens/main/mainMenu.js
+++ b/src/screens/main/mainMenu.js
@@ -2,7 +2,6 @@
* @author crazyh / https://github.com/crazyh2
*/
-import * as THREE from "../../../libraries/three.module.min.js";
import { Screen } from "../screen.js";
class MainMenu extends Screen {
diff --git a/src/screens/screen.js b/src/screens/screen.js
index 7bc5447..178a993 100644
--- a/src/screens/screen.js
+++ b/src/screens/screen.js
@@ -2,8 +2,6 @@
* @author crazyh / https://github.com/crazyh2
*/
-import * as THREE from "../../libraries/three.module.min.js";
-
class Screen {
constructor(root) {
this.root = root;
diff --git a/src/screens/screenManager.js b/src/screens/screenManager.js
index ea1d776..1d8336d 100644
--- a/src/screens/screenManager.js
+++ b/src/screens/screenManager.js
@@ -2,8 +2,6 @@
* @author crazyh / https://github.com/crazyh2
*/
-import * as THREE from "../../libraries/three.module.min.js";
-
class ScreenManager {
constructor(root) {
this.root = root;
diff --git a/src/screens/start/actionsInfo.js b/src/screens/start/actionsInfo.js
index 2e3345b..899bc13 100644
--- a/src/screens/start/actionsInfo.js
+++ b/src/screens/start/actionsInfo.js
@@ -2,7 +2,6 @@
* @author crazyh / https://github.com/crazyh2
*/
-import * as THREE from "../../../libraries/three.module.min.js";
import { Screen } from "../screen.js";
import { TextBox } from "../../../utils/TextBox.js";
diff --git a/src/screens/start/controllerAlign.js b/src/screens/start/controllerAlign.js
index eb36e5d..0947760 100644
--- a/src/screens/start/controllerAlign.js
+++ b/src/screens/start/controllerAlign.js
@@ -2,9 +2,6 @@
* @author crazyh / https://github.com/crazyh2
*/
-import * as THREE from "../../../libraries/three.module.min.js";
-import { MTLLoader } from "../../../utils/MTLLoader.js";
-import { OBJLoader } from "../../../utils/OBJLoader.js";
import { Screen } from "../screen.js";
import { TextBox } from "../../../utils/TextBox.js";
@@ -46,11 +43,11 @@ class ControllerAlignScreen extends Screen {
renderGroup.add( mesh );
- var mtlLoader = new MTLLoader();
+ var mtlLoader = new THREE.MTLLoader();
mtlLoader.load("./assets/objects/gear_vr_controller.mtl", function(materials) {
materials.preload();
- var objLoader = new OBJLoader();
+ var objLoader = new THREE.OBJLoader();
objLoader.setMaterials(materials);
objLoader.load("./assets/objects/gear_vr_controller.obj", function(object) {
object.position.z = -0.8;
diff --git a/src/screens/start/controllerInfo.js b/src/screens/start/controllerInfo.js
index c9a7e25..68e67df 100644
--- a/src/screens/start/controllerInfo.js
+++ b/src/screens/start/controllerInfo.js
@@ -2,9 +2,6 @@
* @author crazyh / https://github.com/crazyh2
*/
-import * as THREE from "../../../libraries/three.module.min.js";
-import { MTLLoader } from "../../../utils/MTLLoader.js";
-import { OBJLoader } from "../../../utils/OBJLoader.js";
import { Screen } from "../screen.js";
import { TextBox } from "../../../utils/TextBox.js";
@@ -46,11 +43,11 @@ class ControllerInfoScreen extends Screen {
renderGroup.add( mesh );
- var mtlLoader = new MTLLoader();
+ var mtlLoader = new THREE.MTLLoader();
mtlLoader.load("./assets/objects/gear_vr_controller.mtl", function(materials) {
materials.preload();
- var objLoader = new OBJLoader();
+ var objLoader = new THREE.OBJLoader();
objLoader.setMaterials(materials);
objLoader.load("./assets/objects/gear_vr_controller.obj", function(object) {
object.position.z = -0.8;
diff --git a/src/screens/start/welcome.js b/src/screens/start/welcome.js
index 2d3c591..a6698c2 100644
--- a/src/screens/start/welcome.js
+++ b/src/screens/start/welcome.js
@@ -2,7 +2,6 @@
* @author crazyh / https://github.com/crazyh2
*/
-import * as THREE from "../../../libraries/three.module.min.js";
import { Screen } from "../screen.js";
import { TextBox } from "../../../utils/TextBox.js";
import { ActionsInfoScreen } from "./actionsInfo.js";
diff --git a/src/world/render.js b/src/world/render.js
index ba56623..8c5ca2f 100644
--- a/src/world/render.js
+++ b/src/world/render.js
@@ -2,7 +2,6 @@
* @author crazyh / https://github.com/crazyh2
*/
-import * as THREE from "../../libraries/three.module.min.js";
import { Scene } from "./scene.js";
class Render {
diff --git a/src/world/scene.js b/src/world/scene.js
index b4a3565..7cf6a4e 100644
--- a/src/world/scene.js
+++ b/src/world/scene.js
@@ -2,10 +2,6 @@
* @author crazyh / https://github.com/crazyh2
*/
-import * as THREE from "../../libraries/three.module.min.js";
-import { DeviceOrientationControls } from "../../utils/DeviceOrientationControls.js";
-import { CardboardActions } from "../../utils/CardboardActions.js";
-import { VREffect } from "../../utils/VREffect.js";
import { WelcomeScreen } from "../screens/start/welcome.js";
import { ScreenManager } from "./../screens/screenManager.js";
@@ -31,10 +27,10 @@ class Scene {
var actionControls = new CardboardActions(this.camera);
// Apply VR headset rotational data to camera.
- var controls = new DeviceOrientationControls(this.camera);
+ var controls = new THREE.DeviceOrientationControls(this.camera);
// Apply VR stereo rendering to renderer.
- var effect = new VREffect(this.top.renderer);
+ var effect = new THREE.VREffect(this.top.renderer);
effect.setSize(window.innerWidth, window.innerHeight);
// Kick off the render loop.
diff --git a/utils/CardboardActions.js b/utils/CardboardActions.js
index cc14be1..7ca1551 100644
--- a/utils/CardboardActions.js
+++ b/utils/CardboardActions.js
@@ -27,5 +27,3 @@ class CardboardActions {
}
};
};
-
-export { CardboardActions };
\ No newline at end of file
diff --git a/utils/DeviceOrientationControls.js b/utils/DeviceOrientationControls.js
index 10279af..7b5093d 100644
--- a/utils/DeviceOrientationControls.js
+++ b/utils/DeviceOrientationControls.js
@@ -3,152 +3,154 @@
* @author crazyh / https://github.com/crazyh2
*/
-import * as THREE from "../libraries/three.module.min.js";
+( function () {
-const _zee = new THREE.Vector3(0, 0, 1);
+ const _zee = new THREE.Vector3( 0, 0, 1 );
-const _euler = new THREE.Euler();
+ const _euler = new THREE.Euler();
-const _q0 = new THREE.Quaternion();
+ const _q0 = new THREE.Quaternion();
-const _q1 = new THREE.Quaternion(- Math.sqrt(0.5), 0, 0, Math.sqrt(0.5)); // - PI/2 around the x-axis
+ const _q1 = new THREE.Quaternion( - Math.sqrt( 0.5 ), 0, 0, Math.sqrt( 0.5 ) ); // - PI/2 around the x-axis
-const _changeEvent = {
- type: 'change'
-};
+ const _changeEvent = {
+ type: 'change'
+ };
-class DeviceOrientationControls extends THREE.EventDispatcher {
+ class DeviceOrientationControls extends THREE.EventDispatcher {
- constructor(object) {
+ constructor( object ) {
- super();
+ super();
- if (window.isSecureContext === false) {
+ if ( window.isSecureContext === false ) {
- console.error('THREE.DeviceOrientationControls: DeviceOrientationEvent is only available in secure contexts (https)');
+ console.error( 'THREE.DeviceOrientationControls: DeviceOrientationEvent is only available in secure contexts (https)' );
- }
-
- const scope = this;
- const EPS = 0.000001;
- const lastQuaternion = new THREE.Quaternion();
- this.object = object;
- this.object.rotation.reorder('YXZ');
- this.enabled = true;
- this.deviceOrientation = {};
- this.screenOrientation = 0;
- this.alphaOffset = 0; // radians
-
- const onDeviceOrientationChangeEvent = function (event) {
-
- scope.deviceOrientation = event;
-
- };
-
- const onScreenOrientationChangeEvent = function () {
+ }
- scope.screenOrientation = window.orientation || 0;
+ const scope = this;
+ const EPS = 0.000001;
+ const lastQuaternion = new THREE.Quaternion();
+ this.object = object;
+ this.object.rotation.reorder( 'YXZ' );
+ this.enabled = true;
+ this.deviceOrientation = {};
+ this.screenOrientation = 0;
+ this.alphaOffset = 0; // radians
- }; // The angles alpha, beta and gamma form a set of intrinsic Tait-Bryan angles of type Z-X'-Y''
+ const onDeviceOrientationChangeEvent = function ( event ) {
+ scope.deviceOrientation = event;
- const setObjectQuaternion = function (quaternion, alpha, beta, gamma, orient) {
+ };
- _euler.set(beta, alpha, - gamma, 'YXZ'); // 'ZXY' for the device, but 'YXZ' for us
+ const onScreenOrientationChangeEvent = function () {
+ scope.screenOrientation = window.orientation || 0;
- quaternion.setFromEuler(_euler); // orient the device
+ }; // The angles alpha, beta and gamma form a set of intrinsic Tait-Bryan angles of type Z-X'-Y''
- quaternion.multiply(_q1); // camera looks out the back of the device, not the top
- quaternion.multiply(_q0.setFromAxisAngle(_zee, - orient)); // adjust for screen orientation
+ const setObjectQuaternion = function ( quaternion, alpha, beta, gamma, orient ) {
- };
+ _euler.set( beta, alpha, - gamma, 'YXZ' ); // 'ZXY' for the device, but 'YXZ' for us
- this.connect = function () {
- onScreenOrientationChangeEvent(); // run once on load
- // iOS 13+
+ quaternion.setFromEuler( _euler ); // orient the device
- if (window.DeviceOrientationEvent && typeof (window.DeviceOrientationEvent.requestPermission) === "function") {
- const permissionPrompt = function () {
- window.DeviceOrientationEvent.requestPermission().then(function (response) {
+ quaternion.multiply( _q1 ); // camera looks out the back of the device, not the top
- if (response == 'granted') {
+ quaternion.multiply( _q0.setFromAxisAngle( _zee, - orient ) ); // adjust for screen orientation
- window.addEventListener('orientationchange', onScreenOrientationChangeEvent);
- window.addEventListener('deviceorientation', onDeviceOrientationChangeEvent);
+ };
- }
+ this.connect = function () {
- }).catch(function (error) {
+ onScreenOrientationChangeEvent(); // run once on load
+ // iOS 13+
- console.error('THREE.DeviceOrientationControls: Unable to use DeviceOrientation API:', error);
+ if ( window.DeviceOrientationEvent && typeof(window.DeviceOrientationEvent.requestPermission) === "function" ) {
+ const permissionPrompt = function() {
+ window.DeviceOrientationEvent.requestPermission().then( function ( response ) {
+
+ if ( response == 'granted' ) {
+
+ window.addEventListener( 'orientationchange', onScreenOrientationChangeEvent );
+ window.addEventListener( 'deviceorientation', onDeviceOrientationChangeEvent );
+
+ }
+
+ } ).catch( function ( error ) {
+
+ console.error( 'THREE.DeviceOrientationControls: Unable to use DeviceOrientation API:', error );
+
+ } );
+ document.body.removeEventListener("click", permissionPrompt);
+ };
- });
- document.body.removeEventListener("click", permissionPrompt);
- };
+ document.body.addEventListener("click", permissionPrompt);
- document.body.addEventListener("click", permissionPrompt);
+ } else {
- } else {
+ window.addEventListener( 'orientationchange', onScreenOrientationChangeEvent );
+ window.addEventListener( 'deviceorientation', onDeviceOrientationChangeEvent );
- window.addEventListener('orientationchange', onScreenOrientationChangeEvent);
- window.addEventListener('deviceorientation', onDeviceOrientationChangeEvent);
+ }
- }
+ scope.enabled = true;
- scope.enabled = true;
+ };
- };
+ this.disconnect = function () {
- this.disconnect = function () {
+ window.removeEventListener( 'orientationchange', onScreenOrientationChangeEvent );
+ window.removeEventListener( 'deviceorientation', onDeviceOrientationChangeEvent );
+ scope.enabled = false;
- window.removeEventListener('orientationchange', onScreenOrientationChangeEvent);
- window.removeEventListener('deviceorientation', onDeviceOrientationChangeEvent);
- scope.enabled = false;
+ };
- };
+ this.update = function () {
- this.update = function () {
+ if ( scope.enabled === false ) return;
+ const device = scope.deviceOrientation;
- if (scope.enabled === false) return;
- const device = scope.deviceOrientation;
+ if ( device ) {
- if (device) {
+ const alpha = device.alpha ? THREE.Math.degToRad( device.alpha ) + scope.alphaOffset : 0; // Z
- const alpha = device.alpha ? THREE.Math.degToRad(device.alpha) + scope.alphaOffset : 0; // Z
+ const beta = device.beta ? THREE.Math.degToRad( device.beta ) : 0; // X'
- const beta = device.beta ? THREE.Math.degToRad(device.beta) : 0; // X'
+ const gamma = device.gamma ? THREE.Math.degToRad( device.gamma ) : 0; // Y''
- const gamma = device.gamma ? THREE.Math.degToRad(device.gamma) : 0; // Y''
+ const orient = scope.screenOrientation ? THREE.Math.degToRad( scope.screenOrientation ) : 0; // O
- const orient = scope.screenOrientation ? THREE.Math.degToRad(scope.screenOrientation) : 0; // O
+ setObjectQuaternion( scope.object.quaternion, alpha, beta, gamma, orient );
- setObjectQuaternion(scope.object.quaternion, alpha, beta, gamma, orient);
+ if ( 8 * ( 1 - lastQuaternion.dot( scope.object.quaternion ) ) > EPS ) {
- if (8 * (1 - lastQuaternion.dot(scope.object.quaternion)) > EPS) {
+ lastQuaternion.copy( scope.object.quaternion );
+ scope.dispatchEvent( _changeEvent );
- lastQuaternion.copy(scope.object.quaternion);
- scope.dispatchEvent(_changeEvent);
+ }
}
- }
+ };
- };
+ this.dispose = function () {
- this.dispose = function () {
+ scope.disconnect();
- scope.disconnect();
+ };
- };
+ this.connect();
- this.connect();
+ }
}
-}
+ THREE.DeviceOrientationControls = DeviceOrientationControls;
-export { DeviceOrientationControls };
\ No newline at end of file
+} )();
\ No newline at end of file
diff --git a/utils/MTLLoader.js b/utils/MTLLoader.js
index b704755..8a495b8 100644
--- a/utils/MTLLoader.js
+++ b/utils/MTLLoader.js
@@ -4,17 +4,15 @@
* @author angelxuanchang
*/
-import * as THREE from "../libraries/three.module.min.js";
-
-var MTLLoader = function ( manager ) {
+THREE.MTLLoader = function ( manager ) {
this.manager = ( manager !== undefined ) ? manager : THREE.DefaultLoadingManager;
};
-MTLLoader.prototype = {
+THREE.MTLLoader.prototype = {
- constructor: MTLLoader,
+ constructor: THREE.MTLLoader,
/**
* Loads and parses a MTL asset from a URL.
@@ -103,7 +101,7 @@ MTLLoader.prototype = {
* Parses a MTL file.
*
* @param {String} text - Content of MTL file
- * @return {MTLLoader.MaterialCreator}
+ * @return {THREE.MTLLoader.MaterialCreator}
*
* @see setPath setTexturePath
*
@@ -161,7 +159,7 @@ MTLLoader.prototype = {
}
- var materialCreator = new MTLLoader.MaterialCreator( this.texturePath || this.path, this.materialOptions );
+ var materialCreator = new THREE.MTLLoader.MaterialCreator( this.texturePath || this.path, this.materialOptions );
materialCreator.setCrossOrigin( this.crossOrigin );
materialCreator.setManager( this.manager );
materialCreator.setMaterials( materialsInfo );
@@ -186,7 +184,7 @@ MTLLoader.prototype = {
* @constructor
*/
-MTLLoader.MaterialCreator = function ( baseUrl, options ) {
+THREE.MTLLoader.MaterialCreator = function ( baseUrl, options ) {
this.baseUrl = baseUrl || '';
this.options = options;
@@ -200,9 +198,9 @@ MTLLoader.MaterialCreator = function ( baseUrl, options ) {
};
-MTLLoader.MaterialCreator.prototype = {
+THREE.MTLLoader.MaterialCreator.prototype = {
- constructor: MTLLoader.MaterialCreator,
+ constructor: THREE.MTLLoader.MaterialCreator,
crossOrigin: 'Anonymous',
@@ -551,5 +549,3 @@ MTLLoader.MaterialCreator.prototype = {
}
};
-
-export { MTLLoader };
\ No newline at end of file
diff --git a/utils/OBJLoader.js b/utils/OBJLoader.js
index b22c0c9..2c4845f 100644
--- a/utils/OBJLoader.js
+++ b/utils/OBJLoader.js
@@ -2,9 +2,7 @@
* @author mrdoob / http://mrdoob.com/
*/
-import * as THREE from "../libraries/three.module.min.js";
-
-var OBJLoader = ( function () {
+THREE.OBJLoader = ( function () {
// o object_name | g group_name
var object_pattern = /^[og]\s*(.+)?/;
@@ -670,5 +668,3 @@ var OBJLoader = ( function () {
return OBJLoader;
} )();
-
-export { OBJLoader };
\ No newline at end of file
diff --git a/utils/TextBox.js b/utils/TextBox.js
index ccc727f..831e978 100644
--- a/utils/TextBox.js
+++ b/utils/TextBox.js
@@ -1,5 +1,3 @@
-import * as THREE from "../libraries/three.module.min.js";
-
/**
* Text = 3D Text
*
diff --git a/utils/VREffect.js b/utils/VREffect.js
index 460bfe0..9a2482e 100644
--- a/utils/VREffect.js
+++ b/utils/VREffect.js
@@ -8,9 +8,7 @@
* Chromium: https://webvr.info/get-chrome
*/
-import * as THREE from "../libraries/three.module.min.js";
-
-var VREffect = function ( renderer, onError ) {
+THREE.VREffect = function ( renderer, onError ) {
var vrDisplay, vrDisplays;
var eyeTranslationL = new THREE.Vector3();
@@ -60,7 +58,7 @@ var VREffect = function ( renderer, onError ) {
var scope = this;
- var rendererSize = new THREE.Vector2( 0, 0 ); renderer.getSize(rendererSize);
+ var rendererSize = renderer.getSize();
var rendererUpdateStyle = false;
var rendererPixelRatio = renderer.getPixelRatio();
@@ -123,7 +121,7 @@ var VREffect = function ( renderer, onError ) {
if ( ! wasPresenting ) {
rendererPixelRatio = renderer.getPixelRatio();
- rendererSize = new THREE.Vector2( 0, 0 ); renderer.getSize(rendererSize);
+ rendererSize = renderer.getSize();
renderer.setPixelRatio( 1 );
renderer.setSize( eyeWidth * 2, eyeHeight, false );
@@ -237,12 +235,12 @@ var VREffect = function ( renderer, onError ) {
if ( vrDisplay && scope.isPresenting ) {
- var autoUpdate = scene.matrixWorldAutoUpdate;
+ var autoUpdate = scene.autoUpdate;
if ( autoUpdate ) {
scene.updateMatrixWorld();
- scene.matrixWorldAutoUpdate = false;
+ scene.autoUpdate = false;
}
@@ -255,7 +253,7 @@ var VREffect = function ( renderer, onError ) {
// When rendering we don't care what the recommended size is, only what the actual size
// of the backbuffer is.
- var size = new THREE.Vector2( 0, 0 ); renderer.getSize(size);
+ var size = renderer.getSize();
var layers = vrDisplay.getLayers();
var leftBounds;
var rightBounds;
@@ -389,7 +387,7 @@ var VREffect = function ( renderer, onError ) {
if ( autoUpdate ) {
- scene.matrixWorldAutoUpdate = true;
+ scene.autoUpdate = true;
}
@@ -456,8 +454,8 @@ var VREffect = function ( renderer, onError ) {
// The eye's model matrix in head space is the inverse of headToEyeMatrix we calculated above.
- eyeMatrixL.invert();//getInverse( eyeMatrixL );
- eyeMatrixR.invert();//getInverse( eyeMatrixR );
+ eyeMatrixL.getInverse( eyeMatrixL );
+ eyeMatrixR.getInverse( eyeMatrixR );
}
@@ -533,5 +531,3 @@ var VREffect = function ( renderer, onError ) {
}
};
-
-export { VREffect };
\ No newline at end of file