echarts绘制一个名山地图

说在前面

最近一年开始爬起了山,半年内也爬了不少的山,所以就想着做一个名山地图记录一下。(文章最后分享了一些最近爬山拍下的照片,有兴趣的也可以看看😀

体验地址:jyeontu.xyz/JDemo/#/mou...

数据整理

要想制作这个地图,我们需要先获取需要展示的山的相关数据,比如:经纬度、所在省份城市、海拔高度和简介。整理出来的数据格式如下:

javascript 复制代码
{
    name: "黄山",
    province: "安徽省",
    city: "黄山市",
    longitude: 118.183,
    latitude: 30.167,
    elevation: 1864.8,
    intro:
      "以奇松、怪石、云海、温泉、冬雪'五绝'闻名,世界文化与自然双重遗产,徐霞客赞'黄山归来不看岳'"
  },
  {
    name: "庐山",
    province: "江西省",
    city: "九江市",
    longitude: 115.97,
    latitude: 29.41,
    elevation: 1474,
    intro:
      "地垒式断块山,以三叠泉瀑布、避暑胜地和多元宗教文化著称,世界文化遗产及地质公园"
  },
  ......

代码实现

地理数据预处理

首先我们需要先引入中国地图数据及前面收集的山脉数据。

javascript 复制代码
const chinaJson = require("../../utils/china.json");
import { mountains } from "./mountains.js";

图标区分

使用不同图标区分状态(爬过/没爬过)。

  • 已爬过的山脉数组

将已经爬过的山脉整理成一个数组。

javascript 复制代码
visited: [
      "华山","黄山","泰山",
      "长白山","武功山","恒山",
      "云台山","三清山","龟峰"
    ]
  • 重组山脉数据

根据原有山脉数据和已爬过山脉数组数据进行重组。

javascript 复制代码
const data = mountainsData.map(item => {
  return {
    name: item.name,
    value: [item.longitude, item.latitude],
    info: item,
    icon: this.visited.includes(item.name) ? "mountain" : "mountain2"
  };
});

给地图添加山脉标注

这里我们可以通过绘制散点数据层来将山脉图片绘制到地图上,具体配置项如下:

配置项 功能 示例值
coordinateSystem 绑定地理坐标系(必填) 'geo'
symbol 图标类型(内置形状或自定义图片) 'circle''image://mountain.png'
symbolSize 图标尺寸(可函数动态计算) 10(val) => val[2] * 2
itemStyle 点样式(颜色、透明度等) { color: '#F4E925', opacity: 0.8 }
emphasis 高亮状态样式 { itemStyle: { shadowBlur: 20 } }
tooltip 自定义提示框内容 formatter: '海拔:{c}米'
javascript 复制代码
series: [
  {
    type: "scatter",
    coordinateSystem: "geo",
    data: data,
    symbol: function(_, params) {
      const data = params.data;
      return (
        "image://" +
        require(`../../assets/${data.icon || "mountain2"}.png`)
      );
    },
    symbolSize: 40,
    label: {
      show: true,
      formatter: "{b}",
      position: "right",
      verticalAlign: "middle",
      align: "left"
    }
  }
]

添加提示信息

将前面整理的山脉信息在地图中按格式展示。

javascript 复制代码
tooltip: {
  trigger: "item",
  formatter: function(params) {
    return ` <span style="font-weight: bolder;">${
      params.name
    }</span><br><hr/<br>位置:${params.data.info.province}-${
      params.data.info.city
    }<br>海拔:${
      params.data.info.elevation
    }米<br><hr/>${params.data.info.intro.replace(
      /(.{15})/g,
      "$1<br/>"
    )}`;
  }
}

源码

源码已开源到gitee,有兴趣的也可以到这里看看:gitee.com/zheng_yongt...

  • 🌟觉得有帮助的可以点个star~
  • 🖊有什么问题或错误可以指出,欢迎pr~
  • 📬有什么想要实现的组件或想法可以联系我~

公众号

关注公众号『 前端也能这么有趣 』,获取更多有趣内容。

发送 加群 还可以加入群聊,一起来学习(摸鱼)吧~

说在后面

🎉 这里是 JYeontu,现在是一名前端工程师,有空会刷刷算法题,平时喜欢打羽毛球 🏸 ,平时也喜欢写些东西,既为自己记录 📋,也希望可以对大家有那么一丢丢的帮助,写的不好望多多谅解 🙇,写错的地方望指出,定会认真改进 😊,偶尔也会在自己的公众号『前端也能这么有趣』发一些比较有趣的文章,有兴趣的也可以关注下。在此谢谢大家的支持,我们下文再见 🙌。

照片分享

河山大好 出去走走

别窝在家 当懒虫

嘿嘿,最后再分享一下之前爬过的山的美景😄

华山

黄山

三清山

武功山

恒山

长白山

云台山

去的时候天气不行,都是雾💀

泰山

相关推荐
苦学编程的谢3 分钟前
计算机是如何工作的
服务器·前端·javascript
蓉妹妹17 分钟前
React+Taro选择日期组件封装
前端·react.js·前端框架
风口上的吱吱鼠21 分钟前
记录 ubuntu 安装中文语言出现 software database is broken
linux·服务器·前端
whltaoin28 分钟前
前端弹性布局:用Flexbox构建现代网页的魔法指南
前端·弹性布局
GISer_Jing2 小时前
前端工程化和性能优化问题详解
前端·性能优化
学渣y2 小时前
React文档-State数据扁平化
前端·javascript·react.js
njsgcs2 小时前
画立方体软件开发笔记 js three 投影 参数建模 旋转相机 @tarikjabiri/dxf导出dxf
前端·javascript·笔记
一口一个橘子2 小时前
[ctfshow web入门] web71
前端·web安全·网络安全
逊嘘2 小时前
【Web前端开发】HTML基础
前端·html
Kay_Liang3 小时前
深入解析JavaScript变量作用域:var、let、const全攻略
开发语言·javascript·const·var