之前章节给大家重点讲解BIMFACE中针对构件状态展示的一些接口方法,那这次就重点和大家说说运维场景中比较高频且好用的功能——二三维标签。

BIMFACE目前支持RVT、SKP、IFC、IGMS、DWG和集成模型,共提供了二维标签、三维标签、聚合标签3种工具。

  1. 二维标签:可应用于图纸/模型场景中,标签是浮于视图之上,不会被构件或图元遮挡。
  2. 三维标签:可用于模型场景中,标签和构件存在三维遮挡关系。
  3. 聚合标签:适用于标签过多导致体验差的场景,它可以将二维或者三维标签按照不同的层级进行缩放展示,大大提升了模型的美观度及加载性能。

其中二维标签又分为3类,包括自定义标签、引线标签和小地图标签。

  1. 自定义标签:可在标签中添加文字、图片、调整样式,也可添加DOM元素以进行更多的功能拓展。
  2. 引线标签:样式较为固定的标签类型,需要与构件进行关联,并且对单次出现的完整标签数量有限制。
  3. 小地图标签:在小地图上显示的标签,可配置需要显示的楼层。
    接下来,我将分别介绍三种不同类型标签的实现方式。

一、二维标签-自定义标签

二维标签的三种类型添加逻辑是类似的,其中自定义标签应用更加灵活,本次我就挑选自定义标签来作为演示案例吧~

step 1. 创建自定义标签容器

BIMFACE中的实现逻辑是将所有的二维标签实例存放在一个二维标签的容器内,这里我们先来创建标签容器DrawableContainer:


// ************************自定义标签***********************
var DrawableContainer= null;
function createDrawableContainer() {if (!cunstomItemContainer) {// 构造自定义标签容器配置drawableConfig
var drawableConfig = new Glodon.Bimface.Plugins.Drawable.DrawableContainerConfig();// 设置markerContainerConfig匹配的viewer对象
drawableConfig.viewer = viewer2D;
// 构造三维标签容器markerContainer
drawableContainer = new Glodon.Bimface.Plugins.Drawable.DrawableContainer(drawableConfig);}
}

step 2. 创建自定义标签

在容器创建完成后,我们可以创建具体的标签了。自定义标签允许添加DOM元素,因此它的样式非常多样,这里我们就在标签中添加一个div并对它的内容和样式进行设置,同时构造函数addItems:


function addItems(objectdata) {position = objectdata.worldPosition;var config = new Glodon.Bimface.Plugins.Drawable.CustomItemConfig();var rectangle = document.createElement('div');//自定义样式,支持Html的任意dom元素rectangle.style.width = '100px';rectangle.style.height = '32px';rectangle.style.lineHeight = '32px';rectangle.style.textAlign = 'center';rectangle.style.fontSize = '14px';rectangle.style.border = 'solid';rectangle.style.borderWidth = '1px';rectangle.style.borderColor = '#32D3A6';rectangle.style.color = '#444444';rectangle.style.borderRadius = '3px';rectangle.style.background = '#F2F2F2';rectangle.innerText = '自定义标签';config.content = rectangle;//设置可以拖拽config.draggable = true;config.offsetY = -32;config.viewer = viewer2D;//增加一个Tip提示config.tooltip = '拖我试试';config.worldPosition = position;//生成customItem实例var customItem = new Glodon.Bimface.Plugins.Drawable.CustomItem(config);//自定义标签的鼠标左键事件customItem.onClick(function (item) {alert('left click');});//自定义标签的鼠标右键事件customItem.onRightClick(function (item) {alert('right click');});customItem.onEndDrag(function (item) {console.log(JSON.stringify(item.worldPosition));});// 添加自定义标签drawableContainer.addItem(customItem);//设置Tip的样式customItem.setTooltipStyle({border: '1px',top: '-33px'});}

step 3. 设置标签添加方式

结合场景的使用频率,在这里主要实现通过鼠标点击模型的方式来放置标签,所以我们要创建鼠标点击的监听事件。当处于激活状态时,可注册监听事件;相反的,当处于未激活状态时,我们则将鼠标点击的监听事件移除。

var isAddCustomItemActtivated = false;function addCustomItem() {if (isAddCustomItemActtivated) {return;} else {// 添加点击监听事件viewer2D.addEventListener(Glodon.Bimface.Viewer.ViewerDrawingEvent.MouseClicked, addItems);isAddCustomItemActtivated = true;}

二、三维标签

刚刚我们实现了在场景中添加二维自定义标签的功能,接下来我们一起在某些特定的运维场景下(如报警点、设备状态显示等)添加三维标签吧。

step 1. 创建三维标签容器

与二维标签相似,在构造三维标签实例之前,我们先要构造一个存放三维标签的容器,并完成对容器的配置。

// ********************** 三维标签*********************
var is3DMarkerPlaced = false;
function addMarker() {if (is3DMarkerPlaced) {return;}// 构造三维标签容器配置markerContainerConfigvar markerContainerConfig = new Glodon.Bimface.Plugins.Marker3D.Marker3DContainerConfig();// 设置markerContainerConfig匹配的viewer对象markerContainerConfig.viewer = viewer3D;// 构造三维标签容器markerContainervar markerContainer = new Glodon.Bimface.Plugins.Marker3D.Marker3DContainer(markerContainerConfig);
}

step 2. 创建三维标签

创建完markerContainer后,我们需要继续构造一个三维标签对象并完成对它的配置。

 function addItems(objectdata) {position = objectdata.worldPosition;var marker3dConfig = new Glodon.Bimface.Plugins.Marker3D.Marker3DConfig();marker3dConfig.src = "http://static.bimface.com/resources/3DMarker/warner/warner_red.png";marker3dConfig.worldPosition = position;//三维标签的提示marker3dConfig.tooltip = "this is 3DMarker.";var marker3d = new Glodon.Bimface.Plugins.Marker3D.Marker3D(marker3dConfig);marker3d.onClick(function (item) {//获取点击图片的postionvar m = item.position;//自己设置一个boundingbox的对象var num = 1.1;var max = m.x * num;var may = m.y * num;var maz = m.z * num;var mix = m.x / num;var miy = m.y / num;var miz = m.z / num;var maxp = new Object();maxp = {x: max,y: may,z: maz};var minp = new Object();minp = {x: mix,y: miy,z: miz};var boundingbox = new Object();boundingbox = {max: maxp,min: minp};//缩放到该boundingboxviewer3D.zoomToBoundingBox(boundingbox);})marker.addItem(marker3d);viewer3D.render();}

step 3. 设置标签添加方式

结合场景的使用频率,在这里主要实现通过鼠标点击模型的方式来放置标签,所以我们要创建鼠标点击的监听事件,实现任意位置点击添加三维标签与自定义标签的实现方法相同。

  var isAddItemActtivated = false;function add3DMarker() {if (isAddItemActtivated) {return;} else {// 添加点击监听事件viewer3D.addEventListener(Glodon.Bimface.Viewer.Viewer3DEvent.MouseClicked, addItems);isAddItemActtivated = true;}}

三、聚合标签

在运维场景下,可能存在众多设备,有成百上千的标签。如果同时展示出来,一方面影响模型浏览性能,另一方面模型浏览不够美观。因此BIMFACE推出了针对模型/图纸的聚合标签的功能,不同缩放层级下,展示不同的标签数量和样式。

step 1. 创建聚合标签

在聚合标签之前,我们要先创建所需要的标签。BIMFACE支持同类型的标签聚合,大家可以根据自己的业务场景需要创建二维或者三维标签。构造一个存放聚合标签的容器,并完成对容器的配置。

// ********************** 聚合标签*********************
function createClusterItem() {// 构造聚合标签容器配置项var clusterContainerConfig = new Glodon.Bimface.Plugins.Cluster.ClusterContainerConfig();clusterContainerConfig.viewer = viewer3D;// 构造聚合标签容器var clusterContainer = new Glodon.Bimface.Plugins.Cluster.ClusterContainer(clusterContainerConfig);// 构造聚合标签配置项var clusterItemConfig = new Glodon.Bimface.Plugins.Cluster.ClusterItemConfig();clusterItemConfig.tags = drawableContainer.getAllItems();console.log(drawableContainer.getAllItems().length);clusterItemConfig.maxLevel = 8;clusterItemConfig.viewer = viewer3D;// 构造聚合标签对象clusterItem = new Glodon.Bimface.Plugins.Cluster.ClusterItem(clusterItemConfig);// 定义聚合标签的点击事件clusterItem.onClick(function (data) {var boundingBox = data.boundingBox;viewer3D.zoomToBoundingBox(boundingBox, 5);});clusterContainer.addCluster(clusterItem);clusterContainer.update();}

step 2. 设置不同状态下的聚合标签

BIMFACE给我们提供了Danger、Waring、Information及Success四种状态,用于展示聚合标签不同状态,去展现更加丰富的应用场景。

var exceptionActivated = false;function setException() {if(!viewAdded) {return;}if(!exceptionActivated) {// 设置标签样式,提供了Danger、Waring、Information及Success四种,默认为SuccessclusterItem.setException(randomTagId_1, Glodon.Bimface.Plugins.Cluster.ClusterStyle.Danger);clusterItem.setException(randomTagId_2, Glodon.Bimface.Plugins.Cluster.ClusterStyle.Warning);clusterItem.setException(randomTagId_3, Glodon.Bimface.Plugins.Cluster.ClusterStyle.Information);// 更新聚合标签状态clusterItem.updateClusterTags();setButtonText('btnSetException', '清空标签样式');} else {// 重置所有标签样式为'Success'clusterItem.clearException();// 更新聚合标签状态clusterItem.updateClusterTags();setButtonText('btnSetException', '设置标签样式');}exceptionActivated = !exceptionActivated;}

好了,本次的分享就到这了,希望对大家有所帮助,详细内容可前往他们的官网哦~~
最近更新的有点慢,但是我会坚持哦,感谢大家的关注,一起努力!

BIMFACE功能测评- 如何创建二三维标签?

  • 一、二维标签-自定义标签
    • *step 1. 创建自定义标签容器*
    • *step 2. 创建自定义标签*
    • *step 3. 设置标签添加方式*
  • 二、三维标签
    • *step 1. 创建三维标签容器*
    • *step 2. 创建三维标签*
    • *step 3. 设置标签添加方式*
  • 三、聚合标签
    • *step 1. 创建聚合标签*
    • *step 2. 设置不同状态下的聚合标签*

BIMFACE功能测评- 如何创建二三维标签?相关推荐

  1. 第一章:Vue3.0+Openlayers+Cesium创建二三维联动项目

    Vue3.0+Openlayers+Cesium创建二三维联动项目 简介 Vue项目创建 安装依赖 框架结构 地图加载 显示效果 结语 简介 大家好!从今天开始,我将分享我在GIS开发的过程中如何利用 ...

  2. BIM轻量化引擎—广联达BIMFACE功能测评(一)

    最近有不少小伙伴后台私信我问题,总结下来主要围绕两块:1.市面上BIM轻量化引擎选型讨论:2.探讨某些轻量化软件的功能及使用感受. 依据大家的这些疑问,在接下来的一段时间内,我将亲自通过实操给大家分享 ...

  3. 二三维一体化平台-FreeXGIS Studio

    FreeXGIS Studio(以下简称FreeXStudio)是集GIS服务.二三维一体化.多业务应用于一体的桌面端插件化承载平台. 一.主要产品功能 采用插件化框架设计 FreeXGIS Stud ...

  4. Matlab创建二维图,三维图基本操作

    要创建二维线图,请使用 plot 函数.例如,绘制从 0 到 2π 之间的正弦函数值: x = 0:pi/100:2*pi; y = sin(x); plot(x,y) 图如下: 可以标记轴并添加标题 ...

  5. Comsol入门:创建二维几何结构和三维几何结构

    教程网址: 创建二维结构 创建三维结构 创建二维几何结构 带狭缝阵列的几何板 正确步骤:创建较小对象,再绘制较大矩形 从空模型入手,选择二维组件 系统是没有狭缝对象,自己要学会思考怎么画 可以用两个圆 ...

  6. ArcGIS Maritime Server 开发教程(九)二三维水深服务

    ArcGIS Maritime Server 开发教程(九)二三维水深服务 本章导读:ArcGIS 软件体系是使用 ArcGIS Bathymetry 桌面扩展构建和管理水深数据库,并且利用 Imag ...

  7. python 全栈开发,Day128(创建二维码,扫码,创建玩具的基本属性)

    python 全栈开发,Day128(创建二维码,扫码,创建玩具的基本属性) 昨日内容回顾 1.app播放音乐plus.audio.createPlayer(文件路径/URL)player.play( ...

  8. 商场楼层地图怎么制作,高效、便捷的商场二三维地图绘制平台

    当顾客走进庞大的商场购物中心,如何让顾客在商场购物消费时有更轻松方便的体验?如何能快速将品牌和商品传递给潜在顾客,并一键引导顾客到店?电子地图作为大家最喜闻乐见的高效应用形式,在商业应用中,不论针对C ...

  9. 【ol-cesium】OpenLayers与Cesium的二三维联动

    OpenLayers与Cesium的二三维联动 本文主要介绍OpenLayers与Cesium二三维联动的实现过程,以及在实现的过程中所遇到的问题以及解决方法. 研究二三维联动的动机是需要开发基于Ge ...

最新文章

  1. String与StringBuffer的区别
  2. 第十六 届全国大学生智能汽车竞赛 讯飞创意组 全国 选拔赛 竞赛规则
  3. Perseus-BERT——业内性能极致优化的BERT训练方案
  4. 数码相机控制点的自动定位检校
  5. visual studio 设计器不显示_设计模式 | Iterator设计模式
  6. excel导入sqlserver数据库大数据量,可每秒控制数量
  7. 12 大热门事件背后,藏着你的 2020 年
  8. BZOJ 3238: [Ahoi2013]差异 [后缀数组 单调栈]
  9. 将 Android* x86 NDK 供 Eclipse* 而移植 NDK 演示示例应用程序
  10. eclipse插件开发流程
  11. 材料成型及控制工程学计算机吗,材料成型及控制工程
  12. JanusGraph图数据库系统简介
  13. fgo升级经验计算机,命运冠位指定狗粮本每日经验表 fgo国服狗粮本刷取技巧攻略[多图]...
  14. 基于ROS的仿人机器人运动规划与实现
  15. html5制作叮当猫,HTML5 canvas画简单的叮当猫头
  16. AutoCAD Civil 3D-装配(标准横断面)
  17. 转:饭后九不要包你保健康
  18. STM32F103C8T6多通道adc采集(3通道)
  19. 到底什么是数字化生意表达?
  20. angular单个页面加载多个ng-app

热门文章

  1. 整数规划----割平面法的Matlab实现
  2. 中国大学生计算机编程第一人楼天城访谈
  3. RPD快速产品开发全流程详解
  4. C#蓝牙通讯 蓝牙模块HC-06
  5. autocad2008中文版
  6. 局域网用程控交换机电源的网络监控系统设计
  7. Nginx-虚拟主机
  8. 转转验机源码+验机报告
  9. [18调剂]华侨大学(厦门校区)田晖教授招收2018级计算机或相近专业调剂生
  10. 计算机网络:02---数据与信号。频率、比特率、波特率、信噪比、衰减