442 lines
33 KiB
JavaScript
442 lines
33 KiB
JavaScript
var Nodes = {
|
|
|
|
// Settings
|
|
density: 6,
|
|
|
|
drawDistance: 1,
|
|
baseRadius: 2,
|
|
maxLineThickness: 4,
|
|
reactionSensitivity: 4,
|
|
lineThickness: 5,
|
|
scaleX: 0.5,
|
|
scaleY: 0.5,
|
|
|
|
points: [],
|
|
mouse: {
|
|
x: -1000,
|
|
y: -1000,
|
|
down: false
|
|
},
|
|
|
|
animation: null,
|
|
|
|
canvas: null,
|
|
context: null,
|
|
|
|
imageInput: null,
|
|
bgImage: null,
|
|
bgCanvas: null,
|
|
bgContext: null,
|
|
bgContextPixelData: null,
|
|
stage: new PIXI.Container(),
|
|
manager: null,
|
|
renderer: null,
|
|
texture: null,
|
|
newmouse: null,
|
|
theta: null,
|
|
blackhole: false,
|
|
mouseDisabled: false,
|
|
|
|
siteWidth: window.innerWidth,
|
|
siteHeight: window.innerHeight,
|
|
headerHeight: null,
|
|
|
|
is_firefox: ((navigator.userAgent.toLowerCase().indexOf('firefox') > -1) ? false : true),
|
|
|
|
isLoaded : false,
|
|
|
|
currentNum : 0,
|
|
|
|
|
|
multipleInit: function(particle_array) {
|
|
|
|
//console.log(particle_array[currentNum]);
|
|
|
|
Nodes.particleLoop(particle_array, 'next');
|
|
|
|
var loopInterval = setInterval( function() { Nodes.particleLoop(particle_array, 'next') }, 14000);
|
|
|
|
$(".prev-arrow a").click(function() {
|
|
clearInterval(loopInterval);
|
|
Nodes.particleLoop(particle_array, 'prev');
|
|
return false;
|
|
});
|
|
|
|
$(".next-arrow a").click(function() {
|
|
clearInterval(loopInterval);
|
|
Nodes.particleLoop(particle_array, 'next');
|
|
return false;
|
|
});
|
|
|
|
|
|
|
|
},
|
|
|
|
particleLoop: function(particle_array, direction) {
|
|
|
|
//var currentNum = 0;
|
|
var arrayLength = particle_array.length - 1;
|
|
|
|
if (Nodes.isLoaded == true) {
|
|
document.body.removeChild( Nodes.renderer.view );
|
|
Nodes.stage.removeChildren();
|
|
cancelAnimationFrame( Nodes.animation );
|
|
$('#bgCanvas').remove();
|
|
}
|
|
|
|
Nodes.init(particle_array[Nodes.currentNum].drawnImage,
|
|
particle_array[Nodes.currentNum].particleDensity,
|
|
particle_array[Nodes.currentNum].particleWidth,
|
|
particle_array[Nodes.currentNum].particleHeight);
|
|
|
|
$(".particle-link a").html(particle_array[Nodes.currentNum].linkTitle);
|
|
$(".particle-link a").attr('href', particle_array[Nodes.currentNum].linkUrl);
|
|
|
|
Nodes.isLoaded = true;
|
|
|
|
console.log(Nodes.currentNum, arrayLength);
|
|
|
|
if (direction == 'prev') {
|
|
|
|
if (Nodes.currentNum == 0) {
|
|
Nodes.currentNum = arrayLength;
|
|
}
|
|
else if (Nodes.currentNum <= arrayLength) {
|
|
Nodes.currentNum--;
|
|
}
|
|
|
|
}
|
|
else {
|
|
|
|
if (Nodes.currentNum < arrayLength) {
|
|
Nodes.currentNum++;
|
|
}
|
|
else if (Nodes.currentNum == arrayLength) {
|
|
Nodes.currentNum = 0;
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
},
|
|
|
|
init: function(image, particleDensity, particleWidth, particleHeight) {
|
|
|
|
//################################################
|
|
// Adding Pixi.js stuff
|
|
// create a renderer instance
|
|
var rendererOptions = {
|
|
transparent: this.is_firefox
|
|
}
|
|
|
|
this.scaleX = particleWidth;
|
|
this.scaleY = particleHeight;
|
|
this.headerHeight = $('#header').outerHeight(true);
|
|
this.siteHeight = window.innerHeight - Nodes.headerHeight;
|
|
|
|
// prevents particles chugging on mobile devices
|
|
if (this.siteWidth > 480) {
|
|
this.density = parseInt(particleDensity);
|
|
}
|
|
else {
|
|
this.density = 7;
|
|
}
|
|
|
|
//this.siteHeight = (this.siteWidth < 480 ? this.siteHeight - 120 : this.siteHeight - 100);
|
|
|
|
if (Nodes.isLoaded == false) {
|
|
this.renderer = PIXI.autoDetectRenderer(this.siteWidth, this.siteHeight, rendererOptions);
|
|
}
|
|
this.renderer.backgroundColor = 0xe9e9e9;
|
|
this.manager = this.renderer.plugins.interaction;
|
|
// add the renderer view element to the DOM
|
|
document.body.appendChild(this.renderer.view);
|
|
// create a texture from an image path
|
|
this.texture = PIXI.Texture.fromImage("");
|
|
this.newmouse = this.manager.mouse;
|
|
this.newmouse.global.x = -1000;
|
|
this.newmouse.global.y = -1000;
|
|
|
|
window.onresize = function(event) {
|
|
Nodes.headerHeight = $('#header').outerHeight(true);
|
|
Nodes.siteWidth = window.innerWidth;
|
|
Nodes.siteHeight = window.innerHeight - Nodes.headerHeight;
|
|
Nodes.onWindowResize();
|
|
}
|
|
|
|
$(this.renderer.view).mousedown(function() {
|
|
Nodes.blackhole = true;
|
|
});
|
|
$(this.renderer.view).mouseup(function() {
|
|
Nodes.blackhole = false;
|
|
});
|
|
this.stage.interactive = true;
|
|
|
|
Nodes.stage.touchmove = Nodes.onTouchMove;
|
|
window.addEventListener("touchend", Nodes.onTouchEnd);
|
|
window.addEventListener("mouseout", Nodes.onTouchEnd);
|
|
|
|
|
|
// Load initial input image (the chrome logo!)
|
|
this.loadData(image);
|
|
|
|
|
|
|
|
Nodes.newmouse.global.x = this.siteWidth / 2;
|
|
Nodes.newmouse.global.y = this.siteHeight / 2;
|
|
Nodes.blackhole = true;
|
|
Nodes.reactionSensitivity = -100;
|
|
|
|
setTimeout(function() {
|
|
|
|
Nodes.mouseDisabled = true;
|
|
Nodes.newmouse.global.x = -1000;
|
|
Nodes.newmouse.global.y = -1000;
|
|
Nodes.blackhole = false;
|
|
Nodes.reactionSensitivity = 6;
|
|
|
|
} , 1000);
|
|
|
|
},
|
|
|
|
preparePoints: function() {
|
|
|
|
// Clear the current points
|
|
this.points = [];
|
|
|
|
var width, height, i, j;
|
|
|
|
var colors = this.bgContextPixelData.data;
|
|
|
|
for (i = 0; i < this.siteHeight; i += this.density) {
|
|
|
|
for (j = 0; j < this.siteWidth; j += this.density) {
|
|
|
|
var pixelPosition = (j + i * this.bgContextPixelData.width) * 4;
|
|
|
|
// Dont use whiteish pixels
|
|
if (colors[pixelPosition] > 200 && (colors[pixelPosition + 1]) > 200 && (colors[pixelPosition + 2]) > 200 || colors[pixelPosition + 3] === 0) {
|
|
continue;
|
|
}
|
|
|
|
var color = 'rgba(' + colors[pixelPosition] + ',' + colors[pixelPosition + 1] + ',' + colors[pixelPosition + 2] + ',' + '1)';
|
|
this.points.push({
|
|
x: j,
|
|
y: i,
|
|
originalX: j,
|
|
originalY: i,
|
|
color: color
|
|
});
|
|
|
|
}
|
|
}
|
|
},
|
|
|
|
|
|
updatePoints: function() {
|
|
|
|
var i, currentPoint, theta, distance;
|
|
|
|
if (this.blackhole == true) {
|
|
this.reactionSensitivity = -10;
|
|
}
|
|
else if (this.blowup == true) {
|
|
this.reactionSensitivity = 300;
|
|
}
|
|
else if (this.isNear() == true) {
|
|
this.reactionSensitivity = 6;
|
|
}
|
|
else {
|
|
this.reactionSensitivity = 0;
|
|
}
|
|
|
|
//console.log(this.isNear());
|
|
|
|
for (i = 0; i < this.stage.children.length; i++) {
|
|
|
|
originalPoint = this.points[i];
|
|
currentPoint = this.stage.children[i];
|
|
|
|
this.theta = Math.atan2(currentPoint.position.y - this.newmouse.global.y,
|
|
currentPoint.position.x - this.newmouse.global.x);
|
|
|
|
distance = this.reactionSensitivity * 100 / Math.sqrt((this.newmouse.global.x - currentPoint.position.x) * (this.newmouse.global.x - currentPoint.position.x) +
|
|
(this.newmouse.global.y - currentPoint.position.y) * (this.newmouse.global.y - currentPoint.position.y));
|
|
|
|
this.stage.children[i].position.x += Math.round(100 * (Math.cos(this.theta) * distance + (originalPoint.originalX - currentPoint.position.x) * 0.05)) / 100;
|
|
this.stage.children[i].position.y += Math.round(100 * (Math.sin(this.theta) * distance + (originalPoint.originalY - currentPoint.position.y) * 0.05)) / 100;
|
|
}
|
|
},
|
|
|
|
|
|
// to check if the mouse is near the bgImage
|
|
isNear: function() {
|
|
|
|
var siteWidth = this.siteWidth;
|
|
var siteHeight = this.siteHeight;
|
|
|
|
var x = this.newmouse.global.x,
|
|
y = this.newmouse.global.y,
|
|
|
|
imageWidth = this.bgImage.width,
|
|
imageHeight = this.bgImage.height,
|
|
|
|
left = ((siteWidth/2) - (imageWidth/2)) - (siteWidth/10),
|
|
right = ((siteWidth/2) + (imageWidth/2)) + (siteWidth/10);
|
|
|
|
return (x > left && x < right);
|
|
|
|
},
|
|
|
|
drawPoints: function() {
|
|
// render the points
|
|
this.renderer.render(this.stage);
|
|
},
|
|
|
|
draw: function() {
|
|
this.animation = requestAnimationFrame(function() {
|
|
Nodes.draw()
|
|
});
|
|
|
|
this.updatePoints();
|
|
this.drawPoints();
|
|
},
|
|
|
|
clear: function() {
|
|
this.canvas.width = this.canvas.width;
|
|
},
|
|
|
|
// The filereader has loaded the image... add it to image object to be drawn
|
|
loadData: function(data) {
|
|
|
|
this.bgImage = new Image;
|
|
//this.bgImage.src = data;
|
|
this.bgImage.crossOrigin = "anonymous";
|
|
this.bgImage.src = data;
|
|
|
|
this.bgImage.onload = function() {
|
|
|
|
//this
|
|
Nodes.drawImageToBackground();
|
|
}
|
|
},
|
|
|
|
// Image is loaded... draw to bg canvas
|
|
drawImageToBackground: function() {
|
|
|
|
this.bgCanvas = document.createElement('canvas');
|
|
this.bgCanvas.setAttribute('id', 'bgCanvas');
|
|
this.bgCanvas.width = this.siteWidth;
|
|
this.bgCanvas.height = this.siteHeight;
|
|
|
|
var newWidth, newHeight;
|
|
|
|
// If the image is too big for the screen... scale it down.
|
|
if (this.bgImage.width > this.bgCanvas.width - 100 || this.bgImage.height > this.bgCanvas.height - 100) {
|
|
//console.log('smaller!');
|
|
var maxRatio = Math.max(this.bgImage.width / this.bgCanvas.width, this.bgImage.height / this.bgCanvas.height);
|
|
newWidth = this.bgImage.width / maxRatio;
|
|
newHeight = this.bgImage.height / maxRatio;
|
|
|
|
} else {
|
|
newWidth = this.bgImage.width;
|
|
newHeight = this.bgImage.height;
|
|
}
|
|
|
|
|
|
|
|
// Draw to background canvas
|
|
Nodes.bgContext = Nodes.bgCanvas.getContext('2d');
|
|
Nodes.bgContext.drawImage(Nodes.bgImage, ((Nodes.siteWidth - newWidth) / 2), ((Nodes.siteHeight - newHeight) / 2), newWidth, newHeight);
|
|
Nodes.bgContextPixelData = Nodes.bgContext.getImageData(0, 0, Nodes.bgCanvas.width, Nodes.bgCanvas.height);
|
|
|
|
Nodes.preparePoints();
|
|
Nodes.draw();
|
|
Nodes.drawPixies();
|
|
},
|
|
|
|
drawPixies: function() {
|
|
var i, currentPoint;
|
|
|
|
for (i = 0; i < this.points.length; i++) {
|
|
currentPoint = this.points[i];
|
|
|
|
// pixi.js particles
|
|
//var texture = PIXI.Texture.fromImage("bunny.png");
|
|
var bunny = new PIXI.Sprite(this.texture);
|
|
bunny.scale = new PIXI.Point(this.scaleX, this.scaleY);
|
|
bunny.interactive = true;
|
|
// center the sprites anchor point
|
|
bunny.anchor.x = 0.5;
|
|
bunny.anchor.y = 0.5;
|
|
// move the sprite t the center of the screen
|
|
bunny.position.x = currentPoint.x;
|
|
bunny.position.y = currentPoint.y;
|
|
Nodes.stage.addChild(bunny);
|
|
}
|
|
|
|
|
|
|
|
// Nodes.newmouse.global.x = this.siteWidth / 2;
|
|
// Nodes.newmouse.global.y = this.siteHeight / 2;
|
|
// Nodes.blackhole = true;
|
|
// Nodes.reactionSensitivity = -100;
|
|
|
|
// setTimeout(function() {
|
|
// // Nodes.manager = Nodes.renderer.plugins.interaction;
|
|
// // Nodes.newmouse = Nodes.manager.mouse;
|
|
|
|
// Nodes.mouseDisabled = true;
|
|
// Nodes.newmouse.global.x = -1000;
|
|
// Nodes.newmouse.global.y = -1000;
|
|
// Nodes.blackhole = false;
|
|
// Nodes.reactionSensitivity = 6;
|
|
|
|
// } , 1000);
|
|
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
onTouchEnd: function(event) {
|
|
// add pixi swipe interaction manager stuff here
|
|
Nodes.newmouse.global.x = -1000;
|
|
Nodes.newmouse.global.y = -1000;
|
|
},
|
|
|
|
|
|
// this isn't working
|
|
onTouchMove: function(event) {
|
|
if (Nodes.mouseDisabled == true) {
|
|
Nodes.newmouse.global.x = event.data.global.x;
|
|
Nodes.newmouse.global.y = event.data.global.y;
|
|
console.log(Nodes.manager.eventData);
|
|
}
|
|
|
|
},
|
|
|
|
mouseDown: function(event) {
|
|
Nodes.reactionSensitivity = -10;
|
|
Nodes.mouse.down = true;
|
|
},
|
|
|
|
mouseUp: function(event) {
|
|
Nodes.reactionSensitivity = 6;
|
|
Nodes.mouse.down = false;
|
|
},
|
|
|
|
|
|
// Resize and redraw the canvas.
|
|
onWindowResize: function() {
|
|
this.stage.removeChildren();
|
|
cancelAnimationFrame( this.animation );
|
|
this.renderer.resize(this.siteWidth, this.siteHeight);
|
|
this.drawImageToBackground();
|
|
}
|
|
|
|
}
|