基于 HTML + WebGL 结合 23D 的疫情地图实时大屏 PC 版

2023-12-11 10:59

本文主要是介绍基于 HTML + WebGL 结合 23D 的疫情地图实时大屏 PC 版,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

2019年12月以来,湖北省武汉市陆续发现了多例肺炎病例,现已证实为一种新型冠状病毒感染引起的急性呼吸道传染病并蔓延全国,肺炎疫情牵动人心,人们每天起来第一件事变成了关注疫情进展,期望这场天灾早日结束,社会回归正常秩序。不久前在前端小伙伴和设计小伙伴的合作下我们推出了移动版疫情地图和GIS版疫情地图,而这次我们又推出了 PC 版的疫情地图,浅色系的色调搭配 2D,3D 的方式综合展示疫情的最新动态和历史数据,希望能给大家带来一点比较愉悦的观感体验,减轻下焦虑。

先打开页面感受一下:

点击预览

还有 GIS 版的预览:

GIS 版可在上方导航栏内点击打开,想单独打开可以点击 GIS版疫情地图

数据源说明

CDC, 百度,腾讯,丁香园都有自己的疫情地图,我们的数据也来源于此,这部分在之前的文章 《HTML5 WebGL 实现 3D 地图助力新型冠状病毒疫情实时数据可视化》 有详细说明,就不再赘述了。

系统介绍

数据展示部分:
1.先从左上的表格开始,这部分展示了各省的累计数据和该省份各地区的数据,可点击展开或折叠,点击 3D 地图相应的位置筛选出该地区的相应数据单独展示,点击空白处恢复显示全国数据。
2.接下来是左下的疫情播报部分,这部分的数据采集了各地卫健委数据轮播展示,这里加上了表格纵偏移缓动效果使得滚动更自然美观。
3.底部最显眼的是最新的确诊,疑似,治愈,死亡等数据,往上的位置还有一条时间轴,点击旁边的播放按钮会动态改变页面的数据,根据不同日期各地区确诊人数来对地图染色,与旁边的色卡对比能清晰地观察出各地区疫情的严重程度。
4.右侧图表展示了按时间排序的确诊,疑似,治愈,死亡等数据,一眼就能从图表中读出疫情的发展趋势。
5.上方导航栏,点击可预览 GIS 版的疫情地图, CDC 官网, 还有移动版的疫情地图。

3D 地图部分:

  1. 渐入效果。打开这个demo后 3D 地图 缓缓地从远处飞入眼前,过渡自然,这部分通过 ht 自带的 startAnim 函数实现,可以指定任意的缓动函数来实现不同的飞入效果,这在接下来的篇幅里会介绍。
  2. 省份点击的效果,从武汉向外输出的流动动画,各省省会位置的旋转动画。

程序的示意图:

1)2D,3D 场景的执行和交互

2)全局的事件管理器
整个项目中涉及到 2D, 3D 的交互比较多,因而用了一个全局事件管理器类实例来管理:

class NotifierManager {constructor() {this._eventMap ={};}add(key, func, scope, first = false) {let notify = this._eventMap[key];if (!notify) notify = this._eventMap[key] = new ht.Notifier();notify.add(func, scope, first);}fire(key, e) {const notify = this._eventMap[key];if (!notify) return;notify.fire(e);}
}const event = new NotifierManager();

主要代码:

1)点击 3D 地图
使用 ht 的事件派发改变 2D 内容:

相关代码如下:

event.fire('clickProvince', {data : this.g3dProvince,node : data
});
clickProvince(dataList, node) { let province = node.getDisplayName();// 选中的省份透明度为1,其他为0.4dataList.forEach(data => {data.s('shape3d.opacity', data === node ? 1: 0.4 );})// 只显示该省份数据if (this.areaDatas && this.areaDatas.length > 0) {let provinceData = [];this.areaDatas.forEach((item) => {if (item.area === province || item.host === province) {item.expand = true;provinceData.push(item);}});this.detailTable.a('ht.dataSource', provinceData);}
}

2)滑块播放
滑块播放使用了 startAnim 的 Frame-Based 来开启动画:

相关代码如下:

// 滑块播放
playDateSlider() {this.playMenu.s('state', '暂停');let value =  this.dateSlider.a('ht.value');let x = this.dateSlider.a('dateArea')[0];// 如果到了最后一天的数据重置if (value >= 100 || x >= SLIDER_TIP_END_X) {// 重置地图背景色event.fire('resetMapColor');value = this.sliderValue = 0;x = SLIDER_TIP_START_X;this.dateSlider.s({'ht.value' : 0,'text' : this.sliderDateList[0],});this.dateSlider.a('dateArea', [SLIDER_TIP_START_X, SLIDER_TIP_Y, SLIDER_TIP_WIDTH, SLIDER_TIP_HEIGHT]);}// 开启动画this.sliderAnim = ht.Default.startAnim({frames: 100,interval: 300,action: () => {this.onPlay = true;this.timerJudgment(value);// 到最大值时停留if (value === 100) {this.onPlay = false;this.dateSlider.a('ht.value', value);// 最新数据this.initBottom(17);this.playMenu.s('state', '播放');this.sliderAnim.stop();};value += 1;this.sliderValue += 1;this.dateSlider.a('ht.value', value);x += STRIDE;if (x >= SLIDER_TIP_END_X) {this.dateSlider.a('dateArea', [SLIDER_TIP_END_X, SLIDER_TIP_Y, SLIDER_TIP_WIDTH, SLIDER_TIP_HEIGHT]);}}})
}

3)3D 入场动画
对于视角变化类的动画,ht 自带了 moveCamera 方法。相关代码如下:

function flyToView(g3d, eye, center, cb) {g3d.moveCamera(eye, center, {duration: 3000,easing: Easing.swing,finishFunc: function () {if (cb) {cb();} else {return;}}});
}

4) 2D 表格动画。
每隔 1.5 秒改变表格的纵向偏移值,并把这个过程通过帧动画的方式播放出来,实现流畅的浏览体验,相关代码如下:

// 疫情播报动画
playTable() {let table =  this.newsTable;// 表格 Y 轴偏移let translateY =  table.a('ht.translateY');this.tableInterval = ht.Default.startAnim({frames: Infinity,interval: 1500,action: () => {if (translateY < 0) {translateY = 0;}let temp = this.articleDataSource.shift();this.articleDataSource.push(temp);ht.Default.startAnim({frames: 20,interval: 10,finishFunc: () => {translateY -= 32;},action: (v, t) => {table.a('ht.translateY', translateY - 32 * v); }});}});
}

5) 预览其他版本的疫情地图和 CDC 官网
使用 ht 的事件派发进行图纸加载和切换处理,以 GIS 版的为例:

相关代码如下:

if (kind === 'mobile') {event.fire('showMobile');
} 
else if (kind === 'cdc') {event.fire('showCdc');
} 
else if (kind === 'gis') {event.fire('showGis');
}

总结

疫情地图 PC 版大致效果就是这些,可以感受到到现代浏览器支持的 3D 技术可实现非常直观的效果,互动性也很好。物联网和即将到来的 5G 给众多行业带来了新的机遇,也带来了新的挑战,海量的数据该如何更生动地展示在人们面前?通过跨平台的浏览器无疑是最好的选择。WebGL 技术依托于浏览器,对于数据的处理有着天然的优势,图扑软件作为在工业可视化领域的一线重度参与者,沉淀了许许多多宝贵的行业经验,前不久对刚过去的 19 年做了总结回顾和分享,整理出了 《2019-分享数百个 HT 工业互联网 2D 3D 可视化应用案例分享》,希望各位看官们喜欢。

写在最后

当前,在举国上下一盘棋,戮力同心战疫情的不懈奋斗下,疫情的传播与蔓延已经得到初步控制。当突发事件来临时我很幸运自己是这个国家的一员,面对疫情时各个公共机构的执行力有效地扼制了疫情的扩散,一方有难八方支援,保证了各地区物资供给,也愈加坚定了全国人民打赢这场战役的决心。但遗憾的是,新冠病毒的魔爪却伸向了世界其他地方,但我相信在中国人民和世界各国人民的共同合作抗争下,一定能阻止这场灾难的蔓延。图扑科技也将关注最新的动态,以自己的方式为疫情加油助力。这里做个预告,世界版的疫情地图很快就会与大家见面,敬请期待!

这篇关于基于 HTML + WebGL 结合 23D 的疫情地图实时大屏 PC 版的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

React实现原生APP切换效果

《React实现原生APP切换效果》最近需要使用Hybrid的方式开发一个APP,交互和原生APP相似并且需要IM通信,本文给大家介绍了使用React实现原生APP切换效果,文中通过代码示例讲解的非常... 目录背景需求概览技术栈实现步骤根据 react-router-dom 文档配置好路由添加过渡动画使用

如何用Java结合经纬度位置计算目标点的日出日落时间详解

《如何用Java结合经纬度位置计算目标点的日出日落时间详解》这篇文章主详细讲解了如何基于目标点的经纬度计算日出日落时间,提供了在线API和Java库两种计算方法,并通过实际案例展示了其应用,需要的朋友... 目录前言一、应用示例1、天安门升旗时间2、湖南省日出日落信息二、Java日出日落计算1、在线API2

使用Vue.js报错:ReferenceError: “Vue is not defined“ 的原因与解决方案

《使用Vue.js报错:ReferenceError:“Vueisnotdefined“的原因与解决方案》在前端开发中,ReferenceError:Vueisnotdefined是一个常见... 目录一、错误描述二、错误成因分析三、解决方案1. 检查 vue.js 的引入方式2. 验证 npm 安装3.

vue如何监听对象或者数组某个属性的变化详解

《vue如何监听对象或者数组某个属性的变化详解》这篇文章主要给大家介绍了关于vue如何监听对象或者数组某个属性的变化,在Vue.js中可以通过watch监听属性变化并动态修改其他属性的值,watch通... 目录前言用watch监听深度监听使用计算属性watch和计算属性的区别在vue 3中使用watchE

python解析HTML并提取span标签中的文本

《python解析HTML并提取span标签中的文本》在网页开发和数据抓取过程中,我们经常需要从HTML页面中提取信息,尤其是span元素中的文本,span标签是一个行内元素,通常用于包装一小段文本或... 目录一、安装相关依赖二、html 页面结构三、使用 BeautifulSoup javascript

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

【 html+css 绚丽Loading 】000046 三才归元阵

前言:哈喽,大家好,今天给大家分享html+css 绚丽Loading!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕 目录 📚一、效果📚二、信息💡1.简介:💡2.外观描述:💡3.使用方式:💡4.战斗方式:💡5.提升:💡6.传说: 📚三、源代码,上代码,可以直接复制使用🎥效果🗂️目录✍️

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06