【BIM】BIMFACE中创建疏散效果
背景
在BIM运维中,消防疏散是不可或缺的一环,当发生火警的时候,触发烟感器发生报警,同时启动消防疏散,指导现场工作人员进行疏散,及时准确地显示出疏散路线对争取疏散时间尤为重要。我将介绍如何在bimface中建立消防疏散指示动画效果。
思路
第一种方式就是通过bimface自带的材质对象,结合requestAnimationFrame
函数实现,具体地址见官网的水流效果。这种方式存在弊端,首先代码量相对来说比较大,要配置各种对象的参数;其次对构件有强依赖性,也就是说这种方式是对构件进行材质重写来实现的;此外这种方式的贴图是通过UV贴图实现,贴图缩放比例不好确定,需要摸索试探地确定比较合适的参数,第二种方式是直接通过threejs来实现,相对于第一种方式而言,无需太多的代码,直奔主题,最重要的是不依赖构件(实际上是自己创建了Mesh
),也就是说没有构件同样可以实现上述效果,最重要的是不用再摸着石头贴图了,自己能够掌握贴图的规律。本文中采用第二种方式来实现疏散效果,其实思路很简单,无非是创建Mesh
,然后给Mesh
贴上带箭头的图片,完成贴图后动态地修改贴图的偏移量(offset
),就实现了箭头动画效果。
实践
首先来制作材质,因为路线由若干个PlaneBufferGeometry
组成,所以每一个都要进行贴图操作,其实除了图片在PlaneBufferGeometry
上的分布个数不一致,其他的参数都是一致的,所以要结合图片的大小和PlaneBufferGeometry
的长度来动态计算每个PlaneBufferGeometry
上材质需要重复的次数。将创建的材质放入集合中是为了后续在执行动画时,可以针对每一个材质进行偏移量的修改,代码如下:
//声明存储材质的集合
var textureCollection = [];
function generateMaterial(repeat) {
var basicMaterial = new THREE.MeshBasicMaterial();
texture = new THREE.TextureLoader().load('images/icon_arrow_right_pow.png', function (map) {
basicMaterial.map = map;
basicMaterial.wireframe = false;
basicMaterial.needsUpdate = true;
basicMaterial.transparent = true;
basicMaterial.side = THREE.DoubleSide;
});
texture.wrapS = THREE.RepeatWrapping;
texture.wrapT = THREE.RepeatWrapping;
texture.repeat.x = repeat;
textureCollection.push(texture);
return basicMaterial;
}
有了材质,还需要创建若干个Mesh
,因为疏散路线是由一个一个的长条矩形组成,所以选择用平面PlaneBufferGeometry
来制作,材质使用箭头图片进行贴图。代码如下:
/**
* @param {若干Mesh的集合,每个Mesh结构如下} planeArray
*
* @param {构件最小点世界坐标} min_position
* @param {构件最大点世界坐标} max_position
* @param {构件方向,上下左右以此对应(1,-1,2,0)} direction
*/
function loadPlane(planeArray) {
// 标准宽度
const statndardWidth = 500;
// 用于计算标准图片重复个数
const statndardRepeat = 600;
// 指定默认角度
const rotate = Math.PI / 2;
var planeGroup = new THREE.Group();
// 思路一:仅用最大点进行定位(目前采用)
// 思路二:用最大点和最小点进行定位
for (let k = 0, l = planeArray.length; k < l; k++) {
let l = position_x = position_y = 0;
//区分横向和纵向
if (planeArray[k].direction === 1 || planeArray[k].direction === -1) {
l = Math.floor(planeArray[k].max_position.y - planeArray[k].min_position.y);
position_x = planeArray[k].max_position.x - (statndardWidth / 2);
position_y = planeArray[k].max_position.y - (l / 2);
} else {
l = Math.floor(planeArray[k].max_position.x - planeArray[k].min_position.x);
position_x = planeArray[k].max_position.x - (l / 2);
position_y = planeArray[k].max_position.y - (statndardWidth / 2);
}
let _material = generateMaterial(Math.floor(l / statndardRepeat));
let planeGeometry = new THREE.PlaneBufferGeometry(l, statndardWidth, 100, 50);
let plane = new THREE.Mesh(planeGeometry, _material);
plane.position.x = position_x;
plane.position.y = position_y;
plane.position.z = planeArray[k].max_position.z + 10;
plane.rotation.z = rotate * planeArray[k].direction;
planeGroup.add(plane);
}
viewer.addExternalObject("planeGroup", planeGroup);
viewer.render();
}
目前形状和材质都已经建立完成,整个场景还是静态的,由箭头组成的平面形状集合,下一步是让这些箭头跑起来,思路就是在渲染的时候动态修改材质的offset
,代码如下:
function animate() {
animationId = requestAnimationFrame(animate);
for (let m = 0, len = textureCollection.length; m < len; m++) {
textureCollection[m].offset.x += 0.005;
}
viewer.render();
}
使用方式,只需要将mesh
对应的包围盒最大点和最小点(用于确定位置)以及箭头方向(用于确定箭头流向)的参数放在数组中传入loadPlane
函数,然后调用animate
函数即可实现疏散效果,代码如下:
let planeArray = [];
const UP = 1;
const DOWN = -1;
const LEFT = 2;
const RIGHT = 0;
let a = { min_position: { x: -10432.83984375, y: 20233.87109375, z: 15 }, max_position: { x: -9932.83984375, y: 26744.16796875, z: 40 }, direction: UP };
let b = { min_position: { x: -14117.83984375, y: 28943.8671875, z: 15 }, max_position: { x: -12812.83984375, y: 29443.8671875, z: 50 }, direction: RIGHT };
let c = { min_position: { x: -7591.01171875, y: 27244.16796875, z: 15 }, max_position: { x: -7091.01171875, y: 33333.8671875, z: 20 }, direction: UP };
planeArray.push(a);
planeArray.push(b);
planeArray.push(c);
loadPlane(planeArray);
animate();
效果
以下是结合真实模型的疏散路线效果
如有描述不当之处,还请不吝赐教。
地址:https://www.cnblogs.com/xhb-bky-blog/p/12521888.html
声明:本博客原创文字只代表本人工作中在某一时间内总结的观点或结论,与本人所在单位没有直接利益关系。非商业,未授权贴子请以现状保留,转载时必须保留此段声明,且在文章页面明显位置给出原文连接。
【BIM】BIMFACE中创建疏散效果的更多相关文章
- 【BIM】BIMFACE中创建雾化效果
背景 在BIM运维场景初始化的时候,一般都是首先将整个运维对象呈现在用户面前,例如一座大厦.一座桥梁.一个园区等等,以便于用户进行总览,总体把握运维对象,如果这个宏大的场景边界过于清晰,与背景融合也不 ...
- 【BIM】BIMFACE中创建矢量文本[下篇]
背景 在上一篇文章中,我们通过THREEJS创建了矢量文本,并添加到了BIMFACE场景中,但是仅仅加入到场景中并不是我们的目的,我们的目的是把这种矢量文本加到指定的构件或者空间上,以此标识该构件或空 ...
- 【BIM】BIMFACE中创建矢量文本
背景 在三维模型产品的设计中,针对空间的管理存在这样一个普遍的需求,那就是在三维模型中,将模型所代表的空间通过附加文本的方式来展示其所代表的实际位置或功能,之前尝试过若干方式,比如直接在建模的时候,将 ...
- 【BIM】BIMFACE中实现电梯实时动效
背景 在运维场景中,电梯作为运维环节重要的一部分是不可获缺的,如果能够在三维场景中,将逼真的电梯效果,包括外观.运行状态等表现出来,无疑是产品的一大亮点.本文将从无到有介绍如何在bimface中实现逼 ...
- SQL Server 在多个数据库中创建同一个存储过程(Create Same Stored Procedure in All Databases)
一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 遇到的问题(Problems) 实现代码(SQL Codes) 方法一:拼接SQL: 方法二: ...
- m.jd.com首页中的js效果
m.jd.com中的部分js效果 昨天把m.jd.com的首页布局写好了,今天写一下首页中部分js效果.头部背景色透明度的改变,焦点图轮播,京东快报的小轮播,以及秒杀倒计时.这里html,css样式就 ...
- 如何在MFC中创建非矩形button
一般情况下,我们创建的按钮都是矩形的,但有时为了满足特殊的需求,我们要在对话框中创建一个非矩形的按钮,比如,圆形,椭圆等. 要实现一个非矩形的按钮,这就涉及到了自绘控件.自绘控件的方法有很多,可以参考 ...
- Sticker.js – 帮助你在网站中加入贴纸效果
Sticker.js 是一个很小的 JavaScript 库,它允许您在网页中创建漂亮的贴纸效果.没有依赖关系(不需要 jQuery),可以在大多数支持 CSS3 的主流浏览器工作.下面有简单的使用示 ...
- ASP.NET 5系列教程 (六): 在 MVC6 中创建 Web API
ASP.NET 5.0 的主要目标之一是统一MVC 和 Web API 框架应用. 接下来几篇文章中您会了解以下内容: ASP.NET MVC 6 中创建简单的web API. 如何从空的项目模板中启 ...
随机推荐
- 由世界坐标系转换到摄像机坐标系的lookAt()函数
在学习图形学和opengl的时候,都涉及到坐标转化,从物体坐标转换为世界的坐标,从世界的坐标转换为摄像机的坐标. 在世界坐标到摄像机转换的过程中常用lookAt函数得到转化矩阵.GLM官方文档对它的解 ...
- mybatis进阶案例之多表查询
mybatis进阶案例之多表查询 一.mybatis中表之间的关系 在数据库中,实体型之间的关系主要有如下几种: 1.一对一 如果对于实体集A中的每一个实体,实体集B中至多有一个(也可以没有)实体与之 ...
- MATLAB神经网络(2)之R练习
1. AMORE 1.1 newff newff(n.neurons, learning.rate.global, momentum.global, error.criterium, Stao, hi ...
- AspNetCore3.1_Middleware源码解析_3_HttpsRedirection
概述 上文提到3.1版本默认没有使用Hsts,但是使用了这个中间件.看名字就很好理解,https跳转,顾名思义,就是跳转到 https地址. 使用场景,当用户使用http访问网站时,自动跳转到http ...
- 《深入理解 Java 虚拟机》读书笔记:早期(编译期)优化
正文 Java 语言的 3 类编译器: 前端编译器:把 java 文件 转变成 class 文件.例如:Sun 的 Javac. JIT 编译器(即时编译器):后端运行期编译器,把字节码转变成机器码. ...
- ajax上传文件,通过FromData把数据传给后端
前端代码 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF- ...
- Python3学习之路~9.4 队列、生产者消费者模型
一 队列queue 当必须在多个线程之间安全地交换信息时,队列在线程编程中特别有用. 队列的作用:1.解耦,使程序直接实现松耦合 2.提高处理效率 列表与队列都是有顺序的,但是他们之间有一个很大的区别 ...
- Fast and accurate bacterial species identification in urine specimens using LC-MS/MS mass spectrometry and machine learning (解读人:闫克强)
文献名:Fast and accurate bacterial species identification in urine specimens using LC-MS/MS mass spectr ...
- [剑指offer]25.合并两个排序的链表(迭代+递归)
25.合并两个排序的链表 题目 输入两个递增排序的链表,合并这两个链表并使新链表中的节点仍然是递增排序的. 示例1: 输入:1->2->4, 1->3->4 输出:1-> ...
- canvas.toDataURL()报错的解决方案全都在这了
报错详尽信息 Uncaught DOMException: Failed to execute 'toDataURL' on 'HTMLCanvasElement': Tainted canvases ...