echarts-地图

news2025/1/12 20:43:55

使用地图的三种的方式:

  1. 注册地图(用json或svg,注册为地图),然后使用map地图
  2. 使用geo坐标系,地图注册后不是直接使用,而是注册为坐标系。
  3. 直接使用百度地图、高德地图,使用百度地图或高德地图作为坐标系。

用json或svg注册为地图,然后使用map地图

从DataV中获取地图数据。
在这里插入图片描述
echarts.registerMap(“china”, china) 注册地图
map :使用 registerMap 注册的地图名称。

import * as echarts from "echarts";
import { onMounted, watch } from "vue";
import "./vintage";
import china from "./china.json";
let myEcharts;
onMounted(() => {
  let canvas = document.getElementById("canvas");
  echarts.registerMap("china", china);
  myEcharts = echarts.init(canvas, "vintage", {
    width: 500,
    height: 500,
    devicePixelRatio: window.devicePixelRatio,
    locale: "ZH",
  });

  let options = {
    tooltip: {},
    series: [
      {
        type: "map",
        roam: true,
        width: 500,
        height: 500,
        map: "china",
      },
    ],
  };
  rednderEcharts(options);
});

function rednderEcharts(options) {
  myEcharts.setOption(options);
}

在这里插入图片描述

使用series调节绘制的地图

地图中也label,tooltip,lenged等属性,也可以用itemStyle调整每块区域的样式。
地图特有的属性:
数据映射: nameMap
缩放相关的:scaleLimit,zoom

如果想给某个省份添加数据,可以设置data

 let options = {
    tooltip: {},
    series: [
      {
        type: "map",
        roam: true,
        width: 500,
        height: 500,
        map: "china",
        label: {
          // show: true,
        },
        itemStyle: { // 地图的颜色
          areaColor: "blue",
        },
        emphasis: { //高亮色
          itemStyle: {
            areaColor: "red",
          },
        },
        data: [{ name: "天津市", value: 20 }],//name要完全对应
      },
    ],
  };

在这里插入图片描述
scaleLimit :滚轮缩放的极限控制,通过min, max最小和最大的缩放值。
zoom:当前视角的缩放比例。
nameMap:自定义地区的名称映射。

 let options = {
  tooltip: {},
  series: [
    {
      type: "map",
      roam: true,
      width: 500,
      height: 500,
      map: "china",
      label: {
        // show: true,
      },
      itemStyle: {
        // 地图的颜色
        areaColor: "blue",
      },
      emphasis: {
        //高亮色
        itemStyle: {
          areaColor: "red",
        },
      },
      nameMap: {
        河北省: "冀",
      },
      scaleLimit: {
        min: 1,
        max: 5,
      },
      zoom: 5,
      data: [
        { name: "天津市", value: 20 },
        {
          name: "冀",
          value: 100,
        },
      ],
    },
  ],
};

在这里插入图片描述

visualMap 根据数值显示不同的颜色,一般配合热力图或地图

inRange 调控颜色的变化范围
min,max 调控最大、最小值
left 调节组件的位置
text调节组件最高最低的文本

 let options = {
    tooltip: {},
    series: [
      {
        type: "map",
        roam: true,
        width: 500,
        height: 500,
        map: "china",
        label: {
          // show: true,
        },
        itemStyle: {
          // 地图的颜色
          areaColor: "blue",
        },
        emphasis: {
          //高亮色
          itemStyle: {
            areaColor: "red",
          },
        },
        nameMap: {
          河北省: "冀",
        },
        scaleLimit: {
          min: 1,
          max: 5,
        },
        //  zoom: 5,
        data: [
          { name: "天津市", value: 20 },
          { name: "山西省", value: 10 },
          { name: "河南省", value: 15 },
          {
            name: "冀",
            value: 40,
          },
        ],
      },
    ],
    visualMap: {
      type: "continuous", //"piecewise" 调控颜色的条是连续的还是不连续的
      min: 0,  // 
      max: 40,
      range: [4, 35],  //范围是从4-35 ,整个范围是0-40
      text: ["最小值", "最大值"], // 调控颜色的条上下的文字
      left: 120,
      inRange: {
        color: ["#313695", "#4575b4", "#74add1", "#abd9e9", "#e0f3f8"],
      },
    },
  };

在这里插入图片描述

geo 地理坐标系绘制地图

如果以地图为基础,在地图的某个位置上绘制一些东西,可以使用geo地理坐标系来绘图
1.图表的调节与map图标一致
2. 如果相对地图中的某一个区域进行特殊的配置,要使用regions

 let options = {
    tooltip: {},
    geo: {
      map: "china",
      roam: true,
      zoom: 2,
      itemStyle: {
        areaColor: "blue",
      },
    },
    visualMap: {
      type: "continuous", //"piecewise"
      min: 0,
      max: 40,
      range: [4, 35],
      text: ["最小值", "最大值"],
      left: 120,
      inRange: {
        color: ["#313695", "#4575b4", "#74add1", "#abd9e9", "#e0f3f8"],
      },
    },
  };

在这里插入图片描述
在图中添加数据,以graph关系图为例

 let options = {
    tooltip: {},
    geo: {
      map: "china",
      roam: true,
      zoom: 1,
      itemStyle: {
        areaColor: "blue",
      },
    },
    series: [
      {
        type: "graph",
        coordinateSystem: "geo",
        data: [
          [112.549248, 37.857014],
          [111.670801, 40.818311],
          [115.426264, 39.950502],
          [116.677853, 40.970888],
        ],
      },
    ],
  };

在这里插入图片描述


  let options = {
    tooltip: {},
    geo: {
      map: "china",
      roam: true,
      zoom: 1,
      itemStyle: {
        areaColor: "blue",
      },
      regions: [
        {
          name: "河北省",
          itemStyle: {
            areaColor: "yellow",
          },
        },
      ],
    },
    series: [
      {
        type: "graph",
        coordinateSystem: "geo",
        data: [
          [112.549248, 37.857014],
          [111.670801, 40.818311],
          [115.426264, 39.950502],
          [116.677853, 40.970888],
        ],
      },
    ],
  };

在这里插入图片描述

geo地理坐标系搭配lines绘制路线

lines经常配合geo使用,用于绘制路线图。与line折线图不同的是,lines主要用来绘制多个线条,数据写法也不同。

lines:路径图
coords:一个包含两个到多个二维坐标的数组

 let options = {
    tooltip: {},
    geo: {
      map: "china",
      roam: true,
      zoom: 1,
      itemStyle: {
        // areaColor: "blue",
      },
      regions: [
        {
          name: "河北省",
          itemStyle: {
            areaColor: "yellow",
          },
        },
      ],
    },
    series: [
      {
        type: "lines",
        lineStyle: {
          color: "red",
          width: 3,
        },
        data: [
          {
            coords: [
              [117.000923, 36.675807],
              [114.27261, 24.700624],
            ],
          },
          {
            coords: [
              [115.057317, 24.703343],
              [114.27261, 24.700624],
            ],
          },
        ],
      },
    ],
  };

在这里插入图片描述

使用高德或百度地图

在这里插入图片描述
在html中引入百度地图(要在vue加载前使用,所以放在head中,提前加载)
必须是3.0,1.0会报错

在这里插入图片描述
在echarts中使用

<script setup>
import * as echarts from "echarts";
import { onMounted, watch } from "vue";
import "./vintage";

import "echarts/extension/bmap/bmap";

let myEcharts;
onMounted(() => {
  let canvas = document.getElementById("canvas");
 
  myEcharts = echarts.init(canvas, null, {
    width: 1200,
    height: 1200,
    devicePixelRatio: window.devicePixelRatio,
    locale: "ZH",
  });

  let options = {
    tooltip: {},
    bmap: {
      center: [116.405285, 39.904989],
      roam: true,
      zoom: 18,
    },
    series: [],
  };
  rednderEcharts(options);
});

function rednderEcharts(options) {
  myEcharts.setOption(options);
}
</script>

<template>
  <div id="canvas" width="400" height="400"></div>
</template>

<style scoped>
#canvas {  //一定要在给 元素设置宽高,否则会报错
  width: 1200px;
  height: 1200px;
}
</style>

在这里插入图片描述
添加数据

 let options = {
    tooltip: {},
    bmap: {
      center: [116.405285, 39.904989],
      roam: true,
      zoom: 18,
    },
    series: [
      {
        type: "lines", //这里的线条有动画效果
        coordinateSystem: "bmap",
        lineStyle: {
          color: "yellow",
          width: 1,
        },
        effect: {
          show: true,
          symbol: "",
        },
        data: [
          {
            coords: [
              [117.000923, 36.675807],
              [114.27261, 24.700624],
            ],
          },
          {
            coords: [
              [115.057317, 24.703343],
              [114.27261, 24.700624],
            ],
          },
        ],
      },
    ],
  };

在这里插入图片描述

自定义地图的颜色

可以修改陆地,海洋的颜色

let options = {
    tooltip: {},
    bmap: {
      center: [116.405285, 39.904989],
      roam: true,
      zoom: 18,
      mapStyle: {
        styleJson: [
          {
            featureType: "land",
            elementType: "all",
            stylers: {
              color: "#f3f3f3",
            },
          },
        ],
      },
    },
    series: [
      {
        type: "lines",
        coordinateSystem: "bmap",
        lineStyle: {
          color: "yellow",
          width: 1,
        },
        effect: {
          show: true,
          symbol: "",
        },
        data: [
          {
            coords: [
              [117.000923, 36.675807],
              [114.27261, 24.700624],
            ],
          },
          {
            coords: [
              [115.057317, 24.703343],
              [114.27261, 24.700624],
            ],
          },
        ],
      },
    ],
  };

在这里插入图片描述

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

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

相关文章

Kubernetes集群上的Etcd备份和恢复

在本教程中&#xff0c;您将学习如何在Kubernetes集群上使用etcd快照进行etcd备份和恢复。 在Kubernetes架构中&#xff0c;etcd是集群的重要组成部分。所有集群对象及其状态都存储在etcd中。为了更好地理解Kubernetes&#xff0c;有几点关于etcd的信息是您需要了解的。 它是…

C++学习笔记(19)——模板

目录 模板参数与非类型模板参数 模板参数 类型模板参数——传递类型 非类型模板参数——传递数量 C11希望array替代静态数组&#xff0c;但实际上vector包揽了一切 模板总结 优点&#xff1a; 缺点&#xff1a; 模板特化&#xff1a;针对某些类型进行特殊化处理 特化…

网页出现为了更好的体验,请将手机竖过来

前言 网站:https://act.xinyue.qq.com/commercial/act/af93dc75d9fc541d4833f05e98a9f54b6pre/index.html 发现必须要手机端才可以,否则显示"为了更好的体验,请将手机竖过来"的提示信息 很好奇怎么做的,UA?发现更改UA后依旧显示,后面看代码就知道了 可以看到是通过…

C++STL---string知识汇总

前言 我们现在开始CSTL的学习&#xff0c;从这时开始我们就要锻炼自己查看英文文档的能力&#xff0c;每种数据结构都有上百个接口函数&#xff0c;我们把他们全部记下来是不可能的&#xff0c;所以我们只记最常见的20几个接口&#xff0c;其他的大概熟悉有什么功能&#xff0…

Vulhub——CAS 4.1、AppWeb、apisix

文章目录 一、Apereo CAS 4.1&#xff08;反序列化命令执行漏洞&#xff09;二、CVE-2018-8715&#xff08;AppWeb认证绕过漏洞&#xff09;三、apisix3.1 CVE-2020-13945(默认密钥漏洞&#xff09;3.2 CVE-2021-45232&#xff08;Dashboard API权限绕过导致RCE&#xff09; 一…

基于长短期记忆网络 LSTM 的送餐时间预测

前言 系列专栏:【深度学习&#xff1a;算法项目实战】✨︎ 涉及医疗健康、财经金融、商业零售、食品饮料、运动健身、交通运输、环境科学、社交媒体以及文本和图像处理等诸多领域&#xff0c;讨论了各种复杂的深度神经网络思想&#xff0c;如卷积神经网络、循环神经网络、生成对…

纯电动汽车硬件在环测试

纯电动汽车硬件在环测试技术研究综述 1、新能源汽车概述 随着新能源汽车“电动化、智能化、网联化、共享化”进程的不断推进&#xff0c;新能源汽车的整体性能得到显著提高&#xff0c;纯电动汽车已经逐渐走进大众视野&#xff0c;消费者对于新能源汽车的认可度和购买欲望也稳…

HCIP的学习(22)

BGP优化 [r1-bgp]peer 12.0.0.2 default-route-advertise ---BGP下放缺省路由&#xff0c;无论本地的路由表中是否存在缺省路由&#xff0c;都会向对等体下发一条下一跳为本地的缺省路由&#xff0c;从而减少网络中路由数量&#xff0c;节省对等体的设备资源 BGP协议优先级 缺…

【Linux】Linux的基本指令_2

文章目录 二、基本指令8. man9. nano 和 cat10. cp11. mv12. echo 和 > 和 >> 和 <13. more 和 less14. head 和 tail 和 | 未完待续 二、基本指令 8. man Linux的命令有很多参数&#xff0c;我们不可能全记住&#xff0c;我们可以通过查看联机手册获取帮助。访问…

JavaFX安装与使用

前言 最近学习了javafx,开始时在配置环境和导包时遇到了一些麻烦,关于网上很多方法都尝试过了,现在问题都解决了,和大家分享一下我是怎么实现javafx的配置,希望大家可以通过这个方法实现自己的环境配置! &#x1f648;个人主页: 心.c &#x1f525;文章专题:javafx &#x1f49…

【linux】多线程(2)

文章目录 线程的应用生产消费者模型自制锁生产消费队列成员参数生产函数消费函数 任务处理方式主函数 POSIX信号量sem_wait()sem_post() 线程池应用场景示例 单例模式饿汉实现单例 吃完饭, 立刻洗碗, 这种就是饿汉方式. 因为下一顿吃的时候可以立刻拿着碗就能吃饭.懒汉实现单例…

CAN总线简介

1. CAN总线概述 1.1 CAN定义与历史背景 CAN&#xff0c;全称为Controller Area Network&#xff0c;是一种基于消息广播的串行通信协议。它最初由德国Bosch公司在1983年为汽车行业开发&#xff0c;目的是实现汽车内部电子控制单元&#xff08;ECUs&#xff09;之间的可靠通信。…

类的继承和方法重载

想象一下&#xff0c;有一个相亲想爱的一家人家族树。在这个家族树中&#xff0c;有一个祖先&#xff08;父类&#xff09;&#xff0c;它拥有一些基本的特征和行为&#xff0c;比如家族的传统、姓氏、某些共同的技能或知识。 现在&#xff0c;这个祖先有多个后代&#xff08;…

vue3模板语法以及attribute

模板语法​ Vue 使用一种基于 HTML 的模板语法&#xff0c;使我们能够声明式地将其组件实例的数据绑定到呈现的 DOM 上。所有的 Vue 模板都是语法层面合法的 HTML&#xff0c;可以被符合规范的浏览器和 HTML 解析器解析。 在底层机制中&#xff0c;Vue 会将模板编译成高度优化…

【每日刷题】Day49

【每日刷题】Day49 &#x1f955;个人主页&#xff1a;开敲&#x1f349; &#x1f525;所属专栏&#xff1a;每日刷题&#x1f34d; &#x1f33c;文章目录&#x1f33c; 1. 110. 平衡二叉树 - 力扣&#xff08;LeetCode&#xff09; 2. 501. 二叉搜索树中的众数 - 力扣&…

XSS+CSRF攻击

一、前言 在DVWA靶场的XSS攻击下结合CSRF攻击完成修改密码 也就是在具有XSS漏洞的情况下实施CSRF攻击 二、实验 环境配置与上一篇博客一致&#xff0c;有兴趣可以参考CSRF跨站请求伪造实战-CSDN博客 首先登录DVWA&#xff0c;打开XSS模块 name随便输入&#xff0c;message…

.lib .a .dll库互转

编译 mingw工具&#xff0c;gendef.exe转换dll为a&#xff0c;reimp转换lib为adlltool.exe --dllname python38.dll --def python38.def --output-lib libpython38.adlltool -k -d crypto.lib -l crypto.a 创作不易&#xff0c; 小小的支持一下吧&#xff01;

【数据结构与算法 经典例题】求带环链表的入口

&#x1f493; 博客主页&#xff1a;倔强的石头的CSDN主页 &#x1f4dd;Gitee主页&#xff1a;倔强的石头的gitee主页 ⏩ 文章专栏&#xff1a;数据结构与算法刷题系列&#xff08;C语言&#xff09; 期待您的关注 目录

DragonKnight CTF2024部分wp

DragonKnight CTF2024部分wp 最终成果 又是被带飞的一天&#xff0c;偷偷拷打一下队里的pwn手&#xff0c;只出了一题 这里是我们队的wp web web就出了两个ez题&#xff0c;确实很easy&#xff0c;只是需要一点脑洞(感觉)&#xff0c; ezsgin dirsearch扫一下就发现有ind…

人工智能为犯罪地下世界带来了巨大的生产力提升

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…