cesium-czml--动态路径实现

 

两个时间都是基于当前时间来计算的

如果将两个属性都去掉,则效果如下,无动态生成路径的效果

  var czml = [{
        "id" : "document",
        "name" : "CZML Path",
        "version" : "1.0",
        "clock": {
            "interval": "2012-08-04T10:00:00Z/2012-08-04T15:00:00Z",
            "currentTime": "2012-08-04T10:00:00Z",
            "multiplier": 10
        }
    }, {
        "id" : "path",
        "name" : "path with GPS flight data",
        "description" : "<p>Hang gliding flight log data from Daniel H. Friedman.<br>Icon created by Larisa Skosyrska from the Noun Project</p>",
        "availability" : "2012-08-04T10:00:00Z/2012-08-04T15:00:00Z",
        "path" : {
            "material" : {
                "polylineOutline" : {
                    "color" : {
                        "rgba" : [255, 0, 255, 255]
                    },
                    "outlineColor" : {
                        "rgba" : [0, 255, 255, 255]
                    },
                    "outlineWidth" : 5
                }
            },
            "width" : 8,
            "leadTime" : 10,
            "trailTime" : 1000,
            "resolution" : 5
        },
        "billboard" : {
            "image" : "",
            "scale" : 1.5,
            "eyeOffset": {
                "cartesian": [ 0.0, 0.0, -10.0 ]
            }
        },
        "position" : {
            "epoch" : "2012-08-04T10:00:00Z",
            "cartographicDegrees" : [
                0,-122.93797,39.50935,1776,
                10,-122.93822,39.50918,1773,
                20,-122.9385,39.50883,1772,
                30,-122.93855,39.50842,1770,
                40,-122.93868,39.50792,1770,
                50,-122.93877,39.50743,1767,
                60,-122.93862,39.50697,1771,
                70,-122.93828,39.50648,1765,
       
      
            ]
        }
    }];

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CZML是一种用于描述时间动态数据的语言。在Cesium中,可以使用CZML实现动画效果。下面是一个简单的例子: ```javascript // 定义一个CZML文档 var czml = [ { "id": "document", "name": "CZML Animations" }, { "id": "animation1", "name": "Animation 1", "position": { "cartographicDegrees": [-75, 40, 0] }, "model": { "gltf": "path/to/model.gltf", "scale": 10 }, "path": { "resolution": 120, "material": { "solidColor": { "color": { "rgba": [255, 0, 0, 128] } } }, "width": 5, "leadTime": 10, "trailTime": 10, "show": true } } ]; // 加载CZML文档 var dataSource = new Cesium.CzmlDataSource(); dataSource.load(czml); // 将CZML数据添加到场景中 viewer.dataSources.add(dataSource); // 创建一个时间轴 var clock = viewer.clock; clock.shouldAnimate = true; clock.currentTime = Cesium.JulianDate.fromIso8601('2021-01-01T00:00:00.00Z'); clock.multiplier = 60; // 开始动画 clock.onTick.addEventListener(function(clock) { var time = clock.currentTime; dataSource.entities.getById('animation1').position.cartographicDegrees = [-75 + Cesium.Math.toDegrees(Math.cos(time.secondsOfDay / 60)), 40 + Cesium.Math.toDegrees(Math.sin(time.secondsOfDay / 60)), 0]; }); ``` 在上面的例子中,我们定义了一个CZML文档,其中包含一个模型和一个路径。模型用于显示在地球表面的一个三维模型,路径则用于显示模型的运动轨迹。我们将CZML文档加载到了Cesium的数据源中,然后将数据源添加到场景中。接着,我们创建了一个时间轴,并通过监听时间轴的事件来实现动画效果。在每一帧中,我们更新模型的位置,使其在地球表面上运动。 需要注意的是,上面的例子中只实现了一个简单的动画效果,如果需要实现更加复杂的动画效果,需要使用更加复杂的CZML文档和更加复杂的代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值