---
### 20 Minutes into the Future with
## Google Cardboard
### and JavaScript
---
# Hello
## I'm Max Glenister
### @omgmog on the Internet
---
data:image/s3,"s3://crabby-images/f1d28/f1d2827320ad22a5d7c04e5818ee367783a40aac" alt=""
## SusHack
### 2013 — 2015
---
data:image/s3,"s3://crabby-images/4525b/4525bdebb44293ee6e863f164a810e699474a0ae" alt=""
#### Pretty cool.
---
data:image/s3,"s3://crabby-images/c81b4/c81b49619d96054ac2f42482bcebda0039bb31a2" alt=""
## The Future
### 2015 — ?
---
### In your pocket is a VR device.
---
data:image/s3,"s3://crabby-images/0f16b/0f16baf743911dff7b25867b0d8445aa3c11b457" alt=""
---
### Most phones contain a lot of sensors...
---
## Camera
---
## Touch Screen
---
## GPS
---
## WiFi
---
## Microphone
---
## Ambient Light Sensor
---
## Accelerometer
---
## Magnetometer
---
## Gyroscope
---
## ...
---
data:image/s3,"s3://crabby-images/d804a/d804a075cb41be1156abd4770b6ee9f5f8eb552c" alt=""
---
### How can we use this for VR?
---
data:image/s3,"s3://crabby-images/3f830/3f8309ac2c48a7308cde728b224533b4961af69e" alt=""
---
data:image/s3,"s3://crabby-images/f5c58/f5c58ef90eb5925f9bd7df34401459aefdf628a1" alt=""
---
data:image/s3,"s3://crabby-images/ed742/ed742fad60282c168f0f393516c107b8fc40c0ab" alt=""
---
- Geolocation
- Device Orientation
- Fullscreen
- getUserMedia
- Web Audio
- WebGL
---
data:image/s3,"s3://crabby-images/07356/0735606054d8483654605e9fa480dd51979c4b97" alt=""
### Geolocation
---
``` javascript
navigator.geolocation.getCurrentPosition(function (pos) {
console.log(pos.coords.latitude);
console.log(pos.coords.longitude);
});
```
---
---
data:image/s3,"s3://crabby-images/bcf24/bcf24d462c45abf31060a941514c53632d02628b" alt=""
---
data:image/s3,"s3://crabby-images/a1f7f/a1f7fde70a461a00ace7c0d46b65d46704063478" alt=""
### Device Orientation
---
#### Rotation on X-axis
_Pitch_ or _Beta_ (β) range of -180° to 180°
---
#### Rotation on Y-axis
_Roll_ or _Gamma_ (γ) range of -90° to 90°
---
#### Rotation on Z-axis
_Yaw_ or _Alpha_ (α) range of 0° to 360°
---
``` javascript
window.addEventListener('deviceorientation',
function (e) {
console.log(e.gamma);
console.log(e.beta);
console.log(e.alpha);
},
false
);
```
---
data:image/s3,"s3://crabby-images/1a723/1a723f53736540b3641d4d330388f26a37ed14f5" alt=""
### Fullscreen
---
data:image/s3,"s3://crabby-images/faff2/faff24eba372c3db4ec0bbe6900e01a2c9512855" alt=""
---
``` javascript
var button = document.querySelector('button');
button.addEventListener('click',
function (e) {
document.body.requestFullScreen();
}
);
```
---
data:image/s3,"s3://crabby-images/1a214/1a2147709a3f0f97a89cca93036675ffae42d371" alt=""
### getUserMedia
---
``` javascript
navigator.getUserMedia(
// Constraints
{ video: true, audio: false },
// Success function
function (stream) {
var video = document.querySelector('video');
video.src = window.URL.createObjectURL(stream);
video.onloadedmetadata = function(e) {
// Stream loaded, do some stuff
};
},
// Error function
function (err) {
console.log(err);
}
);
```
---
---
data:image/s3,"s3://crabby-images/7f20f/7f20f109cffa040b987eea274862e69206862205" alt=""
### Web Audio
---
``` javascript
// Set up the audio context
var context = new AudioContext();
// Create an oscillator
var oscillator = context.createOscillator();
// Connect the oscillator to our playback device
oscillator.connect(context.destination);
// Start the sound output
oscillator.start();
```
---
---
``` javascript
var context = new AudioContext();
var file = 'demo.wav';
var request = new XMLHttpRequest();
var source;
request.open('GET', file, true);
request.responseType = 'arraybuffer';
request.onload = function () {
source = context.createBufferSource();
context.decodeAudioData(request.response, function (buffer) {
source.buffer = buffer;
source.connect(context.destination);
source.start(context.currentTime);
});
};
request.send();
```
---
---
data:image/s3,"s3://crabby-images/ebb6e/ebb6e9daa9e95820b33d33f971dacb09253416a4" alt=""
### WebGL
---
data:image/s3,"s3://crabby-images/36165/36165d2ec9c477b3fb7381bafe6984750942e4b9" alt=""
### WebGL
---
data:image/s3,"s3://crabby-images/c1747/c17473d309de75c1f7c494b6f274cb04f66556b8" alt=""
### WebGL (with three.js)
---
## This bit is really simple!
---
``` javascript
// Set it all up...
var width = 600, height = 300, aspect = width/height;
var scene = new THREE.Scene();
var renderer = new THREE.WebGLRenderer({
alpha: true, antialias: true, logarithmicDepthBuffer: true
});
renderer.setSize( width, height );
document.body.appendChild(renderer.domElement);
// ... Continued
```
---
``` javascript
// Create a cube...
var cubeGeometry = new THREE.BoxGeometry(10, 10, 10);
var cubeMaterial = new THREE.MeshBasicMaterial({color: 0x000000});
var cube = new THREE.Mesh(cubeGeometry, cubeMaterial);
scene.add(cube);
// Add some edges...
var cubeEdges = new THREE.EdgesHelper(cube, 0xff0000);
cubeEdges.material.linewidth = 5;
scene.add(cubeEdges);
// ... Continued
```
---
``` javascript
// Lights...
var ambientLight = new THREE.AmbientLight(0xffffff);
scene.add(ambientLight);
var pointLight = new THREE.PointLight(0xffffff, 6, 40);
pointLight.lookAt(cube.position);
scene.add(pointLight);
// Camera...
var camera = new T.PerspectiveCamera(35, aspect, 1, 1000);
camera.position.set(20, 20, 20);
camera.lookAt(scene.position);
// ... Continued
```
---
``` javascript
// Action!
function render() {
cube.rotation.x += 0.04;
requestAnimationFrame(render);
renderer.render(scene, camera);
}
render();
```
---
---
---
### Making it work in 3D
---
``` javascript
// Include the StereoEffect.js file
// After setting up your renderer
effect = new THREE.StereoEffect(renderer);
effect.eyeSeparation = 1; // Set the IPD
effect.setSize( width, height );
// Instead of calling renderer.render(scene, camera)
effect.render(scene, camera)
```
---
---
## INFORMATION
OVERLOAD
---
data:image/s3,"s3://crabby-images/78851/788514a6680f9be16b9e4a43f5a7bbab669ddaa3" alt=""
---
data:image/s3,"s3://crabby-images/d6601/d660137bc9f492804206d467c5f9007ef76a1f36" alt=""
---
data:image/s3,"s3://crabby-images/859ff/859ffb96a78a1c4800e6672d26d33990c25c648a" alt=""
### Google Cardboard
---
data:image/s3,"s3://crabby-images/1e5a5/1e5a5b6d6fe5ca0de00ed13e0ba9f5a535112f77" alt=""
---
data:image/s3,"s3://crabby-images/003e6/003e62901a51cdded39646acbc12f80166a7ddc6" alt=""
---
data:image/s3,"s3://crabby-images/bdbc5/bdbc534b5b96f3764d4fdeed3d863bbbc59e3eab" alt=""
---
---
## Some demos
---
---
### These are all available online
## [blog.omgmog.net/jscard.xyz](https://blog.omgmog.net/jscard.xyz)
---
## Lastly...
---
### Consider UX
I've made a list of resources...
[github.com/omgmog/ui-ux-vr](https://github.com/omgmog/ui-ux-vr)
---
## I've been Max Glenister
# Thanks