在数据可视化领域,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