欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Echarts自定義地圖和添加圖標代碼示例

 更新時間:2023年09月27日 11:04:18   作者:白豆腐大大  
這篇文章主要給大家介紹了關(guān)于Echarts自定義地圖和添加圖標的相關(guān)資料,項目中經(jīng)常會遇到需要渲染echarts地圖的情況,文中通過代碼示例介紹的非常詳細,需要的朋友可以參考下

介紹:

由于我司在項目中使用到了Echarts,所以我開了Echarts的相關(guān)欄目來分享在使用上的經(jīng)驗。這是本欄目的第一篇文章,需要Echarts相關(guān)基礎(chǔ),之后會介紹Echarts的基礎(chǔ),需要的朋友可以關(guān)注一下。廢話不多說,先看看例子:

以泉州為例

先到阿里云的地理小工具獲取對應(yīng)的地圖json數(shù)據(jù)并保存到本地,通過registerMap方法加載。地理小工具

主要代碼:

<template>
  <!-- 中心地圖 -->
  <div ref="gemEchart" style="width: 100%; height: 100%" />
</template>
<script>
import * as echarts from 'echarts'
import quanZhouJSON from '@/utils/quanzhou.json' // 地圖json
import * as echartsOption from '../echartsOption'
export default {
  data: () => ({
    myEcharts: null,
    myData: []
  }),
  mounted() {
    this.init()
    // 適應(yīng)屏幕大小
    window.addEventListener('resize', () => {
      if (this.myEcharts && this.myEcharts.resize) {
        this.myEcharts.resize()
      }
    })
    // 獲取數(shù)據(jù)
    this.getData()
  },
  methods: {
    init() {
      this.myEcharts = echarts.init(this.$refs['gemEchart'])
      echarts.registerMap('泉州', quanZhouJSON)
      const option = {
        geo: {
          map: '泉州',
          label: {
            show: true,
            // 自定義label
            formatter: (params) => {
              const find = this.myData.find(
                (item) => item.name === params.name
              )
              if (find) {
                return `{name|${find.name}}\n{data|${find.value * 100}%}`
              } else {
                return `{name|${params.name}}`
              }
            },
            // 富文本
            rich: {
              name: {
                height: 24,
                color: 'white',
                padding: [-80, 0, 0, 0],
                fontSize: 18
              },
              data: {
                height: 24,
                color: 'white',
                padding: [-40, 0, 0, 0],
                fontSize: 18
              }
            }
          },
          // 地圖區(qū)域的樣式設(shè)置
          itemStyle: {
            areaColor: 'gray' // 區(qū)域顏色
          },
          top: 10,
          bottom: 10,
          left: 20,
          right: 20
        },
        series: [
          {
            type: 'map',
            map: '泉州',
            // 默認情況下,map series 會自己生成內(nèi)部專用的 geo 組件。用 geoIndex 指定一個 geo 組件,
            // 這樣的話,map 和 其他 series(例如散點圖)就可以共享一個 geo 組件了。
            // 當(dāng)設(shè)定了 geoIndex 后,series-map.map 屬性,以及 series-map.itemStyle 等樣式配置不再起作用,
            // 而是采用 geo 中的相應(yīng)屬性。
            geoIndex: 0,
            data: []
          },
          // 用于地圖中的圖標
          {
            type: 'scatter',
            coordinateSystem: 'geo',
            data: echartsOption.icon,
            symbol: echartsOption.img,
            symbolSize: [50, 50],
            symbolOffset: [0, 8]
          }
        ],
        visualMap: {
          // 設(shè)置地圖范圍值顯示的顏色
          selectedMode: false, // 不能選擇
          hoverLink: false, // 取消鼠標移入效果
          textStyle: {
            color: '#fff'
          },
          align: 'left',
          itemGap: 20,
          pieces: [
            {
              gt: 0.9,
              lte: 1,
              label: '可靠性較高(90-100)',
              color: '#7FB6FF'
            },
            {
              gte: 0.8,
              lte: 0.9,
              label: '可靠性中等(80-90)',
              color: '#5993FF'
            },
            {
              lt: 0.8,
              label: '可靠性較差(80以下)',
              color: '#2458F1'
            }
          ],
          right: 20,
          bottom: 20
        }
      }
      this.myEcharts.setOption(option)
    },
    getData() {
      this.myData = quanZhouJSON.features.map((item) => {
        const {
          name
        } = item.properties
        return {
          name,
          value: (Math.random()).toFixed(2) // 等數(shù)據(jù)接入
        }
      })
      this.myEcharts.setOption({
        series: [
          {
            type: 'map',
            data: this.myData
          }
        ]
      })
    }
  }
}
</script>

echartsOption:地圖的相關(guān)配置

// 中間地圖的一些配置
import quanZhouJSON from '@/utils/quanzhou.json'
// 獲取圖標的數(shù)據(jù)
export const icon = quanZhouJSON.features.map((item) => {
  const {
    name,
    centroid
  } = item.properties
  return {
    name,
    value: centroid
  }
})
// 圖標 base64
export const img = `image://`

總結(jié) 

到此這篇關(guān)于Echarts自定義地圖和添加圖標的文章就介紹到這了,更多相關(guān)Echarts自定義地圖添加圖標內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 使用Echart實現(xiàn)繪制立體的柱狀圖

    使用Echart實現(xiàn)繪制立體的柱狀圖

    EChart開源來自百度商業(yè)前端數(shù)據(jù)可視化團隊,基于html5?Canvas,是一個純Javascript圖表庫,提供直觀,生動,可交互,可個性化定制的數(shù)據(jù)可視化圖表。本文將利用EChart繪制立體的柱狀圖,感興趣的可以學(xué)習(xí)一下
    2022-03-03
  • JS運動改變單物體透明度的方法分析

    JS運動改變單物體透明度的方法分析

    這篇文章主要介紹了JS運動改變單物體透明度的方法,結(jié)合實例形式分析了頁面元素屬性動態(tài)修改相關(guān)操作技巧,需要的朋友可以參考下
    2018-01-01
  • js實現(xiàn)分割上傳大文件

    js實現(xiàn)分割上傳大文件

    這篇文章主要為大家詳細介紹了js實現(xiàn)分割上傳大文件的相關(guān)資料,需要的朋友可以參考下
    2016-03-03
  • JS實現(xiàn)圓形進度條拖拽滑動

    JS實現(xiàn)圓形進度條拖拽滑動

    這篇文章主要為大家詳細介紹了JS實現(xiàn)圓形進度條拖拽滑動,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • JavaScript中自定義swiper組件詳解

    JavaScript中自定義swiper組件詳解

    這篇文章主要介紹了微信小程序 swiper組件輪播圖詳解及實例的相關(guān)資料,需要的朋友可以參考下,希望能給你帶來幫助
    2021-08-08
  • 解決在layer.open中使用時間控件laydate失敗的問題

    解決在layer.open中使用時間控件laydate失敗的問題

    今天小編就為大家分享一篇解決在layer.open中使用時間控件laydate失敗的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • js捕捉鍵盤事件和按鍵鍵值的方法

    js捕捉鍵盤事件和按鍵鍵值的方法

    下面小編就為大家?guī)硪黄猨s捕捉鍵盤事件和按鍵鍵值的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • js數(shù)組相減簡單示例【刪除a數(shù)組所有與b數(shù)組相同元素】

    js數(shù)組相減簡單示例【刪除a數(shù)組所有與b數(shù)組相同元素】

    這篇文章主要介紹了js數(shù)組相減,結(jié)合簡單示例形式分析了JavaScript刪除a數(shù)組所有與b數(shù)組相同元素相關(guān)個遍歷、判斷、刪除等相關(guān)操作技巧,需要的朋友可以參考下
    2020-03-03
  • JavaScript實現(xiàn)簡易tab欄切換內(nèi)容欄

    JavaScript實現(xiàn)簡易tab欄切換內(nèi)容欄

    這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)簡易tab欄切換內(nèi)容欄,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • JavaScript中數(shù)據(jù)結(jié)構(gòu)與算法(四):串(BF)

    JavaScript中數(shù)據(jù)結(jié)構(gòu)與算法(四):串(BF)

    這篇文章主要介紹了JavaScript中數(shù)據(jù)結(jié)構(gòu)與算法(四):串(BF),串是由零個或多個字符組成的有限序列,又叫做字符串,本文著重講解了BF(Brute Force)算法,需要的朋友可以參考下
    2015-06-06

最新評論