【Cesium】日照分析(完整示例)


前言

通过Cesium,实现倾斜摄影模型在24小时日照下影子的变化。
在这里插入图片描述

原理

具体实现日照分析的方法如下:首先,在Cesium中加载需要进行日照分析的地图数据,例如卫星影像或数字高程模型等。然后,通过Cesium的API接口,获取需要进行日照分析的点的经纬度坐标及时间信息。接着,根据点的位置和时间信息,利用天文计算公式计算出该点在该时刻的太阳高度角和方位角等参数。最后,根据太阳高度角和方位角等参数,判断该点当前是否被太阳照射,从而计算出日照时数和日出、日落等指标。


一、播放按钮

<div id="menu">
    <p>
      <button @click="setvisible('play')">播放</button>
    </p>
    <p>
      <button @click="setvisible('stop')">暂停</button>
    </p>
  </div>

二、加载倾斜摄影

let tileset = viewer.scene.primitives.add(new Cesium.Cesium3DTileset({
   
  url: 'http://earthsdk.com/v/last/Apps/assets/dayanta/tileset.json' // '../Source/3DTiles/building/tileset.json'
}))
tileset.readyPromise.then(function(tileset) {
   
  viewer.scene.primitives.add(tileset)
  viewer.zoomTo(tileset, new Cesium.HeadingPitchRange(0.5, -0.2, tileset.boundingSphere.radius * 1.0))
}).otherwise(function(error) {
   
  console.log(error)
})

三、开始和停止

根据场景的数据和时间参数,利用Cesium内置的工具计算出每个时段内地表的日照情况。这一计算过程需要借助Cesium的模拟光线功能,模拟太阳光在地表的投射情况。

stratPlay() {
   
  if (viewer.clock.shouldAnimate = !0, stopTime) {
   
    viewer.clock.currentTime = stopTime
  } else {
   
    var e = '2019-06-18',
      t = 
  • 13
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值