Skip to content
This repository has been archived by the owner on Mar 21, 2019. It is now read-only.

Commit

Permalink
Added snow
Browse files Browse the repository at this point in the history
  • Loading branch information
brianchirls committed Dec 16, 2014
1 parent 2a7bfe3 commit 3298d00
Show file tree
Hide file tree
Showing 5 changed files with 163 additions and 2 deletions.
Binary file added images/snowflake.png
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
2 changes: 2 additions & 0 deletions index.html
Expand Up @@ -207,6 +207,8 @@ <h1>WebVR 3D Map Experiment</h1>

<script src="js/BlueprintOutputBarTiles.js"></script>

<script src="js/snow.js"></script>

<script src="js/main.js" type="text/javascript"></script>
</body>
</html>
2 changes: 1 addition & 1 deletion js/lib/vizi.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

22 changes: 21 additions & 1 deletion js/main.js
Expand Up @@ -29,6 +29,8 @@
vrMouse,
walkControl,
cityContainer,
snow,

//octree, //for picking, collision detection
rayCaster = new THREE.Raycaster(),

Expand Down Expand Up @@ -73,6 +75,7 @@
locationCache = {},

stats,
lastTick = 0,
clock = new THREE.Clock();

function startMoving() {
Expand Down Expand Up @@ -193,7 +196,13 @@
}

function render() {
var tick = Date.now();
var tick = Date.now(),
delta = tick - lastTick;

if (!delta || delta > 1000) {
delta = 1000/60;
}
snow.time(snow.time() + delta * 0.00005);

//Mediator.publish('update', tick - lastTick, lastTick);

Expand All @@ -206,9 +215,11 @@
VIZI.Messenger.emit('controls:move', new VIZI.Point(body.position.x, body.position.z));
}

snow.visible = false;
scene.overrideMaterial = depthMaterial;
vrEffect.render(scene, camera, depthTarget, true);

snow.visible = true;
scene.overrideMaterial = null;
vrEffect.render(scene, camera, sceneTarget, true);

Expand Down Expand Up @@ -245,6 +256,15 @@
);
body.add(pointer);

snow = new THREE.Snow({
count: 300000,
minSize: 10,
maxSize: 20,
range: new THREE.Vector3(6000, 2000, 6000)
});
snow.particles.renderDepth = -100;
body.add(snow.particles);

vrControls = new THREE.VRControls( camera );
vrControls.freeze = true;

Expand Down
139 changes: 139 additions & 0 deletions js/snow.js
@@ -0,0 +1,139 @@
THREE.ShaderLib.snow = {
uniforms: {
color: { type: "c", value: new THREE.Color( 0x777777 ) },
texture: { type: "t", value: null },
globalTime: { type: "f", value: 0.0 },
alphaFalloff: { type: "f", value: 1 / 1800.0 }
},
vertexShader: [
'attribute float size;',
'attribute float time;',
'attribute vec3 customColor;',
'uniform float globalTime;',

'uniform float alphaFalloff;',

'varying vec3 vColor;',
'varying float fAlpha;',

'void main() {',

' vColor = customColor;',

' vec3 pos = position;',
//todo: offset pos by world position and then mod by range so particles repeat forever

// time
' float localTime = time + globalTime;',
' float modTime = mod( localTime, 1.0 );',
' float accTime = modTime;// * modTime;',

' pos.x += cos(modTime*8.0 + (position.z))*70.0;',
' pos.z += sin(modTime*6.0 + (position.x))*100.0;',

//todo: should fall off with distance from camera, not absolute world position
//' fAlpha = 1.0;//(pos.z) * alphaFalloff;',

' vec3 animated = vec3( pos.x, pos.y * accTime, pos.z );',

' vec4 mvPosition = modelViewMatrix * vec4( animated, 1.0 );',

' gl_PointSize = min(150.0, size * ( 150.0 / length( mvPosition.xyz ) ) );',

' gl_Position = projectionMatrix * mvPosition;',

'}'
].join("\n"),
fragmentShader: [
'uniform vec3 color;',
'uniform sampler2D texture;',

'varying vec3 vColor;',
'varying float fAlpha;',

'void main() {',

' gl_FragColor = vec4( color * vColor, 1.0 );',
' gl_FragColor = gl_FragColor * texture2D( texture, gl_PointCoord );',

'}'
].join("\n")
};

THREE.Snow = function (options) {
var snowShader = THREE.ShaderLib.snow;
var uniforms = THREE.UniformsUtils.clone( snowShader.uniforms );
var attributes = {
size: { type: 'f', value: [] },
customColor: { type: 'c', value: [] },
time: { type: 'f', value: [] },
};

var shaderMaterial = new THREE.ShaderMaterial( {
uniforms: uniforms,
attributes: attributes,
vertexShader: snowShader.vertexShader,
fragmentShader: snowShader.fragmentShader,

blending: THREE.AdditiveBlending,
depthTest: false,
transparent: true
});

options = options || {};

var count = options.count || 10000;
var minSize = options.minSize || 50;
var sizeRange = (options.maxSize || 80) - minSize;
var range = options.range || new THREE.Vector3(3000, 3000, 1800);

uniforms.texture.value = THREE.ImageUtils.loadTexture( options.flake || THREE.Snow.flake ); //todo: make configurable
//uniforms.color.value.setRGB(0, 0, 1);

var geometry = new THREE.Geometry();
//todo: http://threejs.org/docs/#Reference/Core/BufferGeometry

for ( var i = 0; i < count; i++ ) {
var vector = new THREE.Vector3(Math.random() * range.x - range.x / 2, -range.y, Math.random() * range.z);

geometry.vertices.push( vector );
}

var particles = new THREE.PointCloud( geometry, shaderMaterial );
particles.position.y = range.y / 2;
particles.position.z = -range.z / 2;

var vertices = particles.geometry.vertices;
var values_size = attributes.size.value;
var values_color = attributes.customColor.value;
var values_time = attributes.time.value;

for( var v = 0; v < vertices.length; v++ ) {
values_size[ v ] = minSize + Math.random() * sizeRange;
values_color[ v ] = new THREE.Color( 0xffffff );
values_color[ v ].setHSL(1.0, 0.0, 0.05 + Math.random() * 0.9);
values_time[ v ] = Math.random();
}

this.particles = particles;
this.position = particles.position;

this.time = function (t) {
if (t !== undefined) {
uniforms.globalTime.value = t;
}

return uniforms.globalTime.value;
};

Object.defineProperty(this, 'visible', {
get: function () {
return particles.visible;
},
set: function (val) {
particles.visible = !!val;
}
});
};

THREE.Snow.flake = '';

0 comments on commit 3298d00

Please sign in to comment.