当前位置:网站首页 > 数据科学与大数据 > 正文

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

用定时器模拟实时获取后台数据 当取到数据后实体同时移动到目标位置 这种方式不再与Cesium时间关联 

实现效果:每秒新增一个坐标;每秒实体运动到相应正确位置

var viewer = new Cesium.Viewer('cesiumContainer', { infoBox : false, selectionIndicator : false, shadows : true, shouldAnimate : true }); var positions = []; var poly = undefined; var entityArr=[]; var PolyLinePrimitive = (function(){ function _(positions){ this.options = { polyline : { show : true, positions : [], material : Cesium.Color.CORNFLOWERBLUE, width : 5, arcType : Cesium.ArcType.RHUMB, } }; this.positions = positions; this._init(); } _.prototype._init = function(){ var _self = this; var _update = function(){ return _self.positions; }; //实时更新polyline.positions this.options.polyline.positions = new Cesium.CallbackProperty(_update,false); viewer.entities.add(this.options); entityArr.push(this.options) }; return _; })(); var czml2 = [{ "id": "document", "name":"CZML Path", "version": "1.0", }, { "id": "path1", "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", "billboard":{ "image":"", "scale":0.2 }, "position": { "cartographicDegrees": [ 118.007, 30., 0.0,] } }]; var c2 = new Cesium.CzmlDataSource(); viewer.dataSources.add(c2.load(czml2)); // 动态赋值 var i = 30.; var a = 20; var b=118.007; 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":"", "scale":0.2 }, "position": { "cartographicDegrees": [ 118.007, 30., 0.0,] } }]; // 动态赋值 var i = 30.; var a = 20; var b=118.01; 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() { for (var i = 0 ; i < ec; i++){ ii[i] += 10.001*Math.random(); bb[i] += 10.001*Math.random(); //图标 czmlBox[i][1].position.cartographicDegrees = [bb[i],ii[i],0]; dataSourceBox[i].process(czmlBox[i]); //线 var cartesian =Cesium.Cartesian3.fromDegrees( bb[i], ii[i], 0); if(positions[i].length == 0){ positions[i].push(cartesian.clone()); positions[i].push(cartesian); } if(positions[i].length >= 2){ if (!Cesium.defined(poly[i])) { poly[i] = new PolyLinePrimitive(positions[i]); }else{ if(positions[i].length>5){ positions[i].shift(); } positions[i].push(cartesian); } } } },2000); Sandcastle.addToolbarButton('清除计时器', function() { clearInterval(realTimeClData); });

二维展示 

 

三维展示 

 

cesium实时更新数据实现实体运功

 cesium在二维地图中移动实体

Cesium基于czml的model模型转向

Cesium基于czml billboard的模型转向

Ceisum实时获取后台数据 实时更新实体位置信息且实现实体转向功能

到此这篇Ceisum实时获取后台数据 实时更新实体位置信息的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!

版权声明


相关文章:

  • 2.typeScript中的数据类型2024-11-27 22:45:04
  • Ceisum实时获取后台数据 实时更新实体位置信息且实现实体转向功能2024-11-27 22:45:04
  • cesium实时更新数据实现实体运功2024-11-27 22:45:04
  • JavaScript技术总结9:轮询数据2024-11-27 22:45:04
  • js基础-(一)-基本数据类型2024-11-27 22:45:04
  • VUE数据更新滚动条定位在最底部 视图展示最新几条数据2024-11-27 22:45:04
  • VUE去除绑定回显数据中的空格:v-model.trim2024-11-27 22:45:04
  • JS判断数据是否为File类型2024-11-27 22:45:04
  • 数据库新手教程(数据库新手教程pdf)2024-11-27 22:45:04
  • odbc数据库(odbc数据库驱动程序字符值无效)2024-11-27 22:45:04
  • 全屏图片