作者:taco
在实际的场景应用中,通常都会在场景中添加一些底图。官网示例中已经包含了本地底图,iserver发布的底图,必应底图等。但是这些底图的清晰度并不能满足大部分人的需求。这时候我们就选择到了天地图。关于全国天地图的加载,之前的文档中已经介绍过了可以在(https://blog.csdn.net/supermapsupport/article/details/119787510)这部分查看到。
最近一阵子总会有人问,我全国天地图加载上了,为什么我同样的方式,地方的天地图却加载不上。本文则针对山东省天地图的加载,详细阐述一下webgl中如何加载地方天地图。
先找到天地图地址
首先如何获取山东省天地图呢?我们只需要百度搜索山东省天地图第一个链接即可访问到改网址,或者通过下面链接直接进入山东省天地图官网(http://www.sdmap.gov.cn/index.html)
针对天地图加载需要找到对应的能力文档,下方链接即山东省天地图能力文档(http://www.sdmap.gov.cn/tileservice/SDRasterPubMap?service=WMTS&request=GetCapabilities)。
需要使用的接口为WMTS接口,api可以参考(http://support.supermap.com.cn:8090/webgl/web/apis/3dwebgl.html)内容。
对照文档内容,填写添加wmts参数。
url: 'http://www.sdmap.gov.cn/tileservice/SDRasterPubMap',
url为对应天地图服务链接;
layer: '山东影像地图',
layer为天地图图层名;
style: 'default',
style为样式风格,大部分style样式默认为default;
format: 'tiles',
format为瓦片格式,默认为image/jpeg.这里使用的是tiles;
tileMatrixSetID: 'SDRasterPubMap',
tileMatrixSetID为瓦片及的唯一标识,可以直接在能力文档中搜索Identifier找到对应名称;
tileMatrixLabels: matrixIds,
这边的matrixIds是根据能力文档中的层级进行设置的。常规情况我们找到最大的层级去设置,通过循环去加载图层。
tilingScheme是椭球体表面上的几何图形平铺的方案,从精细层到粗糙曾分别去配置级别的长宽比。设置使用的切片椭球体,设置平铺范围以及使用的地图投影等参数;
完整代码如下
var matrixIds = [];
for (let i = 0; i < 19; i++) {
matrixIds[i] = i + 1;
}
var wmtsImageryProvider = new Cesium.WebMapTileServiceImageryProvider({
url: 'http://www.sdmap.gov.cn/tileservice/SDRasterPubMap',
layer: '山东影像地图',
style: 'default',
format: 'tiles',
tileMatrixSetID: 'SDRasterPubMap',
tileMatrixLabels: matrixIds,
tilingScheme: new Cesium.GeographicTilingScheme({
ellipsoid: Cesium.Ellipsoid.CGCS2000,
numberOfLevelZeroTilesX: 2,
numberOfLevelZeroTilesY: 1
})
});
viewer.imageryLayers.addImageryProvider(wmtsImageryProvider);
这样我们就在场景中添加了山东省天地图作为底图。且该天地图并不用申请token进行使用,加载效果如下。