在数据可视化领域,ECharts 是一个功能强大且易于使用的 JavaScript 库,它可以帮助开发者轻松创建各种图表,包括地图图表。对于新手来说,掌握 ECharts 地图图表的制作是一项非常有用的技能。本文将为你提供20个实用案例,帮助你快速上手 ECharts 地图图表的制作。
案例一:中国地图基本展示
首先,让我们从最简单的中国地图基本展示开始。在这个案例中,我们将使用 ECharts 的地图插件来展示中国地图。
// 引入 ECharts 主模块
var echarts = require('echarts/lib/echarts');
// 引入中国地图数据
require('echarts/map/js/china');
// 基于准备好的dom,初始化echarts实例
var myChart = echarts.init(document.getElementById('main'));
// 指定图表的配置项和数据
var option = {
title: {
text: '中国地图基本展示'
},
tooltip: {
trigger: 'item'
},
series: [{
name: '中国',
type: 'map',
mapType: 'china',
label: {
show: true
},
data: [{
name: '北京',
value: Math.round(Math.random() * 1000)
}, {
name: '上海',
value: Math.round(Math.random() * 1000)
}, {
name: '广东',
value: Math.round(Math.random() * 1000)
}]
}]
};
// 使用刚指定的配置项和数据显示图表。
myChart.setOption(option);
案例二:世界地图展示
接下来,我们将展示如何使用 ECharts 创建世界地图。
// 引入 ECharts 主模块
var echarts = require('echarts/lib/echarts');
// 引入世界地图数据
require('echarts/map/js/world');
// 基于准备好的dom,初始化echarts实例
var myChart = echarts.init(document.getElementById('main'));
// 指定图表的配置项和数据
var option = {
title: {
text: '世界地图展示'
},
tooltip: {
trigger: 'item',
formatter: '{b}: {c}'
},
series: [{
name: '世界',
type: 'map',
mapType: 'world',
label: {
show: true
},
data: [{
name: 'China',
value: Math.round(Math.random() * 1000)
}, {
name: 'United States',
value: Math.round(Math.random() * 1000)
}]
}]
};
// 使用刚指定的配置项和数据显示图表。
myChart.setOption(option);
案例三:省份地图点击事件
在这个案例中,我们将展示如何为省份地图添加点击事件。
// 引入 ECharts 主模块
var echarts = require('echarts/lib/echarts');
// 引入中国地图数据
require('echarts/map/js/china');
// 基于准备好的dom,初始化echarts实例
var myChart = echarts.init(document.getElementById('main'));
// 指定图表的配置项和数据
var option = {
title: {
text: '省份地图点击事件'
},
tooltip: {
trigger: 'item'
},
series: [{
name: '中国',
type: 'map',
mapType: 'china',
label: {
show: true
},
data: [{
name: '北京',
value: Math.round(Math.random() * 1000)
}, {
name: '上海',
value: Math.round(Math.random() * 1000)
}]
}]
};
// 使用刚指定的配置项和数据显示图表。
myChart.setOption(option);
// 为地图添加点击事件
myChart.on('click', function (params) {
console.log(params.name + '被点击了');
});
案例四:地图数据动态更新
在这个案例中,我们将展示如何动态更新地图数据。
// 引入 ECharts 主模块
var echarts = require('echarts/lib/echarts');
// 引入中国地图数据
require('echarts/map/js/china');
// 基于准备好的dom,初始化echarts实例
var myChart = echarts.init(document.getElementById('main'));
// 指定图表的配置项和数据
var option = {
title: {
text: '地图数据动态更新'
},
tooltip: {
trigger: 'item'
},
series: [{
name: '中国',
type: 'map',
mapType: 'china',
label: {
show: true
},
data: []
}]
};
// 使用刚指定的配置项和数据显示图表。
myChart.setOption(option);
// 动态更新数据
function updateData() {
var data = [];
for (var i = 0; i < 10; i++) {
var name = '省份' + (i + 1);
var value = Math.round(Math.random() * 1000);
data.push({name: name, value: value});
}
myChart.setOption({
series: [{
data: data
}]
});
}
// 每5秒更新一次数据
setInterval(updateData, 5000);
案例五:地图自定义样式
在这个案例中,我们将展示如何自定义地图样式。
// 引入 ECharts 主模块
var echarts = require('echarts/lib/echarts');
// 引入中国地图数据
require('echarts/map/js/china');
// 基于准备好的dom,初始化echarts实例
var myChart = echarts.init(document.getElementById('main'));
// 指定图表的配置项和数据
var option = {
title: {
text: '地图自定义样式'
},
tooltip: {
trigger: 'item'
},
series: [{
name: '中国',
type: 'map',
mapType: 'china',
label: {
show: true
},
itemStyle: {
normal: {
areaColor: '#323c48',
borderColor: '#111'
},
emphasis: {
areaColor: '#2a333d'
}
},
data: [{
name: '北京',
value: Math.round(Math.random() * 1000)
}, {
name: '上海',
value: Math.round(Math.random() * 1000)
}]
}]
};
// 使用刚指定的配置项和数据显示图表。
myChart.setOption(option);
案例六:地图动画效果
在这个案例中,我们将展示如何为地图添加动画效果。
// 引入 ECharts 主模块
var echarts = require('echarts/lib/echarts');
// 引入中国地图数据
require('echarts/map/js/china');
// 基于准备好的dom,初始化echarts实例
var myChart = echarts.init(document.getElementById('main'));
// 指定图表的配置项和数据
var option = {
title: {
text: '地图动画效果'
},
tooltip: {
trigger: 'item'
},
series: [{
name: '中国',
type: 'map',
mapType: 'china',
label: {
show: true
},
animation: true,
data: [{
name: '北京',
value: Math.round(Math.random() * 1000)
}, {
name: '上海',
value: Math.round(Math.random() * 1000)
}]
}]
};
// 使用刚指定的配置项和数据显示图表。
myChart.setOption(option);
案例七:地图热力图
在这个案例中,我们将展示如何使用 ECharts 创建地图热力图。
// 引入 ECharts 主模块
var echarts = require('echarts/lib/echarts');
// 引入中国地图数据
require('echarts/map/js/china');
// 基于准备好的dom,初始化echarts实例
var myChart = echarts.init(document.getElementById('main'));
// 指定图表的配置项和数据
var option = {
title: {
text: '地图热力图'
},
tooltip: {
trigger: 'item'
},
visualMap: {
min: 0,
max: 1000,
left: 'left',
top: 'bottom',
text: ['高', '低'], // 文本,默认为数值文本
calculable: true
},
series: [{
name: '中国',
type: 'map',
mapType: 'china',
label: {
show: true
},
data: [{
name: '北京',
value: Math.round(Math.random() * 1000)
}, {
name: '上海',
value: Math.round(Math.random() * 1000)
}]
}]
};
// 使用刚指定的配置项和数据显示图表。
myChart.setOption(option);
案例八:地图多级联动
在这个案例中,我们将展示如何使用 ECharts 创建多级联动地图。
// 引入 ECharts 主模块
var echarts = require('echarts/lib/echarts');
// 引入中国地图数据
require('echarts/map/js/china');
// 基于准备好的dom,初始化echarts实例
var myChart = echarts.init(document.getElementById('main'));
// 指定图表的配置项和数据
var option = {
title: {
text: '地图多级联动'
},
tooltip: {
trigger: 'item'
},
series: [{
name: '中国',
type: 'map',
mapType: 'china',
label: {
show: true
},
data: [{
name: '北京',
value: Math.round(Math.random() * 1000)
}, {
name: '上海',
value: Math.round(Math.random() * 1000)
}]
}]
};
// 使用刚指定的配置项和数据显示图表。
myChart.setOption(option);
// 添加多级联动事件
myChart.on('click', function (params) {
if (params.componentType === 'series') {
var name = params.name;
if (name === '北京') {
// 切换到北京市地图
myChart.setOption({
series: [{
mapType: 'beijing'
}]
});
} else if (name === '上海') {
// 切换到上海市地图
myChart.setOption({
series: [{
mapType: 'shanghai'
}]
});
}
}
});
案例九:地图数据筛选
在这个案例中,我们将展示如何筛选地图数据。
// 引入 ECharts 主模块
var echarts = require('echarts/lib/echarts');
// 引入中国地图数据
require('echarts/map/js/china');
// 基于准备好的dom,初始化echarts实例
var myChart = echarts.init(document.getElementById('main'));
// 指定图表的配置项和数据
var option = {
title: {
text: '地图数据筛选'
},
tooltip: {
trigger: 'item'
},
series: [{
name: '中国',
type: 'map',
mapType: 'china',
label: {
show: true
},
data: [{
name: '北京',
value: Math.round(Math.random() * 1000)
}, {
name: '上海',
value: Math.round(Math.random() * 1000)
}]
}]
};
// 使用刚指定的配置项和数据显示图表。
myChart.setOption(option);
// 添加筛选事件
function filterData(filterName) {
var data = myChart.getOption().series[0].data;
var filteredData = data.filter(function (item) {
return item.name === filterName;
});
myChart.setOption({
series: [{
data: filteredData
}]
});
}
// 添加筛选按钮
var filterButton = document.createElement('button');
filterButton.innerHTML = '筛选';
filterButton.onclick = function () {
filterData('北京');
};
document.body.appendChild(filterButton);
案例十:地图自定义标签
在这个案例中,我们将展示如何自定义地图标签。
// 引入 ECharts 主模块
var echarts = require('echarts/lib/echarts');
// 引入中国地图数据
require('echarts/map/js/china');
// 基于准备好的dom,初始化echarts实例
var myChart = echarts.init(document.getElementById('main'));
// 指定图表的配置项和数据
var option = {
title: {
text: '地图自定义标签'
},
tooltip: {
trigger: 'item'
},
series: [{
name: '中国',
type: 'map',
mapType: 'china',
label: {
show: true,
formatter: function (params) {
return params.name + ' (' + params.value + ')';
}
},
data: [{
name: '北京',
value: Math.round(Math.random() * 1000)
}, {
name: '上海',
value: Math.round(Math.random() * 1000)
}]
}]
};
// 使用刚指定的配置项和数据显示图表。
myChart.setOption(option);
案例十一:地图数据聚合
在这个案例中,我们将展示如何使用 ECharts 创建地图数据聚合。
// 引入 ECharts 主模块
var echarts = require('echarts/lib/echarts');
// 引入中国地图数据
require('echarts/map/js/china');
// 基于准备好的dom,初始化echarts实例
var myChart = echarts.init(document.getElementById('main'));
// 指定图表的配置项和数据
var option = {
title: {
text: '地图数据聚合'
},
tooltip: {
trigger: 'item'
},
series: [{
name: '中国',
type: 'map',
mapType: 'china',
label: {
show: true
},
data: [{
name: '北京',
value: Math.round(Math.random() * 1000)
}, {
name: '上海',
value: Math.round(Math.random() * 1000)
}]
}]
};
// 使用刚指定的配置项和数据显示图表。
myChart.setOption(option);
// 添加聚合事件
myChart.on('click', function (params) {
if (params.componentType === 'series') {
var name = params.name;
if (name === '北京') {
// 聚合到北京市
myChart.setOption({
series: [{
markPoint: {
data: [{
name: '北京',
value: Math.round(Math.random() * 1000)
}]
}
}]
});
} else if (name === '上海') {
// 聚合到上海市
myChart.setOption({
series: [{
markPoint: {
data: [{
name: '上海',
value: Math.round(Math.random() * 1000)
}]
}
}]
});
}
}
});
案例十二:地图自定义工具栏
在这个案例中,我们将展示如何自定义地图工具栏。
// 引入 ECharts 主模块
var echarts = require('echarts/lib/echarts');
// 引入中国地图数据
require('echarts/map/js/china');
// 基于准备好的dom,初始化echarts实例
var myChart = echarts.init(document.getElementById('main'));
// 指定图表的配置项和数据
var option = {
title: {
text: '地图自定义工具栏'
},
tooltip: {
trigger: 'item'
},
series: [{
name: '中国',
type: 'map',
mapType: 'china',
label: {
show: true
},
data: [{
name: '北京',
value: Math.round(Math.random() * 1000)
}, {
name: '上海',
value: Math.round(Math.random() * 1000)
}]
}],
toolbox: {
feature: {
dataZoom: {
show: true
},
dataView: {
show: true
},
magicType: {
show: true,
type: ['line', 'bar', 'stack', 'tiled']
},
restore: {
show: true
},
saveAsImage: {
show: true
}
}
}
};
// 使用刚指定的配置项和数据显示图表。
myChart.setOption(option);
案例十三:地图联动
在这个案例中,我们将展示如何使用 ECharts 创建地图联动。
”`javascript // 引入 ECharts 主模块 var echarts = require(‘echarts/lib/echarts’); // 引入中国地图数据 require(‘echarts/map/js/china’);
// 基于准备好的dom,初始化echarts实例 var myChart1 = echarts.init(document.getElementById(‘main1’)); var myChart2 = echarts.init(document.getElementById(‘main2’));
// 指定图表的配置项和数据 var option1 = {
title: {
text: '地图联动 - 图1'
},
tooltip: {
trigger: 'item'
},
series: [{
name: '中国',
type: 'map',
mapType: 'china',
label: {
show: true
},
data: [{
name: '北京',
value: Math.round(Math.random() * 1000)
}, {
name: '上海',
value: Math.round(Math.random() * 1000)
}]
}]
};
var option2 = {
title: {
text: '地图联动 - 图2'
},
tooltip: {
trigger: 'item'
},
series: [{
name: '中国',
type: 'map',
mapType: 'china',
label: {
show: true
},
data: [{
name: '北京',
value: Math.round(Math.random() * 1000)
}, {
name: '上海',
value: Math.round(Math.random() * 1000)
}]
}]
};
// 使用刚指定的配置项和数据显示图表。 myChart1.setOption(option1); myChart2.setOption(option2);
// 添加联动事件 myChart1.on(‘click’, function (params) {
if (params.componentType === 'series') {
var name = params.name;
myChart2.set
