|
@@ -0,0 +1,521 @@
|
|
|
+<!doctype html>
|
|
|
+<html lang="en">
|
|
|
+ <head>
|
|
|
+ <title>three.js webgl - physically based shading</title>
|
|
|
+ <meta charset="utf-8">
|
|
|
+ <meta name="viewport" content="width=device-width, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0">
|
|
|
+ <style>
|
|
|
+ body {
|
|
|
+ color: #222;
|
|
|
+ font-family:Monospace;
|
|
|
+ font-size:13px;
|
|
|
+ text-align:center;
|
|
|
+ font-weight: bold;
|
|
|
+
|
|
|
+ background-color: #fff;
|
|
|
+ margin: 0px;
|
|
|
+ overflow: hidden;
|
|
|
+ }
|
|
|
+
|
|
|
+ #info {
|
|
|
+ color:#000;
|
|
|
+ position: relative;
|
|
|
+ margin: 0 auto -2.1em;
|
|
|
+ top: 0px;
|
|
|
+ width: 550px;
|
|
|
+ padding: 5px;
|
|
|
+ z-index:100;
|
|
|
+ }
|
|
|
+
|
|
|
+ a { color: skyblue; }
|
|
|
+ </style>
|
|
|
+ </head>
|
|
|
+
|
|
|
+ <body>
|
|
|
+ <div id="info">
|
|
|
+ <a href="http://github.com/mrdoob/three.js" target="_blank">three.js</a> - webgl physically based shading testbed
|
|
|
+ </div>
|
|
|
+
|
|
|
+ <!--
|
|
|
+ <script src="../build/Three.js"></script>
|
|
|
+ -->
|
|
|
+
|
|
|
+ <script type="text/javascript" src="../src/Three.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/core/Color.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/core/Vector2.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/core/Vector3.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/core/Vector4.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/core/Ray.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/core/Rectangle.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/core/Matrix3.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/core/Matrix4.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/core/Object3D.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/core/Projector.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/core/Quaternion.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/core/Vertex.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/core/Face3.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/core/Face4.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/core/UV.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/core/Geometry.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/core/Spline.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/core/Edge.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/cameras/Camera.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/cameras/OrthographicCamera.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/cameras/PerspectiveCamera.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/lights/Light.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/lights/AmbientLight.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/lights/DirectionalLight.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/lights/PointLight.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/lights/SpotLight.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/materials/Material.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/materials/LineBasicMaterial.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/materials/MeshBasicMaterial.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/materials/MeshLambertMaterial.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/materials/MeshPhongMaterial.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/materials/MeshDepthMaterial.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/materials/MeshNormalMaterial.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/materials/MeshFaceMaterial.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/materials/MeshShaderMaterial.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/materials/ParticleBasicMaterial.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/materials/ParticleCanvasMaterial.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/materials/ParticleDOMMaterial.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/materials/ShaderMaterial.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/textures/Texture.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/textures/DataTexture.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/objects/Particle.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/objects/ParticleSystem.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/objects/Line.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/objects/Mesh.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/objects/Bone.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/objects/SkinnedMesh.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/objects/Ribbon.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/objects/LOD.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/objects/Sprite.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/scenes/Scene.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/scenes/Fog.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/scenes/FogExp2.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/renderers/DOMRenderer.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/renderers/CanvasRenderer.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/renderers/SVGRenderer.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/renderers/WebGLShaders.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/renderers/WebGLRenderer.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/renderers/WebGLRenderTarget.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/renderers/WebGLRenderTargetCube.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/renderers/renderables/RenderableVertex.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/renderers/renderables/RenderableFace3.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/renderers/renderables/RenderableFace4.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/renderers/renderables/RenderableObject.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/renderers/renderables/RenderableParticle.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/renderers/renderables/RenderableLine.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/ColorUtils.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/GeometryUtils.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/ImageUtils.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/SceneUtils.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/ShaderUtils.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/core/Curve.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/core/CurvePath.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/core/Path.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/core/Shape.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/core/TextPath.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/animation/AnimationHandler.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/animation/Animation.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/cameras/CubeCamera.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/cameras/FirstPersonCamera.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/cameras/PathCamera.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/cameras/FlyCamera.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/cameras/RollCamera.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/cameras/TrackballCamera.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/cameras/CombinedCamera.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/controls/FirstPersonControls.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/controls/PathControls.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/controls/FlyControls.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/controls/RollControls.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/controls/TrackballControls.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/geometries/CubeGeometry.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/geometries/CylinderGeometry.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/geometries/ExtrudeGeometry.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/geometries/IcosahedronGeometry.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/geometries/LatheGeometry.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/geometries/OctahedronGeometry.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/geometries/PlaneGeometry.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/geometries/SphereGeometry.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/geometries/TextGeometry.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/geometries/TorusGeometry.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/geometries/TorusKnotGeometry.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/modifiers/SubdivisionModifier.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/loaders/Loader.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/loaders/BinaryLoader.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/loaders/ColladaLoader.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/loaders/JSONLoader.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/loaders/SceneLoader.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/loaders/UTF8Loader.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/objects/Axes.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/objects/MarchingCubes.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/physics/Collisions.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/physics/CollisionUtils.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/renderers/AnaglyphWebGLRenderer.js"></script>
|
|
|
+ <script type="text/javascript" src="../src/extras/renderers/CrosseyedWebGLRenderer.js"></script>
|
|
|
+
|
|
|
+ <script src="js/ShaderExtras.js"></script>
|
|
|
+
|
|
|
+ <script src="js/postprocessing/EffectComposer.js"></script>
|
|
|
+ <script src="js/postprocessing/RenderPass.js"></script>
|
|
|
+ <script src="js/postprocessing/BloomPass.js"></script>
|
|
|
+ <script src="js/postprocessing/ShaderPass.js"></script>
|
|
|
+ <script src="js/postprocessing/MaskPass.js"></script>
|
|
|
+ <script src="js/postprocessing/SavePass.js"></script>
|
|
|
+
|
|
|
+
|
|
|
+ <script src="js/Detector.js"></script>
|
|
|
+ <script src="js/RequestAnimationFrame.js"></script>
|
|
|
+ <script src="js/Stats.js"></script>
|
|
|
+
|
|
|
+ <script>
|
|
|
+
|
|
|
+ var MARGIN = 0;
|
|
|
+
|
|
|
+ var SCREEN_WIDTH = window.innerWidth;
|
|
|
+ var SCREEN_HEIGHT = window.innerHeight - 2 * MARGIN;
|
|
|
+
|
|
|
+ var FAR = 10000;
|
|
|
+
|
|
|
+ var container, stats;
|
|
|
+
|
|
|
+ var camera, scene, renderer;
|
|
|
+
|
|
|
+ var mesh, geometry;
|
|
|
+
|
|
|
+
|
|
|
+ init();
|
|
|
+ animate();
|
|
|
+
|
|
|
+ function init() {
|
|
|
+
|
|
|
+ container = document.createElement( 'div' );
|
|
|
+ document.body.appendChild( container );
|
|
|
+
|
|
|
+ camera = new THREE.PerspectiveCamera( 45, SCREEN_WIDTH / SCREEN_HEIGHT, 2, FAR );
|
|
|
+ camera.position.set( 700, 250, 1200 );
|
|
|
+
|
|
|
+ controls = new THREE.TrackballControls( camera );
|
|
|
+
|
|
|
+ controls.rotateSpeed = 1.0;
|
|
|
+ controls.zoomSpeed = 1.2;
|
|
|
+ controls.panSpeed = 0.8;
|
|
|
+
|
|
|
+ controls.noZoom = false;
|
|
|
+ controls.noPan = false;
|
|
|
+
|
|
|
+ controls.staticMoving = true;
|
|
|
+ controls.dynamicDampingFactor = 0.3;
|
|
|
+
|
|
|
+ controls.keys = [ 65, 83, 68 ];
|
|
|
+
|
|
|
+ // CUBE CAMERA
|
|
|
+
|
|
|
+ cubeCamera = new THREE.CubeCamera( 1, FAR, 0, 128 );
|
|
|
+ var cubeTarget = cubeCamera.renderTarget;
|
|
|
+
|
|
|
+
|
|
|
+ scene = new THREE.Scene();
|
|
|
+
|
|
|
+ scene.fog = new THREE.Fog( 0x00aaff, 1000, FAR );
|
|
|
+ scene.fog.color.setHSV( 0.13, 0.25, 0.99 );
|
|
|
+ //THREE.ColorUtils.adjustHSV( scene.fog.color, 0, 0, 0.5 );
|
|
|
+
|
|
|
+ // TEXTURES
|
|
|
+
|
|
|
+ var x = document.createElement( "canvas" );
|
|
|
+ var xc = x.getContext("2d");
|
|
|
+ x.width = x.height = 128;
|
|
|
+ xc.fillStyle = "#fff";
|
|
|
+ xc.fillRect(0, 0, 128, 128);
|
|
|
+ xc.fillStyle = "#000";
|
|
|
+ xc.fillRect(0, 0, 64, 64);
|
|
|
+ xc.fillStyle = "#999";
|
|
|
+ xc.fillRect(32, 32, 32, 32);
|
|
|
+ xc.fillStyle = "#000";
|
|
|
+ xc.fillRect(64, 64, 64, 64);
|
|
|
+ xc.fillStyle = "#555";
|
|
|
+ xc.fillRect(96, 96, 32, 32);
|
|
|
+
|
|
|
+ var texturePattern = new THREE.Texture( x, new THREE.UVMapping(), THREE.RepeatWrapping, THREE.RepeatWrapping );
|
|
|
+ texturePattern.needsUpdate = true;
|
|
|
+ texturePattern.repeat.set( 1000, 1000 );
|
|
|
+
|
|
|
+ var textureSquares = THREE.ImageUtils.loadTexture( "textures/patterns/bright_squares256.png" );
|
|
|
+ textureSquares.wrapS = textureSquares.wrapT = THREE.RepeatWrapping;
|
|
|
+ textureSquares.magFilter = THREE.NearestFilter;
|
|
|
+ textureSquares.repeat.set( 50, 50 );
|
|
|
+
|
|
|
+ var textureNoiseColor = THREE.ImageUtils.loadTexture( "textures/disturb.jpg" );
|
|
|
+ textureNoiseColor.repeat.set( 1, 1 );
|
|
|
+ textureNoiseColor.wrapS = textureNoiseColor.wrapT = THREE.RepeatWrapping;
|
|
|
+
|
|
|
+ var textureLava = THREE.ImageUtils.loadTexture( "textures/lava/lavatile.jpg" );
|
|
|
+ textureLava.repeat.set( 6, 2 );
|
|
|
+ textureLava.wrapS = textureLava.wrapT = THREE.RepeatWrapping;
|
|
|
+
|
|
|
+ //
|
|
|
+
|
|
|
+ var path = "textures/cube/SwedishRoyalCastle/";
|
|
|
+ var format = '.jpg';
|
|
|
+ var urls = [
|
|
|
+ path + 'px' + format, path + 'nx' + format,
|
|
|
+ path + 'py' + format, path + 'ny' + format,
|
|
|
+ path + 'pz' + format, path + 'nz' + format
|
|
|
+ ];
|
|
|
+
|
|
|
+ var reflectionCube = THREE.ImageUtils.loadTextureCube( urls );
|
|
|
+
|
|
|
+ // GROUND
|
|
|
+
|
|
|
+ var groundMaterial = new THREE.MeshPhongMaterial( { shininess: 80, ambient: 0x222222, color: 0xffffff, specular: 0xffffff, map: textureSquares } );
|
|
|
+ //groundMaterial.color.setHSV( 0.1, 0.1, 0.99 );
|
|
|
+
|
|
|
+ var planeGeometry = new THREE.PlaneGeometry( 100, 100 );
|
|
|
+
|
|
|
+ var ground = new THREE.Mesh( planeGeometry, groundMaterial );
|
|
|
+ ground.position.set( 0, 0, 0 );
|
|
|
+ ground.rotation.x = -Math.PI/2;
|
|
|
+ ground.scale.set( 1000, 1000, 1000 );
|
|
|
+
|
|
|
+ ground.receiveShadow = true;
|
|
|
+
|
|
|
+ scene.add( ground );
|
|
|
+
|
|
|
+ // MATERIALS
|
|
|
+
|
|
|
+ var shader = THREE.ShaderUtils.lib[ "cube" ];
|
|
|
+ shader.uniforms[ "tCube" ].texture = cubeTarget;
|
|
|
+ shader.uniforms[ "tFlip" ].value = 1;
|
|
|
+
|
|
|
+ var materialCube = new THREE.ShaderMaterial( {
|
|
|
+
|
|
|
+ fragmentShader: shader.fragmentShader,
|
|
|
+ vertexShader: shader.vertexShader,
|
|
|
+ uniforms: shader.uniforms
|
|
|
+
|
|
|
+ } );
|
|
|
+
|
|
|
+ var materialLambert = new THREE.MeshPhongMaterial( { shininess: 50, color: 0xffffff, map: textureNoiseColor } );
|
|
|
+ var materialPhong = new THREE.MeshPhongMaterial( { shininess: 50, ambient: 0x222222, color: 0xffffff, specular: 0x999999, map: textureLava } );
|
|
|
+ var materialPhongCube = new THREE.MeshPhongMaterial( { shininess: 50, ambient: 0x222222, color: 0xffffff, specular: 0x999999, envMap: cubeTarget } );
|
|
|
+
|
|
|
+ // OBJECTS
|
|
|
+
|
|
|
+ var sphereGeometry = new THREE.SphereGeometry( 100, 64, 32 );
|
|
|
+ var torusGeometry = new THREE.TorusGeometry( 240, 60, 32, 64 );
|
|
|
+ var cubeGeometry = new THREE.CubeGeometry( 150, 150, 150 );
|
|
|
+
|
|
|
+ addObject( torusGeometry, materialPhong, 0, 100, 0, 0 );
|
|
|
+ addObject( cubeGeometry, materialLambert, 350, 75, 300, 0 );
|
|
|
+ mesh = addObject( sphereGeometry, materialPhongCube, 350, 100, -350, 0 );
|
|
|
+
|
|
|
+ function addObjectColor( geometry, color, x, y, z, ry ) {
|
|
|
+
|
|
|
+ var material = new THREE.MeshPhongMaterial( { color: color, ambient: 0x222222 } );
|
|
|
+ return addObject( geometry, material, x, y, z, ry );
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ function addObject( geometry, material, x, y, z, ry ) {
|
|
|
+
|
|
|
+ var tmpMesh = new THREE.Mesh( geometry, material );
|
|
|
+
|
|
|
+ THREE.ColorUtils.adjustHSV( tmpMesh.materials[ 0 ].color, 0.1, -0.1, 0 );
|
|
|
+
|
|
|
+ tmpMesh.position.set( x, y, z );
|
|
|
+
|
|
|
+ tmpMesh.rotation.y = ry;
|
|
|
+
|
|
|
+ tmpMesh.castShadow = true;
|
|
|
+ tmpMesh.receiveShadow = true;
|
|
|
+
|
|
|
+ scene.add( tmpMesh );
|
|
|
+
|
|
|
+ return tmpMesh;
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ var bigCube = new THREE.CubeGeometry( 50, 500, 50 );
|
|
|
+ var midCube = new THREE.CubeGeometry( 50, 200, 50 );
|
|
|
+ var smallCube = new THREE.CubeGeometry( 100, 100, 100 );
|
|
|
+
|
|
|
+ addObjectColor( bigCube, 0xff0000, -500, 250, 0, 0 );
|
|
|
+ addObjectColor( smallCube, 0xff0000, -500, 50, -150, 0 );
|
|
|
+
|
|
|
+ addObjectColor( midCube, 0x00ff00, 500, 100, 0, 0 );
|
|
|
+ addObjectColor( smallCube, 0x00ff00, 500, 50, -150, 0 );
|
|
|
+
|
|
|
+ addObjectColor( midCube, 0x0000ff, 0, 100, -500, 0 );
|
|
|
+ addObjectColor( smallCube, 0x0000ff, -150, 50, -500, 0 );
|
|
|
+
|
|
|
+ addObjectColor( midCube, 0xff00ff, 0, 100, 500, 0 );
|
|
|
+ addObjectColor( smallCube, 0xff00ff, -150, 50, 500, 0 );
|
|
|
+
|
|
|
+ addObjectColor( new THREE.CubeGeometry( 500, 10, 10 ), 0xffff00, 0, 600, 0, Math.PI/4 );
|
|
|
+ addObjectColor( new THREE.CubeGeometry( 250, 10, 10 ), 0xffff00, 0, 600, 0, 0 );
|
|
|
+
|
|
|
+ addObjectColor( new THREE.SphereGeometry( 100, 32, 26 ), 0xffffff, -300, 100, 300, 0 );
|
|
|
+
|
|
|
+ // LIGHTS
|
|
|
+
|
|
|
+ var ambient = new THREE.AmbientLight( 0x222222 );
|
|
|
+ scene.add( ambient );
|
|
|
+
|
|
|
+ var pointLight = new THREE.PointLight( 0xffffff, 1 );
|
|
|
+ pointLight.position.set( -1000, 1000, -1000 );
|
|
|
+ //scene.add( pointLight );
|
|
|
+
|
|
|
+ var spotLight = new THREE.SpotLight( 0xffffff, 1 );
|
|
|
+ spotLight.position.set( 1000, 2000, 1000 );
|
|
|
+ spotLight.castShadow = true;
|
|
|
+ scene.add( spotLight );
|
|
|
+
|
|
|
+ // RENDERER
|
|
|
+
|
|
|
+ renderer = new THREE.WebGLRenderer( { clearColor: 0x00aaff, clearAlpha: 1, antialias: true } );
|
|
|
+ renderer.setSize( SCREEN_WIDTH, SCREEN_HEIGHT );
|
|
|
+
|
|
|
+ if ( scene.fog )
|
|
|
+ renderer.setClearColor( scene.fog.color, 1 );
|
|
|
+
|
|
|
+ renderer.domElement.style.position = "absolute";
|
|
|
+ renderer.domElement.style.top = MARGIN + "px";
|
|
|
+ renderer.domElement.style.left = "0px";
|
|
|
+
|
|
|
+ container.appendChild( renderer.domElement );
|
|
|
+
|
|
|
+
|
|
|
+ //
|
|
|
+
|
|
|
+ renderer.shadowMapEnabled = true;
|
|
|
+ renderer.shadowMapDarkness = 0.75;
|
|
|
+ renderer.shadowMapBias = 0.00390125;
|
|
|
+
|
|
|
+ //
|
|
|
+
|
|
|
+ renderer.gammaInput = true;
|
|
|
+ renderer.gammaOutput = true;
|
|
|
+ renderer.physicallyBasedShading = true;
|
|
|
+
|
|
|
+
|
|
|
+ // STATS
|
|
|
+
|
|
|
+ stats = new Stats();
|
|
|
+ stats.domElement.style.position = 'absolute';
|
|
|
+ stats.domElement.style.top = '0px';
|
|
|
+ stats.domElement.style.zIndex = 100;
|
|
|
+
|
|
|
+ stats.domElement.children[ 0 ].children[ 0 ].style.color = "#222";
|
|
|
+ stats.domElement.children[ 0 ].style.background = "transparent";
|
|
|
+ stats.domElement.children[ 0 ].children[ 1 ].style.display = "none";
|
|
|
+
|
|
|
+ container.appendChild( stats.domElement );
|
|
|
+
|
|
|
+ // EVENTS
|
|
|
+
|
|
|
+ window.addEventListener( 'resize', onWindowResize, false );
|
|
|
+
|
|
|
+ // COMPOSER
|
|
|
+
|
|
|
+ renderer.autoClear = false;
|
|
|
+
|
|
|
+ renderTargetParameters = { minFilter: THREE.LinearFilter, magFilter: THREE.LinearFilter, format: THREE.RGBFormat, stencilBufer: false };
|
|
|
+ renderTarget = new THREE.WebGLRenderTarget( SCREEN_WIDTH, SCREEN_HEIGHT, renderTargetParameters );
|
|
|
+
|
|
|
+ effectFXAA = new THREE.ShaderPass( THREE.ShaderExtras[ "fxaa" ] );
|
|
|
+ var effectVignette = new THREE.ShaderPass( THREE.ShaderExtras[ "vignette" ] );
|
|
|
+
|
|
|
+ hblur = new THREE.ShaderPass( THREE.ShaderExtras[ "horizontalTiltShift" ] );
|
|
|
+ vblur = new THREE.ShaderPass( THREE.ShaderExtras[ "verticalTiltShift" ] );
|
|
|
+
|
|
|
+ var bluriness = 4;
|
|
|
+
|
|
|
+ hblur.uniforms[ 'h' ].value = bluriness / SCREEN_WIDTH;
|
|
|
+ vblur.uniforms[ 'v' ].value = bluriness / SCREEN_HEIGHT;
|
|
|
+
|
|
|
+ hblur.uniforms[ 'r' ].value = vblur.uniforms[ 'r' ].value = 0.5;
|
|
|
+
|
|
|
+ effectFXAA.uniforms[ 'resolution' ].value.set( 1 / SCREEN_WIDTH, 1 / SCREEN_HEIGHT );
|
|
|
+
|
|
|
+ composer = new THREE.EffectComposer( renderer, renderTarget );
|
|
|
+
|
|
|
+ var renderModel = new THREE.RenderPass( scene, camera );
|
|
|
+
|
|
|
+ effectVignette.renderToScreen = true;
|
|
|
+ vblur.renderToScreen = true;
|
|
|
+
|
|
|
+ composer = new THREE.EffectComposer( renderer, renderTarget );
|
|
|
+
|
|
|
+ composer.addPass( renderModel );
|
|
|
+
|
|
|
+ composer.addPass( effectFXAA );
|
|
|
+
|
|
|
+ composer.addPass( hblur );
|
|
|
+ composer.addPass( vblur );
|
|
|
+
|
|
|
+ //composer.addPass( effectVignette );
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ //
|
|
|
+
|
|
|
+
|
|
|
+ function onWindowResize( event ) {
|
|
|
+
|
|
|
+ SCREEN_WIDTH = window.innerWidth;
|
|
|
+ SCREEN_HEIGHT = window.innerHeight - 2 * MARGIN;
|
|
|
+
|
|
|
+ renderer.setSize( SCREEN_WIDTH, SCREEN_HEIGHT );
|
|
|
+
|
|
|
+ camera.aspect = SCREEN_WIDTH / SCREEN_HEIGHT;
|
|
|
+ camera.updateProjectionMatrix();
|
|
|
+
|
|
|
+ renderTarget = new THREE.WebGLRenderTarget( SCREEN_WIDTH, SCREEN_HEIGHT, renderTargetParameters );
|
|
|
+
|
|
|
+ composer.reset( renderTarget );
|
|
|
+
|
|
|
+ hblur.uniforms[ 'h' ].value = 4 / SCREEN_WIDTH;
|
|
|
+ vblur.uniforms[ 'v' ].value = 4 / SCREEN_HEIGHT;
|
|
|
+
|
|
|
+ effectFXAA.uniforms[ 'resolution' ].value.set( 1 / SCREEN_WIDTH, 1 / SCREEN_HEIGHT );
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ //
|
|
|
+
|
|
|
+ function animate() {
|
|
|
+
|
|
|
+ requestAnimationFrame( animate );
|
|
|
+
|
|
|
+ render();
|
|
|
+ stats.update();
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ function render() {
|
|
|
+
|
|
|
+ controls.update();
|
|
|
+
|
|
|
+ mesh.visible = false;
|
|
|
+
|
|
|
+ renderer.autoClear = true;
|
|
|
+ cubeCamera.updatePosition( mesh.position );
|
|
|
+ cubeCamera.updateCubeMap( renderer, scene );
|
|
|
+ renderer.autoClear = false;
|
|
|
+
|
|
|
+ mesh.visible = true;
|
|
|
+
|
|
|
+ //renderer.render( scene, camera );
|
|
|
+ //renderer.clearTarget( null, 1, 1, 1 );
|
|
|
+ composer.render( 0.1 );
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ </script>
|
|
|
+
|
|
|
+ </body>
|
|
|
+</html>
|
|
|
+
|