ceisum 加载geojson,使用 Cesium 动态加载 GeoJSON 数据

前言

需求是这样的,我需要在地图中显示 08 年到现在的地震情况,地震都是发生在具体的时间点的,那么问题就来了,如何实现地震情况按照时间动态渲染而不是一次全部加载出来。

一、 方案分析

这里面牵扯到两个问题:第一个是如何加载 GeoJSON 格式的数据,其实也就是矢量数据,因为矢量数据之间是可以任意转换的;第二个是如何让加载的数据根据自身的时间显示。

所以就有两种解决问题的思路了:第一种,一次加载 GeoJSON 中所有数据,然后逐个设置显示时间;第二种,逐个加载 GeoJSON 中数据,并设置每个对象的显示时间。

下面我们就一步步来实现解决方案。

二、 解决方案

先来看一下整体效果:

d8e4f9f661cd3ea00c225b45f8d4f7f1.gif

2.1 加载 GeoJSON 数据

在Cesium基础使用介绍一文中已经介绍了如何加载多种格式矢量数据,加载 GeoJSON 数据已经写出了两种方式,第一种是整体读取的,明显无法满足我们的需求,那么就只能寻求第二种方式了:

Cesium.GeoJsonDataSource.load('data/earthquake.geojson').then(function(dataSource) {

viewer.dataSources.add(dataSource);

var entities = dataSource.entities.values;

for (var i = 0; i < entities.length; i++) {

var entity = entities[i];

entity.billboard = undefined;

entity.point = new Cesium.PointGraphics({

color: Cesium.Color.RED,

pixelSize: 10

});

}

});

这里需要注意一个细节,地震数据为点状数据,需要先设置 entity.billboard = undefined,而后再设置 entity.point 来显示点状元素,否则会显示一个图标而不是点。

这样看上去是逐一添加了点状元素,但是我们的问题并没有解决,所有地震点还是全部显示出来了,并没有按照时间显示。

2.2 空间对象按照时间显示

查阅了很多资料,发现可以通过设置对象的 availability 属性来控制对象的显示时间,这正是我需要的,于是修改如下:

Cesium.GeoJsonDataSource.load('data/earthquake.geojson').then(function(dataSource) {

viewer.dataSources.add(dataSource);

var entities = dataSource.entities.values;

for (var i = 0; i < entities.length; i++) {

var entity = entities[i];

entity.billboard = undefined;

entity.point = new Cesium.PointGraphics({

color: Cesium.Color.RED,

pixelSize: 10

});

entity.availability = new Cesium.TimeIntervalCollection([new Cesium.TimeInterval({

start: Cesium.JulianDate.fromIso8601(entity.properties.date),

stop: addDay(Cesium.JulianDate.fromIso8601(entity.properties.date))

})]);

}

});

});

可以看到只是多加了 entity.availability = ... 一项,这样就能够按照时间显示,主要是其中的 start 和 stop 属性,控制显示的时间范围。date 是 GeoJSON 中数据的一个字段,格式为 '2008-01-01',当然你也可以使用其他格式,在此处进行自定义处理即可,addDay 用于控制显示一天,此处不用多考虑。

2.3 GeoJSON 的另外一种读取方式

写到这里问题已经解决了,但是这里再说一个小插曲。刚开始的时候我将 availability 属性直接写到了 point 里,无法得到结果,于是怀疑是此方法走不通,又思考和搜索了片刻,找到了另一种读取 GeoJSON 的方法,如下:

Cesium.loadJson('data/boundary/earthquake.geojson').then(function(jsonData) {

for (var i =0 ;i<=jsonData.features.length; i++) {

var ifeature = jsonData.features[i];

viewer.entities.add({

position: Cesium.Cartesian3.fromDegrees(ifeature.geometry.coordinates[0], ifeature.geometry.coordinates[1]),

availability: new Cesium.TimeIntervalCollection([new Cesium.TimeInterval({

start: Cesium.JulianDate.fromIso8601(ifeature.properties.date),

stop: addDay(Cesium.JulianDate.fromIso8601(ifeature.properties.date))

})]),

point: {

pixelSize: 10,

color: Cesium.Color.RED

}

});

}

});

这同样能达到效果,这就是刚开始讨论时描述的逐个读取数据,这与前一种方式不同的是此处读取到的是逐个的 feature 对象(前一种直接读取 entity 对象),根据 feature 生成 entity 对象,再使用 viewer.entities.add 将对象添加到场景中,每个对象单独根据时间设置 availability 属性,这样同样达到了效果。

当此种方式达到效果的时候,再回头来看第一种方式豁然开朗,读取到的 entity 就是一个真实的 entity 对象,于是将 availability 从 point 中移出到外面便达到了效果。

2.4 问题分析

两种方式都能达到效果,而我在刚开始的时候对细节、对 cesium 的各个对象并没有理解的那么透彻,只是看到了表面现象,当研究的稍微深入的时候对整个 cesium 框架也就有了更多的理解,于是条条道路通罗马。

三、 总结

本文简单介绍了如何动态的根据时间加载 GeoJSON 对象,一定要保持深度思考的习惯,凡事不能只看到表面,应该多一些深入的思考。

geotrellis使用(二十三)动态加载时间序列数据

目录 前言 实现方法 总结 一.前言        今天要介绍的绝对是华丽的干货.比如我们从互联网上下载到了一系列(每天或者月平均等)的MODIS数据,我们怎么能够对比同一区域不同时间的数据情况,采用 ...

Echarts使用及动态加载图表数据

Echarts使用及动态加载图表数据 官网:http://echarts.baidu.com/ 1.文档 2.实例 名词: 1.统计维度(说明数据) 维度就是统计致力于建立一个基于多方位统计(时间.地 ...

Echarts动态加载后台数据

注意:1.用Ajax请求获取后台数据 2.Echarts只能处理Json数据 后台Controller:根据业务需求不同而返回不同数据,我前台要循环遍历Echarts的series进行数据添加,所以后 ...

python获取动态网站上面的动态加载的数据(初级)

我们在处理一些网站数据的时候,有时候我们需要的数据很多都是动态加载的,而不都是静态的,以下以一个实例来介绍简单的获取动态数据,首先申明本人小白,还在学习python中,这个方法还是比较笨拙的,但是对于 ...

Echarts使用及动态加载图表数据 折线图X轴数据动态加载

Echarts简介 echarts,缩写来自Enterprise Charts,商业级数据图表,一个纯JavaScript的图表库,来自百度...我想应该够简洁了 使用Echarts 目前,就官网的文 ...

AJAX 动态加载后台数据 绑定select

js:(使用jquery) $(document ...

dhtmlxtree动态加载节点数据的小随笔

最近做了一个这个东西,颇有些感触,随笔记录一下自己的过程. 首先特别感谢:https://blog.csdn.net/cfl20121314/article/details/46852591,对我的帮 ...

EasyUI datagrid动态加载json数据

最近做一个项目,要求是两张张表可能查找出10多种不同的结果集. 如果想只用一个表格就把全部的结果不同的显示出来那么就肯定不同使用固定的字段名字,要通过动态加载后台返回来的数据把它显示出来就必须动态加载 ...

viewPager动态加载listview数据

废话不多说,先上效果图.(代码见附件) 代码是修改自某大神的,我做了很多修改,之前只能向右滑动,现在可以左右无限滑动,只要数据没加载完就可以一直滑动.过程不算复杂,代码主要的地方都有注释. 附件dem ...

随机推荐

使用OpenSSL为支付宝生成RSA私钥

通过openssl工具生成RSA的公钥和私钥(opnssl工具可在互联网中下载到,也可以点此下载无线接口包,里面包含此工具)打开openssl文件夹下的bin文件夹,执行openssl.exe文件: ...

C语言求x的y次方,自定义函数,自己的算法

我是一名高二中学生,初中时接触电脑,非常酷爱电脑技术,自己百度学习了有两年多了,编程语言也零零散散的学习了一点,想在大学学习计算机专业,所以现在准备系统的学习C语言,并在博客中与大家分享我学习中的心得 ...

dom处理配置文件&lowbar;待完善

import java.io.File;import java.io.FileNotFoundException;import java.io.FileOutputStream;import java ...

Redis实现高并发分布式序列号

使用Redis实现高并发分布式序列号生成服务 序列号的构成 为建立良好的数据治理方案,作数据掌握.分析.统计.商业智能等用途,业务数据的编码制定通常都会遵循一定的规则,一般来讲,都会有自己的编码规则和 ...

Python之MRO及其C3算法

[, , ] (

DialogFragment的应用

一.DialogFragment简单介绍: 1.基本概念 DialogFrament 指一个与fragment建立了关联的Dialog, 随fragment生, 随fragment死, 即Dialog ...

图解 sql 事务隔离级别

sql 事务隔离级别有四种分种为: 一 Read Uncpommitted(未提交读) 二 Read Committed(提交读) 三 Repeated Read(可重复读) 四 Serializab ...

Netty、t-io、Voovan 框架比较

以下是对三个框架在设计或者说是编码特点中选取的几个我比较关注的点的对比图: 首先我们对几个关键的概念进行一些解析,方便大家更好的理解上面表中的概念: NIO.AIO 的区别? 在这里我们来看一下两者最 ...

Vue 制作简易计算器

...

Eureka的优势

http://www.cnblogs.com/zgghb/p/6515062.html Eureka的优势 1.在Eureka平台中,如果某台服务器宕机,Eureka不会有类似于ZooKeeper的选 ...

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要在Cesium加载GeoJSON数据,您可以按照以下步骤操作: 1. 将GeoJSON文件加载Cesium中。您可以使用Cesium的load方法来加载文件,如下所示: ``` Cesium.load('/path/to/your/geojson/file.geojson').then(function(data) { // Do something with the data }); ``` 2. 解析GeoJSON数据。您可以使用CesiumGeoJsonDataSource来解析数据,如下所示: ``` var dataSource = new Cesium.GeoJsonDataSource(); dataSource.load('/path/to/your/geojson/file.geojson').then(function() { // Do something with the data source }); ``` 3. 将数据源添加到场景中。您可以使用Cesium的viewer对象来添加数据源,如下所示: ``` viewer.dataSources.add(dataSource); ``` 4. 设置点的样式。您可以使用Cesium的点图形来设置点的样式,如下所示: ``` dataSource.entities.point = { pixelSize: 10, color: Cesium.Color.RED }; ``` 以上是加载GeoJSON数据的基本步骤,您可以根据自己的需求进行调整和修改。 ### 回答2: Cesium是一款开源的地图可视化引擎,能够快速高效地展示地理数据,支持多种数据格式。GeoJSON是一种常用的地理数据格式,可用于描述地图上的点、线和面等要素。Cesium提供了丰富的API,能够便捷地加载GeoJSON数据,并在地图上展示。 要加载GeoJSON数据,首先需要将数据转换为Cesium可识别的格式。Cesium支持将GeoJSON转换为Cesium的Entities、Primitives和Imagery Layers等形式,其中Entities是最常用的一种形式。通过CesiumGeoJsonDataSource对象可以实现将GeoJSON数据加载为Entities,并在地图上展示。 接下来,我们可以通过Cesium内置的Viewer对象,创建一个基础地图,并将GeoJSON数据添加到地图上。下面是一段示例代码: ```javascript var viewer = new Cesium.Viewer('cesiumContainer'); //创建Viewer对象,将地图加载到'cesiumContainer'元素中 var dataSource = new Cesium.GeoJsonDataSource('myData'); //创建GeoJsonDataSource对象,并指定数据名称为'myData' var promise = dataSource.load('myPoints.geojson'); //通过load方法加载GeoJSON数据文件 viewer.dataSources.add(dataSource); //将数据源添加到Viewer中 promise.then(function() { viewer.zoomTo(dataSource); }); //当数据加载完毕,将Viewer缩放至图层范围 ``` 在上面的代码中,我们首先创建了一个Viewer对象,并将它加载到HTML元素'cesiumContainer'中。然后,创建一个GeoJsonDataSource对象,并通过load方法加载GeoJSON数据文件'myPoints.geojson'。将数据源添加到Viewer中后,使用promise.then()回调函数,在数据加载完成后将Viewer缩放至图层范围。 需要注意的是,GeoJSON数据中的属性信息将自动转换为Cesium的Entity属性,并可用于自定义标签、颜色和大小等信息。此外,通过调用Entity的show和position属性,可以方便地控制Entity的显示状态和位置。 ### 回答3: Cesium是一款开源的WebGIS平台,支持加载geojson数据GeoJson是一种基于JavaScript对象表示法(JSON)的地理数据交换格式,它能够将矢量地理数据以一种简单、轻量级的方式表示出来。 在Cesium中,加载GeoJson数据可以通过以下步骤实现: 1.创建数据源 首先,我们需要创建一个Cesium.GeoJsonDataSource对象,用于加载GeoJson数据。我们可以使用以下代码创建一个空的GeoJson数据源: var dataSource = new Cesium.GeoJsonDataSource(); 2.加载GeoJson数据 接下来,我们需要读取包含GeoJson数据URL加载这些数据。可以使用Cesium的load方法读取GeoJson文件并将其加载数据源中。以下是加载GeoJson数据并将其添加到数据源的示例代码: Cesium.load('path/to/geojson.json').then(function (geojson) { dataSource.load(geojson); }) 3.显示GeoJson数据 一旦我们将GeoJson数据添加到数据源中,就可以将其添加到场景中显示。以下是将GeoJson数据添加到场景中的示例代码: viewer.dataSources.add(dataSource); 完成这些步骤后,应该可以在Cesium应用程序中看到已加载GeoJson数据。 总而言之,Cesium支持加载GeoJson数据,只需要使用Cesium.GeoJsonDataSource对象方法读取、加载和显示GeoJson数据即可。这种方法使得加载大规模点数据的展示和分析变得简单,方便且易于操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值