Toggle navigation
Sign Up
Log In
Explore
Works
Folders
Tools
Collections
Artists
Groups
Groups
Topics
Tasks
Tasks
Jobs
Teams
Jobs
Recommendation
More Effects...
JS
// shim layer with setTimeout fallback window.requestAnimFrame = (function(){ return window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || function( callback ){ window.setTimeout(callback, 1000 / 60); }; })(); // Utilities //--- function mapRange(value, srcRange, dstRange){ //(value, array, array) if (value < srcRange[0] || value > srcRange[1]){ // value is outside source range return return NaN; } var srcMax = srcRange[1] - srcRange[0], dstMax = dstRange[1] - dstRange[0], adjValue = value - srcRange[0]; return (adjValue * dstMax / srcMax) + dstRange[0]; } function dist( x1, y1, x2, y2 ){ var xs = (x2 - x1) * (x2 - x1); var ys = (y2 - y1) * (y2 - y1); return Math.sqrt( xs + ys ); } function constrain(aNumber, aMin, aMax) { return aNumber > aMax ? aMax : aNumber < aMin ? aMin : aNumber; } function getAngle( x1, y1, x2, y2 ){ var deltaY = y2 - y1, deltaX = x2 - x1; return Math.atan2(deltaY, deltaX) * 180 / Math.PI; // In Degrees } // Library //--- // Particle function Particle(depth, direction, x, y, width, height) { this.image = new Image(); this.image.src = ''; this.imagealt = new Image(); this.imagealt.src = ''; this.depth = depth; this.direction = direction; this.x = x; this.y = y; this.width = width; this.height = height; if(this.depth == 'close') { this.width = 200; this.height = 200; } else if(this.depth == 'mid') { this.width = 100; this.height = 100; } else if(this.depth == 'far') { this.width = 50; this.height = 50; } } Particle.prototype.update = function(velo, angle){ this.x = this.x + Math.cos(angle) * velo; this.y = this.y + Math.sin(angle) * velo; if( this.x > $window.width() + world.padding ) { this.x = -world.padding; } if( this.y > $window.height() + world.padding ) { this.y = -world.padding; } if( this.x < -world.padding ) { this.x = $window.width() + world.padding; } if( this.y < -world.padding ) { this.y = $window.height() + world.padding; } } Particle.prototype.draw = function(context){ if(this.depth == 'far'){ context.globalAlpha = 0.2; } else if(this.depth == 'mid') { context.globalAlpha = 0.6; } if(this.direction == 'right') { context.drawImage(this.image, this.x, this.y, this.width, this.height); context.globalAlpha = 1; }else if(this.direction == 'left') { context.drawImage(this.imagealt, this.x, this.y, this.width, this.height); context.globalAlpha = 1; } return this; } //setup world var canvas = document.getElementById('canvas'), ctx = canvas.getContext('2d'), $window = $(window), images = []; var world = { padding: 200, mousePos: { x: $window.width()/2 + 60, // Default mouse position on page load y: $window.height()/2 }, center: { x: $window.width()/2, y: $window.height()/2 }, angle: function(){ var a = getAngle(world.mousePos.x, world.mousePos.y, world.center.x, world.center.y), radians = a * (Math.PI / 180); return radians; }, velocity: function(){ var d = dist(world.mousePos.x, world.mousePos.y, world.center.x, world.center.y), c = constrain(d, 0, $window.width()/2), v = mapRange(c, [0,$window.width()/2], [0,5]); return v; } } canvas.width = $window.width(); canvas.height = $window.height(); // Iterator to create 30 particles for (var i = 0; i < 30; i++) { var depth, direction = mapRange(Math.random(), [0,1], [0,1]); // Assign Depth if(i <= 10){ depth = 'far'; } else if (i <= 20){ depth = 'mid'; } else if (i <= 30){ depth = 'close'; } // Assign Direction if(direction >= 0.5) { direction = 'left'; } else if(direction <= 0.5) { direction = 'right'; } if(images.length == 0){ var x = mapRange(Math.random(), [0,1], [-world.padding,$window.width()+ world.padding]), y = mapRange(Math.random(), [0,1], [-world.padding,$window.height()+ world.padding]), image = new Particle(depth, direction, x, y); images.push(image); } else { testIsolation(); } function testIsolation(){ var isIsolated = false, testX = mapRange(Math.random(), [0,1], [0,$window.width()]), testY = mapRange(Math.random(), [0,1], [0,$window.height()]); console.log('testIsolation'); for (var i = 0; i < images.length; i++) { var image = images[i], distance = dist(image.x, image.y, testX, testY); if(distance < world.padding){ // console.log('testIsolation return false'); isIsolated = false; } else { // console.log('testIsolation return true'); isIsolated = true; } }; if(isIsolated == true){ console.log('isIsolate is true'); var newImage = new Particle(depth, direction, testX, testY); images.push(newImage); return; } else { console.log('rerun test isolation'); testIsolation() } } }; //draw world (function animloop(){ var velocity = world.velocity(), angle = world.angle(); requestAnimFrame(animloop); ctx.fillStyle ='#00224a'; ctx.fillRect(0, 0, $window.width(), $window.height()); for (var i = 0; i < images.length; i++) { var depth = images[i].depth; if(depth == 'far'){ images[i].update(velocity/2, angle); }else if(depth == 'mid'){ images[i].update(velocity/1.2, angle); }else { images[i].update(velocity, angle); } images[i].draw(ctx); }; })(); // Events canvas.addEventListener('mousemove', function(e){ // mouse position calculation based on when mouse moves onto canvas var rect = canvas.getBoundingClientRect(); world.mousePos = { x: e.clientX - rect.left, y: e.clientY - rect.top } });
CSS
HTML
Particles + Birds
Join Effecthub.com
Working with Global Gaming Artists and Developers!
Login
Sign Up
Or Login with Your Email Address:
Email
Password
Remember
Or Sign Up with Your Email Address:
Your Email
This field must contain a valid email
Set Password
Password should be at least 1 character
Stay informed via email