乐趣区

关于编辑器:cesiumCZML路径动态改变

举荐:将 NSDT 场景编辑器 退出你的 3D 开发工具链 https://ted.sinoccdc.cn/?sourceId=9

这篇文章和上一篇 cesium 编程中级 (六) 寰球视频纹理一样, 也是跟群友一起探讨时想出的解决方案 ^^ 起因是群友心愿实现一个性能,在加载 czml 数据之后,有物体沿着 czml 中的门路静止,而后静止过程中,会每个几秒钟在门路最初增加一个点,心愿能看到门路动静扭转而且物体的挪动连贯这里其实重要的点有两个 1. 门路前面每隔一段时间增加一个点 2. 物体连贯静止 (这一点是在实现之后,回过头来反思间接写进去的) 群友本人写了一份代码,咱们先来粗略看一下代码组成 var viewer = new Cesium.Viewer(‘cesiumContainer’);

var czml = [{

        "id": "document",
        "name": "polygon",
        "version": "1.0"
    }, {
        "id": "shape2",
        "name": "Red box with black outline",
        "availability": "2012-08-04T16:00:00Z/2012-08-04T18:00:00Z",
        "box": {
            "dimensions": {"cartesian": [30.0, 30.0]
            },
            "material": {
                "stripe": {
                    "orientation": "VERTICAL",
                    "evenColor": {"rgba": [10, 211, 250, 0]
                    },
                    "oddColor": {"rgba": [10, 211, 250, 255]
                    },
                    "offset": {"number": 1},
                    "repeat": 0.5
                }
            },
        },
        "path": {
            "material": {
                "solidColor": {
                    "color": {
                        "interval": "2012-08-04T16:00:00Z/2012-08-04T18:00:00Z",
                        "rgba": [255, 255, 255, 128]
                    }
                }
            },
            "width": [{
                "interval": "2012-08-04T16:00:00Z/2012-08-04T18:00:00Z",
                "number": 3.0
            }],
            "show": [{
                "interval": "2012-08-04T16:00:00Z/2012-08-04T18:00:00Z",
                "boolean": true
            }]
        },
        "position": {
            "interpolationAlgorithm": "LAGRANGE",
            "interpolationDegree": 1,
            "epoch": "2012-08-04T16:00:00Z",
            "cartographicDegrees": [
                0.0, 118.87841653400005, 30.95679870500004, 0.0,
                10.0, 118.87826541800007, 30.95680770900003, 0.0,
                20.0, 118.8774481050001, 30.956860625000047, 0.0,
                30.0, 118.87660414600009, 30.956910105000077, 0.0,
                ... 省略
            ]
        }
    }];

var dataSourcePromise;
var i = 30;
var a = 410;
setInterval(function() {
    i += 0.001;
    a += 10;
    czml[1].position.cartographicDegrees.push(a, 118.813667, i, 0);
}, 10000);

dataSourcePromise = Cesium.CzmlDataSource.load(czml);
viewer.dataSources.add(dataSourcePromise);
viewer.zoomTo(dataSourcePromise);

步骤简略归纳如下:1. 创立三维球 2. 创立 czml 文件 3. 动静增加点到 czml 的门路中 4. 增加 czml 到三维球上咱们要解决第一点,比拟惯例,动静增加点首先想到的是 setInterval, 每隔 10 秒钟增加一个点,这里没有问题,然而问题是,增加了点之后,界面上并没有体现进去,调试代码之后发现 czml 门路中的点数的确是减少了,所以,可能性比拟大的是数据没刷新,于是在增加点后尝试增加 …
setInterval(function() {

...
// 门路最初增加节点
czml[1].position.cartographicDegrees.push(a, 118.8747338, i, 0);
// 清空之前数据,否则数据越来越多
viewer.entities.removeAll();
// 从新增加批改后的数据
viewer.dataSources.add(Cesium.CzmlDataSource.load(czml));

}, 1000);
到这里第一个问题解决了,门路变动了,然而随之第二个问题也显现出来,每次增加完数据之后,方块都回到了原点。看第二个问题之前,咱们先来看看官网的一些示例 czml path (留神这里是本地部署门路)发现它有一个 clock 属性 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",
.....

}];
以后工夫咱们能够通过 viewer.clock.currentTime 来获取,如同有搞头,来试试 …
// 门路最初增加节点
czml[1].position.cartographicDegrees.push(a, 118.8747338, i, 0);
// 批改以后工夫
czml[0].clock.currentTime = viewer.clock.currentTime.toString();

尝试了一下,果然可行。

成果如下:

退出移动版