<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0"> <title>three.js css3d - youtube</title> <style> html, body { height: 100%; } body { background-color: #000000; margin: 0; font-family: Arial; overflow: hidden; } #search { position: absolute; bottom: 30px; width: 100%; text-align: center; } #search input { color: #ffffff; background-color: transparent; border: 1px solid #0080ff; padding: 10px; font-size: 20px; text-transform: uppercase; -webkit-border-radius: 0px; /* workaround for ios safari */ } #search button { color: #0080ff; background-color: transparent; border: 1px solid #0080ff; padding: 10px; font-size: 20px; text-transform: uppercase; cursor: pointer; } </style> </head> <body> <script src="../build/three.min.js"></script> <script src="js/libs/tween.min.js"></script> <script src="js/renderers/CSS3DRenderer.js"></script> <div id="container"></div> <div id="search"><input id="query" type="text" value="cats"><button id="button">search</button></div> <script> var camera, scene, renderer; var player; var auto = true; var Element = function ( entry ) { var dom = document.createElement( 'div' ); dom.style.width = '480px'; dom.style.height = '360px'; var image = document.createElement( 'img' ); image.style.position = 'absolute'; image.style.width = '480px'; image.style.height = '360px'; image.src = entry.media$group.media$thumbnail[ 2 ].url; dom.appendChild( image ); var button = document.createElement( 'img' ); button.style.position = 'absolute'; button.style.left = ( ( 480 - 86 ) / 2 ) + 'px'; button.style.top = ( ( 360 - 61 ) / 2 ) + 'px'; button.style.visibility = 'hidden'; button.style.WebkitFilter = 'grayscale()'; button.src = ''; dom.appendChild( button ); var blocker = document.createElement( 'div' ); blocker.style.position = 'absolute'; blocker.style.width = '480px'; blocker.style.height = '360px'; blocker.style.background = 'rgba(0,0,0,0.5)'; blocker.style.cursor = 'pointer'; dom.appendChild( blocker ); var object = new THREE.CSS3DObject( dom ); object.position.x = Math.random() * 4000 - 2000; // object.position.y = Math.random() * 2000 - 1000; object.position.y = 3000; object.position.z = Math.random() * - 5000; // image.addEventListener( 'load', function ( event ) { button.style.visibility = 'visible'; new TWEEN.Tween( object.position ) .to( { y: Math.random() * 2000 - 1000 }, 2000 ) .easing( TWEEN.Easing.Exponential.Out ) .start(); }, false ); dom.addEventListener( 'mouseover', function () { button.style.WebkitFilter = ''; blocker.style.background = 'rgba(0,0,0,0)'; }, false ); dom.addEventListener( 'mouseout', function () { button.style.WebkitFilter = 'grayscale()'; blocker.style.background = 'rgba(0,0,0,0.75)'; }, false ); dom.addEventListener( 'click', function ( event ) { event.stopPropagation(); auto = false; if ( player !== undefined ) { player.parentNode.removeChild( player ); player = undefined; } player = document.createElement( 'iframe' ); player.style.position = 'absolute'; player.style.width = '480px'; player.style.height = '360px'; player.style.border = '0px'; player.src = 'http://www.youtube.com/embed/' + entry.id.$t.split( ':' ).pop() + '?rel=0&autoplay=1&controls=1&showinfo=0'; this.appendChild( player ); // var prev = object.position.z + 400; new TWEEN.Tween( camera.position ) .to( { x: object.position.x, y: object.position.y - 25 }, 1500 ) .easing( TWEEN.Easing.Exponential.Out ) .start(); new TWEEN.Tween( { value: prev } ) .to( { value: 0 }, 2000 ) .onUpdate( function () { move( this.value - prev ); prev = this.value; } ) .easing( TWEEN.Easing.Exponential.Out ) .start(); }, false ); return object; }; init(); animate(); function init() { camera = new THREE.PerspectiveCamera( 75, window.innerWidth / window.innerHeight, 1, 5000 ); camera.position.y = - 25; scene = new THREE.Scene(); renderer = new THREE.CSS3DRenderer(); renderer.setSize( window.innerWidth, window.innerHeight ); renderer.domElement.style.position = 'absolute'; renderer.domElement.style.top = 0; document.getElementById( 'container' ).appendChild( renderer.domElement ); // var query = document.getElementById( 'query' ); query.addEventListener( 'keyup', function ( event ) { if ( event.keyCode === 13 ) { search( query.value ); } }, false ); var button = document.getElementById( 'button' ); button.addEventListener( 'click', function ( event ) { search( query.value ); }, false ); if ( window.location.hash.length > 0 ) { query.value = window.location.hash.substr( 1 ); } search( query.value ); document.body.addEventListener( 'mousewheel', onMouseWheel, false ); document.body.addEventListener( 'click', function ( event ) { auto = true; if ( player !== undefined ) { player.parentNode.removeChild( player ); player = undefined; } new TWEEN.Tween( camera.position ) .to( { x: 0, y: - 25 }, 1500 ) .easing( TWEEN.Easing.Exponential.Out ) .start(); }, false ); window.addEventListener( 'resize', onWindowResize, false ); } function search( query ) { window.location.hash = query; for ( var i = 0, l = scene.children.length; i < l; i ++ ) { ( function () { var object = scene.children[ i ]; var delay = i * 15; new TWEEN.Tween( object.position ) .to( { y: - 2000 }, 1000 ) .delay( delay ) .easing( TWEEN.Easing.Exponential.In ) .onComplete( function () { scene.remove( object ); } ) .start(); } )(); } var request = new XMLHttpRequest(); request.addEventListener( 'load', onData, false ); request.open( 'GET', 'https://gdata.youtube.com/feeds/api/videos?v=2&alt=json&max-results=50&q=' + query, true ); request.send( null ); } function onData( event ) { var data = JSON.parse( event.target.responseText ); var entries = data.feed.entry; // console.log( entries ); for ( var i = 0; i < entries.length; i ++ ) { ( function ( data, time ) { setTimeout( function () { scene.add( new Element( data ) ); }, time ); } )( entries[ i ], i * 15 ); } } function move( delta ) { for ( var i = 0; i < scene.children.length; i ++ ) { var object = scene.children[ i ]; object.position.z += delta; if ( object.position.z > 0 ) { object.position.z -= 5000; } else if ( object.position.z < - 5000 ) { object.position.z += 5000; } } } function onMouseWheel( event ) { move( event.wheelDelta ); } function onWindowResize() { camera.aspect = window.innerWidth / window.innerHeight; camera.updateProjectionMatrix(); renderer.setSize( window.innerWidth, window.innerHeight ); } function animate() { requestAnimationFrame( animate ); TWEEN.update(); if ( auto === true ) { move( 1 ); } renderer.render( scene, camera ); } </script> </body> </html>