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(); } }