CINXE.COM

The page you were looking for doesn't exist (404)

<!DOCTYPE html> <html> <head> <title>The page you were looking for doesn't exist (404)</title> <meta name="robots" content="noindex"> <style type="text/css"> body { background:#fafafa; font-family: 'Open Sans', sans-serif; font-weight:300; color:#979997; } * ,h1, h2, h3, h4, h5, h6, p { font-family: 'Open Sans', sans-serif; font-weight:300; } h1, h2{ text-align:center; margin:10px 0; } h1{ font-size:45px; } hgroup{ position:absolute; bottom:15%; width:100%; left:0; } a{ text-decoration:underline; cursor:pointer; } #canvas{ position:absolute; top:0; left:0; z-index:-1; //min-height:350px; } hr { border: 0; width: 60%; min-width:300px; color:#7c7e7c; background-color: #afafaf; height: 1px; } @media (max-width: 767px) { h1{ font-size:22px; } h2{ font-size:10px; } } @media (max-width: 480px) { h1, h2{ text-align:left; padding-left:30px; } h2{ font-size:18px; } hgroup{ position:absolute; top:7%; } } </style> <link href="//fonts.googleapis.com/css?family=Open+Sans:400,700" rel="stylesheet" type="text/css"> </head> <body> <canvas id="canvas"></canvas> <hgroup> <h1>The page you were looking for doesn't exist.</h1> <h2> You may have mistyped the address or the page may have moved. <a href="/" rel="nofollow">Homepage</a> </h2> </hgroup> <script> (function() { var lastTime = 0; var vendors = ['ms', 'moz', 'webkit', 'o']; for(var x = 0; x < vendors.length && !window.requestAnimationFrame; ++x) { window.requestAnimationFrame = window[vendors[x]+'RequestAnimationFrame']; window.cancelAnimationFrame = window[vendors[x]+'CancelAnimationFrame'] || window[vendors[x]+'CancelRequestAnimationFrame']; } if (!window.requestAnimationFrame) window.requestAnimationFrame = function(callback, element) { var currTime = new Date().getTime(); var timeToCall = Math.max(0, 16 - (currTime - lastTime)); var id = window.setTimeout(function() { callback(currTime + timeToCall); }, timeToCall); lastTime = currTime + timeToCall; return id; }; if (!window.cancelAnimationFrame) window.cancelAnimationFrame = function(id) { clearTimeout(id); }; }()); var Nodes = { // Settings density: 11, drawDistance: 20, baseRadius: 1.4, maxLineThickness: 0.5, reactionSensitivity: 0.5, lineThickness: 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, init: function() { // Set up the visual canvas this.canvas = document.getElementById( 'canvas' ); this.context = canvas.getContext( '2d' ); this.context.globalCompositeOperation = "lighter"; this.canvas.width = window.innerWidth; this.canvas.height = window.innerHeight; this.canvas.style.display = 'block' this.imageInput = document.createElement( 'input' ); this.imageInput.setAttribute( 'type', 'file' ); this.imageInput.style.visibility = 'hidden'; this.imageInput.addEventListener('change', this.upload, false); document.body.appendChild( this.imageInput ); this.canvas.addEventListener('mousemove', this.mouseMove, false); this.canvas.addEventListener('mousedown', this.mouseDown, false); this.canvas.addEventListener('mouseup', this.mouseUp, false); this.canvas.addEventListener('mouseout', this.mouseOut, false); window.onresize = function(event) { Nodes.canvas.width = window.innerWidth; Nodes.canvas.height = window.innerHeight; Nodes.onWindowResize(); } // Load image this.loadData( ''); }, preparePoints: function() { // Clear the current points this.points = []; var width, height, i, j; var colors = this.bgContextPixelData.data; for( i = 0; i < this.canvas.height; i += this.density ) { for ( j = 0; j < this.canvas.width; 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; for (i = 0; i < this.points.length; i++ ){ currentPoint = this.points[i]; theta = Math.atan2( currentPoint.y - this.mouse.y, currentPoint.x - this.mouse.x); if ( this.mouse.down ) { distance = this.reactionSensitivity * 200 / Math.sqrt((this.mouse.x - currentPoint.x) * (this.mouse.x - currentPoint.x) + (this.mouse.y - currentPoint.y) * (this.mouse.y - currentPoint.y)); } else { distance = this.reactionSensitivity * 100 / Math.sqrt((this.mouse.x - currentPoint.x) * (this.mouse.x - currentPoint.x) + (this.mouse.y - currentPoint.y) * (this.mouse.y - currentPoint.y)); } currentPoint.x += Math.cos(theta) * distance + (currentPoint.originalX - currentPoint.x) * 0.05; currentPoint.y += Math.sin(theta) * distance + (currentPoint.originalY - currentPoint.y) * 0.05; } }, drawLines: function() { var i, j, currentPoint, otherPoint, distance, lineThickness; for ( i = 0; i < this.points.length; i++ ) { currentPoint = this.points[i]; // Draw the dot. this.context.fillStyle = currentPoint.color; this.context.strokeStyle = currentPoint.color; for ( j = 0; j < this.points.length; j++ ){ // Distaqnce between two points. otherPoint = this.points[j]; if ( otherPoint == currentPoint ) { continue; } distance = Math.sqrt((otherPoint.x - currentPoint.x) * (otherPoint.x - currentPoint.x) + (otherPoint.y - currentPoint.y) * (otherPoint.y - currentPoint.y)); if (distance <= this.drawDistance) { this.context.lineWidth = (1 - (distance / this.drawDistance)) * this.maxLineThickness * this.lineThickness; this.context.beginPath(); this.context.moveTo(currentPoint.x, currentPoint.y); this.context.lineTo(otherPoint.x, otherPoint.y); this.context.stroke(); } } } }, drawPoints: function() { var i, currentPoint; for ( i = 0; i < this.points.length; i++ ) { currentPoint = this.points[i]; // Draw the dot. this.context.fillStyle = currentPoint.color; this.context.strokeStyle = currentPoint.color; this.context.beginPath(); this.context.arc(currentPoint.x, currentPoint.y, this.baseRadius ,0 , Math.PI*2, true); this.context.closePath(); this.context.fill(); } }, draw: function() { this.animation = requestAnimationFrame( function(){ Nodes.draw() } ); this.clear(); this.updatePoints(); this.drawLines(); 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.onload = function() { //this Nodes.drawImageToBackground(); } }, // Image is loaded... draw to bg canvas drawImageToBackground: function () { this.bgCanvas = document.createElement( 'canvas' ); this.bgCanvas.width = this.canvas.width; this.bgCanvas.height = this.canvas.height; 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) { var maxRatio = Math.max( this.bgImage.width / (this.bgCanvas.width - 100) , this.bgImage.height / (this.bgCanvas.height - 100) ); newWidth = this.bgImage.width / maxRatio; newHeight = this.bgImage.height / maxRatio; } else { newWidth = this.bgImage.width; newHeight = this.bgImage.height; } // Draw to background canvas this.bgContext = this.bgCanvas.getContext( '2d' ); this.bgContext.drawImage( this.bgImage, (this.canvas.width - newWidth) / 2, (this.canvas.height - newHeight) / 2, newWidth, newHeight); this.bgContextPixelData = this.bgContext.getImageData( 0, 0, this.bgCanvas.width, this.bgCanvas.height ); this.preparePoints(); this.draw(); }, mouseDown: function( event ){ Nodes.mouse.down = true; }, mouseUp: function( event ){ Nodes.mouse.down = false; }, mouseMove: function(event){ Nodes.mouse.x = event.offsetX || (event.layerX - Nodes.canvas.offsetLeft); Nodes.mouse.y = event.offsetY || (event.layerY - Nodes.canvas.offsetTop); }, mouseOut: function(event){ Nodes.mouse.x = -1000; Nodes.mouse.y = -1000; Nodes.mouse.down = false; }, // Resize and redraw the canvas. onWindowResize: function() { cancelAnimationFrame( this.animation ); this.drawImageToBackground(); } } setTimeout( function() { Nodes.init(); }, 10 ); </script> <script>(function(){function c(){var b=a.contentDocument||a.contentWindow.document;if(b){var d=b.createElement('script');d.innerHTML="window.__CF$cv$params={r:'8e911b97481281d1',t:'MTczMjY5OTkxMy4wMDAwMDA='};var a=document.createElement('script');a.nonce='';a.src='/cdn-cgi/challenge-platform/scripts/jsd/main.js';document.getElementsByTagName('head')[0].appendChild(a);";b.getElementsByTagName('head')[0].appendChild(d)}}if(document.body){var a=document.createElement('iframe');a.height=1;a.width=1;a.style.position='absolute';a.style.top=0;a.style.left=0;a.style.border='none';a.style.visibility='hidden';document.body.appendChild(a);if('loading'!==document.readyState)c();else if(window.addEventListener)document.addEventListener('DOMContentLoaded',c);else{var e=document.onreadystatechange||function(){};document.onreadystatechange=function(b){e(b);'loading'!==document.readyState&&(document.onreadystatechange=e,c())}}}})();</script></body> </html>

Pages: 1 2 3 4 5 6 7 8 9 10