iClient模拟疫情变化过程

2024-02-25 09:18

本文主要是介绍iClient模拟疫情变化过程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作者:lly

背景

为了方便直观的了解疫情的变化过程,我们使用iClien客户端专题图来动态展示疫情的变化。
首先我们来看一看实现效果:
在这里插入图片描述

一、数据制作

数据需要制作为以下格式,即每天对应一个属性字段,并填充相应的数据,例:

行政区划D25D26
四川12
湖北1020

二、字段查询

查询时间字段,用于专题图赋值

var param = new SuperMap.FieldParameters({datasource: "NCP",dataset: "China_Province_pg_1_2_1"});L.supermap.fieldService(dataUrl).getFields(param, function(serviceResult) {var innerHTML = serviceResult.result.fieldNames.join(', ');for(var i = 9; i < serviceResult.result.fieldNames.length; i++) {var monthCount=0;var dateTemp="月";var day="/";					    var filed=serviceResult.result.fieldNames[i];time.push(filed);}});

三、制作专题图

使用客户端分段专题图来制作,首先初始化图层,并设置style

themeLayer = L.supermap.rangeThemeLayer("ThemeLayer", {// 开启 hover 高亮效果isHoverAble: false,opacity: 1,alwaysMapCRS: true}).addTo(map);themeLayer.style = new SuperMap.ThemeStyle({stroke: true,strokeColor: '#f4f4f4',strokeWidth: 1});// 用于单值专题图的属性字段名称themeLayer.themeField = time[0];// 风格数组,设定值对应的样式themeLayer.styleGroups = [{start: 0,end: 1,style: {color: style[0]}}, {start: 1,end: 99,style: {color: style[1]}}, {start: 99,end: 499,style: {color: style[2]}}, {start: 499,end: 999,style: {color: style[3]}}, {start: 1000,end: 9999,style: {color: style[4]}}, {start: 9999,end: 99999999999999999,style: {color: style[5]}}];

通过SQL查询数据服务,查询出行政区划面

var getFeatureBySQLParams = new SuperMap.GetFeaturesBySQLParameters({queryParameter: new SuperMap.FilterParameter({name: "China_Province_pg_1_2_1@NCP",attributeFilter: "SMID > -1"}),toIndex: 500,datasetNames: ["NCP:China_Province_pg_1_2_1"]});L.supermap.featureService(dataUrl).getFeaturesBySQL(getFeatureBySQLParams, processComplete, SuperMap.DataFormat.ISERVER);

将查询结果加到地图,并解析相应返回值用于总数显示

searchData = serviceResult;var result = serviceResult.result;var data = result.features;if(result && result.features) {themeLayer.addFeatures(result.features);var count = 0;for(var i = 0; i < result.features.length; i++) {count += Number(data[i].fieldValues[9]);}}

设置div用于制作图例

	<div class="legend"><div class="content"><div class="color" style="background: rgb(244, 244, 244);"></div><div class="text">0</div></div><div class="content"><div class="color" style="background: rgb(253, 212, 158);"></div><div class="text">1-99</div></div><div class="content"><div class="color" style="background: rgb(253, 187, 132);"></div><div class="text">100-499</div></div><div class="content"><div class="color" style="background: rgb(252, 141, 89);"></div><div class="text">500-999</div></div><div class="content"><div class="color" style="background: rgb(239, 101, 72);"></div><div class="text">1000-9999</div></div><div class="content"><div class="color" style="background: rgb(215, 48, 31);"></div><div class="text">10000人或以上</div></div></div>

css设置图例样式

	.legend {position: absolute;bottom: 10px;left: 20px;z-index: 99999;}.legend .content {height: 12px;margin-bottom: 6px;}.legend .content .color {width: 16px;height: 12px;margin-bottom: -5px;}.text {position: relative;font-size: 12px;color: rgba(255, 255, 255, 0.85);margin-left: 20px;line-height: 0px;}

四、添加时间轴

	var chart = echarts.init(document.getElementById("timeE"));option = {baseOption: {timeline: {axisType: 'category',autoPlay: true,currentIndex:0,playInterval: 1000,data: dataTimer,label: {formatter: function(s) {return s;},color:'#dfdfdf'}}}};chart.setOption(option);

监听时间轴改变事件,刷新专题图,并将对应统计值显示在div中

		chart.on('timelinechanged', function(timeLineIndex) {themeLayer.themeField = time[timeLineIndex.currentIndex];themeLayer.redraw();var result = searchData.result;var data = result.features;if(result && result.features) {var count = 0;for(var i = 0; i < result.features.length; i++) {count += Number(data[i].fieldValues[9 + Number(timeLineIndex.currentIndex)]);}}$(".value").html(count);$(".subTitle").html("截止" + date[timeLineIndex.currentIndex])});

五、结语

至此,我们已实现全部效果,底图和标签可根据自身喜好进行更换,其中标签需新建窗格将其置于顶层,例:

map.createPane('labels');
map.getPane('labels').style.zIndex = 650;
L.supermap.tiledMapLayer(tapUrl, {transparent: true,pane: "labels"}).addTo(map);

数据及代码下载地址,提取码:zqrk

这篇关于iClient模拟疫情变化过程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/745041

相关文章

Django HTTPResponse响应体中返回openpyxl生成的文件过程

《DjangoHTTPResponse响应体中返回openpyxl生成的文件过程》Django返回文件流时需通过Content-Disposition头指定编码后的文件名,使用openpyxl的sa... 目录Django返回文件流时使用指定文件名Django HTTPResponse响应体中返回openp

Linux线程同步/互斥过程详解

《Linux线程同步/互斥过程详解》文章讲解多线程并发访问导致竞态条件,需通过互斥锁、原子操作和条件变量实现线程安全与同步,分析死锁条件及避免方法,并介绍RAII封装技术提升资源管理效率... 目录01. 资源共享问题1.1 多线程并发访问1.2 临界区与临界资源1.3 锁的引入02. 多线程案例2.1 为

批量导入txt数据到的redis过程

《批量导入txt数据到的redis过程》用户通过将Redis命令逐行写入txt文件,利用管道模式运行客户端,成功执行批量删除以Product*匹配的Key操作,提高了数据清理效率... 目录批量导入txt数据到Redisjs把redis命令按一条 一行写到txt中管道命令运行redis客户端成功了批量删除k

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Win10安装Maven与环境变量配置过程

《Win10安装Maven与环境变量配置过程》本文介绍Maven的安装与配置方法,涵盖下载、环境变量设置、本地仓库及镜像配置,指导如何在IDEA中正确配置Maven,适用于Java及其他语言项目的构建... 目录Maven 是什么?一、下载二、安装三、配置环境四、验证测试五、配置本地仓库六、配置国内镜像地址

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

python运用requests模拟浏览器发送请求过程

《python运用requests模拟浏览器发送请求过程》模拟浏览器请求可选用requests处理静态内容,selenium应对动态页面,playwright支持高级自动化,设置代理和超时参数,根据需... 目录使用requests库模拟浏览器请求使用selenium自动化浏览器操作使用playwright

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一

解密SQL查询语句执行的过程

《解密SQL查询语句执行的过程》文章讲解了SQL语句的执行流程,涵盖解析、优化、执行三个核心阶段,并介绍执行计划查看方法EXPLAIN,同时提出性能优化技巧如合理使用索引、避免SELECT*、JOIN... 目录1. SQL语句的基本结构2. SQL语句的执行过程3. SQL语句的执行计划4. 常见的性能优