本章的主要内容

  1 three.js有哪些可用的光源

  2 什么时候用什么光源、

  3 如何调整配置各种光源

  4 如何创建镜头炫光

一 光源

 光源大概有7种,

  其中基础光源有4种

    环境光(AmbientLight会它的颜色会添加到整个场景和所有对象的当前颜色上),

    点光源(PointLight空间中的一点,朝所有的方向发射光线),

    聚光灯光源(SpotLight这种光源有聚光的效果,类似于台灯,吊灯,手电筒),

    方向光(DirectionalLight也称无限光,从这种光源发出的光线可以看作是平行的,例如太阳光)

   特殊光源有3种(这三种我们后面再详述)

    半球光光源(HemisphereLight,可以为室内场景创建更加自然的光照效果,模拟反光面和光线微弱的天气)

    面光源(AreaLight使用这种光源可以指定散发光线的平面,而不是空间的一个点)

    镜头炫光(LensFlare这不是一种光源,但是通过该炫光可以为场景中的光源添加炫目的效果)

  1.1  环境光

    AmbientLight光源的颜色会影响到整个场景,

    环境光没有特定的光源,是模拟漫反射的一种光源,因此不需要指定位置

    它能将灯光均匀地照射在场景中每个物体上面,一般情况下用来弱化阴影或者添加一些颜色到环境中,

    因此不能将AmbientLight作为场景中的唯一光源,那样的会就会导致下图左边的情况,

    右边为使用了SpotLight光源,并使用AmbientLight用来弱化SpotLight生成的生硬的阴影,

    注意一下AmbientLight会将颜色应用于整个场景,因此使用AmbientLight的时候,用色应该尽量的保守,如果颜色过于明亮,画面颜色就会饱和

var ambiColor = "#0c0c0c";
var ambientLight = new THREE.AmbientLight(ambiColor);
scene.add(ambientLight);
//环境光不需要设置光源的位置等信息,只需要一个颜色即可,这个颜色就是漫反射到所有对象上的颜色
<!DOCTYPE html>

<html>

<head>
<title>1</title>
<script type="text/javascript" src="three.js"></script>
<script type="text/javascript" src="dat.gui.js"></script>
<script type="text/javascript" src="AsciiEffect.js"></script>
<style>
body {
/* set margin to 0 and overflow to hidden, to go fullscreen */
margin: 0;
overflow: hidden;
}
</style>
</head>
<body> <!-- Div which will hold the Output -->
<div id="WebGL-output">
</div> <!-- Javascript code that runs our Three.js examples -->
<script type="text/javascript">
//var scene
function init() {
var scene=new THREE.Scene();//生成一个场景
//生成一个相机
var camera=new THREE.PerspectiveCamera(45,window.innerWidth/window.innerHeight,0.1,1000);//视场,长宽比,近面,远面
camera.position.x=-20;
camera.position.y=40;
camera.position.z=30;
camera.lookAt(scene.position);
//生成一个渲染器
var render=new THREE.WebGLRenderer();
render.setClearColorHex(0xEEEEEE);
render.setSize(window.innerWidth,window.innerHeight);
render.shadowMapEnabled=true;//允许阴影映射,渲染阴影需要大量的资源,因此我们需要告诉渲染器我们需要阴影 //生成一个坐标轴,辅助线
var axes=new THREE.AxisHelper(20);
//生成一个平面
var planeGeometry=new THREE.PlaneGeometry(60,20,10,10);//平面
//生成一个材质
var planeMaterial=new THREE.MeshLambertMaterial({color:0xffffff});
//生成一个网格,将平面和材质放在一个网格中,组合在一起,组成一个物体
var plane=new THREE.Mesh(planeGeometry,planeMaterial);
plane.rotation.x=-0.5*Math.PI;//将平面沿着x轴进行旋转
plane.position.x=0;
plane.position.y=0;
plane.position.z=0;
plane.receiveShadow=true;//平面进行接受阴影 var cubeGeometry=new THREE.CubeGeometry(10,10,10);
var planeMaterial1=new THREE.MeshLambertMaterial({color:0xff0000});
/*var cube=new THREE.Mesh(cubeGeometry,planeMaterial1);
//plane1.rotation.x=-0.5*Math.PI;//将平面沿着x轴进行旋转
cube.position.x=-4;
cube.position.y=3;
cube.position.z=0;
cube.castShadow=true;//需要阴影,方块进行投射阴影*/ //聚光灯光源
/*var spotLight=new THREE.SpotLight(0xffffff);
spotLight.position.set(-40,60,-10);
spotLight.castShadow=true;*/
var ambientLight=new THREE.AmbientLight("#0c0c0c");
scene.add(ambientLight);
//将相机,渲染器,坐标轴,平面都追加到场景中,然后对场景和相机进行渲染
scene.add(camera);
scene.add(render);
scene.add(axes);
scene.add(plane);
//scene.add(cube);
//scene.add(spotLight);
//var effect=new THREE.AsciiEffect(render);
///effect.setSize(window.innerWidth,window.innerHeight);
document.getElementById("WebGL-output").append(render.domElement); var controls=new function(){
this.rotationSpeed=0.02;
this.numberofObject=scene.children.length;
this.addCube=function(){
var cubeSize=Math.ceil(Math.random()*3);
var cubeGeometry=new THREE.BoxGeometry(cubeSize,cubeSize,cubeSize);
var cubeMaterial=new THREE.MeshLambertMaterial({color:Math.random()*0xffffff});
var cube=new THREE.Mesh(cubeGeometry,cubeMaterial);
cube.castShadow=true;
cube.name="cube-"+scene.children.length;
cube.position.x=-30+Math.round(Math.random()*planeGeometry.parameters.width);
cube.position.y=Math.round(Math.random()*5);
cube.position.z=-20+Math.round(Math.random()*planeGeometry.parameters.height);
scene.add(cube);
this.numberofObject=scene.children.length;
};
this.removeCube=function(){
var allChildren=scene.children;
var lastChild=allChildren[allChildren.length-1];
if(lastChild instanceof THREE.Mesh){
scene.remove(lastChild);
this.numberofObject=scene.children.length;
}
};
};
var gui=new dat.GUI();
gui.add(controls,"rotationSpeed",0,0.5);
gui.add(controls,"addCube");
gui.add(controls,"removeCube");
gui.add(controls,"numberofObject").listen();;
function renderScene(){
scene.traverse(function (e) {
if (e instanceof THREE.Mesh && e != plane) { e.rotation.x += controls.rotationSpeed;
e.rotation.y += controls.rotationSpeed;
e.rotation.z += controls.rotationSpeed;
}
});
requestAnimationFrame(renderScene);
render.render(scene, camera);
}
//scene.fog=new THREE.Fog(0xffffff,0.015,100);
renderScene();
} window.onload = init; </script>
</body>
</html>

  1.2 点光源

    点光源是一种单点发光,照射全部方向的光源,例如生活中的照明弹就属于点光源,

    由于点光源是向所有方向发射光线,因此不会产生阴影,

    它有颜色color,强度intensity,距离distance,位置position,是否可见visible等几个属性,

    PointLight光源的distance属性决定的是光线可以照射多远,值为0时,表示光线的亮度不会随着距离的增加而递减

    其中左图为强度较小的情况,右图为强度较大的情况

 var pointColor = "#ccffcc";
var pointLight = new THREE.PointLight(pointColor);
pointLight.distance = 100;//距离,决定了光线可以照射多远
pointLight.intensity = 1;//强度
scene.add(pointLight);

  1.3 聚光灯光源

    SpotLight聚光灯光源有一种锥形的效果,例如日常生活中的手电筒,灯笼等,该光源具有下面的属性

        var pointColor = "#ffffff";
var spotLight = new THREE.SpotLight(pointColor);
spotLight.position.set(-40, 60, -10);
spotLight.castShadow = true;
spotLight.shadowCameraNear = 2;
spotLight.shadowCameraFar = 200;
spotLight.shadowCameraFov = 30; spotLight.target = plane;
/*设置聚光灯光源的target属性,为3D空间的一个点,target属性的值为Object3D
var target = new THREE.Object3D();
target.position = new THREE.Vector3(5, 0, 0);
spotLight.target = target;
*/
spotLight.distance = 0;
spotLight.angle = 0.4; scene.add(spotLight);
属性 描述
castShadow(投影) 设置为true,则该光源可以产生阴影
shadowCameraNear 从距离光源的哪一点开始生成阴影
shadowCameraFar 从距离光源哪一点开始停止生成阴影
shadowCameraFov 形成阴影的视场
target 决定了光源的方向,如果target属性的值出现移动的情况,那么光源也会跟着该target进行移动,该值必须为Object3D类型,因此可以是geom,也可以是具体的某一个点,这个代码中会有体现
angle 光源照射出来的光柱有多宽
exponent 光强衰减指数,距离光源越远,光照强度越弱,但是减弱的速度是由该值控制
shadowCameraVisible 通过设置此值,可以看到光源在哪里,以及如何产生阴影,即该值主要用于调试
shadowDarkness 阴影强度,即阴影有多黑,场景渲染后该值不可以再修改了
shadowMapWidth 多少像素用来生成阴影,如果阴影的边缘看起来不够光滑参差不齐,那么可以考虑加大该值,该值同shadowDarkness,场景渲染后不可修改
distance 距离target的距离
<!DOCTYPE html>

<html>

<head>
<title>1</title>
<script type="text/javascript" src="three.js"></script>
<script type="text/javascript" src="dat.gui.js"></script>
<script type="text/javascript" src="AsciiEffect.js"></script>
<style>
body {
/* set margin to 0 and overflow to hidden, to go fullscreen */
margin: 0;
overflow: hidden;
}
</style>
</head>
<body> <!-- Div which will hold the Output -->
<div id="WebGL-output">
</div> <!-- Javascript code that runs our Three.js examples -->
<script type="text/javascript">
//var scene
function init() {
var scene=new THREE.Scene();//生成一个场景
//生成一个相机
var camera=new THREE.PerspectiveCamera(45,window.innerWidth/window.innerHeight,0.1,1000);//视场,长宽比,近面,远面
camera.position.x=-20;
camera.position.y=40;
camera.position.z=30;
camera.lookAt(scene.position);
//生成一个渲染器
var render=new THREE.WebGLRenderer();
render.setClearColorHex(0xEEEEEE);
render.setSize(window.innerWidth,window.innerHeight);
render.shadowMapEnabled=true;//允许阴影映射,渲染阴影需要大量的资源,因此我们需要告诉渲染器我们需要阴影 //生成一个坐标轴,辅助线
var axes=new THREE.AxisHelper(20);
//生成一个平面
var planeGeometry=new THREE.PlaneGeometry(60,20,10,10);//平面
//生成一个材质
var planeMaterial=new THREE.MeshLambertMaterial({color:0xffffff});
//生成一个网格,将平面和材质放在一个网格中,组合在一起,组成一个物体
var plane=new THREE.Mesh(planeGeometry,planeMaterial);
plane.rotation.x=-0.5*Math.PI;//将平面沿着x轴进行旋转
plane.position.x=0;
plane.position.y=0;
plane.position.z=0;
plane.receiveShadow=true;//平面进行接受阴影 var cubeGeometry=new THREE.CubeGeometry(10,10,10);
var planeMaterial1=new THREE.MeshLambertMaterial({color:0xff0000});
/*var cube=new THREE.Mesh(cubeGeometry,planeMaterial1);
//plane1.rotation.x=-0.5*Math.PI;//将平面沿着x轴进行旋转
cube.position.x=-4;
cube.position.y=3;
cube.position.z=0;
cube.castShadow=true;//需要阴影,方块进行投射阴影*/ //聚光灯光源
/**/var spotLight=new THREE.SpotLight(0xffffff);
spotLight.position.set(0,20,0);
        spotLight.castShadow=true;
        spotLight.target=plane;//光源照射的方向
        spotLight.angle=Math.PI/3;//光源的角度
        spotLight.shadowCameraNear=2;
        spotLight.shadowCameraFar=20;
        
        spotLight.shadowCameraVisible=true;
        scene.add(spotLight); //环境光
/*var ambientLight=new THREE.AmbientLight("#0c0c0c");
scene.add(ambientLight);*/ //点光源
/*
var pointLight=new THREE.PointLight(0xffffff);
pointLight.position.set(0,10,10);
pointLight.distance=100;
pointLight.castShadow=true;
pointLight.intensity=3;
scene.add(pointLight);*/
var lightGeometry=new THREE.BoxGeometry(4,4,4);
var lightMaterial=new THREE.MeshLambertMaterial({color:Math.random()*0xffffff});
var light=new THREE.Mesh(lightGeometry,lightMaterial); light.position.set(0,20,0);
scene.add(light); //将相机,渲染器,坐标轴,平面都追加到场景中,然后对场景和相机进行渲染
scene.add(camera);
scene.add(render);
scene.add(axes);
scene.add(plane);
//scene.add(cube);
//
//var effect=new THREE.AsciiEffect(render);
///effect.setSize(window.innerWidth,window.innerHeight);
document.getElementById("WebGL-output").append(render.domElement); var controls=new function(){
this.rotationSpeed=0.02;
this.numberofObject=scene.children.length;
this.addCube=function(){
var cubeSize=Math.ceil(Math.random()*3);
var cubeGeometry=new THREE.BoxGeometry(cubeSize,cubeSize,cubeSize);
var cubeMaterial=new THREE.MeshLambertMaterial({color:Math.random()*0xffffff});
var cube=new THREE.Mesh(cubeGeometry,cubeMaterial);
cube.castShadow=true;
cube.name="cube-"+scene.children.length;
cube.position.x=-30+Math.round(Math.random()*planeGeometry.parameters.width);
cube.position.y=Math.round(Math.random()*5);
cube.position.z=-20+Math.round(Math.random()*planeGeometry.parameters.height);
scene.add(cube);
this.numberofObject=scene.children.length;
};
this.removeCube=function(){
var allChildren=scene.children;
var lastChild=allChildren[allChildren.length-1];
if(lastChild instanceof THREE.Mesh){
scene.remove(lastChild);
this.numberofObject=scene.children.length;
}
};
};
var gui=new dat.GUI();
gui.add(controls,"rotationSpeed",0,0.5);
gui.add(controls,"addCube");
gui.add(controls,"removeCube");
gui.add(controls,"numberofObject").listen();;
function renderScene(){
requestAnimationFrame(renderScene);
render.render(scene, camera);
}
//scene.fog=new THREE.Fog(0xffffff,0.015,100);
renderScene();
} window.onload = init; </script>
</body>
</html>

aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAA2QAAAJkCAIAAADx/XUrAAAgAElEQVR4nO3d2YGjvBIG0I6rA3I8HY2TmWB6HnqzZaoQIFad83TvtI2hXBLfz+a3TwAACLztvQIAAByXsAgAQEhYBAAgJCwCABASFgEACAmLAACEhEUAAELCIgAAIWERAICQsAgAQEhYBAAgJCwCABASFgEACAmLAACEhEUAAELCIgAAIWERAICQsAgAQEhYBAAgJCwCABASFgEACAmLAACEhEUAAELCIgAAIWERAICQsAgAQEhYBAAgJCwCABASFgEACAmLAACEhEUAAELCIgAAIWERAICQsAgAQEhYBAAgJCwCABASFgEACAmLAACEhEUAAELCIgAAIWERAICQsAgAQEhYBAAgJCwCABASFgEACAmLAACEhEUAAELCIgAAIWERAICQsAgAQEhYBAAgJCwCABASFgEACAmLAACEhEUAAELCIgAAIWERAICQsAgAQEhYBAAgJCwCABASFgEACAmLAACEhEUAAELCIgAAIWERAICQsAgAQEhYBAAgJCwCABASFgEACAmLAACEhEUAAELCIgAAIWERAICQsAgAQEhYBAAgJCwCABASFgEACAmLAACEhEUAAELCIgAAIWERAICQsAgAQEhYBAAgJCwCABASFgEACAmLAACEhEUAAELCIgAAIWERAICQsAgAQEhYBAAgJCwCABASFgEACAmLAACEhEUAAELCIgAAIWERAICQsAgAQEhYBAAgJCwCABASFgEACAmLAACEhEUAAELCIgAAIWERAICQsAgAQEhYBAAgJCwCABASFgEACAmLAACEhEUAAELCIgAAIWERAICQsAgAQEhYBAAgJCwCABASFgEACAmLAACEhEUAAELCIgAAIWERgB69/dh7ReDoDBIAuvP2bO/VgUMzQgDojrBIQRsklAaA7rwB9fYesACwEbtCItogoTQAXJ/jJuS0QUJpALgyJ9mooQ0SSgPANbkii3raIKE0AFxNfUwUFvmiDRJKA8BF1OdCYZGCNkgoDQCnN/XwobBIQRsklAaAE5saEwfftf1qczTaIKE0AJzSvJg4+N4tV5tj0gYJpQHgZJbExMElbLPaHJk2SCgNAKexPCYOLmft1eb4tEFCaQA4gVYxcXBp6602Z6ENEkoDwKE1zIjRMpuvM6ejDRJKA8BBrRET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" alt="" width="399" height="281" />

  1.4 DirectinalLight---方向光光源(类似于太阳光的一种光源)

    该光源可以看做是距离很远很远的光源,以至于该光源所发出的所有光线都是相互平行的,

    方向光光源的一个范例就是太阳,方向光光源不像聚焦光那样离目标越远越暗淡,被方向光光源照亮的整个区域接收到的光强是一样的

    方向光光源的shadowCameraNear,far,left,right,top,bottom六个属性构成了一个方块的范围,

    在这个方块的范围内的所有对象都可以投影或者接收投影,包围对象的方块范围定义的越紧密,投影的效果越好

<!DOCTYPE html>

<html>

<head>
<title>1</title>
<script type="text/javascript" src="three.js"></script>
<script type="text/javascript" src="dat.gui.js"></script>
<script type="text/javascript" src="AsciiEffect.js"></script>
<style>
body {
/* set margin to 0 and overflow to hidden, to go fullscreen */
margin: 0;
overflow: hidden;
}
</style>
</head>
<body> <!-- Div which will hold the Output -->
<div id="WebGL-output">
</div> <!-- Javascript code that runs our Three.js examples -->
<script type="text/javascript">
//var scene
function init() {
var scene=new THREE.Scene();//生成一个场景
//生成一个相机
var camera=new THREE.PerspectiveCamera(45,window.innerWidth/window.innerHeight,0.1,1000);//视场,长宽比,近面,远面
camera.position.x=-20;
camera.position.y=40;
camera.position.z=30;
camera.lookAt(scene.position);
//生成一个渲染器
var render=new THREE.WebGLRenderer();
render.setClearColorHex(0xEEEEEE);
render.setSize(window.innerWidth,window.innerHeight);
render.shadowMapEnabled=true;//允许阴影映射,渲染阴影需要大量的资源,因此我们需要告诉渲染器我们需要阴影 //生成一个坐标轴,辅助线
var axes=new THREE.AxisHelper(20);
//生成一个平面
var planeGeometry=new THREE.PlaneGeometry(60,20,10,10);//平面
//生成一个材质
var planeMaterial=new THREE.MeshLambertMaterial({color:0xffffff});
//生成一个网格,将平面和材质放在一个网格中,组合在一起,组成一个物体
var plane=new THREE.Mesh(planeGeometry,planeMaterial);
plane.rotation.x=-0.5*Math.PI;//将平面沿着x轴进行旋转
plane.position.x=0;
plane.position.y=0;
plane.position.z=0;
plane.receiveShadow=true;//平面进行接受阴影 var cubeGeometry=new THREE.CubeGeometry(10,10,10);
var planeMaterial1=new THREE.MeshLambertMaterial({color:0xff0000});
/*var cube=new THREE.Mesh(cubeGeometry,planeMaterial1);
//plane1.rotation.x=-0.5*Math.PI;//将平面沿着x轴进行旋转
cube.position.x=-4;
cube.position.y=3;
cube.position.z=0;
cube.castShadow=true;//需要阴影,方块进行投射阴影*/ //聚光灯光源
/*var spotLight=new THREE.SpotLight(0xffffff);
spotLight.position.set(0,20,0);
spotLight.castShadow=true;
spotLight.target=plane;//光源照射的方向
spotLight.angle=Math.PI/3;//光源的角度
spotLight.shadowCameraNear=2;
spotLight.shadowCameraFar=20; spotLight.shadowCameraVisible=true;
scene.add(spotLight);*/ //环境光
/*var ambientLight=new THREE.AmbientLight("#0c0c0c");
scene.add(ambientLight);*/ //点光源
/*
var pointLight=new THREE.PointLight(0xffffff);
pointLight.position.set(0,10,10);
pointLight.distance=100;
pointLight.castShadow=true;
pointLight.intensity=3;
scene.add(pointLight);*/ /*方向光光源*/
var pointColor = "white";
var directionalLight = new THREE.DirectionalLight(pointColor);
directionalLight.position.set(0,10,0);
directionalLight.castShadow = true;
directionalLight.shadowCameraNear =6;
directionalLight.shadowCameraFar =10;
directionalLight.shadowCameraLeft =-5;
//directionalLight.shadowCameraLeft = 10;
directionalLight.shadowCameraRight =5;
directionalLight.shadowCameraTop =5;
directionalLight.shadowCameraBottom =-5;
directionalLight.shadowCameraVisible=true;
//directionalLight.distance = 5;
directionalLight.target=plane;
directionalLight.intensity = 0.5;
//directionalLight.shadowMapHeight = 1024;
//directionalLight.shadowMapWidth = 1024; scene.add(directionalLight); var lightGeometry=new THREE.BoxGeometry(1,1,1);
var lightMaterial=new THREE.MeshLambertMaterial({color:Math.random()*0xffffff});
var light=new THREE.Mesh(lightGeometry,lightMaterial); light.position.set(0,10,0);
scene.add(light); //将相机,渲染器,坐标轴,平面都追加到场景中,然后对场景和相机进行渲染
scene.add(camera);
scene.add(render);
//scene.add(axes);
scene.add(plane);
//scene.add(cube);
//
//var effect=new THREE.AsciiEffect(render);
///effect.setSize(window.innerWidth,window.innerHeight);
document.getElementById("WebGL-output").append(render.domElement); var controls=new function(){
this.rotationSpeed=0.02;
this.numberofObject=scene.children.length;
this.addCube=function(){
var cubeSize=Math.ceil(Math.random()*3);
var cubeGeometry=new THREE.BoxGeometry(cubeSize,cubeSize,cubeSize);
var cubeMaterial=new THREE.MeshLambertMaterial({color:Math.random()*0xffffff});
var cube=new THREE.Mesh(cubeGeometry,cubeMaterial);
cube.castShadow=true;
cube.name="cube-"+scene.children.length;
cube.position.x=-30+Math.round(Math.random()*planeGeometry.parameters.width);
cube.position.y=Math.round(Math.random()*5);
cube.position.z=-20+Math.round(Math.random()*planeGeometry.parameters.height);
scene.add(cube);
this.numberofObject=scene.children.length;
};
this.removeCube=function(){
var allChildren=scene.children;
var lastChild=allChildren[allChildren.length-1];
if(lastChild instanceof THREE.Mesh){
scene.remove(lastChild);
this.numberofObject=scene.children.length;
}
};
};
var gui=new dat.GUI();
gui.add(controls,"rotationSpeed",0,0.5);
gui.add(controls,"addCube");
gui.add(controls,"removeCube");
gui.add(controls,"numberofObject").listen();;
function renderScene(){ requestAnimationFrame(renderScene);
render.render(scene, camera);
}
//scene.fog=new THREE.Fog(0xffffff,0.015,100);
renderScene();
} window.onload = init; </script>
</body>
</html>

aaarticlea/png;base64,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" alt="" width="347" height="262" />  

  1.5 半球光源----HemisphereLight

    这种光源可以为室外场景创建更加自然的光照效果

    我们模拟室外光照的时候,可以使用方向光源来模拟太阳,再添加一个环境光源,为场景添加基础色

    但是这样看起来不太自然,因为室外的光并不都是来自于上方,很多是来自于空气的散射和地面的反射,以及其他物体的反射

    所以在使用方向光源来模拟太阳的情况下再添加一个半球光就自然多了

<!DOCTYPE html>

<html>

<head>
<title>1</title>
<script type="text/javascript" src="three.js"></script>
<script type="text/javascript" src="dat.gui.js"></script>
<script type="text/javascript" src="AsciiEffect.js"></script>
<style>
body {
/* set margin to 0 and overflow to hidden, to go fullscreen */
margin: 0;
overflow: hidden;
}
</style>
</head>
<body> <!-- Div which will hold the Output -->
<div id="WebGL-output">
</div> <!-- Javascript code that runs our Three.js examples -->
<script type="text/javascript">
//var scene
function init() {
var scene=new THREE.Scene();//生成一个场景 //生成一个相机
var camera=new THREE.PerspectiveCamera(45,window.innerWidth/window.innerHeight,0.1,1000);//视场,长宽比,近面,远面
camera.position.x=-20;
camera.position.y=40;
camera.position.z=30;
camera.lookAt(scene.position);
scene.add(camera); //生成一个渲染器
var render=new THREE.WebGLRenderer();
render.setClearColorHex(0xEEEEEE);
render.setSize(window.innerWidth,window.innerHeight);
render.shadowMapEnabled=true;
//允许阴影映射,渲染阴影需要大量的资源,因此我们需要告诉渲染器我们需要阴影
scene.add(render); //生成一个地面的平面,该地面的材质不再只是颜色,而是一个图片
var textureGrass = THREE.ImageUtils.loadTexture("grasslight-big.jpg");
textureGrass.wrapS = THREE.RepeatWrapping;
textureGrass.wrapT = THREE.RepeatWrapping;
textureGrass.repeat.set(4, 4); var planeGeometry = new THREE.PlaneGeometry(1000, 200, 20, 20);
var planeMaterial = new THREE.MeshLambertMaterial({map: textureGrass});
var plane = new THREE.Mesh(planeGeometry, planeMaterial);
plane.receiveShadow = true;
plane.rotation.x = -0.5 * Math.PI;
plane.position.x = 15;
plane.position.y = 0;
plane.position.z = 0;
scene.add(plane); //生成一个方块
var cubeGeometry=new THREE.BoxGeometry(10,10,10);
var cubeMaterial=new THREE.MeshLambertMaterial({color:"red"});
var cube=new THREE.Mesh(cubeGeometry,cubeMaterial);
cube.castShadow=true;
cube.position.x = -4;
cube.position.y = 3;
cube.position.z = 0;
scene.add(cube); //生成半球光源
var hemiLight=new THREE.HemisphereLight(0x0000ff,0x00ff00,0.6);
hemiLight.position.set(0,500,0);
hemiLight.groundColor = new THREE.Color(0x00ff00);//设置地面发出的光线的颜色
hemiLight.color = new THREE.Color(0x0000ff);//设置天空发出的光线的颜色
hemiLight.intensity = 0.6;
scene.add(hemiLight); //生成聚光灯
var spotLight0 = new THREE.SpotLight(0xcccccc);
spotLight0.position.set(-40, 60, -10);
spotLight0.lookAt(plane);
scene.add(spotLight0); //生成一个方向光,模拟太阳光
var pointColor = "#ffffff";
var dirLight = new THREE.DirectionalLight(pointColor);
dirLight.position.set(0, 10, 0);
dirLight.castShadow = true;
dirLight.target = plane;
dirLight.shadowCameraNear = 0.1;
dirLight.shadowCameraFar = 200;
dirLight.shadowCameraLeft = -50;
dirLight.shadowCameraRight = 50;
dirLight.shadowCameraTop = 50;
dirLight.shadowCameraBottom = -50;
dirLight.shadowMapWidth = 2048;
dirLight.shadowMapHeight = 2048;
scene.add(dirLight); document.getElementById("WebGL-output").append(render.domElement); function renderScene(){ requestAnimationFrame(renderScene);
render.render(scene, camera);
}
scene.fog=new THREE.Fog(0xffffff,0.015,100);
renderScene();
} window.onload = init; </script>
</body>
</html>

  1.6 平面光光源------AreaLight

    平面光光源可以定义为一个发光的矩形

    1 由于该光源是THREE.js的扩展,需要引入扩展库

    2 平面光源是一种很复杂的光源,因此不能再使用WebGLRenderer对象了,该对象会造成严重的性能损失

    3 因此在处理复杂光源或者多个光源的时候,使用WebGL的延迟渲染器WebGLDeferredRenderer

<!DOCTYPE html>

<html>

<head>
<title>Example 03.06 - Area Light</title>
<script type="text/javascript" src="../libs/three.js"></script> <script type="text/javascript" src="../libs/stats.js"></script>
<script type="text/javascript" src="../libs/dat.gui.js"></script>
<script type="text/javascript" src="../libs/WebGLDeferredRenderer.js"></script>
<script type="text/javascript" src="../libs/ShaderDeferred.js"></script>
<script type="text/javascript" src="../libs/RenderPass.js"></script>
<script type="text/javascript" src="../libs/EffectComposer.js"></script>
<script type="text/javascript" src="../libs/CopyShader.js"></script>
<script type="text/javascript" src="../libs/ShaderPass.js"></script>
<script type="text/javascript" src="../libs/FXAAShader.js"></script>
<script type="text/javascript" src="../libs/MaskPass.js"></script> <style>
body {
/* set margin to 0 and overflow to hidden, to go fullscreen */
margin: 0;
overflow: hidden;
}
</style>
</head>
<body> <div id="Stats-output">
</div>
<!-- Div which will hold the Output -->
<div id="WebGL-output">
</div> <!-- Javascript code that runs our Three.js examples -->
<script type="text/javascript"> var camera; // once everything is loaded, we run our Three.js stuff.
function init() { var stats = initStats(); // create a scene, that will hold all our elements such as objects, cameras and lights.
var scene = new THREE.Scene(); // create a camera, which defines where we're looking at.
camera = new THREE.PerspectiveCamera(45, window.innerWidth / window.innerHeight, 0.1, 1000);
scene.add(camera); // create a render and set the size
// var renderer = new THREE.WebGLRenderer();
var renderer = new THREE.WebGLDeferredRenderer({
width: window.innerWidth,
height: window.innerHeight,
scale: 1, antialias: true,
tonemapping: THREE.FilmicOperator, brightness: 2.5
}); // renderer.setSize(window.innerWidth, window.innerHeight);
// renderer.shadowMapEnabled = true; // create the ground plane
var planeGeometry = new THREE.PlaneGeometry(70, 70, 1, 1);
var planeMaterial = new THREE.MeshPhongMaterial({color: 0xffffff, specular: 0xffffff, shininess: 200});
var plane = new THREE.Mesh(planeGeometry, planeMaterial);
// plane.receiveShadow = true; // rotate and position the plane
plane.rotation.x = -0.5 * Math.PI;
plane.position.x = 0;
plane.position.y = 0;
plane.position.z = 0; // add the plane to the scene
scene.add(plane); // position and point the camera to the center of the scene
camera.position.x = 20;
camera.position.y = 30;
camera.position.z = 21;
camera.lookAt(new THREE.Vector3(0, 0, -30)); // add the output of the renderer to the html element
document.getElementById("WebGL-output").appendChild(renderer.domElement); // call the render function
var step = 0; var spotLight0 = new THREE.SpotLight(0xcccccc);
spotLight0.position.set(-40, 60, -10);
spotLight0.intensity = 0.1;
spotLight0.lookAt(plane);
scene.add(spotLight0); var areaLight1 = new THREE.AreaLight(0xff0000, 3);// color和instensity
areaLight1.position.set(-10, 10, -35);
areaLight1.rotation.set(-Math.PI / 2, 0, 0);
areaLight1.width = 4;
areaLight1.height = 9.9;
scene.add(areaLight1); var areaLight2 = new THREE.AreaLight(0x00ff00, 3);
areaLight2.position.set(0, 10, -35);
areaLight2.rotation.set(-Math.PI / 2, 0, 0);
areaLight2.width = 4;
areaLight2.height = 9.9;
scene.add(areaLight2); var areaLight3 = new THREE.AreaLight(0x0000ff, 3);
areaLight3.position.set(10, 10, -35);
areaLight3.rotation.set(-Math.PI / 2, 0, 0);
areaLight3.width = 4;
areaLight3.height = 9.9;
scene.add(areaLight3); var planeGeometry1 = new THREE.BoxGeometry(4, 10, 0);
var planeGeometry1Mat = new THREE.MeshBasicMaterial({color: 0xff0000});
var plane1 = new THREE.Mesh(planeGeometry1, planeGeometry1Mat);
plane1.position.copy(areaLight1.position);
scene.add(plane1); var planeGeometry2 = new THREE.BoxGeometry(4, 10, 0);
var planeGeometry2Mat = new THREE.MeshBasicMaterial({color: 0x00ff00});
var plane2 = new THREE.Mesh(planeGeometry2, planeGeometry2Mat); plane2.position.copy(areaLight2.position);
scene.add(plane2); var planeGeometry3 = new THREE.BoxGeometry(4, 10, 0);
var planeGeometry3Mat = new THREE.MeshBasicMaterial({color: 0x0000ff});
var plane3 = new THREE.Mesh(planeGeometry3, planeGeometry3Mat); plane3.position.copy(areaLight3.position);
scene.add(plane3); var controls = new function () {
this.rotationSpeed = 0.02;
this.color1 = 0xff0000;
this.intensity1 = 2;
this.color2 = 0x00ff00;
this.intensity2 = 2;
this.color3 = 0x0000ff;
this.intensity3 = 2;
}; var gui = new dat.GUI();
gui.addColor(controls, 'color1').onChange(function (e) {
areaLight1.color = new THREE.Color(e);
planeGeometry1Mat.color = new THREE.Color(e);
scene.remove(plane1);
plane1 = new THREE.Mesh(planeGeometry1, planeGeometry1Mat);
plane1.position.copy(areaLight1.position);
scene.add(plane1); });
gui.add(controls, 'intensity1', 0, 5).onChange(function (e) {
areaLight1.intensity = e;
});
gui.addColor(controls, 'color2').onChange(function (e) {
areaLight2.color = new THREE.Color(e);
planeGeometry2Mat.color = new THREE.Color(e);
scene.remove(plane2);
plane2 = new THREE.Mesh(planeGeometry2, planeGeometry2Mat);
plane2.position.copy(areaLight2.position);
scene.add(plane2);
});
gui.add(controls, 'intensity2', 0, 5).onChange(function (e) {
areaLight2.intensity = e;
});
gui.addColor(controls, 'color3').onChange(function (e) {
areaLight3.color = new THREE.Color(e);
planeGeometry3Mat.color = new THREE.Color(e);
scene.remove(plane3);
plane3 = new THREE.Mesh(planeGeometry1, planeGeometry3Mat);
plane3.position.copy(areaLight3.position);
scene.add(plane3);
});
gui.add(controls, 'intensity3', 0, 5).onChange(function (e) {
areaLight3.intensity = e;
}); render(); function render() {
stats.update(); // render using requestAnimationFrame
requestAnimationFrame(render);
renderer.render(scene, camera);
} function initStats() { var stats = new Stats(); stats.setMode(0); // 0: fps, 1: ms // Align top-left
stats.domElement.style.position = 'absolute';
stats.domElement.style.left = '0px';
stats.domElement.style.top = '0px'; document.getElementById("Stats-output").appendChild(stats.domElement); return stats;
}
}
window.onload = init;
</script>
</body>
</html>

  1.7 镜头眩光----LensFlare

    当我们直接朝着太阳拍照时就会出现镜头眩光,对于游戏或者三维图像来说,镜头眩光会使得场景看起来更真实

<!DOCTYPE html>

<html>

<head>
<title>Example 03.07 - Lensflarest</title>
<script type="text/javascript" src="../libs/three.js"></script> <script type="text/javascript" src="../libs/stats.js"></script>
<script type="text/javascript" src="../libs/dat.gui.js"></script>
<style>
body {
/* set margin to 0 and overflow to hidden, to go fullscreen */
margin: 0;
overflow: hidden;
}
</style>
</head>
<body> <div id="Stats-output">
</div>
<!-- Div which will hold the Output -->
<div id="WebGL-output">
</div> <!-- Javascript code that runs our Three.js examples -->
<script type="text/javascript"> // once everything is loaded, we run our Three.js stuff.
function init() { var stats = initStats(); // create a scene, that will hold all our elements such as objects, cameras and lights.
var scene = new THREE.Scene();
scene.fog = new THREE.Fog(0xaaaaaa, 0.010, 200); // create a camera, which defines where we're looking at.
var camera = new THREE.PerspectiveCamera(45, window.innerWidth / window.innerHeight, 0.1, 1000); // create a render and set the size
var renderer = new THREE.WebGLRenderer({antialias: true, alpha: true}); renderer.setClearColor(new THREE.Color(0xaaaaff, 1.0));
renderer.setSize(window.innerWidth, window.innerHeight);
renderer.shadowMapEnabled = true; // 生成一个平面的地面
var textureGrass = THREE.ImageUtils.loadTexture("grasslight-big.jpg");
textureGrass.wrapS = THREE.RepeatWrapping;
textureGrass.wrapT = THREE.RepeatWrapping;
textureGrass.repeat.set(4, 4);
var planeGeometry = new THREE.PlaneGeometry(1000, 200, 20, 20);
var planeMaterial = new THREE.MeshLambertMaterial({map: textureGrass});
var plane = new THREE.Mesh(planeGeometry, planeMaterial);
plane.receiveShadow = true; // rotate and position the plane
plane.rotation.x = -0.5 * Math.PI;
plane.position.x = 15;
plane.position.y = 0;
plane.position.z = 0; // add the plane to the scene
scene.add(plane); // create a cube
var cubeGeometry = new THREE.BoxGeometry(4, 4, 4);
var cubeMaterial = new THREE.MeshLambertMaterial({color: 0xff3333});
var cube = new THREE.Mesh(cubeGeometry, cubeMaterial);
cube.castShadow = true; // position the cube
cube.position.x = -4;
cube.position.y = 3;
cube.position.z = 0; // add the cube to the scene
scene.add(cube); var sphereGeometry = new THREE.SphereGeometry(4, 25, 25);
var sphereMaterial = new THREE.MeshLambertMaterial({color: 0x7777ff});
var sphere = new THREE.Mesh(sphereGeometry, sphereMaterial); // position the sphere
sphere.position.x = 10;
sphere.position.y = 5;
sphere.position.z = 10;
sphere.castShadow = true; // add the sphere to the scene
scene.add(sphere); // position and point the camera to the center of the scene
camera.position.x = -20;
camera.position.y = 15;
camera.position.z = 45;
camera.lookAt(new THREE.Vector3(10, 0, 0)); // 增加环境光,弱化阴影,使得场景看起来更真实
var ambiColor = "#1c1c1c";
var ambientLight = new THREE.AmbientLight(ambiColor);
scene.add(ambientLight); // 增加聚光灯,为场景增加亮度
var spotLight0 = new THREE.SpotLight(0xcccccc);
spotLight0.position.set(-40, 60, -10);
spotLight0.lookAt(plane);
scene.add(spotLight0); var target = new THREE.Object3D();
target.position = new THREE.Vector3(5, 0, 0); var pointColor = "#ffffff";
// 增加方向光光源,模拟太阳
var spotLight = new THREE.DirectionalLight(pointColor);
spotLight.position.set(30, 10, -50);
spotLight.castShadow = true;
spotLight.shadowCameraNear = 0.1;
spotLight.shadowCameraFar = 100;
spotLight.shadowCameraFov = 50;
spotLight.target = plane;
spotLight.distance = 0;
spotLight.shadowCameraNear = 2;
spotLight.shadowCameraFar = 200;
spotLight.shadowCameraLeft = -100;
spotLight.shadowCameraRight = 100;
spotLight.shadowCameraTop = 100;
spotLight.shadowCameraBottom = -100;
spotLight.shadowMapWidth = 2048;
spotLight.shadowMapHeight = 2048; scene.add(spotLight); // add the output of the renderer to the html element
document.getElementById("WebGL-output").appendChild(renderer.domElement); // call the render function
var step = 0; // used to determine the switch point for the light animation
var invert = 1;
var phase = 0; var controls = new function () {
this.rotationSpeed = 0.03;
this.bouncingSpeed = 0.03;
this.ambientColor = ambiColor;
this.pointColor = pointColor;
this.intensity = 0.1;
this.distance = 0;
this.exponent = 30;
this.angle = 0.1;
this.debug = false;
this.castShadow = true;
this.onlyShadow = false;
this.target = "Plane"; }; var gui = new dat.GUI();
gui.addColor(controls, 'ambientColor').onChange(function (e) {
ambientLight.color = new THREE.Color(e);
}); gui.addColor(controls, 'pointColor').onChange(function (e) {
spotLight.color = new THREE.Color(e);
}); gui.add(controls, 'intensity', 0, 5).onChange(function (e) {
spotLight.intensity = e;
}); var textureFlare0 = THREE.ImageUtils.loadTexture("lensflare0.png");
var textureFlare3 = THREE.ImageUtils.loadTexture("lensflare3.png"); var flareColor = new THREE.Color(0xffaacc);
/*参数1:纹理,眩光的材质
参数2:尺寸,眩光的大小,-1的话就是使用材质本身大小
参数3:距离,光源(0)到相机(1)的距离
参数4:融合,//当眩光有多种材质的时候,这些材质如何融合在一起
参数5:颜色,眩光的颜色*/
var lensFlare = new THREE.LensFlare(textureFlare0, 350, 0.0, THREE.AdditiveBlending, flareColor); lensFlare.add(textureFlare3, 60, 0.6, THREE.AdditiveBlending);
lensFlare.add(textureFlare3, 70, 0.7, THREE.AdditiveBlending);
lensFlare.add(textureFlare3, 120, 0.9, THREE.AdditiveBlending);
lensFlare.add(textureFlare3, 70, 1.0, THREE.AdditiveBlending); lensFlare.position.copy(spotLight.position);
scene.add(lensFlare); render(); function render() {
stats.update();
// rotate the cube around its axes
cube.rotation.x += controls.rotationSpeed;
cube.rotation.y += controls.rotationSpeed;
cube.rotation.z += controls.rotationSpeed; // bounce the sphere up and down
step += controls.bouncingSpeed;
sphere.position.x = 20 + ( 10 * (Math.cos(step)));
sphere.position.y = 2 + ( 10 * Math.abs(Math.sin(step))); requestAnimationFrame(render);
renderer.render(scene, camera);
} function initStats() { var stats = new Stats(); stats.setMode(0); // 0: fps, 1: ms // Align top-left
stats.domElement.style.position = 'absolute';
stats.domElement.style.left = '0px';
stats.domElement.style.top = '0px'; document.getElementById("Stats-output").appendChild(stats.domElement); return stats;
}
}; window.onload = init; </script>
</body>
</html>

总结

环境光源没有位置概念,会将颜色应用到场景的每一个物体上,主要作用是弱化阴影,给场景添加颜色

点光源类似于照明弹,朝所有的方向发光,因此不产生阴影

聚光灯光源类似于手电筒,形成锥形的光束,随着距离的增加而变弱,可以设定生成阴影

方向光光源类似于太阳,从很远的地方发出的平行光束,距离越远,衰减的越多

想要一个自然的室外效果,除了添加环境光弱化阴影,添加聚光灯为场景增加光线,还需要使用半球光光源将天空和空气以及地面的散射计算进去,使得更自然,更真实

平面光光源定义了一个发光的发光体,需要使用webgl的延迟渲染机制

眩光效果,在有太阳的时候使用眩光光源,会使得场景更真实

Three.js开发指南---使用three.js里的各种光源(第三章)的更多相关文章

  1. Three.js开发指南---使用three.js的材质(第四章)

    材质就像物体的皮肤,决定了几何体的外表,例如是否像草地/金属,是否透明,是否显示线框等 一 材质 THREE.js的材质分为多种,Three.js提供了一个材质基类THREE.Material, 该基 ...

  2. -Three.js开发指南---用three.js创建你的第一个三维场景(第一章)

    本章主要做了下面的工作 1 生成一个简单的场景,该场景的物体只有平面和坐标轴 2 在第一个demo的基础上添加光源和方块物体,并生成阴影 3 在第二个demo的基础上,增加动画,使得方块进行旋转 4 ...

  3. Node.js开发指南中的例子(mysql版)

    工作原因需要用到nodejs,于是找到了<node.js开发指南>这本书来看看,作者BYVoid 为清华大学计算机系的高材生,年纪竟比我还小一两岁,中华地广物博真是人才辈出,佩服. 言归正 ...

  4. 学习Nodejs:《Node.js开发指南》微博项目express2迁移至express4过程中填的坑

    <Node.js开发指南>项目地址https://github.com/BYVoid/microblog好不容易找到的基础版教程,但书中是基于express2的,而现在用的是express ...

  5. KeyboardJS 开发指南 - 与 Three.js 配合使用的捕捉键盘组合键库

    KeyboardJS 开发指南 - 与 Three.js 配合使用的捕捉键盘组合键库 太阳火神的漂亮人生 (http://blog.csdn.net/opengl_es) 本文遵循"署名-非 ...

  6. 《Three js开发指南》 PDF

    电子版仅供预览及学习交流使用,下载后请24小时内删除,支持正版,喜欢的请购买正版书籍:<Three js开发指南> pdf下载地址:链接: https://pan.baidu.com/s/ ...

  7. 《node.js开发指南》partial is not defined的解决方案

    由于ejs的升级,<node.js开发指南>中使用的 partial 函数已经摒弃,使用foreach,include代替 原来的代码是: <%- partial('listitem ...

  8. NODE.JS开发指南学习笔记

    1.Node.js是什么 Node.js是一个让JS运行在服务器端的开发平台,它可以作为服务器向用户提供服务.Node.js中的javascript只是Core javascript,或者说是ECMA ...

  9. Node.js 开发指南笔记

    第一章:node简介 介绍了node是什么:node.js是一个让javascript运行在服务器端的开发平台, node能做些什么:[书上的] 具有复杂逻辑的网站 基于社交网络的大规模Web应用 W ...

随机推荐

  1. string和char*的相互转换

    原文地址: 点击打开链接

  2. 从log中分析Android wif连接状态的方法

    1.这里是从log中通过搜索关键字wpa_supplicant: wlan0: State过滤之后的log: Line 1: 11-25 20:10:14.968120  1104  1104 D w ...

  3. 作业八:团队项目——Alpha阶段项目总结

    1.项目的预期目标 最初的项目计划实现一款类似微信飞机大战这样的一款模拟飞行游戏,中途也没有变动. 2.目前项目实现的功能. 击落飞机并计分. 3.下阶段我们可以增加游戏更多的功能,以及增加网络在线对 ...

  4. C#中隐藏(new)、方法重写(override)、重载(overload)的区别

    转自:http://www.cnblogs.com/glife/archive/2009/12/28/1633947.html 重载.重写和隐藏的定义: 重载:public string ToStri ...

  5. git学习:关于origin和master

    [转载请注明出处]http://www.cnblogs.com/mashiqi 2016/10/27 本文主要是对这篇博客文章的理解. git的服务器端(remote)端包含多个repository, ...

  6. php判断json对象是否存在的方法

    在实际测试中php读取json数组时 使用简单的 if 或者 array_key_exists 去判断对象是否存在是会报错的,以下是google搜寻的正确判断方法 实际上出现报错只是我对php还不是很 ...

  7. 记一些之前忘记积累的问题(fiddler 学习、XP系统不能上网、XP不能装fiddler、注册表快速找到)

    记一些之前忘记积累的问题: fiddler学习:http://www.cnblogs.com/kingwolf_JavaScript/archive/2012/11/07/FiddlerUI.html ...

  8. CSS中的text-overflow:clip|ellipsis的使用

    如果想让某个容器(div或者li或者...块级元素)显示一行文字,当文字内容过多时,不换行,而是出现...,可以使用text-overflow:clip|ellipsis 基本语法:text-over ...

  9. CSS3+JS切割轮播图

    以下说明数据,是指有4张图片的轮播图,分别切割成4张. 首先,做成单张切换的立体效果,即通过旋转,确定四张图片的位置,分别是一个立方体的上下前后的图片翻转移动角度. .box ul li:nth-ch ...

  10. ecshop后台分页浅析

      既然是分页,道理都是一样的,不过ecshop前台分页的函数和后台分页的函数不同,后台分页函数为page_and_size(),在admin/includes/lib_main.php里.都是用aj ...