echarts 使用地图,设置背景图片和高亮图片,点击实现高亮显示,更换散点图图片,高亮散点图形,3D悬浮效果展示地图,集成Vue组件

这篇具有很好参考价值的文章主要介绍了echarts 使用地图,设置背景图片和高亮图片,点击实现高亮显示,更换散点图图片,高亮散点图形,3D悬浮效果展示地图,集成Vue组件。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

先看下   需要实现的效果:

echarts地图背景炫酷,echarts,vue.js,前端

第一步 需准备需要的插件

 1  注意新版 echarts 的引入方式为:  import * as echarts from 'echarts',这里我把 echarts 直接挂载到了Vue上,本项目使用echarts比较多,这样的话很方便,也可以在需要echarts的模块按需引入

       在main.js中添加以下代码:

import * as echarts from 'echarts'
Vue.prototype.$echarts = echarts;

2 引入地图数据  ,我这里是下载到本地引用的

import China from '@assets/js/100000';

第二步 需要用到的 知识点 知识点

  1 想要实现3D效果,可以通过设置阴影和边框来搞定,但是发现echarts 给地图设置边框后,会导致所有省的边框都会改变,这不是我们想要的效果,另辟蹊径 ,其实就是把多个地图实例重叠错位显示,实现悬浮3D效果。

2  echarts  image属性 支持 纹理图片,支持base64位图片

代码设置itemStyle:

itemStyle: {

              color: {

                image: piePatternImg,

                repeat: 'repeat'

              },

              areaColor: {

                image: piePatternImg,

                repeat: 'repeat'

              },

              borderColor: '#bddee6',

              borderWidth: 1,

            },

设置选中高亮样式

select: {

              label: {

                show: false,

                color: '#fff'

              },

              itemStyle: {

                areaColor: {

                  image: patternImg,

                  repeat: 'repeat'

                }

              }

            },

设置高亮样式

emphasis: {

              label: {

                show: false,

                color: '#fff'

              },

              itemStyle: {

                areaColor: {

                  image: patternImg,

                  repeat: 'repeat'

                }

              }

            }

单独设置样式:

regions: [

            {

              name: "南海诸岛",

              value: 0,

              itemStyle: {

                normal: {

                  opacity: 0,

                  label: {

                    show: false

                  }

                }

              }

            }

          ],

绑定点击事件 ,选中高亮散点图和底图

myChart.on('click', e => {
        if (!e.data) {
          this.scatterData.map(item => {
            if (item.symbolSize == 30) {
              item.selected = true;
            }
          })
          myChart.setOption(this.option, true);
          return
        }
        // this.$emit('handle-map', this.scatterData[e.dataIndex]);
        this.scatterData.map(item => {
          item.symbol = item.name == e.name ? scatterHImg : scatterImg
          item.label = item.name == e.name ? { backgroundColor: { image: scatterHBg } } : { backgroundColor: { image: scatterBg } };
          item.symbolSize = item.name == e.name ? 30 : 20
          item.selected = item.name == e.name ? true : false;
        })
        myChart.setOption(this.option, true);
      });

下面是代码部分,封装了一个Vue组件,包括给散点图添加点击事件,高亮图标,悬浮显示。文章来源地址https://www.toymoban.com/news/detail-685784.html


<template>
  <div class="container">
    <div class="xx-map" id="baseMap"></div>
  </div>
</template>

<script>
import China from '@assets/js/100000';
var piePatternSrc = ''
var piePatternImg = new Image();
piePatternImg.src = piePatternSrc;
var patternSrc = ''
var patternImg = new Image();
patternImg.src = patternSrc;
var scatterImg = 'image://'
var scatterHImg = 'image://'
var scatterBg = ''
var scatterHBg = ''

export default {
  name: 'xx-map',
  components: {},
  props: {
    mapData: {
      type: Array,
      default: []
    }
  },
  data() {
    return {
      map: China, // 加载地图
      chinaData: [
        { name: "北京", value: [116.405289, 39.904987] },
        { name: "天津", value: [117.190186, 39.125595] },
        { name: "河北", value: [114.502464, 38.045475] },
        { name: "黑龙江", value: [126.642464, 45.756966] },
        { name: "吉林", value: [125.324501, 43.886841] },
        { name: "辽宁", value: [123.429092, 41.796768], },
        { name: "内蒙古", value: [111.75199, 40.84149] },
        { name: "山西", value: [112.549248, 37.857014] },
        { name: "山东", value: [117.000923, 36.675808] },
        { name: "河南", value: [113.665413, 34.757977] },
        { name: "陕西", value: [108.948021, 34.263161] },
        { name: "湖北", value: [114.298569, 30.584354] },
        { name: "江苏", value: [118.76741, 32.041546] },
        { name: "安徽", value: [117.283043, 31.861191] },
        { name: "上海", value: [121.472641, 31.231707] },
        { name: "湖南", value: [112.982277, 28.19409] },
        { name: "江西", value: [115.892151, 28.676493] },
        { name: "浙江", value: [120.15358, 30.287458] },
        { name: "福建", value: [119.306236, 26.075302] },
        { name: "广东", value: [113.28064, 23.125177] },
        { name: "台湾", value: [121.520076, 25.030724] },
        { name: "海南", value: [110.19989, 20.04422] },
        { name: "广西", value: [108.320007, 22.82402] },
        { name: "重庆", value: [106.504959, 29.533155] },
        { name: "云南", value: [102.71225, 25.040609] },
        { name: "贵州", value: [106.713478, 26.578342] },
        { name: "四川", value: [104.065735, 30.659462] },
        { name: "宁夏", value: [106.23248, 38.48644] },
        { name: "甘肃", value: [103.83417, 36.06138] },
        { name: "青海", value: [101.77782, 36.61729] },
        { name: "西藏", value: [91.1145, 29.64415] },
        { name: "新疆", value: [87.61688, 43.82663] },
        { name: "香港", value: [114.16546, 22.27534] },
        { name: "澳门", value: [113.54913, 22.19875] },
      ],
      scatterData: [],
      option: {
        // backgroundColor: '#001f4833',
        tooltip: {
          show: true,
          trigger: 'item',
          textStyle: {
            fontSize: 14
          },
          formatter: function (params) {
            console.log(params)
            if (params.componentSubType === 'scatter') {
              return `项目总数:${params.data.count}`
            }
          },
        },
        animation: false,
        geo: {
          show: true,
          map: 'china', // 要与 `registerMap()` 的第一个参数对应, 'china' 会显示南海诸岛
          roam: false, // 鼠标缩放+平移
          aspectScale: 0.9,
          zoom: 1.16,
          selectedMode: 'single', // 选中
          // label: {
          //   show: false,
          //   fontSize: 22,
          //   color: '#fff',
          //   position: 'inside' // 注: 将地图 JSON 文件的 cp 坐标删掉才有效
          // },

          silent: true,
          center: [105.194115019531, 36.582111640625],
          regions: [
            {
              name: "南海诸岛",
              value: 0,
              itemStyle: {
                normal: {
                  opacity: 0,
                  label: {
                    show: false
                  }
                }
              }
            }
          ],
          itemStyle: {
            color: '#9bdbdc',
            areaColor: '#9bdbdc',
            // areaColor: {
            //   type: 'radial', // 径向渐变
            //   x: 0.5,
            //   y: 0.5,
            //   r: 0.8,
            //   colorStops: [
            //     // 0% 处的颜色
            //     {
            //       offset: 0,
            //       color: 'rgba(147, 235, 248, 0)'
            //     },
            //     // 100% 处的颜色
            //     {
            //       offset: 1,
            //       color: 'rgba(147, 235, 248, .2)'
            //     }
            //   ]
            // },
            // borderColor: 'rgba(147, 235, 248, 1)',
            borderColor: '#71cdcb',
            borderWidth: 7,
            shadowColor: '#b6e7e5',
            shadowBlur: 5,
            shadowOffsetX: 5,
            shadowOffsetY: 5,
          },
        },
        series: [
          {
            type: 'map',
            map: 'china',
            roam: false, // 鼠标缩放+平移
            aspectScale: 0.9,
            zoom: 1.16,
            center: [105.194115019531, 35.582111640625], // 设置地图中心
            data: this.scatterData,
            // geoIndex: 0, // 共享 geo 样式
            itemStyle: {
              color: {
                image: piePatternImg,
                repeat: 'repeat'
              },
              areaColor: {
                image: piePatternImg,
                repeat: 'repeat'
              },
              borderColor: '#bddee6',
              borderWidth: 1,
            },
            select: {
              label: {
                show: false,
                color: '#fff'
              },
              itemStyle: {
                areaColor: {
                  image: patternImg,
                  repeat: 'repeat'
                }
              }
            },
            emphasis: {
              label: {
                show: false,
                color: '#fff'
              },
              itemStyle: {
                areaColor: {
                  image: patternImg,
                  repeat: 'repeat'
                }
              }
            }
          },
          {
            type: 'scatter',
            coordinateSystem: 'geo',
            data: this.scatterData,
            symbol: function (params) {
              return scatterImg
              if (params[2] === '0') {
                return 'pin'
              } else {
                return 'diamond'
              }
            },
            symbolSize: 20,
            symbolOffset: [0, '-100%'],
            label: {
              show: true,
              formatter: '{b}',
              fontSize: 12,
              fontWeight: 'bold',
              position: 'top',
              backgroundColor: {
                image: scatterBg
              },
              align: 'center',
              padding: [8, 15],
              color: "#fff",

            },

            itemStyle: {
              color: '#1dfd28'
            }
          },
        ]
      }
    };
  },
  computed: {},
  watch: {
    mapData: {
      handler(newName, oldName) {
        this.initMap();
      },
      deep: true
    }
  },
  created() { },
  mounted() {

    this.initMap();
  },
  methods: {
    // 销毁图表实例, 防止内存泄漏
    destroyChart() {
      let chart = this.$echarts.getInstanceByDom(document.getElementById('baseMap'));

      if (chart) {
        chart.clear(); // 释放图形资源
        chart.dispose(); // 销毁实例对象
      }
    },

    // 图表初始化
    initMap() {
      this.scatterData = [];
      this.mapData.map((item) => {
        this.chinaData.map((city) => {
          if (item.area == city.name) {
            let obj = { ...item, ...city }
            this.scatterData.push(obj)
          }
        })
      })
      if (this.scatterData.length) {
        this.scatterData[0].selected = true;
        this.scatterData[0].symbol = scatterHImg;
        this.scatterData[0].label = {
          backgroundColor: {
            image: scatterHBg
          }
        }
        this.scatterData[0].symbolSize = 30;
      }
      // console.log(this.scatterData)
      // this.$emit('handle-map', this.scatterData[0]);
      this.destroyChart();

      let myChart = this.$echarts.init(document.getElementById('baseMap'));

      // 注册地图
      this.$echarts.registerMap(this.option.geo.map, this.map);

      // 事件解绑
      myChart.off('click');

      this.$set(this.option.series[1], 'data', this.scatterData);
      this.$set(this.option.series[0], 'data', this.scatterData);
      myChart.setOption(this.option, true);

      // 点击事件
      myChart.on('click', e => {
        if (!e.data) {
          this.scatterData.map(item => {
            if (item.symbolSize == 30) {
              item.selected = true;
            }
          })
          myChart.setOption(this.option, true);
          return
        }
        // this.$emit('handle-map', this.scatterData[e.dataIndex]);
        this.scatterData.map(item => {
          item.symbol = item.name == e.name ? scatterHImg : scatterImg
          item.label = item.name == e.name ? { backgroundColor: { image: scatterHBg } } : { backgroundColor: { image: scatterBg } };
          item.symbolSize = item.name == e.name ? 30 : 20
          item.selected = item.name == e.name ? true : false;
        })
        myChart.setOption(this.option, true);
      });
      window.addEventListener("resize", () => {
        myChart.resize();
      });
    },
  }
};
</script>

<style scoped lang="less">
.container {
  position: relative;
  width: 100%;
  height: 100%;

  .xx-map {
    width: 100%;
    height: 100%;
  }
}
</style>

到了这里,关于echarts 使用地图,设置背景图片和高亮图片,点击实现高亮显示,更换散点图图片,高亮散点图形,3D悬浮效果展示地图,集成Vue组件的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • vue设置页面背景及背景图片

    本地静态图片  cdn图片 设置背景色 实战-PC web登录页 实战-小程序登录页

    2024年02月12日
    浏览(54)
  • flutter背景图片设置

    1、在配置文件pubspec.yaml中,设置以下代码 2、如果目录中没有assets文件夹,则创建一个文件夹,并且取名为assets,在此文件夹中存放图片资源即可,如果想分文件夹管理,在assets目录下创建文件夹,并且在配置文件pubspec.yaml中加入路径即可 3、图片的使用、在界面文件中,有

    2024年02月04日
    浏览(45)
  • CSS 设置背景图片

    一、基本设置 使用 CSS 可以通过以下属性设置背景图片: background-image : 设置背景图片的 URL。 background-size : 设置背景图片的大小。可以设置为绝对像素值,也可以设置为百分比或 \\\"cover\\\"(填充整个容器)或 \\\"contain\\\"(完整显示图片)。 background-repeat : 设置背景图片是否重复。可

    2024年02月12日
    浏览(46)
  • Eclipse背景图片的设置

    我在网上也查找了很多教程,发现有些小伙伴按照如下路径并不能找到images文件夹:、eclipsepluginsorg.eclipse.ui.themes_1.2.1800.v20220316-1102,以及不知如何设置透明度 下面我用最简单的方式教大家解决这些问题。 首先打开eclipse文件夹按照该路径找到images:(ecil是我自己创建的ecl

    2024年02月05日
    浏览(85)
  • VSCode 如何设置背景图片

     VSCode 设置背景图片 1.打开应用商店,搜索 background ,选择第一个,点击安装。 2. 安装完成后点击设置,点击扩展设置。 3.点击在 settings.json 中编辑。    4.将原代码注释后,加入以下代码。   5. 保存后重启 VSCode 就能看到设置的背景图片啦。 6.最后再点击设置,点击颜色主

    2024年02月06日
    浏览(55)
  • 小程序背景图片设置方法

    3、利用image标签做到设置背景图片 思路:我们只要利用css中的z-index改变层级既可做到变成背景图的样子 看代码 wxml: wxss: 这样我们也可以做到背景图的效果。 相关推荐:小程序开发教程 以上就是小程序背景图片设置方法的详细内容,更多请关注群英网络其它相关文章!

    2024年02月07日
    浏览(55)
  • 微信小程序 背景图片设置

            微信小程序设置背景图片时,有两种方法:         第一:直接在.wxss中中使用 “background-image:url()” 设置背景图片,但是这种加载背景图片的方法存在一个问题,就是所加载的图片只能是 网络图片 或 base64 图片,是不可以加载本地图片的。 但是使用base64图片

    2024年02月11日
    浏览(63)
  • QT设置widget背景图片

    首先说方法,在给widget或者frame或者其他任何类型的控件添加背景图时,在样式表中加入如下代码,指定某个控件,设置其背景。 如果单纯改变样式表,没有指定控件的话,内部的其他控件背景也会改变。 特别提醒:类名 # 控件名,其中控件名要准确,假如你把widget的名字改

    2024年02月11日
    浏览(46)
  • CSS-设置背景图片的大小

    要设置背景图片的大小,您可以使用CSS的 background-size 属性。这个属性允许您指定背景图片的尺寸。 background-size 属性可以接受不同的值,包括: auto :保持原始图片的尺寸。 cover :将图片缩放到完全覆盖背景区域,可能会裁剪部分图片。 contain :将图片缩放到完全适应背景

    2024年01月25日
    浏览(45)
  • Uniapp设置页面的背景图片

    设置背景有两种 注意一个是全背景设置,一个是在相应的view内设置背景 这是设置大背景 这是在相应的view内设置view块的背景

    2024年02月08日
    浏览(38)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包