{
"type": "note",
"title": "从零开始用Echart做一个自己心仪的地图标记!",
"tags": [
"post"
],
"sources": [
"xlog"
],
"external_urls": [
"https://character-4200.xlog.app/cong-ling-kai-shi-yong-Echart-zuo-yi-ge-zi-ji-xin-yi-de-di-tu-biao-ji-md"
],
"date_published": "2022-03-11T08:15:58.000Z",
"content": "---\r\ntitle: 萌新从零开始用Echarts做一个自己的地图标记网页!\r\ndate: 2022-03-10 17:00\r\ncategories:\r\n-web前端\r\n---\r\n\r\n## 起因\r\n\r\n那是一个风和日丽的夜晚,我可爱的老婆大人突然跟我说她最近制作一份 PPT 的时候需要进行地图标记,但是原先她使用的网站失效了,问我有没有什么地图标记的好办法,最好能按照她的要求进行一定的定制。我想了想,要不直接再给我老婆做一个网页算了,虽然我已经很久没练过HTML,CSS和JavaScript了,但好歹之前接触过点皮毛,要不趁这次机会再试一次?\r\n\r\n<!--more-->\r\n\r\n## 准备工作\r\n\r\n说干就干,反正电脑上本身就装了[VSCode](https://code.visualstudio.com/),那么直接写个静态的HTML文件应该就能搞定。至于制作地图的方案么,想到前段时间分析数据的时候用过pyecharts进行制表,这次索性直接用Echarts进行做个试试。由于之前从来没用过Echarts,所以先上[官网](https://echarts.apache.org/zh/index.html)看看[上手教程](https://echarts.apache.org/handbook/zh/get-started/)和[地图案例](https://echarts.apache.org/examples/zh/editor.html?c=map-HK)。\r\n\r\n按照[上手教程]([Handbook - Apache ECharts](https://echarts.apache.org/handbook/zh/get-started/)),先把[echarts.js](https://www.jsdelivr.com/package/npm/echarts)文件下载下来,然后根据[地图案例](https://echarts.apache.org/examples/zh/editor.html?c=map-HK)还需要下载[jquery.js](https://www.jsdelivr.com/package/npm/jquery)。这两个依赖下载完成后就能开始编写HTML文件了。\r\n\r\n## 撸代码\r\n\r\n### 创建空白模板\r\n\r\n在echarts.js和jquery.js文件的同目录下创建一个名为index.html的空白文件(反正需求简单,一个静态网页搞定一切)。VSCode编辑时,直接输入\r\n\r\n```bash\r\n!\r\n```\r\n\r\n回车后,一个空白的HTML文件模板就完成了。\r\n\r\n![](https://md-1307777334.cos.ap-shanghai.myqcloud.com/typora本地图床/index模板.png)\r\n\r\n### 引入外部js文件并创建视图容器\r\n\r\n在头部文件中添加echarts.js和jquery.js\r\n\r\n```html\r\n<!DOCTYPE html>\r\n<html lang=\"en\">\r\n<head>\r\n <meta charset=\"UTF-8\">\r\n <meta http-equiv=\"X-UA-Compatible\" content=\"IE=edge\">\r\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\r\n <script src=\"echarts.min.js\"></script>\r\n <script src=\"jquery.min.js\"></script>\r\n <title>Document</title>\r\n</head>\r\n<body>\r\n <!--style中定义视图的长宽尺寸-->\r\n <div id=\"main\" style=\"width: 1600px;height:1200px;\"></div>\r\n <!--生成地图的主代码文件-->\r\n <script type=\"text/javascript\">\r\n ……\r\n \t……\r\n ……\r\n </script>\r\n</body>\r\n</html>\r\n```\r\n\r\n### 参考案例画出中国地图\r\n\r\n根据官网上的[文档](https://echarts.apache.org/zh/option.html#title),及其他百度到的案例,利用阿里云的[geoJson](http://datav.aliyun.com/portal/school/atlas/area_selector)作为绘制中国地图的数据源\r\n\r\n```html\r\n<!DOCTYPE html>\r\n<html lang=\"en\">\r\n<head>\r\n <meta charset=\"UTF-8\">\r\n <meta http-equiv=\"X-UA-Compatible\" content=\"IE=edge\">\r\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\r\n <script src=\"echarts.min.js\"></script>\r\n <script src=\"jquery.min.js\"></script>\r\n <title>Document</title>\r\n</head>\r\n<body>\r\n <!--style中定义视图的长宽尺寸-->\r\n <div id=\"main\" style=\"width: 1600px;height:1200px;\"></div>\r\n <script type=\"text/javascript\">\r\n // 初始化echarts实例\r\n var myChart = echarts.init(document.getElementById('main'));\r\n myChart.showLoading();\r\n$.get('https://geo.datav.aliyun.com/areas_v3/bound/100000_full.json', function (geoJson) \r\n {\r\n myChart.hideLoading();\r\n echarts.registerMap('china', geoJson);\r\n myChart.setOption(\r\n option = {\r\n title: {\r\n text: '中国地图'\r\n },\r\n geo: {\r\n name: '中国地图',\r\n type: 'map',\r\n map: 'china',\r\n }\r\n }\r\n )\r\n })\r\n </script>\r\n</body>\r\n</html>\r\n```\r\n\r\n这样一个最简单的中国地图网页就已经完成了,而且在鼠标移动到不同区域的时候能够高亮并显示省名。\r\n\r\n![](https://md-1307777334.cos.ap-shanghai.myqcloud.com/typora本地图床/鼠标选择.gif)\r\n\r\n### 定制属于自己的地图标记\r\n\r\n查阅了很多他人写的案例,但最终发现只有[官方文档](https://echarts.apache.org/zh/option.html#title)最有用。因为Echarts就像是一件功能丰富的工具,而官方的文档就是这件工具具体的使用手册,涵盖了这个工具所有的功能。只要你像查字典一样学会了查询官方文档,那么就能将地图按你心目中想象地样子进行定制。\r\n\r\n比如想用鼠标可以选中多个中国地图中的区域,而不是只能置于其上时高亮。那么就需要先看看geo这个类有哪些方法可以被使用。\r\n\r\n在文档中搜索geo后,下图中红框圈出的就是geo具有属性和方法\r\n\r\n![](https://md-1307777334.cos.ap-shanghai.myqcloud.com/typora本地图床/搜索geo.png)\r\n\r\n而我们需要的就是「selectMode」这个方法,根据查询到的手册,这一栏我们可以填写布尔值或是'single','multiple'的。那么我们只要将「selectMode」添加到「geo」类中,并输入'multiple',就能开启鼠标选中地图中的区域的功能。\r\n\r\n![](https://md-1307777334.cos.ap-shanghai.myqcloud.com/typora本地图床/selectMode.png)\r\n\r\n```html\r\n <script type=\"text/javascript\">\r\n // 初始化echarts实例\r\n var myChart = echarts.init(document.getElementById('main'));\r\n myChart.showLoading();\r\n$.get('https://geo.datav.aliyun.com/areas_v3/bound/100000_full.json', function (geoJson) \r\n {\r\n ……\r\n geo: {\r\n name: '中国地图',\r\n type: 'map',\r\n map: 'china',\r\n selectedMode: 'multiple',\r\n }\r\n \t……\r\n })\r\n </script>\r\n```\r\n\r\n同理,如果我们想要添加标记的散点,那么除了绘制geo地图外,还要在此图层上添加一层散点图。我们查看一下「setOption」中「series」属性具有的选项。在这些选项中,很快我们就能发现「scatter」就是我们要的散点。于是和「geo」一样,我们将「scatter」添加进「setOption」中,并采用「geo」的坐标系。\r\n\r\n```html\r\n <script type=\"text/javascript\">\r\n // 初始化echarts实例\r\n var myChart = echarts.init(document.getElementById('main'));\r\n myChart.showLoading();\r\n$.get('https://geo.datav.aliyun.com/areas_v3/bound/100000_full.json', function (geoJson) \r\n {\r\n ……\r\n geo: {\r\n name: '中国地图',\r\n type: 'map',\r\n map: 'china',\r\n selectedMode: 'multiple',\r\n },\r\n series: {\r\n name: '标记点',\r\n type: 'scatter',\r\n coordinateSystem: 'geo',\r\n }\r\n \t……\r\n })\r\n </script>\r\n```\r\n\r\n完成到这里,打开index.html文件,你会发现地图上并没有任何标记点。这当然是因为——你没告诉它点在哪里,那它当然就啥也不给你标出来!所以和上面的步骤一样,我们查询官方文档中scatter.data,并在散点图上给一个标记点。\r\n\r\n![](https://md-1307777334.cos.ap-shanghai.myqcloud.com/typora本地图床/series_data.png)\r\n\r\n既然是中国地图,那么以广东省广州市为例,我们查询一下广州市的经纬坐标值,将数据填写进scatter,并将「label」的「show」属性设置为 true ,格式化「label」的显示格式和放在标记点左边显示(都是查官方文档查的),这样再次打开地图就能看到标记点了。\r\n\r\n```html\r\n <script type=\"text/javascript\">\r\n // 初始化echarts实例\r\n var myChart = echarts.init(document.getElementById('main'));\r\n myChart.showLoading();\r\n$.get('https://geo.datav.aliyun.com/areas_v3/bound/100000_full.json', function (geoJson) \r\n {\r\n ……\r\n geo: {\r\n name: '中国地图',\r\n type: 'map',\r\n map: 'china',\r\n selectedMode: 'multiple',\r\n },\r\n series: {\r\n name: '标记点',\r\n type: 'scatter',\r\n coordinateSystem: 'geo',\r\n data: {name: 'Guangzhou', value:[113.23333,23.16667]},\r\n label:{\r\n formatter: '{b}',\r\n show: true,\r\n position: 'right',\r\n },\r\n }\r\n \t……\r\n })\r\n </script>\r\n```\r\n\r\n## 总结\r\n\r\n“授人以鱼不如授人以渔”。只要按照上面「根据需求」->「[查官方文档](https://echarts.apache.org/zh/option.html#title)」->「将查到属性或方法放入加进源代码」的逻辑,那么就能完全定制出自己想要的一个地图标记网页。如果你也是个爱折腾的人,不妨也试试看做一个属于自己的地图标记网页。(最后把这篇文章做的示例放在结尾,并且把echarts.js和jquery.js改成从网站获取,有需要的人可以拷走直接看成果)\r\n\r\n```html\r\n<!DOCTYPE html>\r\n<html lang=\"en\">\r\n<head>\r\n <meta charset=\"UTF-8\">\r\n <meta http-equiv=\"X-UA-Compatible\" content=\"IE=edge\">\r\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\r\n <script src=\"https://cdn.jsdelivr.net/npm/[email protected]/dist/echarts.min.js\"></script>\r\n <script src=\"https://cdn.jsdelivr.net/npm/[email protected]/dist/jquery.min.js\"></script>\r\n <title>地图Demo</title>\r\n</head>\r\n<body>\r\n <!--style中定义视图的长宽尺寸-->\r\n <div id=\"main\" style=\"width: 1600px;height:1200px;\"></div>\r\n <script type=\"text/javascript\">\r\n // 初始化echarts实例\r\n var myChart = echarts.init(document.getElementById('main'));\r\n myChart.showLoading();\r\n$.get('https://geo.datav.aliyun.com/areas_v3/bound/100000_full.json', function (geoJson) \r\n {\r\n myChart.hideLoading();\r\n echarts.registerMap('china', geoJson);\r\n myChart.setOption(\r\n option = {\r\n title: {\r\n text: '中国地图'\r\n },\r\n geo: {\r\n name: '中国地图',\r\n type: 'map',\r\n map: 'china',\r\n selectedMode: 'multiple',\r\n },\r\n series: {\r\n name: '标记点',\r\n type: 'scatter',\r\n coordinateSystem: 'geo',\r\n data: [{name: 'Guangzhou', value:[113.23333,23.16667]}],\r\n label:{\r\n formatter: '{b}',\r\n show:true,\r\n position: 'right',\r\n },\r\n }\r\n }\r\n )\r\n })\r\n </script>\r\n</body>\r\n</html>\r\n```\r\n\r\n\r\n\r\nPS:很高兴老婆大人对我最后的成品非常满意,嘿嘿嘿~\r\n",
"attributes": [
{
"value": "cong-ling-kai-shi-yong-Echart-zuo-yi-ge-zi-ji-xin-yi-de-di-tu-biao-ji-md",
"trait_type": "xlog_slug"
}
]
}