资讯专栏INFORMATION COLUMN

如何用基于WebGL架构的3D可视化平台搭建-设备管理系统

jiekechoo / 3076人阅读

摘要:下面我们将用平台来模拟一个设备管理系统。查看是否创建了定时器第三步,创建摄像机面板,烟感报警面板以及控制设备的开关,这里简单调整一下面板位置之后会增加两个创建设备的按钮。创建对象数组,以及数组标识第五步,为每个设备对应的创建控制开关。

国内高层建筑不断兴建,它的特点是高度高、层数多、体量大。面积可达几万平方米到几十万平方米。这些建筑都是一个个庞然大物,高高的耸立在地面上,这是它的外观,而随之带来的内部的建筑设备也是大量的。为了提高设备利用率,合理地使用能源,加强对建筑设备状态的监视等,自然地就提出了楼宇自动化控制系统。下面我们将用ThingJS平台来模拟一个设备管理系统。

第一步,利用CampusBuilder搭建模拟场景。CampusBuilder的模型库有各种各样的模型,使我们搭建出的场景更逼真。使用CampusBuilder创建层级,之后再给层级加外立面就出现了当前的效果。详情移步:CampusBuilder3D场景制作工具

第二步,创建Equipment类,这里创建。switchControl方法主要一个完成一个计时器的功能来模拟设备警报。

</>复制代码

  1. class Equipment extends THING.Thing {
  2. constructor(app, name, obj, url) {
  3. super(app);
  4. this.name = name;
  5. this.obj = obj;
  6. this.url = url;
  7. this.interval = null;
  8. this.localPosition = [Math.floor(Math.random() * 7), 2.9, Math.floor(Math.random() * 7)];
  9. }
  10. createSelf() {
  11. app.create({
  12. type: "Equipment",
  13. name: this.name,
  14. url: this.url,
  15. parent: this.obj,
  16. localPosition: this.localPosition,
  17. angle: 0
  18. });
  19. }
  20. switchControl(ev) {
  21. var flag;
  22. var equipment = app.query(this.name)[0];
  23. app.level.change(equipment);
  24. if (ev) {
  25. this.interval = setInterval(function () {
  26. if (flag) {
  27. equipment.style.color = "#FF0000";
  28. flag = false;
  29. } else {
  30. flag = true;
  31. equipment.style.color = "";
  32. }
  33. }, 500);
  34. console.log(this.interval + "查看是否创建了定时器");
  35. } else {
  36. console.log(this.interval);
  37. clearInterval(this.interval);
  38. if (equipment.style.color == "#FF0000")
  39. equipment.style.color = "";
  40. }
  41. }
  42. }
  43. THING.factory.registerClass("Equipment", Equipment);

第三步,创建摄像机面板,烟感报警面板以及控制设备的开关,这里简单调整一下面板位置之后会增加两个创建设备的按钮。

</>复制代码

  1. //创建主面板
  2. var panel1 = new THING.widget.Panel({
  3. titleText: "摄像机列表",
  4. closeIcon: false, // 是否有关闭按钮
  5. dragable: true,
  6. retractable: true,
  7. opacity: 0.9,
  8. hasTitle: true,
  9. });
  10. panel1.position = [80, 0];
  11. var panel2 = new THING.widget.Panel({
  12. titleText: "烟感报警列表",
  13. closeIcon: false, // 是否有关闭按钮
  14. dragable: true,
  15. retractable: true,
  16. opacity: 0.9,
  17. hasTitle: true,
  18. });
  19. panel2.position = [80, 320];
  20. // 创建任意对象
  21. var dataObj1 = {
  22. open1: false,
  23. open2: false,
  24. open3: false,
  25. open4: false,
  26. }
  27. var dataObj2 = {
  28. open5: false,
  29. open6: false,
  30. open7: false,
  31. open8: false,
  32. };
  33. // 动态绑定物体
  34. var open1 = panel1.addBoolean(dataObj1, "open1").caption("设备01");
  35. var open2 = panel1.addBoolean(dataObj1, "open2").caption("设备02");
  36. var open3 = panel1.addBoolean(dataObj1, "open3").caption("设备03");
  37. var open4 = panel1.addBoolean(dataObj1, "open4").caption("设备04");
  38. var open5 = panel2.addBoolean(dataObj2, "open5").caption("设备01");
  39. var open6 = panel2.addBoolean(dataObj2, "open6").caption("设备02");
  40. var open7 = panel2.addBoolean(dataObj2, "open7").caption("设备03");
  41. var open8 = panel2.addBoolean(dataObj2, "open8").caption("设备04");

第四步,开启场景层级切换,创建摄像机和烟感报警器各四个,创建一个数字标识index和保存equipment对象的数组equipmentGroup。

</>复制代码

  1. /创建equipment对象数组,以及数组标识
  2. var equipmentGroup = [];
  3. var index = 0;
  4. app.on("load", function (ev) {
  5. app.level.change(ev.campus);
  6. for (var i = 0; i < 8; i++) {
  7. var type = null;
  8. if (i < 4) {
  9. type = "http://model.3dmomoda.cn/models/62A8A75C75044E6AB3D8463FA0CB67AF/0/gltf/";
  10. } else {
  11. type = "http://model.3dmomoda.cn/models/641A9B800DE5431E8C84DC290F8EFDE6/0/gltf/";
  12. }
  13. var equipment = new Equipment(app, "equipment" + index++, app.query("floor" + (Math.floor(Math.random() * 5) + 1))[0], type);
  14. equipment.createSelf();
  15. equipmentGroup.push(equipment);
  16. }
  17. });

第五步,为每个设备对应的创建控制开关。

</>复制代码

  1. open1.on("change", function (ev) {
  2. equipmentGroup[0].switchControl(ev);
  3. });
  4. open2.on("change", function (ev) {
  5. equipmentGroup[1].switchControl(ev);
  6. });
  7. open3.on("change", function (ev) {
  8. equipmentGroup[2].switchControl(ev);
  9. });
  10. open4.on("change", function (ev) {
  11. equipmentGroup[3].switchControl(ev);
  12. });
  13. open5.on("change", function (ev) {
  14. equipmentGroup[4].switchControl(ev);
  15. });
  16. open6.on("change", function (ev) {
  17. equipmentGroup[5].switchControl(ev);
  18. });
  19. open7.on("change", function (ev) {
  20. equipmentGroup[6].switchControl(ev);
  21. });
  22. open8.on("change", function (ev) {
  23. equipmentGroup[7].switchControl(ev);
  24. });

最后一步,创建两个按钮来控制创建设备。

</>复制代码

  1. new THING.widget.Button("创建烟感报警", function () {
  2. var type = "http://model.3dmomoda.cn/models/641A9B800DE5431E8C84DC290F8EFDE6/0/gltf/";
  3. var equipment = new Equipment(app, "equipment" + index++, app.query("floor" + (Math.floor(Math.random() * 5) + 1))[0], type,);
  4. equipment.createSelf();
  5. equipmentGroup.push(equipment);
  6. app.level.change(app.query(equipment.name)[0]);
  7. });
  8. new THING.widget.Button("创建摄像头", function () {
  9. var type = "http://model.3dmomoda.cn/models/62A8A75C75044E6AB3D8463FA0CB67AF/0/gltf/";
  10. var equipment = new Equipment(app, "equipment" + index++, app.query("floor" + (Math.floor(Math.random() * 5) + 1))[0], type,);
  11. equipment.createSelf();
  12. equipmentGroup.push(equipment);
  13. app.level.change(app.query(equipment.name)[0]);
  14. });

在编写过程还是走了不少弯路的,最主要的就是计时器的卸载问题,最初的版本写来写去发现不能控制警报的关闭,后来才 发现计时器没有卸载,警报不但不会关闭而且闪动的频率越来越快。更改之后创建了Equipment这个类来控制所有设备,通过创建这个类的对象给他赋id,父物体,模型地址。这里控制器在开关被触发的时候创建一个新的计时器并赋给的这个对象,再次触发时清除这个计时器,警报的动画就关闭了。演示地址

最后附上完整代码:

</>复制代码

  1. /**
  2. * 说明:创建App,url为场景地址(可选)
  3. */
  4. var app = new THING.App({
  5. url: "http://www.thingjs.com/./uploads/wechat/oLX7p05lsWJZUIxnIWsNXAzJ40X8/scene/CampusBuilder20181126134710", // 场景地址
  6. "skyBox": "BlueSky"
  7. });
  8. //创建主面板
  9. var panel1 = new THING.widget.Panel({
  10. titleText: "设备列表",
  11. closeIcon: false, // 是否有关闭按钮
  12. dragable: true,
  13. retractable: true,
  14. opacity: 0.9,
  15. hasTitle: true,
  16. titleImage: "https://www.thingjs.com/static/images/example/icon.png"
  17. });
  18. panel1.position = [80, 0];
  19. var panel2 = new THING.widget.Panel({
  20. titleText: "设备列表",
  21. closeIcon: false, // 是否有关闭按钮
  22. dragable: true,
  23. retractable: true,
  24. opacity: 0.9,
  25. hasTitle: true,
  26. titleImage: "https://www.thingjs.com/static/images/example/icon.png"
  27. });
  28. panel2.position = [80, 320];
  29. // 创建任意对象
  30. var dataObj1 = {
  31. open1: false,
  32. open2: false,
  33. open3: false,
  34. open4: false,
  35. }
  36. var dataObj2 = {
  37. open5: false,
  38. open6: false,
  39. open7: false,
  40. open8: false,
  41. };
  42. // 动态绑定物体
  43. var open1 = panel1.addBoolean(dataObj1, "open1").caption("设备01");
  44. var open2 = panel1.addBoolean(dataObj1, "open2").caption("设备02");
  45. var open3 = panel1.addBoolean(dataObj1, "open3").caption("设备03");
  46. var open4 = panel1.addBoolean(dataObj1, "open4").caption("设备04");
  47. var open5 = panel2.addBoolean(dataObj2, "open5").caption("设备01");
  48. var open6 = panel2.addBoolean(dataObj2, "open6").caption("设备02");
  49. var open7 = panel2.addBoolean(dataObj2, "open7").caption("设备03");
  50. var open8 = panel2.addBoolean(dataObj2, "open8").caption("设备04");
  51. new THING.widget.Button("创建烟感报警", function () {
  52. var type = "http://model.3dmomoda.cn/models/641A9B800DE5431E8C84DC290F8EFDE6/0/gltf/";
  53. var equipment = new Equipment(app, "equipment" + index++, app.query("floor" + (Math.floor(Math.random() * 5) + 1))[0], type,);
  54. equipment.createSelf();
  55. equipmentGroup.push(equipment);
  56. app.level.change(app.query(equipment.name)[0]);
  57. });
  58. new THING.widget.Button("创建摄像头", function () {
  59. var type = "http://model.3dmomoda.cn/models/62A8A75C75044E6AB3D8463FA0CB67AF/0/gltf/";
  60. var equipment = new Equipment(app, "equipment" + index++, app.query("floor" + (Math.floor(Math.random() * 5) + 1))[0], type,);
  61. equipment.createSelf();
  62. equipmentGroup.push(equipment);
  63. app.level.change(app.query(equipment.name)[0]);
  64. });
  65. //创建equipment对象数组,以及数组标识
  66. var equipmentGroup = [];
  67. var index = 0;
  68. app.on("load", function (ev) {
  69. app.level.change(ev.campus);
  70. for (var i = 0; i < 8; i++) {
  71. var type = null;
  72. if (i < 4) {
  73. type = "http://model.3dmomoda.cn/models/62A8A75C75044E6AB3D8463FA0CB67AF/0/gltf/";
  74. } else {
  75. type = "http://model.3dmomoda.cn/models/641A9B800DE5431E8C84DC290F8EFDE6/0/gltf/";
  76. }
  77. var equipment = new Equipment(app, "equipment" + index++, app.query("floor" + (Math.floor(Math.random() * 5) + 1))[0], type);
  78. equipment.createSelf();
  79. equipmentGroup.push(equipment);
  80. }
  81. open1.on("change", function (ev) {
  82. equipmentGroup[0].switchControl(ev);
  83. });
  84. open2.on("change", function (ev) {
  85. equipmentGroup[1].switchControl(ev);
  86. });
  87. open3.on("change", function (ev) {
  88. equipmentGroup[2].switchControl(ev);
  89. });
  90. open4.on("change", function (ev) {
  91. equipmentGroup[3].switchControl(ev);
  92. });
  93. open5.on("change", function (ev) {
  94. equipmentGroup[4].switchControl(ev);
  95. });
  96. open6.on("change", function (ev) {
  97. equipmentGroup[5].switchControl(ev);
  98. });
  99. open7.on("change", function (ev) {
  100. equipmentGroup[6].switchControl(ev);
  101. });
  102. open8.on("change", function (ev) {
  103. equipmentGroup[7].switchControl(ev);
  104. });
  105. });
  106. class Equipment extends THING.Thing {
  107. constructor(app, name, obj, url) {
  108. super(app);
  109. this.name = name;
  110. this.obj = obj;
  111. this.url = url;
  112. this.interval = null;
  113. }
  114. createSelf() {
  115. app.create({
  116. type: "Equipment",
  117. name: this.name,
  118. url: this.url,
  119. parent: this.obj,
  120. localPosition: [Math.floor(Math.random() * 7), 2.9, Math.floor(Math.random() * 7)],
  121. angle: 0
  122. });
  123. }
  124. switchControl(ev) {
  125. var flag;
  126. var equipment = app.query(this.name)[0];
  127. app.level.change(equipment);
  128. if (ev) {
  129. this.interval = setInterval(function () {
  130. if (flag) {
  131. equipment.style.color = "#FF0000";
  132. flag = false;
  133. } else {
  134. flag = true;
  135. equipment.style.color = "";
  136. }
  137. }, 500);
  138. console.log(this.interval + "查看是否创建了定时器");
  139. } else {
  140. console.log(this.interval);
  141. clearInterval(this.interval);
  142. if (equipment.style.color == "#FF0000")
  143. equipment.style.color = "";
  144. }
  145. }
  146. }
  147. THING.factory.registerClass("Equipment", Equipment);

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/100074.html

相关文章

  • SegmentFault 技术周刊 Vol.35 - WebGL:打开网页看大片

    摘要:在文末,我会附上一个可加载的模型方便学习中文艺术字渲染用原生可以很容易地绘制文字,但是原生提供的文字效果美化功能十分有限。 showImg(https://segmentfault.com/img/bVWYnb?w=900&h=385); WebGL 可以说是 HTML5 技术生态链中最为令人振奋的标准之一,它把 Web 带入了 3D 的时代。 初识 WebGL 先通过几个使用 Web...

    objc94 评论0 收藏0
  • 基于WebGL架构3D视化平台—平面图导航(一)

    摘要:接下来我们就用平面导航图来解决这一问题。第二部分我会给页加上鼠标悬停事件让页的标签和我们场景中的一起动起来完整代码加载场景代码场景地址场景相关面板相关平面图导航事件相关点击事件返回事件 前言 利用CampusBuilder来搭建自己的虚拟世界过程有这样一个问题:如何快速聚焦到虚拟场景的某一位置。当然我们可以创建几个按钮对应查找我们需要去的位置(参照物)并聚焦,但是按钮并不是很炫酷也不能...

    Labradors 评论0 收藏0
  • 基于WebGL架构3D视化平台ThingJS—让粮仓“智慧”升级

    摘要:随着信息化技术发展,全国各地开始智慧粮仓的建设,我们可以通过一个视频看一下使用可视化平台做的可视应用,可视一体化,让粮仓智慧升级。构建粮仓内粮情的监控预警诊断分析一体化的可视化平台。 首先我们先了解一下基于WebGL架构的3D可视化平台——ThingJS是什么? ThingJS是优锘科技开发的一套面向物联网应用的在线3D可视化应用开发及运营PaaS平台,以 ThingJS云视PaaS服...

    aaron 评论0 收藏0
  • 基于WebGL架构(ThingJS)3D视化平台—停车场管理系统

    摘要:车辆集中存放管理的场所被人类提出车辆进出的秩序车辆存放的安全性车辆存放管理的有偿性等要求。随着科技的发展,停车场管理系统也日新月异,目前最为专业化的停车场系统为免取卡停车场。下面我们就用平台来搭建一个可视化的停车场管理系统。 随着社会的发展,城市中的汽车越来越多。车辆集中存放管理的场所被人类提出车辆进出的秩序、车辆存放的安全性、车辆存放管理的有偿性等要求。停车场系统应用现代机械电子及通...

    weij 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<