Cesium加载三维地形及WMS地图,并实现动态控制显示

写在前面:
本次工程主要实现的是cesium基础三维地形加载、视角控制、经纬度显示;重点是实现cesium加载wms图层,并对wms图层进行参数更新,实现动态控制,进一步实现时间地图的展示目的。为时间地图可视化提供了三维显示的思路。中间进行参数控制的时候,需要销毁provider,目前没找到比这个更好的方式,希望能抛砖引玉,共同探讨是否有更高性能的实现方式。

1. 实现路线

基础实现步骤脑图

2.项目搭建运行

2.1 基础环境搭建

在此处不再赘述,请自行百度“NodeJS安装部署”;cesium的文件包可下可不下,如果下载不方便的话,可以直接使用在线的。

2.2 项目工程结构

项目工程结构

2.3 index.html

<!DOCTYPE html>
<html lang="en">
    <head>
        <META HTTP-EQUIV="pragma" CONTENT="no-cache">
        <META HTTP-EQUIV="Cache-Control" CONTENT="no-cache, must-revalidate">
        <META HTTP-EQUIV="expires" CONTENT="0">
        <!-- Use correct character set. -->
        <meta charset="utf-8">
        <!-- Tell IE to use the latest, best version. -->
        <meta http-equiv="X-UA-Compatible" content="IE=Edge">
        <!-- Make the app on mobile take up the full browser screen and disable user scaling. -->
        <meta name="viewport"
            content="width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no">
        <title>三维地形展示融合项目</title>
        <!-- The Cesium library. -->
        <script src="ThirdParty/require.js" defer async="true" ></script>
        <script src="ThirdParty/jquery-3.3.1.js"></script>
        <script src="ThirdParty/Cesium/Cesium.js"></script>
        <!-- Style our app. -->
        <link rel="stylesheet" href="index.css" media="screen">
        <link rel="stylesheet" href="layui.css">
        <!--<link rel="stylesheet" href="./layui/css/layui.css">-->
    </head>
    <body>
        <!-- A container for the Cesium Viewer to live in. -->
        <div id="cesiumContainer"></div>
        <div id="btn_show" style="width:450px;height:30px;position:absolute;bottom:40px;right:300px;z-index:1;font-size:15px;">

            <button class="layui-btn"  id="btn_onStarted" >开始</button>
            <button class="layui-btn"  id="btn_onPaused">暂停</button>

        </div>
        <!--显示的标注-->
        <div id="latlng_show" style="width:450px;height:30px;position:absolute;bottom:40px;right:100px;z-index:1;font-size:15px;">
            <div style="width:140px;height:30px;float:left;">
                <font size="3" color="white">经度:<span id="longitude_show"></span></font>
            </div>
            <div style="width:140px;height:30px;float:left;">
                <font size="3" color="white">纬度:<span id="latitude_show"></span></font>
            </div>
            <div style="width:160px;height:30px;float:left;">
                <font size="3" color="white">视角高:<span id="altitude_show"></span>km</font>
            </div>
        </div>
        <!--引用的js组件-->
        <script src="ThirdParty/layui.js"></script>
        <!-- Our app code. -->
        <script src="Source/App.js"></script>
    </body>
</html>

2.4 App.js

//cesium使用的token
Cesium.Ion.defaultAccessToken='eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJqdGkiOiIyNmM1YmJlZS02Mzg3LTQ2MjAtYjRiMi00MDAwOTFkZmZlODgiLCJpZCI6OTA5NCwic2NvcGVzIjpbImFzciIsImdjIl0sImlhdCI6MTU1MzQ3OTQ4OX0.HFtKvqdsytW2oyXelYtUwrlfH07BXCJJ_hU0BRj-WUo';
//时间显示间隔为1s
var timeValue=1;
var animationId=null;
var ip="127.0.0.1";
//cesium容器
var viewer=new Cesium.Viewer('cesiumContainer',{
    scene3DOnly:true,
    selectionIndicator:false,
    baseLayerPicker: false
});
//cesium三维地形显示
var terrainProvider=new Cesium.CesiumTerrainProvider({
    url: Cesium.IonResource.fromAssetId(3957),
    requestVertexNormals:true,
    requestWaterMask : true,
})
viewer.terrainProvider=terrainProvider;
viewer.scene.globe.enableLighting=true;
viewer.scene.globe.depthTestAgainstTerrain = true;

//cesium加载wms底图
var raster_provider = new Cesium.WebMapServiceImageryProvider({
    url: 'http://'+ip+':8080/geoserver/main_TS_defo/wms',
    layers: 'main_TS_defo:AvgNorResult3_1',
    parameters: {
        service : 'WMS',
        format: 'image/png',
        transparent: true,
    }
});
viewer.imageryLayers.addImageryProvider(raster_provider);
//添加时间控制属性
var time_interval_property = new Cesium.TimeIntervalCollectionProperty();

time_interval_property.intervals.addInterval(Cesium.TimeInterval.fromIso8601({
    iso8601 : '2018-12-31T00:12:00.00Z/2019-01-01T00:00:00.00Z',
    isStartIncluded : true,
    isStopIncluded : false,
    data : "time=1"
}));
time_interval_property.intervals.addInterval(Cesium.TimeInterval.fromIso8601({
    iso8601 : '2019-01-01T00:00:01.00Z/2019-01-01T12:00:00.00Z',
    isStartIncluded : true,
    isStopIncluded : false,
    data : "time=2"
}));
time_interval_property.intervals.addInterval(Cesium.TimeInterval.fromIso8601({
    iso8601 : '2019-01-01T12:00:01.00Z/2019-01-02T00:00:00.00Z',
    isStartIncluded : true,
    isStopIncluded : false,
    data : "time=3"
}));
time_interval_property.intervals.addInterval(Cesium.TimeInterval.fromIso8601({
    iso8601 : '2019-01-02T00:00:01.00Z/2019-01-02T12:00:00.00Z',
    isStartIncluded : true,
    isStopIncluded : false,
    data : "time=4"
}));
time_interval_property.intervals.addInterval(Cesium.TimeInterval.fromIso8601({
    iso8601 : '2019-01-02T12:00:01.00Z/2019-01-03T00:00:00.00Z',
    isStartIncluded : true,
    isStopIncluded : true,
    data : "time=5"
}));
//wms地图参数
var wmsParameters={
    service : 'WMS',
        format: 'image/png',
        transparent: true,
        cql_filter:'time=2'
}
//加载具有指定参数的wms图层
var vector_provider = new Cesium.WebMapServiceImageryProvider({
    url:  'http://'+ip+':8080/geoserver/main_TS_defo/wms',
    layers: 'main_TS_defo:contourline_total',
    parameters: wmsParameters
});
//将图层加载到容器中
viewer.imageryLayers.addImageryProvider(vector_provider);
//更新时间地图显示
function updateLayerList() {

    if(timeValue<5){
        var deleteLayer=viewer.imageryLayers.get(2);
        viewer.imageryLayers.remove(deleteLayer);
        wmsParameters.cql_filter='time='+timeValue;
        console.log(wmsParameters.cql_filter)
        vector_provider = new Cesium.WebMapServiceImageryProvider({
            url:  'http://'+ip+':8080/geoserver/main_TS_defo/wms',
            layers: 'main_TS_defo:contourline_total',
            parameters: wmsParameters
        });
        viewer.imageryLayers.addImageryProvider(vector_provider);
        timeValue=timeValue+1;
    }else{
        var deleteLayer=viewer.imageryLayers.get(2);
        viewer.imageryLayers.remove(deleteLayer);
        timeValue=1
    }
}

//开始按钮控制逻辑
$('#btn_onStarted').click(function(){
    stop();
    animationId=window.setInterval(
        function(){
            updateLayerList()
        },
        2000);

})
//停止按钮控制逻辑
function stop(){
    window.clearInterval(animationId);
    animationId=null;
}

$('#btn_onPaused').click(function(){
    stop();
})

//添加经纬度显示
var longitude_show=document.getElementById('longitude_show');
var latitude_show=document.getElementById('latitude_show');
var altitude_show=document.getElementById('altitude_show');
var canvas=viewer.scene.canvas;
//具体事件的实现
var ellipsoid=viewer.scene.globe.ellipsoid;
var handler = new Cesium.ScreenSpaceEventHandler(canvas);
handler.setInputAction(function(movement){
    //捕获椭球体,将笛卡尔二维平面坐标转为椭球体的笛卡尔三维坐标,返回球体表面的点
    var cartesian=viewer.camera.pickEllipsoid(movement.endPosition, ellipsoid);
    if(cartesian){
        //将笛卡尔三维坐标转为地图坐标(弧度)
        var cartographic=viewer.scene.globe.ellipsoid.cartesianToCartographic(cartesian);
        //将地图坐标(弧度)转为十进制的度数
        var lat_String=Cesium.Math.toDegrees(cartographic.latitude).toFixed(4);
        var log_String=Cesium.Math.toDegrees(cartographic.longitude).toFixed(4);
        var alti_String=(viewer.camera.positionCartographic.height/1000).toFixed(2);
        longitude_show.innerHTML=log_String;
        latitude_show.innerHTML=lat_String;
        altitude_show.innerHTML=alti_String;
    }
},Cesium.ScreenSpaceEventType.MOUSE_MOVE);

3. 项目运行展示

三维时间地图.gif
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 201,784评论 5 474
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,745评论 2 378
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 148,702评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,229评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,245评论 5 363
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,376评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,798评论 3 393
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,471评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,655评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,485评论 2 318
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,535评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,235评论 3 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,793评论 3 304
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,863评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,096评论 1 258
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,654评论 2 348
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,233评论 2 341

推荐阅读更多精彩内容