利用Cesium加载 M3D BIM 模型

M3D BIM加载
本文介绍如何在三维场景中加载M3D的BIM模型数据,并对接IGServer发布的三维地图服务。通过创建布局、构造三维场景控件及加载M3D图层,实现了三维模型的展示。

本例展示如何在在三维场景中加载 M3D 的 BIM 模型数据,对接 IGServer 发布的三维地图服务。

实现步骤

1. 引用开发库
本示例引用 local 本地【include-cesium-local.js】开发库,完成此步骤后才可调用三维 WebGL 的功能;

2. 创建布局
创建id='GlobeView'的 div 作为三维视图的容器,并设置其样式;

3. 构造三维场景控件
实例化Cesium.WebSceneControl对象,完成此步骤后可在三维场景中加载三维球控件;

//构造三维视图对象(视图容器div的id,三维视图设置参数)
 var webGlobe = new Cesium.WebSceneControl('GlobeView', {})

4. 加载数据:
加载数据:构造CesiumZondy.Layer.M3DLayerM3D 图层管理对象,调用append()方法,传入 M3D 缓存三维地图服务的 URL 地址即可加载浏览数据,同时可传入相关配置参数。

//构造M3D模型层管理对象(视图)var m3dLayer = new CesiumZondy.Layer.M3DLayer({
  viewer: webGlobe.viewer,})//加载M3D地图文档(服务地址,配置参数)var bimLayer = m3dLayer.append('http://develop.smaryun.com:6163/igs/rest/g3d/school', {
  //模型细节显示控制参数:较大值可提高渲染性能,较低值可提高视觉质量
  maximumScreenSpaceError: 8,})

关键接口

1.【三维场景控件类】Cesium.WebSceneControl(elementId, options)

参数名类 型说 明
elementIdElement | String放置视图的 div 的 id
optionsObject(可选)附加属性

· options属性主要参数

参数名类 型默认值说 明
viewerModeString‘3D’(可选)初始视图模式默认为三维球视图 '2D’表示二维视图 ‘COLUMBUS_VIEW’ 表示三维平面视图
showInfoBooleanfalse(可选)是否显示默认的属性信息框
animationBooleantrue(可选)默认动画控制不显示
baseLayerPickerBooleantrue(可选)是否创建图层控制显示小组件
fullscreenButtonBooleantrue(可选)是否创建全屏控制按钮
vrButtonBooleanfalse(可选)是否创建 VR 按钮

2.【M3D 模型层管理类】:添加 M3D 地图文档服务

参数名类 型说 明
urlString文档服务地址
optionsObject附加属性

· options属性主要参数

参数名类 型默认值说 明
autoResetBooleantrue(可选)是否自动定位
synchronousBooleantrue(可选)是否异步请求
loadedBooleanfunction(可选)回调函数
proxyDefaultProxydefaultProxy(可选)代理
showBoundingVolumeBooleanfalse(可选)是否显示包围盒
maximumScreenSpaceErrorNumber16(可选)用于控制模型显示细节,值较大将会渲染更少的贴图,进而可以提高性能,而较低的值将提高视觉质量

代码块:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">

<head>
    <meta charset='utf-8' />
    <title>M3D-BIM模型数据展示</title>
    <!--引用第三方的jQuery脚本库-->
    <script include="jquery" src="./static/libs/include-lib-local.js"></script>
    <!--引用Cesium脚本库文件-->
    <script src="./static/libs/include-cesium-local.js"></script>
    <!--引用示例页面样式表-->
    <link rel="stylesheet" href="./static/demo/cesium/style.css" />
    <script>
        //在JS脚本开发中使用严格代码规范模式,及时捕获一些不规范的行为,从而避免编程错误
        'use strict';

        //定义三维场景控件对象
        var webGlobe;
        //定义M3D图层对象
        var bimLayerArr;

        //加载三维场景
        function init() {
            //构造三维视图对象(视图容器div的id,三维视图设置参数)
            webGlobe = new Cesium.WebSceneControl('GlobeView', {});

            //构造视图功能管理对象(视图)
            var sceneManager = new CesiumZondy.Manager.SceneManager({
                viewer: webGlobe.viewer
            });
            //设置鼠标位置信息展示控件:经纬度、高程、视角高度(容器div的id)
            sceneManager.showPosition('coordinate_location');

            //构造M3D模型层管理对象(视图)
            var m3dLayer = new CesiumZondy.Layer.M3DLayer({
                viewer: webGlobe.viewer
            });
            //加载M3D地图文档(服务地址,配置参数)
            var {
                protocol,
                ip,
                port
            } = window.webclient;
            bimLayerArr = m3dLayer.append(`${protocol}://${ip}:${port}/igs/rest/g3d/school`, {
                //模型细节显示控制参数:较大值可提高渲染性能,较低值可提高视觉质量
                maximumScreenSpaceError: 8
            });

            //视点跳转(经度,纬度,视角高度,方位角,俯仰角,翻滚角)
            sceneManager.flyToEx(112.9991, 33.0015, {
                height: 19,
                heading: 140,
                pitch: 0,
                roll: 0
            });
        }
    </script>
</head>

<body onload="init()">
    <!--三维场景容器-->
    <div id='GlobeView'></div>
    <!--位置信息容器-->
    <div id="coordinateDiv" class="coordinateClass">
        <label id="coordinate_location"></label>
    </div>
</body>

</html>

### 如何在 Cesium加载 BIM 模型 Cesium 是一个功能强大的开源 JavaScript 库,用于创建 3D 地球和地图。加载 BIM(建筑信息模型)可以通过多种方式实现,具体取决于模型的格式和支持的加载方法。以下是一个基于引用内容[^1]和[^2]的示例代码,展示如何使用 Cesium 加载 BIM 模型。 #### 示例代码:加载 M3D 格式的 BIM 模型 M3D 是一种常用的三维模型格式,可以用来表示 BIM 数据。以下代码展示了如何通过 `CesiumZondy.Layer.M3DLayer` 类加载 M3D 格式的 BIM 模型。 ```javascript // 初始化 Cesium 视图 var viewer = new Cesium.Viewer('cesiumContainer', { terrainProvider: Cesium.createWorldTerrain(), }); // 构造 M3D 模型层管理对象 var m3dLayer = new CesiumZondy.Layer.M3DLayer({ viewer: viewer, }); // 加载 M3D 地图文档(服务地址,配置参数) var bimLayer = m3dLayer.append('http://develop.smaryun.com:6163/igs/rest/g3d/school', { // 模型细节显示控制参数:较大值可提高渲染性能,较低值可提高视觉质量 maximumScreenSpaceError: 8, }); ``` 上述代码中,`CesiumZondy.Layer.M3DLayer` 是一个扩展类,用于管理 M3D 格式的三维模型层。通过调用 `append()` 方法并传入模型的服务地址和相关配置参数,即可加载 BIM 模型。 #### 示例代码:加载 IFC 格式的 BIM 模型 IFC(Industry Foundation Classes)是另一种常见的 BIM 文件格式。虽然 Cesium 官方并未直接支持 IFC 格式,但可以通过第三方库(如 [Three.js](https://threejs.org/) 或 [Babylon.js](https://www.babylonjs.com/))将 IFC 转换为 GLTF 格式后加载Cesium 中。 以下是加载 GLTF 格式模型的示例代码: ```javascript // 初始化 Cesium 视图 var viewer = new Cesium.Viewer('cesiumContainer'); // 加载 GLTF 格式的 BIM 模型 viewer.scene.primitives.add(Cesium.Model.fromGltf({ url: 'path/to/bim_model.gltf', scale: 1.0, minimumPixelSize: 128, // 控制模型的最小像素大小 })); ``` 在此示例中,`Cesium.Model.fromGltf` 方法用于加载 GLTF 格式的模型文件。需要确保模型文件的路径正确,并根据实际需求调整模型的比例和其他参数。 --- #### 注意事项 1. **模型格式支持**:Cesium 原生支持 GLTF 和 3D Tiles 格式。如果 BIM 模型是以其他格式(如 IFC、Revit 等)存储的,则需要先将其转换为 GLTF 或 3D Tiles 格式。 2. **性能优化**:对于大规模 BIM 模型,建议使用 `maximumScreenSpaceError` 参数来控制模型细节显示,以平衡性能和视觉质量[^2]。 3. **服务地址**:如果使用在线服务加载模型,请确保服务地址可用,并且符合跨域资源共享(CORS)规则。 ---
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值