ThingJS如何完成第一人称视角的场景巡检功能

简介: 在数据可视化领域利用webgl来创建三维场景或VR已经越来越普遍,各种开发框架也应运而生。

在数据可视化领域利用webgl来创建三维场景或VR已经越来越普遍,各种开发框架也应运而生。ThingJS如何完成第一人称视角的场景巡检功能?
目前 ThingJS 内置了「第一人称行走」控件,实现第一人称人物动作:走、跑、跳、移动视角,可供开发者使用。
“第一人称行走”交互模式会让人想到游戏射击游戏,给玩家一定的空间来让他们来真正感受处于每个位置的感觉。而实现人物动画,例如行走步伐,就需要一定的交互,包括周围的环境、重力或撞击影响。
ThingJS实现第一人称控制移动,主要通过js脚本让鼠标控制任务或者摄像机的旋转。官方添加「第一人称行走」控件后,鼠标按住左键拖拽方向,默认的交互为键盘按键来控制行走方向:
• A:左移
• D:右移
• W:前进
• S:后退
• 空格:跳跃(当开启重力时生效)
• 鼠标:按下左键旋转场景

用于物体移动的控制器支持js开发,提供GUI(图形用户界面)手动调整参数。不懂开发?动动手也可以调整空间参数啦!
1.jpg

视角移动的起始位置是摄像机位置,实时代码示例如下:

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

// 加载场景后执行
app.on('load', function () {
    // 创建按钮
    new THING.widget.Button('添加控件', add_control);
    new THING.widget.Button('删除控件', remove_control);
});

// 添加控件
var ctrl = null;
var gui = null;
function add_control() {
    if (ctrl) {
        return;
    }

    app.camera.position = [0, 10, 0];// 起始位置 就是摄像机位置, 不设置就会在摄像机位置直接开始
    ctrl = app.addControl(
        new THING.WalkControl({ // 参数可以动态修改
            walkSpeed: 0.02, // 行走速度
            turnSpeed: 0.25, // 右键旋转速度
            gravity: 29.8, // 物体重量
            eyeHeight: 1.6, // 人高度
            jumpSpeed: 10, // 按空格键 跳跃的速度
            enableKeyRotate: false, // 默认不开启键盘控制旋转
            useCollision: false, // 默认不开启碰撞检测
            useGravity: true // 默认开启重力
        })
    );
    // GUI
    gui = new THING.widget.Panel({ 'titleText': '第一人称行走', 'hasTitle': true });

    gui.position = [10, 200];

    gui.addBoolean(ctrl, 'enableKeyRotate').caption('键盘控制旋转');
    gui.addBoolean(ctrl, 'useCollision').caption('碰撞检测');
    gui.addBoolean(ctrl, 'useGravity').caption('重力检测');

    gui.addNumberSlider(ctrl, 'gravity').caption('重力').step(1).min(0).max(50).isChangeValue(true);
    gui.addNumberSlider(ctrl, 'jumpSpeed').caption('跳起速度').step(1).min(0).max(30).isChangeValue(true);
}

// 删除控件
function remove_control() {
    if (ctrl) {
        app.removeControl(ctrl);
        ctrl = null;
        gui.destroy();
    }
}

ThingJS,让场景巡检3D可视化更加强大

相关文章
|
2月前
|
数据可视化 BI 项目管理
如何用看板工具提升生命管理质量?
看板管理源自企业项目管理,现应用于个人生活,通过任务可视化、灵活调整和持续优化,帮助人们在健康、工作、学习、家庭等多方面实现高效有序管理,使生活更加有条理,提高生活质量。
35 1
如何用看板工具提升生命管理质量?
|
6月前
|
测试技术 网络安全 Python
在可视会议系统工程中,系统工程方法可以帮助我们系统地规划、设计和实现一个高效、可靠的可视会议系统。
在可视会议系统工程中,系统工程方法可以帮助我们系统地规划、设计和实现一个高效、可靠的可视会议系统。
产品设计——无处不入口,无处不按钮
产品设计——无处不入口,无处不按钮
108 0
|
8月前
|
监控 安全 5G
UWB人员精准定位系统源码,实现实时定位、人机料配对、物料标签配置、智慧调度、轨迹追踪
人员定位管理系统通过在厂区、车间部署UWB定位基站,实时采集人员、机具、物料上定位标签回传的位置信息数据,采用多维定位模式,精确定位人、机具、物料的实时位置,实现实时定位、人机料配对、物料标签配置、智慧调度、轨迹追踪、工时统计、区域物料统计、电子围栏等应用功能。
138 1
|
存储 智能设计 运维
案例酷 | 索菲亚:产品全生命周期管理,多维升级谋“整家定制”新篇
编者按: 当前定制家居企业的竞争,不仅局限于渠道布局和品类扩展,智能化生产设备的使用范围正逐渐成为定制家居行业新的竞争领域。在数字化战略的指引下,索菲亚以数智化为引擎,建立起从消费端到设备端的整个产品全生命周期的管理,信息化、数字化、智能化“三驾马车”共同发力,推动索菲亚步入未来定制家具增长的新阶段。 全文约4777字,建议阅读时间14分钟。
1207 0
案例酷 | 索菲亚:产品全生命周期管理,多维升级谋“整家定制”新篇
|
运维 安全 数据安全/隐私保护
BIM在设计、施工和运维的细分应用点(中英文对照)
BIM在设计、施工和运维的细分应用点(中英文对照)
BIM在设计、施工和运维的细分应用点(中英文对照)
|
移动开发 数据可视化 前端开发
基于自然流布局的可视化拖拽搭建平台设计方案
LowCode 是高效、高性能的拖拽式低代码开发平台. 也是笔者最近一直在研究的方向, 对于可视化搭建平台的实现方案笔者之前写过很多文章, 这里带大家探索一个新方向——基于自然流布局的可视化搭建平台.
964 0
资深交互设计师教你:四类弹框的四大设计准则
资深交互设计师教你:四类弹框的四大设计准则
资深交互设计师教你:四类弹框的四大设计准则
|
移动开发 数据可视化 信息无障碍
|
存储 JSON 运维
基于WebGL的3D可视化告警系统关键技术解析 ThingJS
1. WebGL 3D技术 2. 新一代3D框架-ThingJS 3. 3D可视化告警系统案例 4. 基于ThingJS的通用架构设计