实现步骤

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

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

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

Example:

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

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

Example:

//构造M3D模型层管理对象(视图)var m3dLayer = new CesiumZondy.Layer.M3DLayer({viewer: webGlobe.viewer,})//加载M3D地图文档(服务地址,配置参数)var obliqueLayer = m3dLayer.append('http://develop.smaryun.com:6163/igs/rest/g3d/钻孔分层点_Sur_000_Ent', {})

关键接口

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

参数名 类 型 说 明
elementId Element | String 放置视图的div的id
options Object (可选)附加属性
  • options属性主要参数
参数名 类 型 默认值 说 明
viewerMode String ‘3D’ (可选)初始视图模式默认为三维球视图 '2D’表示二维视图 ‘COLUMBUS_VIEW’ 表示三维平面视图
showInfo Boolean false (可选)是否显示默认的属性信息框
animation Boolean true (可选)默认动画控制不显示
baseLayerPicker Boolean true (可选)是否创建图层控制显示小组件
fullscreenButton Boolean true (可选)是否创建全屏控制按钮
vrButton Boolean false (可选)是否创建VR按钮

2.【M3D 模型层管理类】CesiumZondy.Layer.M3DLayer

【method】append(url, options):添加 M3D 地图文档服务

参数名 类 型 说 明
url String 文档服务地址
options Object 附加属性
  • options属性主要参数
参数名 类 型 默认值 说 明
autoReset Boolean true (可选)是否自动定位
synchronous Boolean true (可选)是否异步请求
loaded Boolean function (可选)回调函数
proxy DefaultProxy defaultProxy (可选)代理
showBoundingVolume Boolean false (可选)是否显示包围盒
maximumScreenSpaceError Number 16 (可选)用于控制模型显示细节,值较大将会渲染更少的贴图,进而可以提高性能,而较低的值将提高视觉质量

代码:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml"><head><meta charset="utf-8" /><title>M3D-地质体数据展示</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;//定义图层类var geobodyLayerArr;//加载三维场景function init() {//构造三维视图对象(视图容器div的id,三维视图设置参数)webGlobe = new Cesium.WebSceneControl('GlobeView', {});//构造视图功能管理对象(视图)var sceneManager = new CesiumZondy.Manager.SceneManager({viewer: webGlobe.viewer});//设置鼠标位置信息展示控件:经纬度、高程、视角高度(容器div的id)sceneManager.showPosition('coordinate_location');//是否显示场景球webGlobe.viewer.scene.globe.show = false;//大气显示webGlobe.viewer.scene.skyAtmosphere.show = false;//透明度webGlobe.viewer.scene.globe.enableTransparent = true;webGlobe.viewer.scene.globe.baseColor = new Cesium.Color(255 / 255, 255 / 255, 255 / 255, 0.001);//开启地形深度检测webGlobe.viewer.scene.globe.depthTestAgainstTerrain = true;// 亮度设置var stages = webGlobe.viewer.scene.postProcessStages;webGlobe.viewer.scene.brightness = webGlobe.viewer.scene.brightness || stages.add(Cesium.PostProcessStageLibrary.createBrightnessStage());webGlobe.viewer.scene.brightness.enabled = true;webGlobe.viewer.scene.brightness.uniforms.brightness = Number(1.3);// 修改场景时间var utc = Cesium.JulianDate.fromDate(new Date("2020/7/04 24:00:00"));webGlobe.viewer.clock.currentTime = Cesium.JulianDate.addHours(utc, 0, new Cesium.JulianDate());//构造M3D模型层管理对象(视图)var m3dLayer = new CesiumZondy.Layer.M3DLayer({viewer: webGlobe.viewer});//加载M3D地图文档(服务地址,配置参数)var { protocol, ip, port } = window.webclient;geobodyLayerArr = m3dLayer.append(`${protocol}://${ip}:${port}/igs/rest/g3d/钻孔分层点_Sur_000_Ent`,{autoReset: true,loaded: function (layer) {var boundingSphere = layer.boundingSphere;var cartographic = Cesium.Cartographic.fromCartesian(layer.boundingSphere.center);var surface = Cesium.Cartesian3.fromRadians(cartographic.longitude,cartographic.latitude,0.0);var offset = Cesium.Cartesian3.fromRadians(cartographic.longitude,cartographic.latitude,-12);var translation = Cesium.Cartesian3.subtract(offset,surface,new Cesium.Cartesian3());layer.modelMatrix = Cesium.Matrix4.fromTranslation(translation);},});//视点跳转(经度,纬度,视角高度,方位角,俯仰角,翻滚角)sceneManager.flyToEx(112.94845170512113, 30.004246325952618, {height: 2600,heading: 67,pitch: -30,roll: 0});initPick();}function initPick() {let handler = new Cesium.ScreenSpaceEventHandler(webGlobe.viewer.scene.canvas);handler.setInputAction(handleClick.bind(this),Cesium.ScreenSpaceEventType.LEFT_DOWN);}function handleClick(screenPosition) {const viewer = webGlobe.viewer;const scene = webGlobe.viewer.scene;const { position } = screenPosition;var pickedFeature = viewer.scene.pick(position);console.warn("screenPosition", pickedFeature);}</script>
</head><body onload="init()"><!--三维场景容器--><div id='GlobeView'></div><!--位置信息容器--><div id="coordinateDiv" class="coordinateClass"><label id="coordinate_location"></label></div>
</body></html>

三维GIS开发:利用Cesium加载 M3D 地质体模型(附代码)相关推荐

  1. 利用Cesium加载 M3D BIM 模型

    本例展示如何在在三维场景中加载 M3D 的 BIM 模型数据,对接 IGServer 发布的三维地图服务. 实现步骤 1. 引用开发库: 本示例引用 local 本地[include-cesium-l ...

  2. 三维GIS开发的发展路线以及需要掌握的技能

    什么是三维gis? ​ 三维GIS在WebGIS的基础上,增加了对地球表面的第三维度,即高度或深度. 相比于二维层面的WebGIS,三维GIS能够更好的分析和处理地理空间数据,使用准确的三维地理模型可 ...

  3. Cesium加载模型两种方式

    Cesium加载模型两种方式 代码如下 <!DOCTYPE html> <html><head><meta charset="UTF-8" ...

  4. 三维地图之cesium加载天地图(有代码)

    天地图官网上写了cesium加载天地图的方法,http://lbs.tianditu.gov.cn/docs/#/sanwei/,但读起来,写起来,的确令人费解. 下面写一段非常简单的代码,用cesi ...

  5. QGIS离线GeoJSON数据,使用Cesium加载并根据楼层高度拉伸(weixin公众号【图说GIS】)

    前言 往往好多事情是需求推动的,正好一个网友在群里问到"怎么让Cesium加载GeoJSON的白膜并贴在地形上?",联系到他,要了他的数据,完成了代码并测试通过.正好出差,而且一个 ...

  6. vite+cesium加载3DTile数据

    Cesium 3D Tile是Cesium的一种特有的3D模型格式,其文件名后缀为.b3dm,而要在自己开发的平台上调用这些3D Tile,一般为通过后缀为.json格式的文件来调用.b3dm格式的3 ...

  7. Cesium加载3D Tiles模型

    最近遇到一个问题,使用大疆无人机做的倾斜摄影三维模型,需要加载到地图上进行显示.从大疆的制图软件导出后,三维模型文件的后缀名为b3dm,经查阅资料发现,是3D Tiles格式. 3D Tiles 3D ...

  8. 基于TerraDeveloper的三维GIS开发研究

    [中文题名]  基于TerraDeveloper的三维GIS开发研究 [英文题名]  Research on the Development of 3D GIS Based on TerraDevel ...

  9. C# WPF Caliburn.Micro框架下利用Mef加载其它项目界面

    01 - 前言 MEF是微软自家的托管可扩展框架,在这里我把它用成了ioc容器.在Caliburn.Micro框架下,view和viewmodel被注入到CompositionContainer容器中 ...

最新文章

  1. JavaScript之图片的无缝滚动
  2. react 封装表格组件_React--封装的表单组件
  3. 在Java8的foreach()中不能break,如果需要continue时,可以使用return
  4. 电脑开机3秒就重启循环_3秒开机不是梦,泰捷WE40旗舰升级版体验
  5. 局域网内Windows允许其他电脑指定IP访问本地mysql-8.0.23数据库
  6. SELinux入门:了解和配置SELinux
  7. c语言变量的值也可以不改变6,C语言学习复盘整理笔记(六)
  8. 信赖铃音的PS2游戏目录2017.6
  9. 华为平板解锁工具_华为平板M6 10.8英寸首发评测 办公+影音+智能全面开花
  10. 这游戏全服只有一个玩家,硬是坚挺了18年,官方竟还推新版本?
  11. 实体消歧方法(1)__BOOTLEG
  12. 计算机ping命令6,Mac电脑ping命令区别和IPv6命令
  13. html网页两边有空隙,怎么让整个内容缩进?就是四周都有间隙。
  14. UE4场景流程规范-纹理压缩(美术版/程序版/太长不看版)
  15. 美女数码宝贝(天女兽、蔷薇兽、花仙兽、莉莉丝兽、维纳斯兽、仙女兽、人鱼兽、古代人鱼兽、丁香兽)
  16. Shell脚本书写方法详解
  17. 电压的符号代表的是什么意思
  18. 近20万奖金+ 学术会议论文:2021PAKDD异常检测大赛来了!
  19. 自定义函数处理excel单元格列序数
  20. VM虚拟机Ubuntu设置静态IP方法

热门文章

  1. 『人脸识别系列教程』1·目录与概述
  2. 【IT技术】阿里RDS首席产品架构师何云飞:阿里云数据库的架构演进之路
  3. [源码和文档分享]基于VC++和OpenCV实现的全民飞机大战游戏
  4. java 数据库 树_在数据库中保存树数据(族树)
  5. html5树json,jstree -- 使用JSON 数据组装成树
  6. 74HC165编程篇(二)
  7. 揭开斐讯免费路由器通过京东热销的幕后真相
  8. 主动安全智能防控系统规范要求比较(JT/T883,苏标,陕标,浙标,川标,渝标)
  9. 盘点国外那些「值得模仿」的互联网产品
  10. java精简学习笔记(黑马毕老师授)