Skip to content

Instantly share code, notes, and snippets.

@AaronGhent
Created September 7, 2017 05:19
Show Gist options
  • Save AaronGhent/94306ccafb5bc27808617a939ccdeef1 to your computer and use it in GitHub Desktop.
Save AaronGhent/94306ccafb5bc27808617a939ccdeef1 to your computer and use it in GitHub Desktop.
[EmberJS] Doobs Cloudy Day + ThreeJS

import Ember from 'ember';
/* global THREE */
/* global Detector */
/* jshint -W079 */
var start_time = Date.now();
var camera = null;
var position = null;
var renderer = null;
var mouseX = 0;
var mouseY = 0;
var scene = null;
var speed = 0.03;
var rotation = 0;
var requestAnimationFrameRequestID = null;
var requestAnimationFrame = window.requestAnimationFrame || window.mozRequestAnimationFrame || window.webkitRequestAnimationFrame || window.msRequestAnimationFrame;
var cancelAnimationFrame = window.cancelAnimationFrame || window.mozCancelAnimationFrame;
export default Ember.Component.extend({
classNames: ['doobs-cloudy-day-background'],
tagName: 'div',
containerGfx: null,
mesh: null,
geometry: null,
material: null,
didInsertElement() {
if (!Detector.webgl) {
Detector.addGetWebGLMessage();
} else {
this.initGfx();
}
},
initGfx() {
this.containerGfx = this.$().get(0);
// Bg gradient
var canvas = document.createElement('canvas');
canvas.width = 32;
canvas.height = window.innerHeight;
var context = canvas.getContext('2d');
var gradient = context.createLinearGradient(0, 0, 0, canvas.height);
gradient.addColorStop(0, "#1e4877");
gradient.addColorStop(0.5, "#4584b4");
context.fillStyle = gradient;
context.fillRect(0, 0, canvas.width, canvas.height);
this.containerGfx.style.background = 'url(' + canvas.toDataURL('image/png') + ')';
this.containerGfx.style.backgroundSize = '32px 100%';
camera = new THREE.PerspectiveCamera(30, window.innerWidth / window.innerHeight, 1, 3000 );
camera.position.z = 6000;
scene = new THREE.Scene();
this.geometry = new THREE.Geometry();
var texture = THREE.ImageUtils.loadTexture('img/cloud9.png', null, animate);
texture.magFilter = THREE.LinearFilter;
texture.minFilter = THREE.LinearMipMapLinearFilter;
var fog = new THREE.Fog( 0x4584b4, - 100, 3000 );
this.material = new THREE.ShaderMaterial({
uniforms: {
"map": { type: "t", value: texture },
"fogColor" : { type: "c", value: fog.color },
"fogNear" : { type: "f", value: fog.near },
"fogFar" : { type: "f", value: fog.far },
},
vertexShader: document.getElementById('vs').textContent,
fragmentShader: document.getElementById('fs').textContent,
depthWrite: false,
depthTest: false,
transparent: true
});
var plane = new THREE.Mesh(new THREE.PlaneGeometry(64, 64));
for (var i = 0; i < 8000; i++) {
plane.position.x = Math.random() * 1000 - 500;
plane.position.y = - Math.random() * Math.random() * 200 - 15;
plane.position.z = i;
plane.rotation.z = Math.random() * Math.PI;
plane.scale.x = plane.scale.y = Math.random() * Math.random() * 1.5 + 0.5;
THREE.GeometryUtils.merge(this.geometry, plane);
}
this.mesh = new THREE.Mesh(this.geometry, this.material);
scene.add(this.mesh);
this.mesh = new THREE.Mesh(this.geometry, this.material);
this.mesh.position.z = -8000;
scene.add(this.mesh);
renderer = new THREE.WebGLRenderer({ antialias: false });
renderer.setSize(window.innerWidth, window.innerHeight);
this.containerGfx.appendChild(renderer.domElement);
window.addEventListener('resize', onWindowResize, false);
},
willDestroyElement() {
this._super(...arguments);
window.removeEventListener('resize', onWindowResize, false);
cancelAnimationFrame(requestAnimationFrameRequestID);
this.geometry.dispose();
this.material.dispose();
}
});
function animate() {
position = ((Date.now() - start_time) * speed) % 8000;
camera.position.x += (mouseX - camera.position.x) * 0.01;
camera.position.y += (-mouseY - camera.position.y) * 0.01;
camera.position.z = - position + 8000;
camera.rotation.z = rotation;
renderer.render(scene, camera);
requestAnimationFrameRequestID = requestAnimationFrame(animate);
}
function onWindowResize() {
camera.aspect = window.innerWidth / window.innerHeight;
camera.updateProjectionMatrix();
renderer.setSize(window.innerWidth, window.innerHeight);
}
<div id="vs" type="x-shader/x-vertex" style="display: none;">
varying vec2 vUv;
void main() {
vUv = uv;
gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );
}
</div>
<div id="fs" type="x-shader/x-fragment" style="display: none;">
uniform sampler2D map;
uniform vec3 fogColor;
uniform float fogNear;
uniform float fogFar;
varying vec2 vUv;
void main() {
float depth = gl_FragCoord.z / gl_FragCoord.w;
float fogFactor = smoothstep( fogNear, fogFar, depth );
gl_FragColor = texture2D( map, vUv );
gl_FragColor.w *= pow( gl_FragCoord.z, 20.0 );
gl_FragColor = mix( gl_FragColor, vec4( fogColor, gl_FragColor.w ), fogFactor );
}
</div>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment