前言
本文基于上文的配置,继续讲cesium的基础使用
viewer查看器
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
| var viewer = new Cesium.Viewer("cesiumContainer", { infoBox: false, geocoder: false, homeButton: false, sceneModePicker: false, baseLayerPicker: false, navigationHelpButton: false, animation: false, timeline: false, fullscreenButton: false, });
|
data:image/s3,"s3://crabby-images/fd325/fd325bd92f7caf214e386401265b822b29c7a37b" alt="效果图"
设置天空盒子
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
| var viewer = new Cesium.Viewer("cesiumContainer", { infoBox: false, geocoder: false, homeButton: false, sceneModePicker: false, baseLayerPicker: false, navigationHelpButton: false, animation: false, timeline: false, fullscreenButton: false, skyBox: new Cesium.SkyBox({ sources: { positiveX: "./texture/sky/px.jpg", negativeX: "./texture/sky/nx.jpg", positiveY: "./texture/sky/ny.jpg", negativeY: "./texture/sky/py.jpg", positiveZ: "./texture/sky/pz.jpg", negativeZ: "./texture/sky/nz.jpg", }, }), });
|
自定义地图
使用天地图
如何注册天地图和添加天地图的tk我就不展开了,我们来到这个页面
data:image/s3,"s3://crabby-images/20068/20068c329d52f488cd8143d0aecf862f57a548ac" alt="页面图"
使用天地图地图
使用WebMapTileServiceImageryProvider
- http://t0.tianditu.gov.cn,这部分代码是上面你要渲染的地图选择
- service=wmts:指定所使用的服务类型为 WMTS(Web Map Tile Service)。
- request=GetTile:指定请求类型为获取瓦片。
- version=1.0.0:指定所使用的 WMTS 版本。
- LAYER=vec:指定图层类型为矢量图层。对应的图层名(图层路径的前缀,如vec_c的前缀是vec)
- tileMatrixSet=w:指定切片矩阵集合为墨卡托投影坐标系。
- TileMatrix={TileMatrix}:动态替换为具体的切片级别。
- TileRow={TileRow}:动态替换为具体的切片行号。
- TileCol={TileCol}:动态替换为具体的切片列号。
- style=default:指定样式为默认样式。
- format=tiles:指定瓦片格式为 tiles,表示以瓦片形式返回地图数据。
data:image/s3,"s3://crabby-images/9aad6/9aad6a86c043117c9674300b034030bee54d93df" alt="文档图"
1 2 3 4 5 6 7 8
| imageryProvider: new Cesium.WebMapTileServiceImageryProvider({ url: "http://t0.tianditu.gov.cn/img_w/wmts?service=wmts&request=GetTile&version=1.0.0&LAYER=img&tileMatrixSet=w&TileMatrix={TileMatrix}&TileRow={TileRow}&TileCol={TileCol}&style=default&format=tiles&tk=您的密钥", layer: "tdtBasicLayer", style: "default", format: "image/jpeg", tileMatrixSetID: "GoogleMapsCompatible", }),
|
data:image/s3,"s3://crabby-images/fd831/fd831852a52798ec35a71a285411531e6061a64a" alt="效果图"
1 2 3 4 5 6 7 8
| imageryProvider: new Cesium.WebMapTileServiceImageryProvider({ url: "http://t0.tianditu.gov.cn/vec_w/wmts?service=wmts&request=GetTile&version=1.0.0&LAYER=vec&tileMatrixSet=w&TileMatrix={TileMatrix}&TileRow={TileRow}&TileCol={TileCol}&style=default&format=tiles&tk=b7ac87e8c7a0af26f6378bde574cec2e", layer: "tdtBasicLayer", style: "default", format: "image/jpeg", tileMatrixSetID: "GoogleMapsCompatible", }),
|
data:image/s3,"s3://crabby-images/445f5/445f5490a1c5056d004de79a8f0df751eac74c7d" alt="效果图"
使用UrlTemplateImageryProvider
1 2 3 4 5 6 7
| imageryProvider: new Cesium.UrlTemplateImageryProvider({ url: "http://t0.tianditu.gov.cn/img_w/wmts?SERVICE=WMTS&REQUEST=GetTile&VERSION=1.0.0&LAYER=img&STYLE=default&TILEMATRIXSET=w&FORMAT=tiles&TILEMATRIX={z}&TILEROW={y}&TILECOL={x}&tk=b7ac87e8c7a0af26f6378bde574cec2e", layer: "tdtBasicLayer", style: "default", format: "image/jpeg", tileMatrixSetID: "GoogleMapsCompatible", }),
|
使用这个属性就可以直接用官网提供的获取瓦片的url来获取
data:image/s3,"s3://crabby-images/d20b4/d20b4b123601beb449f80ede0db3937a3c433a25" alt="官网瓦片示例图"
使用高德地图
1 2 3 4 5 6 7 8
| imageryProvider: new Cesium.UrlTemplateImageryProvider({ url: "http://webrd02.is.autonavi.com/appmaptile?lang=zh_cn&size=1&scale=1&style=8&x={x}&y={y}&z={z}", layer: "tdtVecBasicLayer", style: "default", format: "image/png", tileMatrixSetID: "GoogleMapsCompatible", }),
|
data:image/s3,"s3://crabby-images/64f36/64f36067c47380d11035ec111bd2d5020680322f" alt="高德矢量图"
注:当然还有的地图可以使用new Cesium.OpenStreetMapImageryProvider来获取
地图叠加
开启天地图
1 2 3 4 5 6 7
| imageryProvider: new Cesium.WebMapTileServiceImageryProvider({ url: "http://t0.tianditu.com/img_w/wmts?service=wmts&request=GetTile&version=1.0.0&LAYER=img&tileMatrixSet=w&TileMatrix={TileMatrix}&TileRow={TileRow}&TileCol={TileCol}&style=default&format=tiles&tk=您的密钥", layer: "tdtBasicLayer", style: "default", format: "image/jpeg", tileMatrixSetID: "GoogleMapsCompatible", }),
|
追加高德地图
1 2 3 4 5 6 7 8 9 10 11 12 13
| var imageryLayers = viewer.imageryLayers; var layer=imageryLayers.addImageryProvider( new Cesium.UrlTemplateImageryProvider({ url: "http://webrd02.is.autonavi.com/appmaptile?lang=zh_cn&size=1&scale=1&style=8&x={x}&y={y}&z={z}", layer: "tdtVecBasicLayer", style: "default", format: "image/png", tileMatrixSetID: "GoogleMapsCompatible", }) )
layer.alpha=0.5
|
效果展示
data:image/s3,"s3://crabby-images/cc069/cc069c77f26055e450c780c70e69e94cd20c3386" alt="地图叠加"
添加地形
默认情况
默认情况下地形是平的
data:image/s3,"s3://crabby-images/095f3/095f3ee48c191b07d681d1c2614c1b1ef7f6c2c2" alt="默认地形"
添加cesium自带的地形设置
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| onMounted(() => { var viewer = new Cesium.Viewer("cesiumContainer", { infoBox: false, terrainProvider: Cesium.createWorldTerrain({ requestVertexNormals: true, requestWaterMask: true, }), });
viewer.cesiumWidget.creditContainer.style.display = "none"; });
|
陆地地形
requestVertexNormals: true,
data:image/s3,"s3://crabby-images/1b422/1b42285cbd28ae9552529767db9569799733644c" alt="陆地地形"
海洋地形
requestWaterMask: true,
data:image/s3,"s3://crabby-images/cf6d3/cf6d363ba675ec18be46dba214b61d64d6e24349" alt="海洋地形"
自定义地形
使用地理数据空间云下载数据
data:image/s3,"s3://crabby-images/69280/692804b397ddd2a05f3f61e5f664784e74e5cb68" alt="地理数据空间云"
data:image/s3,"s3://crabby-images/02b02/02b026cf8981306559ceb65e83e54422ee4d0ab9" alt="地理数据空间云下载"
data:image/s3,"s3://crabby-images/e6a99/e6a99d9bb28bc554976e958f28b40d93dd062100" alt="下载结束后的内容"
使用cesiumlab转换数据
没有安装的可以先去安装,官网地址:http://cesiumlab.com/
安装好之后通过搜索启动
data:image/s3,"s3://crabby-images/011b5/011b5113ab964e18b0ad571ae965f9c8263acc92" alt="cesiumlab启动"
通过地形切片把文件添加,三角算法选择vcg,存储类型改成散列然后选择置顶文件夹导出
data:image/s3,"s3://crabby-images/9f197/9f1975e74a635c24d34c40d87e26a363798060f9" alt="cesiumlab转换数据"
使用转换后的数据
1 2 3
| terrainProvider: new Cesium.CesiumTerrainProvider({ url: "./terrains/gz", }),
|
我们可以看到广州这块有一定的地形凸起
data:image/s3,"s3://crabby-images/2cf59/2cf596bb4c0d6abe16f06f0edd72b9241bffbefe" alt="地形凸起"
坐标系与数值
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35
| onMounted(() => { var viewer = new Cesium.Viewer("cesiumContainer", { infoBox: false, });
viewer.cesiumWidget.creditContainer.style.display = "none";
var radians = Cesium.Math.toRadians(90); console.log(radians); var degrees = Cesium.Math.toDegrees(2 * Math.PI); console.log(degrees);
var cartesian3 = Cesium.Cartesian3.fromDegrees( 89.5, 20.4, 100 ); console.log(cartesian3);
var cartographic = Cesium.Cartographic.fromCartesian(cartesian3); console.log(cartographic); });
|
data:image/s3,"s3://crabby-images/83f17/83f17c398091e56e08d98697cf56b40f83a5d3e0" alt="数值互换"
相机基础设置
可以设置相机的基础位置和飞往动画
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
| onMounted(() => { var viewer = new Cesium.Viewer("cesiumContainer", { infoBox: false, });
viewer.cesiumWidget.creditContainer.style.display = "none";
var position = Cesium.Cartesian3.fromDegrees(116.393428, 39.90923, 100); viewer.camera.setView({ destination: position, orientation: { heading: Cesium.Math.toRadians(0), pitch: Cesium.Math.toRadians(-20), roll: 0, }, });
});
|
data:image/s3,"s3://crabby-images/34808/34808ebbab4b7be8acd9c6512ad57dac43a12982" alt="相机设置"
添加按键交互
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38
| document.addEventListener("keydown", (e) => { var height = viewer.camera.positionCartographic.height; var moveRate = height / 100; if (e.key == "w") { viewer.camera.moveForward(moveRate); } else if (e.key == "s") { viewer.camera.moveBackward(moveRate); } else if (e.key == "a") { viewer.camera.moveLeft(moveRate); } else if (e.key == "d") { viewer.camera.moveRight(moveRate); } else if (e.key == "q") { viewer.camera.lookLeft(Cesium.Math.toRadians(0.1)); } else if (e.key == "e") { viewer.camera.lookRight(Cesium.Math.toRadians(0.1)); } else if (e.key == "r") { viewer.camera.lookUp(Cesium.Math.toRadians(0.1)); } else if (e.key == "f") { viewer.camera.lookDown(Cesium.Math.toRadians(0.1)); } else if (e.key == "g") { viewer.camera.twistLeft(Cesium.Math.toRadians(0.1)); } else if (e.key == "h") { viewer.camera.twistRight(Cesium.Math.toRadians(0.1)); } });
|