Ceisum实时获取后台数据 实时更新实体位置信息

文章讲述了如何使用CZML数据在三维环境中动态展示实时数据,包括GPS飞行数据和PolyLinePrimitive的使用,以及与前端开发结合的实例,还提到了提供前端开发学习资料的重要性。
摘要由CSDN通过智能技术生成

return _;

})();

var czml2 = [{

“id”: “document”,

“name”:“CZML Path”,

“version”: “1.0”,

}, {

“id”: “path1”,

“name”: “path with GPS flight data”,

“description”: “

Hang gliding flight log data from Daniel H. Friedman.
Icon created by Larisa Skosyrska from the Noun Project

”,

“availability”: “2012-08-04T10:00:00Z/2012-08-04T15:00:00Z”,

“billboard”:{

“image”:“data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4NCjwhLS0gR2VuZXJhdG9yOiBBZG9iZSBJbGx1c3RyYXRvciAyMy4wLjMsIFNWRyBFeHBvcnQgUGx1Zy1JbiAuIFNWRyBWZXJzaW9uOiA2LjAwIEJ1aWxkIDApICAtLT4NCjxzdmcgdmVyc2lvbj0iMS4xIiBpZD0i5Zyw56m65a+85by5XzFfIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4PSIwcHgiDQoJIHk9IjBweCIgdmlld0JveD0iMCAwIDMyIDMyIiBzdHlsZT0iZW5hYmxlLWJhY2tncm91bmQ6bmV3IDAgMCAzMiAzMjsiIHhtbDpzcGFjZT0icHJlc2VydmUiPg0KPHN0eWxlIHR5cGU9InRleHQvY3NzIj4NCgkuc3Qwe3N0cm9rZTojMDAwMEZGO3N0cm9rZS1taXRlcmxpbWl0OjEwO30NCgkuc3Qxe2ZpbGw6bm9uZTtzdHJva2U6IzAwMDBGRjtzdHJva2UtbWl0ZXJsaW1pdDoxMDt9DQo8L3N0eWxlPg0KPHBvbHlnb24gY2xhc3M9InN0MCIgcG9pbnRzPSIxNS41LDUuMDQgMTIuNSwxMC4yMyAxOC41LDEwLjIzICIvPg0KPGxpbmUgY2xhc3M9InN0MSIgeDE9IjE1LjUiIHkxPSIxMC41IiB4Mj0iMTUuNSIgeTI9IjI2LjUiLz4NCjxsaW5lIGNsYXNzPSJzdDEiIHgxPSIxMi41IiB5MT0iMjYuNSIgeDI9IjE4LjUiIHkyPSIyNi41Ii8+DQo8bGluZSBjbGFzcz0ic3QxIiB4MT0iMTUuNSIgeTE9IjIwLjUiIHgyPSIxMi41IiB5Mj0iMjMuNSIvPg0KPGxpbmUgY2xhc3M9InN0MSIgeDE9IjE4LjUiIHkxPSIyMy41IiB4Mj0iMTUuNSIgeTI9IjIwLjUiLz4NCjwvc3ZnPg0K”,

“scale”:0.2

},

“position”: {

“cartographicDegrees”: [ 118.87826541800007, 30.956799, 0.0,]

}

}];

var c2 = new Cesium.CzmlDataSource();

viewer.dataSources.add(c2.load(czml2));

// 动态赋值

var i = 30.956799;

var a = 20;

var b=118.87826541800007;

var realTimeClData=setInterval(function() {

i+= 10.001*Math.random();

b+=10.001*Math.random();

a+= 10;

//图标:更新czml坐标

czml2[1].position.cartographicDegrees = [b,i,0];

c2.process(czml2);

//线:更新entities坐标

var cartesian =Cesium.Cartesian3.fromDegrees( b, i, 0);

if(positions.length == 0) {

positions.push(cartesian.clone());

positions.push(cartesian);

}

if(positions.length >= 2){

if (!Cesium.defined(poly)) {

poly = new PolyLinePrimitive(positions);

}else{

//positions.pop();

//cartesian.y += (1 + Math.random());

positions.push(cartesian);

//只展示5条坐标数据

//if(positions.length>5){

// positions.shift();

//}

console.log(positions.length,“positions”);

}

}

}, 1000);

Sandcastle.addToolbarButton(‘清除计时器’, function() {

clearInterval(realTimeClData);

});

二维展示

三维展示

多个实体运动:实时加载数据 更新位置信息

var viewer = new Cesium.Viewer(‘cesiumContainer’, {

infoBox : false,

selectionIndicator : false,

shadows : true,

shouldAnimate : true

});

var PolyLinePrimitive = (function(){

function _(positions){

this.options = {

polyline : {

show : true,

positions : [],

material : Cesium.Color.CORNFLOWERBLUE,

width : 1,

arcType : Cesium.ArcType.RHUMB,

}

};

this.positions = positions;

this._init();

}

_.prototype._init = function(){

var _self = this;

var _update = function(){

// 1秒将近100次的调用定义的positions数组,实时加载更新线的坐标位置!!!

return _self.positions;

};

//实时更新polyline.positions

this.options.polyline.positions = new Cesium.CallbackProperty(_update,false);

viewer.entities.add(this.options);

};

return _;

})();

// 记录线的坐标,PolyLinePrimitive实体类监听的坐标

var positions = [];

// 记录线的所有实体对象

var poly = [];//undefined

// 测试实体条数

var ec =5;

// 添加初始化数据(positions、poly)

for (var i = 0; i < ec; i++){

positions.push([]);

poly.push(undefined);

}

var czml2 = [{

“id”: “document”,

“name”:“CZML Path”,

“version”: “1.0”,

}, {

“id”: “path1”,

“name”: “path with GPS flight data”,

“availability”: “2012-08-04T10:00:00Z/2012-08-04T15:00:00Z”,

“billboard”:{

“image”:“data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4NCjwhLS0gR2VuZXJhdG9yOiBBZG9iZSBJbGx1c3RyYXRvciAyMy4wLjMsIFNWRyBFeHBvcnQgUGx1Zy1JbiAuIFNWRyBWZXJzaW9uOiA2LjAwIEJ1aWxkIDApICAtLT4NCjxzdmcgdmVyc2lvbj0iMS4xIiBpZD0i5Zyw56m65a+85by5XzFfIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4PSIwcHgiDQoJIHk9IjBweCIgdmlld0JveD0iMCAwIDMyIDMyIiBzdHlsZT0iZW5hYmxlLWJhY2tncm91bmQ6bmV3IDAgMCAzMiAzMjsiIHhtbDpzcGFjZT0icHJlc2VydmUiPg0KPHN0eWxlIHR5cGU9InRleHQvY3NzIj4NCgkuc3Qwe3N0cm9rZTojMDAwMEZGO3N0cm9rZS1taXRlcmxpbWl0OjEwO30NCgkuc3Qxe2ZpbGw6bm9uZTtzdHJva2U6IzAwMDBGRjtzdHJva2UtbWl0ZXJsaW1pdDoxMDt9DQo8L3N0eWxlPg0KPHBvbHlnb24gY2xhc3M9InN0MCIgcG9pbnRzPSIxNS41LDUuMDQgMTIuNSwxMC4yMyAxOC41LDEwLjIzICIvPg0KPGxpbmUgY2xhc3M9InN0MSIgeDE9IjE1LjUiIHkxPSIxMC41IiB4Mj0iMTUuNSIgeTI9IjI2LjUiLz4NCjxsaW5lIGNsYXNzPSJzdDEiIHgxPSIxMi41IiB5MT0iMjYuNSIgeDI9IjE4LjUiIHkyPSIyNi41Ii8+DQo8bGluZSBjbGFzcz0ic3QxIiB4MT0iMTUuNSIgeTE9IjIwLjUiIHgyPSIxMi41IiB5Mj0iMjMuNSIvPg0KPGxpbmUgY2xhc3M9InN0MSIgeDE9IjE4LjUiIHkxPSIyMy41IiB4Mj0iMTUuNSIgeTI9IjIwLjUiLz4NCjwvc3ZnPg0K”,

“scale”:0.2

},

“position”: {

“cartographicDegrees”: [ 118.87826541800007, 30.956799, 0.0,]

}

}];

// 动态赋值

var i = 30.956800;

var a = 20;

var b=118.8774481050001;

var czmlBox=[];

var dataSourceBox=[];

var ii = [];

var bb = [];

for (var i = 0 ; i < ec; i++){

ii.push(i);

bb.push(b);

czmlBox.push(czml2);

var DataSource = new Cesium.CzmlDataSource();

viewer.dataSources.add(DataSource.load(czml2));

dataSourceBox.push(DataSource);

}

var realTimeClData=setInterval(function() {
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

资料过多,篇幅有限,需要文中全部资料可以点击这里获取前端面试资料PDF完整版!

自古成功在尝试。不尝试永远都不会成功。勇敢的尝试是成功的一半。

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

[外链图片转存中…(img-2ydMenCT-1712399209037)]

[外链图片转存中…(img-C6GLdfCe-1712399209037)]

资料过多,篇幅有限,需要文中全部资料可以点击这里获取前端面试资料PDF完整版!

自古成功在尝试。不尝试永远都不会成功。勇敢的尝试是成功的一半。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值