vue+echarts+map散点図を描く
23597 ワード
echartsとvueをインストールするには書かないで、echartsが持参したmapに基づいてどのように散点図を描くかを説明すれば、echartsの公式サイトではダウンロードは許可されていませんが、vueにインストールされているechartsプラグインには完全なjsファイルとjsonファイルがあり、node_modules/echarts/mapフォルダには、中国地図、世界地図、各省地図があります
1.まずvueにグローバルに登録するか、必要なページに必要なファイルを導入します.ここではグローバル登録を使用します.
2.必要な地図に必要な地図を引用する
3.地図はcanvasと同じように容器が必要です
5.必要なデータを用意して、私は公式サイトのケースのデータを使っています.
6.描画開始
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)
}