UNPKG

threex

Version:

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

116 lines (105 loc) 4.84 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/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.glow.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> <!-- includes for the examples to blend the output of threex.glow --> <script src="../../../vendor/three.js/examples/js/shaders/BlendShader.js"></script> <!-- Start the code itself --> <body style='margin: 0px; background-color: #bbbbbb;overflow: hidden;'><script> // init renderer var renderer = new THREE.WebGLRenderer(); 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 geometry = new THREE.TorusGeometry( 0.5-0.15, 0.15) var material = new THREE.MeshNormalMaterial() var mesh = new THREE.Mesh( geometry, material ) mesh.scale.set(1,1,1).multiplyScalar(2) scene.add( mesh ) mesh.userData.domClasses += ' glowing ' 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 materialOn = new THREE.MeshBasicMaterial() materialOn.color.set(0x88ccff) var materialOff = new THREE.MeshBasicMaterial() materialOff.color.set('black') var glow = new THREEx.Glow(renderer, camera) glow.copyScene(scene, function(srcObject){ var domClasses = srcObject.userData.domClasses var glowing = domClasses && domClasses.match(/glowing/) var material = glowing ? materialOn : materialOff return material }) // add a DAT.gui for find tuning new THREEx.addGlow2DatGui(glow) ////////////////////////////////////////////////////////////////////////////////// // blend main scene with glow.renderTexture // ////////////////////////////////////////////////////////////////////////////////// var composer = new THREE.EffectComposer(renderer); // add Render Pass var effect = new THREE.RenderPass(scene, camera); composer.addPass( effect ); // add Blend Pass - to blend with glow.renderTarget var effect = new THREE.ShaderPass( THREE.BlendShader, 'tDiffuse1'); effect.uniforms['tDiffuse2' ].value = glow.renderTarget; effect.uniforms['mixRatio' ].value = 0.5; effect.uniforms['opacity' ].value = 2; composer.addPass( effect ); // mark the last pass as ```renderToScreen``` composer.passes[composer.passes.length-1].renderToScreen = true; ////////////////////////////////////////////////////////////////////////////////// // render the scene // ////////////////////////////////////////////////////////////////////////////////// updateFcts.push(function(delta, now){ glow.update(delta) composer.render(delta) }) ////////////////////////////////////////////////////////////////////////////////// // 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>