ThingJS场景效果加入新成员—聚光灯

简介: 聚光灯光源从一个点向一个方向发出,沿着一个圆锥,光照越远它的尺寸就越大。ThingJS场景效果加入新成员—聚光灯。

聚光灯光源从一个点向一个方向发出,沿着一个圆锥,光照越远它的尺寸就越大。ThingJS场景效果加入新成员—聚光灯。
光源 (Lights) 是每个场景的重要组成部分。网格和纹理决定了场景的形状和外观,而光源则决定了三维环境的颜色和氛围。您可能会在每个场景中使用多个光源。让它们一起工作需要一些实践,但结果却相当惊人。
1.jpg

ThingJS 提供一个模拟手电筒、车灯、等线性光照效果的光源—聚光灯,从一个点向锥形范围内发射光线,官方类型是spotlight。
聚光灯是3D世界中的一种光源类型,其灯光从一点发出,沿着某一个方向照射出一个锥形光照范围。聚光灯近似于一个有夹角范围限定的点光源。聚光灯可用于模拟舞台、汽车车头灯,手电筒,台灯等光源效果,可添加至3D容器、摄像机等对象下方,对其中所有对应的对象生效。

聚光灯属性介绍

灯光角度
聚光灯的灯光聚光角度。
亮度
光线的明亮程度。
半影
投射光线边缘的虚化,默认为0,不模糊。
距离
光源照射的距离。默认为0,如果为0,表示光源不受距离影响,可照射至无穷远。
高度
光源照射的高度。聚光灯有方向和位置,并且以圆锥的形状制造灯光。
影子
光源被物体所遮蔽而产生阴影效果,默认关闭。
辅助线
默认显示。这种灯光从一点发出,在一个方向按照—个锥形的范围照射,呈现圆锥的形状。
跟随物体
通过设定追踪对象,可将该聚光灯设定为追光灯。
颜色
光线的颜色,对象的颜色受光线颜色影响。
2.png

3dmax之中,聚光灯是室内打光的基础,这种类型的3dmax灯光可以方便我们快速提亮目标区域的亮度,如果目标物体是动态的呢?官方采用JS mousemove鼠标移动事件来实现目标物体运动。
mousemove 事件是一个实时响应的事件,当鼠标指针的位置发生变化时(至少移动一个像素),就会触发 mousemove 事件。该事件响应的灵敏度主要参考鼠标指针移动速度的快慢以及浏览器跟踪更新的速度。官方在物体上方5米创建一个聚光灯,并让物体沿着路径方向不断循环,实现“跟随物体”的聚光灯效果。光打在了移动的物体上,照射范围和角度随着物体移动变化而变化。

跟随物体的聚光灯代码示例如下。完整版请登录ThingJS平台-场景效果-聚光灯查看。

var app = new THING.App({
    url: 'https://www.thingjs.com/static/models/storehouse',
});

// 参数
var dataObj = {
    'type': 'SpotLight',
    'lightAngle': 30,
    'intensity': 1,
    'penumbra': 0.5,
    'castShadow': false,
    'position': null,
    'height': 0,
    'color': 0xFFFFFF,
    'distance': null,
    'target': null,
    'helper': true,
};
// 叉车
let car1;
let car2;
// 当前灯光
let curLight;
let curLightPosition;
// 创建聚光灯方法
function createSpotLight(position, target) {
    dataObj['lightAngle'] = 30;
    dataObj['intensity'] = 0.5;
    dataObj['penumbra'] = 0.5;
    dataObj['castShadow'] = false;
    dataObj['position'] = position;
    dataObj['distance'] = 25;
    dataObj['color'] = 0xFFFFFF;
    dataObj['helper'] = true;
    dataObj['follow'] = false;
    //创建聚光灯
    var spotLight = app.create(dataObj);
    curLight = spotLight;
    curLightPosition = spotLight.position;
    createSpotLightControlPanel(spotLight);
}
……
// 注册鼠标移动事件,检查是否按下'shift'键, 按下设置聚光灯跟随鼠标位置
app.on('mousemove', function (ev) {
    if (!curLight) {
        return;
    }

    if (!ev.shiftKey) {
        return;
    }

    var pickedPosition = ev.pickedPosition;
    if (pickedPosition) {
        curLight.lookAt(pickedPosition);
    }
})
// 注册场景load事件
app.on('load', function (ev) {

    // 主灯强度设置为0,突出聚光灯效果
    app.lighting = {
        mainLight: {
            intensity: 0
        }
    };

    // 获取场景内id为'car01' 和 'car02' 的叉车
    car1 = app.query('car01')[0];
    car2 = app.query('car02')[0];

    // 参数1: 在car2上方5米创建一个聚光灯
    // 参数2: 初始target设置为car1的位置
    createSpotLight(THING.Math.addVector(car2.position, [0, 5, 0]), car1.position);

    // 创建一个圆形路径
    var path = [];
    var radius = 6;
    for (var degree = 0; degree <= 360; degree += 10) {
        var x = Math.cos(degree * 2 * Math.PI / 360) * radius;
        var z = Math.sin(degree * 2 * Math.PI / 360) * radius;
        path.push(THING.Math.addVector(car1.position, [x, 0, z]));
    }
    // 让 car1 沿圆形路径运动
    car1.movePath({
        orientToPath: true, // 物体移动时沿向路径方向
        path: path,
        time: 10 * 1000,
        // 循环类型
        // THING.LoopType.Repeat 不断循环
        // THING.LoopType.PingPong 往复循环
        loopType: THING.LoopType.Repeat
    });
    console.log("按住'shift' 聚光灯可以追踪鼠标位置(开启'跟随物体'后失效)");
})

ThingJS,场景效果基础打好了,让你的项目应用更加轻松!

相关文章
|
6月前
鬼刀画风扁平化粒子炫动引导页美化源码
鬼刀画风扁平化粒子炫动引导页美化源码
45 5
鬼刀画风扁平化粒子炫动引导页美化源码
|
6月前
|
图形学
【unity小技巧】unity3d创建和实现破碎打破物品,万物可破碎
【unity小技巧】unity3d创建和实现破碎打破物品,万物可破碎
292 0
【unity小技巧】unity3d创建和实现破碎打破物品,万物可破碎
|
5月前
|
前端开发
好的商业模式,一定要做的事情,代码库,Canvas画线之蚂蚁线,代码库,一个方框线条断裂循环往复的效果
好的商业模式,一定要做的事情,代码库,Canvas画线之蚂蚁线,代码库,一个方框线条断裂循环往复的效果
|
定位技术 图形学
Unity3D——射击游戏(多地图,多人物,枪支切换,驾车,扔手雷等功能,堪比小型和平精英)
Unity3D——射击游戏(多地图,多人物,枪支切换,驾车,扔手雷等功能,堪比小型和平精英)
好客租房110-修改tabber样式外观
好客租房110-修改tabber样式外观
142 0
好客租房110-修改tabber样式外观
好客租房159-组件内样式覆盖问题的说明
好客租房159-组件内样式覆盖问题的说明
93 0
|
前端开发 Swift iOS开发
SwiftUI直通车系列(1)—— 视图的布局与组织
SwiftUI直通车系列(1)—— 视图的布局与组织
220 0
SwiftUI直通车系列(1)—— 视图的布局与组织
|
人工智能 编解码 搜索推荐
被福特选中的技术!MIT开发可编程墨水,让你的AJ“色随心变”
被福特选中的技术!MIT开发可编程墨水,让你的AJ“色随心变”
200 0
|
物联网
ThingJS有4种技术实现对象拾取方式
对象的拾取,这是3D技术的一个专业术语。
ThingJS有4种技术实现对象拾取方式
|
数据可视化 JavaScript 物联网
ThingJS让3D灯光管理更容易!
场景中的灯光与真正的灯光不同,它需要在渲染时间上多花功夫
ThingJS让3D灯光管理更容易!