vue+echarts+map散点図を描く

23597 ワード

echartsとvueをインストールするには書かないで、echartsが持参したmapに基づいてどのように散点図を描くかを説明すれば、echartsの公式サイトではダウンロードは許可されていませんが、vueにインストールされているechartsプラグインには完全なjsファイルとjsonファイルがあり、node_modules/echarts/mapフォルダには、中国地図、世界地図、各省地図があります
1.まずvueにグローバルに登録するか、必要なページに必要なファイルを導入します.ここではグローバル登録を使用します.
//main.js

import echarts from 'echarts'
import china from 'echarts/map/json/china.json'
Vue.prototype.$echarts = echarts

2.必要な地図に必要な地図を引用する
import 'echarts/map/js/china.js'

3.地図はcanvasと同じように容器が必要です

4.初始化echatrs并添加事件监听

 document.getElementById('myChart').style.height = window.screen.availHeight * 0.9 + 'px'
      this.$nextTick(() => {
        this.drawLine()
      })
      window.addEventListener('resize', () => {
        this.$echarts.init(document.getElementById('myChart')).resize()
      })

5.必要なデータを用意して、私は公式サイトのケースのデータを使っています.
initOptions: {
          renderer: 'canvas'
        },
        pmData: [
          {name: '  ', value: 9},
          {name: '    ', value: 12},
          {name: '  ', value: 12},
          {name: '  ', value: 12},
          {name: '    ', value: 14},
          {name: '  ', value: 15},
          {name: '  ', value: 16},
          {name: '  ', value: 18},
          {name: '  ', value: 18},
          {name: '  ', value: 19},
          {name: '  ', value: 21},
          {name: '  ', value: 21},
          {name: '  ', value: 21},
          {name: '  ', value: 22},
          {name: '  ', value: 23},
          {name: '  ', value: 24},
          {name: '  ', value: 24},
          {name: '  ', value: 25},
          {name: '  ', value: 25},
          {name: '  ', value: 25},
          {name: '   ', value: 25},
          {name: '  ', value: 25},
          {name: '  ', value: 25},
          {name: '  ', value: 26},
          {name: '  ', value: 26},
          {name: '  ', value: 26},
          {name: '  ', value: 27},
          {name: '  ', value: 27},
          {name: '  ', value: 27},
          {name: '  ', value: 28},
          {name: '  ', value: 29},
          {name: '   ', value: 30},
          {name: '  ', value: 30},
          {name: '  ', value: 31},
          {name: '  ', value: 31},
          {name: '   ', value: 31},
          {name: '  ', value: 31},
          {name: '  ', value: 32},
          {name: '  ', value: 32},
          {name: '  ', value: 32},
          {name: '  ', value: 33},
          {name: '  ', value: 33},
          {name: '  ', value: 33},
          {name: '  ', value: 34},
          {name: '  ', value: 34},
          {name: '   ', value: 35},
          {name: '   ', value: 35},
          {name: '  ', value: 36},
          {name: '  ', value: 36},
          {name: '  ', value: 36},
          {name: '  ', value: 36},
          {name: '  ', value: 36},
          {name: '  ', value: 37},
          {name: '  ', value: 37},
          {name: '  ', value: 37},
          {name: '  ', value: 37},
          {name: '  ', value: 37},
          {name: '  ', value: 38},
          {name: '   ', value: 38},
          {name: '  ', value: 38},
          {name: '  ', value: 38},
          {name: '  ', value: 39},
          {name: '  ', value: 39},
          {name: '  ', value: 39},
          {name: '  ', value: 39},
          {name: '  ', value: 40},
          {name: '  ', value: 40},
          {name: '  ', value: 41},
          {name: '  ', value: 41},
          {name: '  ', value: 42},
          {name: '  ', value: 43},
          {name: '  ', value: 43},
          {name: '  ', value: 44},
          {name: '  ', value: 44},
          {name: '  ', value: 44},
          {name: '  ', value: 44},
          {name: '  ', value: 45},
          {name: '  ', value: 45},
          {name: '  ', value: 46},
          {name: '  ', value: 47},
          {name: '  ', value: 47},
          {name: '  ', value: 47},
          {name: '   ', value: 49},
          {name: '  ', value: 50},
          {name: '  ', value: 50},
          {name: '  ', value: 50},
          {name: '  ', value: 51},
          {name: '  ', value: 51},
          {name: '  ', value: 52},
          {name: '  ', value: 52},
          {name: '   ', value: 52},
          {name: '   ', value: 53},
          {name: '  ', value: 54},
          {name: '  ', value: 54},
          {name: '  ', value: 54},
          {name: '  ', value: 54},
          {name: '  ', value: 56},
          {name: '  ', value: 56},
          {name: '  ', value: 57},
          {name: '  ', value: 57},
          {name: '  ', value: 57},
          {name: '  ', value: 58},
          {name: '    ', value: 58},
          {name: '  ', value: 58},
          {name: '  ', value: 58},
          {name: '  ', value: 59},
          {name: '  ', value: 59},
          {name: '   ', value: 59},
          {name: '  ', value: 59},
          {name: '  ', value: 60},
          {name: '  ', value: 61},
          {name: '  ', value: 62},
          {name: '  ', value: 62},
          {name: '   ', value: 63},
          {name: '  ', value: 63},
          {name: '  ', value: 63},
          {name: '  ', value: 64},
          {name: '  ', value: 64},
          {name: '  ', value: 65},
          {name: '  ', value: 66},
          {name: '  ', value: 67},
          {name: '  ', value: 67},
          {name: '  ', value: 70},
          {name: '  ', value: 71},
          {name: '  ', value: 71},
          {name: '  ', value: 71},
          {name: '    ', value: 72},
          {name: '  ', value: 72},
          {name: '   ', value: 72},
          {name: '  ', value: 72},
          {name: '  ', value: 75},
          {name: '  ', value: 75},
          {name: '  ', value: 79},
          {name: '  ', value: 79},
          {name: '  ', value: 80},
          {name: '  ', value: 80},
          {name: '  ', value: 80},
          {name: '    ', value: 84},
          {name: '  ', value: 84},
          {name: '  ', value: 84},
          {name: '  ', value: 85},
          {name: '  ', value: 86},
          {name: '  ', value: 86},
          {name: '   ', value: 86},
          {name: '  ', value: 90},
          {name: '  ', value: 90},
          {name: '  ', value: 92},
          {name: '  ', value: 93},
          {name: '  ', value: 95},
          {name: '  ', value: 96},
          {name: '  ', value: 98},
          {name: '  ', value: 99},
          {name: '  ', value: 99},
          {name: '  ', value: 100},
          {name: '  ', value: 103},
          {name: '  ', value: 104},
          {name: '  ', value: 105},
          {name: '  ', value: 106},
          {name: '  ', value: 112},
          {name: '  ', value: 112},
          {name: '  ', value: 113},
          {name: '   ', value: 114},
          {name: '  ', value: 116},
          {name: '  ', value: 117},
          {name: '  ', value: 119},
          {name: '   ', value: 119},
          {name: '  ', value: 119},
          {name: '  ', value: 120},
          {name: '  ', value: 120},
          {name: '  ', value: 127},
          {name: '  ', value: 130},
          {name: '  ', value: 132},
          {name: '  ', value: 133},
          {name: '  ', value: 134},
          {name: '   ', value: 136},
          {name: '  ', value: 143},
          {name: '   ', value: 147},
          {name: '  ', value: 148},
          {name: '  ', value: 152},
          {name: '  ', value: 153},
          {name: '  ', value: 154},
          {name: '  ', value: 157},
          {name: '  ', value: 169},
          {name: '  ', value: 175},
          {name: '  ', value: 177},
          {name: '  ', value: 193},
          {name: '  ', value: 194},
          {name: '  ', value: 229},
          {name: '  ', value: 273},
          {name: '  ', value: 279}
        ],
        geoCoordMap: {
          '  ': [121.15, 31.89],
          '    ': [109.781327, 39.608266],
          '  ': [120.38, 37.35],
          '  ': [122.207216, 29.985295],
          '    ': [123.97, 47.33],
          '  ': [120.13, 33.38],
          '  ': [118.87, 42.28],
          '  ': [120.33, 36.07],
          '  ': [121.52, 36.89],
          '  ': [102.188043, 38.520089],
          '  ': [118.58, 24.93],
          '  ': [120.53, 36.86],
          '  ': [119.46, 35.42],
          '  ': [119.97, 35.88],
          '  ': [121.05, 32.08],
          '  ': [91.11, 29.97],
          '  ': [112.02, 22.93],
          '  ': [116.1, 24.55],
          '  ': [122.05, 37.2],
          '  ': [121.48, 31.22],
          '   ': [101.718637, 26.582347],
          '  ': [122.1, 37.5],
          '  ': [117.93, 40.97],
          '  ': [118.1, 24.46],
          '  ': [115.375279, 22.786211],
          '  ': [116.63, 23.68],
          '  ': [124.37, 40.13],
          '  ': [121.1, 31.45],
          '  ': [103.79, 25.51],
          '  ': [121.39, 37.52],
          '  ': [119.3, 26.08],
          '   ': [121.979603, 39.627114],
          '  ': [120.45, 36.38],
          '  ': [123.97, 41.97],
          '  ': [102.52, 24.35],
          '   ': [114.87, 40.82],
          '  ': [113.57, 37.85],
          '  ': [119.942327, 37.177017],
          '  ': [120.1, 30.86],
          '  ': [116.69, 23.39],
          '  ': [120.95, 31.39],
          '  ': [121.56, 29.86],
          '  ': [110.359377, 21.270708],
          '  ': [116.35, 23.55],
          '  ': [122.41, 37.16],
          '   ': [119.16, 34.59],
          '   ': [120.836932, 40.711052],
          '  ': [120.74, 31.64],
          '  ': [113.75, 23.04],
          '  ': [114.68, 23.73],
          '  ': [119.15, 33.5],
          '  ': [119.9, 32.49],
          '  ': [108.33, 22.84],
          '  ': [122.18, 40.65],
          '  ': [114.4, 23.09],
          '  ': [120.26, 31.91],
          '  ': [120.75, 37.8],
          '  ': [113.62, 24.84],
          '   ': [98.289152, 39.77313],
          '  ': [113.23, 23.16],
          '  ': [109.47, 36.6],
          '  ': [112.53, 37.87],
          '  ': [113.01, 23.7],
          '  ': [113.38, 22.52],
          '  ': [102.73, 25.04],
          '  ': [118.73, 36.86],
          '  ': [122.070714, 41.119997],
          '  ': [113.08, 36.18],
          '  ': [114.07, 22.62],
          '  ': [113.52, 22.3],
          '  ': [118.3, 33.96],
          '  ': [108.72, 34.36],
          '  ': [109.11, 35.09],
          '  ': [119.97, 36.77],
          '  ': [113.11, 23.05],
          '  ': [110.35, 20.02],
          '  ': [113.06, 22.61],
          '  ': [117.53, 36.72],
          '  ': [112.44, 23.05],
          '  ': [121.62, 38.92],
          '  ': [111.5, 36.08],
          '  ': [120.63, 31.16],
          '   ': [106.39, 39.04],
          '  ': [123.38, 41.8],
          '  ': [120.62, 31.32],
          '  ': [110.88, 21.68],
          '  ': [120.76, 30.77],
          '  ': [125.35, 43.88],
          '  ': [120.03336, 36.264622],
          '  ': [106.27, 38.47],
          '   ': [120.555821, 31.875428],
          '   ': [111.19, 34.76],
          '  ': [121.15, 41.13],
          '  ': [115.89, 28.68],
          '  ': [109.4, 24.33],
          '  ': [109.511909, 18.252847],
          '  ': [104.778442, 29.33903],
          '  ': [126.57, 43.87],
          '  ': [111.95, 21.85],
          '  ': [105.39, 28.91],
          '  ': [101.74, 36.56],
          '  ': [104.56, 29.77],
          '    ': [111.65, 40.82],
          '  ': [104.06, 30.67],
          '  ': [113.3, 40.12],
          '  ': [119.44, 32.2],
          '  ': [110.28, 25.29],
          '   ': [110.479191, 29.117096],
          '  ': [119.82, 31.36],
          '  ': [109.12, 21.49],
          '  ': [108.95, 34.27],
          '  ': [119.56, 31.74],
          '  ': [118.49, 37.46],
          '   ': [129.58, 44.6],
          '  ': [106.9, 27.7],
          '  ': [120.58, 30.01],
          '  ': [119.42, 32.39],
          '  ': [119.95, 31.79],
          '  ': [119.1, 36.62],
          '  ': [106.54, 29.59],
          '  ': [121.420757, 28.656386],
          '  ': [118.78, 32.04],
          '  ': [118.03, 37.36],
          '  ': [106.71, 26.57],
          '  ': [120.29, 31.59],
          '  ': [123.73, 41.3],
          '    ': [84.77, 45.59],
          '  ': [109.5, 34.52],
          '   ': [118.48, 31.56],
          '  ': [107.15, 34.38],
          '  ': [113.21, 35.24],
          '  ': [119.16, 31.95],
          '  ': [116.46, 39.92],
          '  ': [117.2, 34.26],
          '  ': [115.72, 37.72],
          '  ': [110, 40.58],
          '  ': [104.73, 31.48],
          '    ': [87.68, 43.77],
          '  ': [117.57, 34.86],
          '  ': [120.19, 30.26],
          '  ': [118.05, 36.78],
          '  ': [122.85, 41.12],
          '  ': [119.48, 31.43],
          '   ': [86.06, 41.68],
          '  ': [114.35, 36.1],
          '  ': [114.35, 34.79],
          '  ': [117, 36.65],
          '  ': [104.37, 31.13],
          '  ': [120.65, 28.01],
          '  ': [115.97, 29.71],
          '  ': [114.47, 36.6],
          '  ': [119.72, 30.23],
          '  ': [103.73, 36.03],
          '  ': [116.83, 38.33],
          '  ': [118.35, 35.05],
          '  ': [106.110698, 30.837793],
          '  ': [117.2, 39.13],
          '  ': [119.95, 30.07],
          '  ': [117.13, 36.18],
          '  ': [120.23, 29.71],
          '  ': [113.65, 34.76],
          '   ': [126.63, 45.75],
          '  ': [115.97, 36.45],
          '  ': [118.38, 31.33],
          '  ': [118.02, 39.63],
          '   ': [113.29, 33.75],
          '  ': [114.48, 37.05],
          '  ': [116.29, 37.45],
          '  ': [116.59, 35.38],
          '  ': [112.239741, 30.335165],
          '  ': [111.3, 30.7],
          '  ': [120.06, 29.32],
          '  ': [119.92, 28.45],
          '  ': [112.44, 34.7],
          '   ': [119.57, 39.95],
          '  ': [113.16, 27.83],
          '   ': [114.48, 38.03],
          '  ': [117.67, 36.19],
          '  ': [111.69, 29.05],
          '  ': [115.48, 38.85],
          '  ': [112.91, 27.87],
          '  ': [119.64, 29.12],
          '  ': [113.09, 29.37],
          '  ': [113, 28.21],
          '  ': [118.88, 28.97],
          '  ': [116.7, 39.53],
          '  ': [115.480656, 35.23375],
          '  ': [117.27, 31.86],
          '  ': [114.31, 30.52],
          '  ': [125.03, 46.58]
        }

6.描画開始
 convertData(data) {
        let res = []
        for (let i = 0; i < data.length; i++) {
          let geoCoord = this.geoCoordMap[data[i].name];
          if (geoCoord) {
            res.push({
              name: data[i].name,
              value: geoCoord.concat(data[i].value)
            })
          }
        }
        return res
      },
      renderItem(params, api) {
        let coords = [
          [116.7, 39.53],
          [103.73, 36.03],
          [112.91, 27.87],
          [120.65, 28.01],
          [119.57, 39.95]
        ]
        let points = []
        for (let i = 0; i < coords.length; i++) {
          points.push(api.coords[i])
        }
        let color = api.visual('color')
        return {
          type: 'polygon',
          shape: {
            points: this.$echarts.graphic.clipPointsByRect(points, {
              x: params.coordSys.x,
              y: params.coordSys.y,
              width: params.coordSys.width,
              height: params.coordSys.height
            })
          },
          style: api.style({
            fill: color,
            stroke: this.$echarts.color.lift(color)
          })
        }

      },
      drawLine() {
        let myChartContainer = document.getElementById('myChart');
        let resizeMyChartContainer = function () {
          myChartContainer.style.width = document.body.offsetWidth + 'px'
          myChartContainer.style.height = document.body.offsetHeight + 'px'
        }
        resizeMyChartContainer();
        //       dom,   echarts  
        let myChart = this.$echarts.init(myChartContainer)
        let optionMap = {
          title: {
            text: '          ',
            subtext: 'data from PM25.in',
            sublink: 'http://www.pm25.in',
            left: 'center',
            textStyle: {
              color: '#fff'
            }
          },
          tooltip: {
            trigger: 'item'
          },
          legend: {
            orient: 'vertical',
            left: 'left',
            data: ['']
          },
          //      
          /*  visualMap: {
              min: 0,
              max: 1500,
              left: '10%',
              top: 'bottom',
              text: [' ', ' '],
              calculable: true,
              color: ['#0b50b9', '#c3e2f4']
            },*/
          geo: {
            // type: 'map',
            map: 'china',
            label: {
              emphasis: {
                show: false
              }
            },
            roam: true,
            move: true,
            center: [117.00, 36.40],
            zoom: 5,
            itemStyle: {
              normal: {
                borderColor: '#019fd4', //       
                areaColor: 'rgba(0,72,129,0.8)' //         
              },
              emphasis: {
                shadowOffsetX: 0,
                shadowOffsetY: 0,
                shadowBlur: 20,
                borderWidth: 0,
                shadowColor: 'rgba(0, 0, 0, 0.5)',
                areaColor: '#004881' //            
              }
            },
            showLegendSymbol: true
          },
          selectedMode: 'single',
          series: [

            {
              name: 'PM2.5',
              type: 'scatter',
              coordinateSystem: 'geo',
              data: this.convertData(this.pmData),
              symbolSize: function (val) {
                return val[2] / 10;
              },
              label: {
                normal: {
                  formatter: '{b}',
                  position: 'right',
                  show: false
                },
                emphasis: {
                  show: true
                }
              },
              tooltip: {
                trigger: 'item',
                formatter: function (params) {
                  return "

" + params.seriesName + '

' + "

" + params.name + ' : ' + params.value[2] + "

" } }, itemStyle: { normal: { color: '#ddb926' } } }, { name: 'Top 5', type: 'effectScatter', coordinateSystem: 'geo', // data: this.convertData(this.pmData.sort((a, b) => b.value - a.value).slice(0, 6)), // PM2.5 symbolSize: function (val) { return val[2] / 10 }, // showEffectOn: 'emphasis', rippleEffect: { brushType: 'stroke' }, hoverAnimation: true, label: { normal: { formatter: '{b}', // b name position: "right", show: true } }, tooltip: { trigger: 'item', formatter: function (params) { return "

" + params.seriesName + '

' + "

" + "" + params.name + ' : ' + params.value[2] + "

" } }, itemStyle: { normal: { color: '#f4e925', shadowBlur: 10, shadowColor: '#333' } }, zlevel: 1 } ] } myChart.setOption(optionMap) }