图形化开发(五)022-Three.js之材质——受光影响-MeshLambertMaterial 兰伯特材质 & MeshPhongMaterial 高光材质
程序员文章站
2022-06-11 11:35:53
...
图形化开发(五)022-Three.js之材质——受光影响-MeshLambertMaterial 兰伯特材质 & MeshPhongMaterial 高光材质
添加光
由于MeshBasicMaterial
不会受光的影响,即使有光也不会影响它的效果,前面我们也没有添加光。但是后面介绍的材质会受到光源的影响,在介绍之前,我们需要添加一个光源,来影响材质的显示效果。
//创建灯光
function initLight() {
var light = new THREE.DirectionalLight(0xffffff); //添加了一个白色的平行光
light.position.set(20, 50, 50); //设置光的方向
scene.add(light); //添加到场景
//添加一个全局环境光
scene.add(new THREE.AmbientLight(0x222222));
}
MeshLambertMaterial 兰伯特材质
这种材质会对光有反应,但是不会出现高光,可以模拟一些粗糙的材质的物体,比如木头或者石头。实现案例:
geometry = new THREE.BoxGeometry( 2, 2, 2 ); //创建几何体
material = new THREE.MeshLambertMaterial({color:0x00ffff}); //创建材质
mesh = new THREE.Mesh( geometry, material ); //创建网格
scene.add( mesh ); //将网格添加到场景
MeshPhongMaterial 高光材质
这种材质具有高光效果,可以模拟一些光滑的物体的材质效果,比如油漆面,瓷瓦等光滑物体。实现案例:
geometry = new THREE.BoxGeometry( 2, 2, 2 ); //创建几何体
material = new THREE.MeshPhongMaterial({color:0x00ffff}); //创建材质
mesh = new THREE.Mesh( geometry, material ); //创建网格
scene.add( mesh ); //将网格添加到场景
上一篇: php将access数据库转换到mysql数据库的方法
下一篇: 温馨告戒即将上大学的高中生