zoukankan      html  css  js  c++  java
  • WebGL6---五彩的光源(1)

    1、Threejs中各种光源

          1)光源基类

                在Threejs中,光源用Light表示,它是所有光源的基类。它的构造函数是:THREE.Light(hex);

           它有一个参数hex,接受一个16进制的颜色值。如果要定义一种红色的光源,例如:

                var RedLight = new THREE.Light(0xFF0000);

          2) 有基类派生出来的其他种类的光源

               

                    接下来对各种光源详细介绍:

                  2.1)THREE.AmbientLight(环境光

                          环境光是经过多次反射而来的光,无法确定其最初方向;环境光是一种无处不在的光;

                 当你仅为场景制定环境光时,所有的物体无论法向量如何,都将表现为同样的明暗程度;

                  2.2)THREE.PointLight(点光源)

                           由这种光源放出来的光线来自同一点,且方向辐射到四面八方。例如:蜡烛放出的光,萤火虫放出的光;

                           构造函数: PointLight(color,intensity,distance);

                           ① color: 光的颜色     ②intensity: 光的强度,默认是1.0(100%强度的灯光)  ③distance:光的距离,

                  从光源所在的位置,经过distance这段距离之后,光的强度从intensity衰减到0.默认情况下,这个值为0,表示光源强度不衰减;

                   2.3)THREE.SpotLight(聚光灯)

                            这种光源的光线从一个锥体中射出,在被照射的物体上产生聚光的效果;使用这种光源需要指定光的射出方向以及锥体的顶角。

                            构造函数: THREE.SpotLight(hex,intensity,distance,angle,exponent);

                            ① hex:聚光灯发出的颜色,如:0xFFFFFF

                            ② intensity: 光源的强度,默认是1.0,如果为0.5,则强度是一半;

                            ③ distance : 光线的强度,从最大值衰减到0需要的距离;默认值为0,表示光不衰减;如果非0,则表示到离光源Distance时,光源强度为0;

                            ④ angle:聚光灯着色的角度,用弧度作为单位,这个角度是和光源的方向形成的角度;

                            ⑤ exponent: 光源模型中,衰减的一个参数,越大衰减越快;

                 

                  总结:

                        1)当没有任何光源的时候,最终的颜色将是黑色,无论材质是什么颜色;

                        2)Lamber 材质会在所有方向上均匀的散射灯光;

                

                   2.4) THREE.DirectionalLight(方向光)

                         方向光是一组没有衰减的平行的光线,类似太阳光的效果; 

                                         

                            构造函数: THREE.DirectionalLight =  function(hex,intensity)

                        ①hex: 光线的颜色,用16进制表示;

                        ②intensity: 光线的强度,默认为1;如果为0,表示光线基本没什么用,物体就会显示为黑色;

                      总结:ligth.position.set(0,0,100)

                              1)更改z值渲染结果相同-------颜色的深浅与里物体的距离没有关系;

                              2)更改x,y值结果不同----由于更改的平行光的方向;

                                 

  • 相关阅读:
    桥接模式
    单例模式
    SpringAOP aspectJ ProceedingJoinPoint 获取当前方法
    springMVC实现文件下载
    JAVA的变量初始化类成员变量和局部变量区别
    JAVA枚举类型的应用
    linux下svn命令大全
    转:shell脚本的一些注意事项
    转: linux下不同服务器间数据传输(rcp,scp,rsync,ftp,sftp,lftp,wget,curl)
    TCP三次握手/四次挥手详解
  • 原文地址:https://www.cnblogs.com/sunqq/p/10412981.html
Copyright © 2011-2022 走看看