Cesium - 离线使用方法

时间:2022-02-19 13:49:29

  使用Cesium可以直观的看基于DEM切片产生的Terrain地形数据,有种身临其境的感觉,但缺点是Cesium默认缺省加载了微软Bing提供的地形以及遥感影像数据,可以跟踪日志,总提示让你申请微软的Bing地图Key。如果Cesium在绝对离线,即不连接互联网的情况下,第一步加载Bing地形图时候就抛出了异常,后面的图层也无法加载,整个地图区域将显示漆黑的天空,这就意味着需要在底层,取消对Bing地形图的访问。

  由于Cesium超乎寻常的大,未压缩情况下有6Mb多,好处是 可以看清楚代码结构。这样就可以跟踪分析,如何取消对Bing地图的访问(如采用一般的文本编辑器,基本会死掉,Sublime也会经常卡死,因此我使用宇宙中最强大的IDE-VS2015)。打开Cesium.js后搜索代码行,有一个createDefaultImageryProviderViewModels函数,里面加载在线地图服务近10多种,其中一些就是Bing地图,还有其他互联网在线地图商提供的地图服务。由于我的场景是物理隔绝的网络,即不能使用在线地图服务,因此,全部将这些代码注释掉,返回空的providerViewModels。

Cesium - 离线使用方法

  注释后保存,编写测试代码发现加载后的地图有黑色天空变成了蓝色,当然,很丑陋。

Cesium - 离线使用方法

  为了避免蓝色地球,预先加载了一张全球地图作为背景,效果如下:

Cesium - 离线使用方法

  接下来,采用爬虫爬取谷歌地形图和影像图,硬盘越大越好,缩放级别越高越好,使用IIS发布后,调用如下接口在Cesium中显示地形图,代码如下:

layersTerrainMap.addImageryProvider(Cesium.createTileMapServiceImageryProvider({
   url: 'http://192.168.198.183/Google_DEM/',
   credit: 'Google_DEM'
 }));

  效果如下图所示:

Cesium - 离线使用方法