请选择 进入手机版 | 继续访问电脑版
2021ThingJS数字孪生智慧场景可视化开发大赛获奖者专访
查看: 340|回复: 0

[分享] 禁区告警的3D电子围栏可视化

[复制链接]
avatar

52

主题

57

帖子

79

积分

注册会员

Rank: 2

积分
79
ico_lz  楼主| 发表于 2020-12-22 19:29:45 | 显示全部楼层 |阅读模式

电子围栏又称周界防盗报警系统,监控防区工作状态,实景中的电子围栏系统用于农业、畜牧业,以及牢狱、军事设备等平安敏感地域,而在传统的可视化监控范畴,一般都是基于 Web SCADA 的前端技术来实现 2D 可视化监控。3D可视化场景则加倍轻量化实现,展现工人的实时位置、电子围栏的范围、现场的平安情况,帮助我们直观领会当前工场职员的平安状态。

禁区告警的3D电子围栏可视化

ThingJS平台上,电子围栏指的是一个地区,利用PolygonRegion属性。建立物体工具或模子并开启移动功用,即可起头检测方针点能否进入电子围栏地区,判定true或false显现告警反应。
当人物或物体工具动身警报时,有2种方式提醒用户留意,一是踏足的禁区围栏色彩发生改变;二是展现面板显现报警信息,可视化监控方针点的移动范围。还有更多可视化告警功用待你挖掘。
  1. /**
  2. * 检测方针点能否进入电子围栏地区
  3. * @param {Array} checkPoint - 校验坐标
  4. * @param {Array} polygonPoints - 构成电子围栏的坐标
  5. * @returns {Boolean} true 或 false
  6. * @description 此方式仅判定处于同一个平面的方针点能否在地区内(只判定坐标x和z值),
  7. * 不斟酌两者当前离地高度(坐标的y值)
  8. */
  9. function isInPolygon(checkPoint, polygonPoints) {
  10. var counter = 0;
  11. var i;
  12. var xinters;
  13. var p1, p2;
  14. var pointCount = polygonPoints.length;
  15. p1 = polygonPoints[0];
  16. for (i = 1; i <= pointCount; i++) {
  17. p2 = polygonPoints[i % pointCount];
  18. if (checkPoint[0] > Math.min(p1[0], p2[0]) && checkPoint[0] <= Math.max(p1[0], p2[0])) {
  19. if (checkPoint[1] <= Math.max(p1[1], p2[1])) {
  20. if (p1[0] != p2[0]) {
  21. xinters = (checkPoint[0] - p1[0]) * (p2[1] - p1[1]) / (p2[0] - p1[0]) + p1[1];
  22. if (p1[1] == p2[1] || checkPoint[1] <= xinters) {
  23. counter++;
  24. }
  25. }
  26. }
  27. }
  28. p1 = p2;
  29. }
  30. if (counter % 2 == 0) {
  31. return false;
  32. } else {
  33. return true;
  34. }
  35. }
复制代码


回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则