可视化 | 【echarts】中国地图热力图

文章目录

  • 📚html和css
  • 📚js
    • 🐇整体框架
    • 🐇getGeoJson
    • 🐇echarts绘图
      • ⭐️整体框架
      • ⭐️option配置项

在这里插入图片描述

  • 【echarts】渐变条形+折线复合图
  • 【echarts】金字塔图

📚html和css

  • html:整合
    <!DOCTYPE html>
    <html lang="en">
    <head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>可视化模板三</title><link rel="stylesheet" href="./style.css">
    </head>
    <body><div id="test1"></div>
    </body>
    <!-- echarts引入 -->
    <script src="https://cdn.staticfile.org/echarts/4.3.0/echarts.min.js"></script>
    <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
    <script src="./script.js"></script>
    </html>
    
  • css:样式
    body{background-color: #f5f2e9;
    }
    #test1 {position: absolute;top: 50%;left: 50%;transform: translate(-50%, -50%);height: 100vh;width: 100vw;
    }
    

📚js

🐇整体框架

  • 初始化地理信息可视化图表:
    • 使用 echarts.init初始化了一个 ECharts 图表。
    • 通过调用getGeoJson方法获取了所有地理坐标的 GeoJSON 数据和中国的 GeoJSON 数据。
    • 然后调用 initEcharts方法初始化 ECharts 图表。
    let publicUrl = 'https://geo.datav.aliyun.com/areas_v2/bound/';
    async function initChart() {let chart = echarts.init(document.getElementById('test1'));//使用 await 等待获取地理坐标数据let alladcode = await getGeoJson('all.json')let chinaGeoJson = await getGeoJson('100000_full.json')initEcharts(chinaGeoJson, '唐朝历史人物分布', chart, alladcode)
    }
    initChart();
    

  • async function 是 ECMAScript 2017(ES8)引入的语法特性之一,用于简化异步操作的处理。
  • 通过使用 async function,可以方便地编写和管理异步代码,并且可以使用 await关键字轻松地处理 Promise 对象。
  • 在 JavaScript 中,常见的异步操作包括处理异步函数、Promise 对象和其他需要等待操作的场景。使用传统的回调函数或 Promise 链式调用的方式来处理这些异步操作可能使得代码混乱、难以阅读和维护。
  • 定义一个异步函数时,可以使用 async 关键字在函数声明之前,如下所示:
    async function myAsyncFunction() {// 异步操作逻辑
    }
    
  • 在异步函数内,可以使用 await 关键字等待一个 Promise 对象的解析,并将其结果返回。
  • await 关键字只能在声明为 async 的函数中使用,它让 JavaScript 引擎暂停该函数的执行,直到 Promise 对象状态变为 resolved(已完成)或 rejected(已拒绝)时再继续执行函数。

🐇getGeoJson

  • 该函数用于获取地图 JSON 数据。
  • 函数的参数是jsonName,表示需要获取的地图数据的名称。
  • 使用 $.get 方法来发起异步请求获取地图数据。
  • $.get(publicUrl + jsonName) 返回的是一个 Promise 对象,使用 await 关键字等待 Promise 对象的解析。
    //获取地图json数据
    async function getGeoJson(jsonName) {return await $.get(publicUrl + jsonName)
    }
    

🐇echarts绘图

  • 首先定义好地图数据(即每个省份对应的数值)
    let mapData = [{name: "河南省",value: 14827},{name: "陕西省",value: 10333},...]
    
  • function initEcharts(geoJson, name, chart, alladcode)geoJson:地理信息数据的 GeoJSON 对象,包含了地图的地理信息数据,如各地区的边界坐标等。name:地图的名称或标题,用于在图表中显示地图的名称。chart:ECharts 图表实例,用于初始化和展示地理信息可视化图表。alladcode:地理坐标数据,可能包含了各地区的经纬度信息。

以下细说initEcharts函数框架

⭐️整体框架

  1. 生成地理坐标映射表:通过遍历 geoJson 对象的 features 属性,获取了每个地区的名称及其经纬度信息,并构建了地理坐标映射表 geoCoordMap。
  2. 注册地图:使用 echarts.registerMap 方法注册地图,将地图名称和地理信息关联起来。
  3. 定义图表的配置项option:设置了地图的标题、提示框格式、地图区域样式、鼠标交互、series 属性设置了地图项,设置颜色标注及色块指示。
  4. 通过myChart.setOption将配置项应用到echarts实例。
  5. 绑定事件处理函数myChart.resize以便让图表自适应新的窗口大小,确保图表在不同尺寸的屏幕上能够正确显示。
    //生成地理坐标映射表
    let geoCoordMap = {};
    let mapFeatures = geoJson.features;
    mapFeatures.forEach(function (v, i) {let name = v.properties.name;if (name) {geoCoordMap[name] = v.properties.center;}
    });//注册地图
    echarts.registerMap(name, geoJson);//定义图表配置项
    var option = {...};//将配置项应用到echarts实例
    if (option && typeof option === 'object') {chart.setOption(option);
    }//以让图表自适应新的窗口大小
    window.addEventListener('resize', chart.resize);
    

⭐️option配置项

  • 标题及悬浮提示框(关注提示框的样式设置,相当于一个小型的html样式)
    title: {text: name,  // 设置标题文本为函数参数中所传递的地图名称left: 'center',  // 标题水平居中top: '6%',  // 标题距离顶部的距离为6%textStyle: {fontSize: 34,  // 标题文字大小为34fontFamily: 'KaiTi, serif'  // 标题文字字体为楷体或Serif字体}
    },
    tooltip: {triggerOn: "mousemove",  // 触发方式为鼠标移动触发formatter: function (params) {  // 自定义提示框的格式化函数if (isNaN(params.value)) {  // 如果数值为非数字,将其设置为0params.value = 0}var html = '<span>' + params.name + ':</span><br/>'  // 构造提示框的HTML内容,包括地区名称html += '<span>值:' + params.value + '</span><br/>'  // 添加数值信息return html  // 返回HTML内容作为提示框的显示内容},backgroundColor: 'rgba(29, 38, 71)',  // 设置提示框背景颜色extraCssText: 'box-shadow:0 0 4px rgba(11, 19, 43,0.8)',  // 为提示框添加额外的阴影效果
    }
    
  • geo地图配置
    • 关注label标签设置itemStyle地图基础样式设置(这里的itemStyle主要是颜色设置,指的是不考虑热力色块的地图初始颜色)。
    • normal普通状态及emphasis高亮状态。
    • roam: false:关闭鼠标缩放和平移漫游操作,否则可通过鼠标拖动或滑轮滚动改变地图大小及位置。
    geo: {show: true,  // 设置地图显示为可见top: '10%',  // 设置地图距离顶部的距离为10%map: name,  // 指定使用的地图名称label: {normal: {show: false  // 普通状态下地图标签不显示},emphasis: {show: true,  // 高亮状态下地图标签显示color: "#31322c",  // 高亮状态下地图标签的颜色}},roam: false,  // 关闭鼠标缩放和平移漫游操作itemStyle: {normal: {areaColor: '#fff',  // 地图区域的普通状态的背景颜色borderColor: '#686a67',  // 地图区域的普通状态的边框颜色},emphasis: {areaColor: '#00828B',  // 地图区域的高亮状态的背景颜色}},
    }
    
  • 数据系列的配置:配置了用于地图展示的系列(series)选项。
    • 如果页面上有多个地理组件时(比如多个地图或地图的放大缩小),通过geoIndex可以指定当前系列要使用的地理组件的索引,从而将该系列与指定的地理组件进行关联,确保数据能够正确显示在指定的地图上。类似于yAxisIndex:指定对应的y轴(有时候可以是双y轴)
    • 当设置 animation: true 时,表示开启了系列的动画。在图表加载或数据更新时,系列会以动画的形式进行显示,这种动态效果能够吸引用户的注意力,使数据更加生动和直观。
    series: [  {type: 'map',  geoIndex: 0,  //设置地图长宽比aspectScale: 0.75,  animation: true,  data: mapData  },
    ]
    
  • 添加色块及图例框指示
    visualMap: {min: 0,max: 15000,// 设置颜色标注,区分颜色范围,完成颜色映射pieces: [{gt: 12000, color: '#b0112f'}, {gt: 10000, lte: 12000, color: '#c34654'}, {gt: 4000, lte: 10000, color: '#ca5860'}, {gt: 2000, lte: 4000, color: '#df928a'}, {gt: 1000, lte: 2000, color: '#e3a89a'}, {gt: 600, lte: 1000, color: '#eabdaa'}, {gt: 300, lte: 600, color: '#f3dabc'},{gt: 50, lte: 300, color: '#f8ecd1'},{gt: 1, lte: 50, color: '#fcf9e5'}],// 显示图例show: true,// 以下是图例框设置right: '65%',bottom: '12%',// 显示标签(图例的text)showLabel: true,text: ['High', 'Low'],textStyle: {fontSize: 24,color: '#333'},//同上geoIndex: 0seriesIndex: [0],// 图例色块的宽高itemHeight: 20,itemWidth: 20,// 图例垂直排列且自动调整orient: 'vertical',align: 'auto',borderWidth: 2,borderColor: '#ccc',}
    

  • 完整代码包

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/638644.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

5G_射频测试_发射机测量(四)

6.2 Base station output power 用于测量载波发射功率的大小&#xff0c;功率越大小区半径越大但是杂散也会越大 载波功率&#xff08;用频谱仪测&#xff09;天线口功率&#xff08;用功率计测&#xff09;载波功率是以RBW为单位的filter测量的积分功率不同带宽的多载波测试时…

java垃圾回收GC过程

GC&#xff08;Gabage Collection&#xff09; 用于回收堆中的垃圾数据 清理方法 1.标记-清理 对数据标记&#xff0c;然后清理 缺点&#xff1a;容易产生内存碎片 2.标记-整理 对标记后的数据清理&#xff0c;剩下数据前移 缺点&#xff1a;每次清理后数据都要迁移&#xff0…

JAVA算法-查找

目录 基本查找*&#xff1a; 二分查找*&#xff1a; 数据单调递增&#xff1a; 数据单调递减&#xff1a; 总结规律&#xff1a; 插值查找*&#xff1a; 斐波那契查找&#xff08;了解原理&#xff09;&#xff1a;以后补 分块 查找*&#xff1a; 特殊 情况&#xff0…

docker部署

//创建一个文件夹 mkdir soft //进入soft文件夹 cd soft 安装必要的系统工具: yum install -y yum-utils device-mapper-persistent-data lvm2 配置阿里云Docker Yum源: yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.rep…

c# 视频播放之Windows Media Player

最近想给软件加个视频播放功能&#xff0c;在网上看有好几个方式&#xff0c;最后决定用 Windows Media Player 和Vlc.DotNet.Forms。 这篇文章主要讲Windows Media Player&#xff0c;它的优点&#xff1a;代码简单&#xff0c;视频操作功能都有&#xff0c;能播放网络和本地…

数据结构之顺序表的增删查改

别丢了你的勇敢 前言&#xff1a; 自今日起&#xff0c;我们正式越过C语言的大山&#xff0c;走向了数据结构的深山&#xff0c;现如今摆在我们面前的第一个坎就是顺序表&#xff0c;我们需要了解顺序表的定义&#xff0c;并且知道&#xff0c;如何对其进行增删查改&#xff0…

MyBatis 使用报错: Can‘t generate mapping method with primitive return type

文章目录 前言问题原因解决方案个人简介 前言 今天在新项目中使用 MyBatis 报如下错误&#xff1a;Cant generate mapping method with primitive return type 问题原因 发现是 Mapper 注解引入错误&#xff0c;错误引入 org.mapstruct.Mapper, 实际应该引入 org.apache.ibat…

接口测试 04 -- Jsonpath断言、接口关联处理

1. JsonPath基本介绍 1.1 JsonPath简介 JsonPath是一种用于在JSON数据中定位和提取特定数据的表达式语言。它类似于XPath用于XML的定位和提取&#xff0c;可以帮助我们灵活地从复杂的JSON结构中获取所需的数据。 1.2 JsonPath的特点 ● JsonPath可处理的报文类型为字典类型 …

4.servera修改主机名,配置网络,以及在cmd中远程登录servera的操作

1.先关闭这两节省资源 2.对于新主机修改主机名&#xff0c;配置网络 一、配置网络 1.推荐图形化界面nmtui 修改完成后测试 在redhat ping一下 在redhat远程登录severa 2、使用nmcli来修改网络配置 2.1、配置要求&#xff1a;主机名&#xff1a; node1.domain250.exam…

C++:类与对象(上)

C&#xff1a;类与对象&#xff08;上&#xff09; 类的引入类的定义访问限定符类域实例化对象模型this指针 类的引入 C的类是基于C语言的结构体优化出来的&#xff0c;那我们先来看一看C对结构体有哪些优化点。 C语言与C的结构体的类型名称略有区别&#xff0c;我们看一个案…

寒假每日一题-小苹果

小 Y 的桌子上放着 n 个苹果从左到右排成一列&#xff0c;编号为从 1 到 n。 小苞是小 Y的好朋友&#xff0c;每天她都会从中拿走一些苹果。 每天在拿的时候&#xff0c;小苞都是从左侧第 1个苹果开始、每隔 2 个苹果拿走 1个苹果。 随后小苞会将剩下的苹果按原先的顺序重新…

【Leetcode】接雨水(双指针、单调栈)

目录 &#x1f4a1;题目描述 &#x1f4a1;双指针解法 &#x1f4a1;单调栈解法 &#x1f4a1;题目描述 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图&#xff0c;计算按此排列的柱子&#xff0c;下雨之后能接多少雨水。 提示&#xff1a; n height.length1 < n…

010-新手如何建立一个属于自己的图像处理FPGA/ZYNQ框架(自己的用着才舒服,内容非常全面!)

文章目录 前言一、图像处理框架二、图像采集输入1.常用视频流格式&#xff1a;Rgb565/Bayer1.RGB565数据流格式2.Bayer阵列数据流格式 2.图像预处理&#xff1a;时钟域同步/去马赛克/色彩空间转换/滤波1.时钟域同步2.图像去马赛克化3.色彩空间转换4.滤波 三、图像算法处理1.图像…

【后端】深入浅出Node.js

文章目录 1.Node简介1.1 诞生历程1.2 阻塞IO和异步IO 【后端目录贴】 1.Node简介 1.1 诞生历程 Node特点 事件驱动、非阻塞I/O node和chrome浏览器区别 除了HTML、WebKit和显卡这些UI相关技术没有支持外&#xff0c;Node结构与Chrome十分相似&#xff0c;他们都是基于事件驱动…

Vue 组件通信方式

✨ 专栏介绍 在当今Web开发领域中&#xff0c;构建交互性强、可复用且易于维护的用户界面是至关重要的。而Vue.js作为一款现代化且流行的JavaScript框架&#xff0c;正是为了满足这些需求而诞生。它采用了MVVM架构模式&#xff0c;并通过数据驱动和组件化的方式&#xff0c;使…

AI大模型开发架构设计(1)——LLM大模型Agent剖析和应用案例实战

文章目录 LLM大模型Agent剖析和应用案例实战1 从 LLM 大模型到智能体演进技术语言模型是什么&#xff1f;大语音模型是什么&#xff1f;大语言模型日新月异LLM大模型存在局限性LLM Agent来势凶凶LLM Agent增长迅猛LLM Agent是什么&#xff1f; 2 LLM Agent 架构深度剖析规划能力…

OpenCV实战——OpenCV.js介绍

OpenCV实战——OpenCV.js介绍 0. 前言1. OpenCV.js 简介2. 网页编写3. 调用 OpenCV.js 库4. 完整代码相关链接 0. 前言 本节介绍如何使用 JavaScript 通过 OpenCV 开发计算机视觉算法。在 OpenCV.js 之前&#xff0c;如果想要在 Web 上执行一些计算机视觉任务&#xff0c;必须…

线性代数:矩阵运算(加减、数乘、乘法、幂、除、转置)

目录 加减 数乘 矩阵与矩阵相乘 矩阵的幂 矩阵转置 方阵的行列式 方阵的行列式&#xff0c;证明&#xff1a;|AB| |A| |B| 加减 数乘 矩阵与矩阵相乘 矩阵的幂 矩阵转置 方阵的行列式 方阵的行列式&#xff0c;证明&#xff1a;|AB| |A| |B|

核密度曲线(python

目录 1.代码&#xff1a;2.效果&#xff1a;小结&#xff1a; 1.代码&#xff1a; import pandas as pd import matplotlib.pyplot as plt # 读入数据 file r123.xlsx sheet Sheet2 col S213 # 标题名称 title col 供订比曲线 xlabel 供订比 # 横轴显示范围 xleft 0 xr…

解决 conda新建虚拟环境只有一个conda-meta文件&conda新建虚拟环境不干净

像以前一样通过conda 新建虚拟环境时发现环境一团糟&#xff0c;首先新建虚拟环境 conda create -n newenv这时候activate newenv&#xff0c;通过pip list&#xff0c;会发现有很多很多的包&#xff0c;都是我在其他环境用到的。但诡异的是&#xff0c;来到anaconda下env的目…