UNPKG

threex

Version:

Game Extensions for three.js http://www.threejsgames.com/extensions/

107 lines (96 loc) 4.1 kB
<!DOCTYPE html> <script src="../../../vendor/three.js/build/three.min.js"></script> <!-- includes for THREE.EffectComposer --> <script src="../../../vendor/three.js/examples/js/postprocessing/EffectComposer.js"></script> <script src="../../../vendor/three.js/examples/js/postprocessing/RenderPass.js"></script> <script src="../../../vendor/three.js/examples/js/postprocessing/ShaderPass.js"></script> <script src="../../../vendor/three.js/examples/js/postprocessing/MaskPass.js"></script> <script src="../../../vendor/three.js/examples/js/postprocessing/SavePass.js"></script> <script src="../../../vendor/three.js/examples/js/shaders/CopyShader.js"></script> <!-- includes for threex.glow --> <script src="../../../vendor/three.js/examples/js/shaders/HorizontalBlurShader.js"></script> <script src="../../../vendor/three.js/examples/js/shaders/VerticalBlurShader.js"></script> <script src="../threex.glowkeycolor.js"></script> <script src="../threex.glowrenderer.js"></script> <!-- include for threex.glowdatgui --> <script src='../../../vendor/three.js/examples/js/libs/dat.gui.min.js'></script> <script src="../threex.glowdatgui.js"></script> <!-- Start the code itself --> <body style='margin: 0px; background-color: #bbbbbb;overflow: hidden;'><script> // init renderer var renderer = new THREE.WebGLRenderer({ antialias : true }); renderer.setSize( window.innerWidth, window.innerHeight ); document.body.appendChild( renderer.domElement ); var updateFcts = []; var scene = new THREE.Scene(); // init camera var camera = new THREE.PerspectiveCamera(45, window.innerWidth / window.innerHeight, 1, 1000 ); camera.position.z = 3; var keyColor = new THREE.Color('hotpink') // var keyColor = new THREE.Color(0x88ccff) var glowColor = new THREE.Color('blue') var glowColor = new THREE.Color('white') var glowColor = new THREE.Color('white') var geometry = new THREE.TorusGeometry( 0.5-0.15, 0.15, 32, 16) var geometry = new THREE.SphereGeometry( 0.5, 32, 16) var material = new THREE.MeshNormalMaterial() // var material = new THREE.MeshBasicMaterial({ // color : keyColor // }); var mesh = new THREE.Mesh( geometry, material ) mesh.scale.set(1,1,1).multiplyScalar(2) // mesh.visible = false scene.add( mesh ) var meshWire = new THREE.Mesh(geometry.clone(), new THREE.MeshBasicMaterial({ color : keyColor, wireframe : true, wireframeLinewidth : 4, }) ) meshWire.scale.multiplyScalar(1.001) mesh.add( meshWire ) var geometry = new THREE.CubeGeometry(1, 1, 1) var material = new THREE.MeshNormalMaterial() var torus1 = new THREE.Mesh( geometry, material ) torus1.position.x = 0.5; torus1.scale.set(1,1,1).multiplyScalar(1/2) mesh.add( torus1 ) var geometry = new THREE.CubeGeometry( 1, 1, 1) var material = new THREE.MeshNormalMaterial() var torus2 = new THREE.Mesh( geometry, material ) torus2.position.x = -0.5; torus2.scale.set(1,1,1).multiplyScalar(1/2) scene.add( torus2 ) updateFcts.push(function(delta, now){ mesh.rotation.x += 0.005; mesh.rotation.y += 0.01; }) ////////////////////////////////////////////////////////////////////////////////// // init glow // ////////////////////////////////////////////////////////////////////////////////// var glowRenderer = new THREEx.GlowRenderer(renderer, camera, scene, keyColor, glowColor) updateFcts.push(function(delta, now){ glowRenderer.update(delta, now) }) // updateFcts.push(function(delta, now){ // renderer.render(scene,camera) // }) ////////////////////////////////////////////////////////////////////////////////// // loop runner // ////////////////////////////////////////////////////////////////////////////////// var lastTimeMsec= null requestAnimationFrame(function animate(nowMsec){ // keep looping requestAnimationFrame( animate ); // measure time lastTimeMsec = lastTimeMsec || nowMsec-1000/60 var deltaMsec = Math.min(200, nowMsec - lastTimeMsec) lastTimeMsec = nowMsec // call each update function updateFcts.forEach(function(updateFn){ updateFn(deltaMsec/1000, nowMsec/1000) }) }) </script></body>