ECharts 是一个使用 JavaScript 实现的开源可视化库,它可以帮助我们轻松地将数据转换为可视化的图表。其中,ECharts 地图是 ECharts 中的一个特色功能,可以绘制各种地图,包括中国地图。本篇文章将为你介绍如何使用 ECharts 快速上手地图图表,并提供 5 个实用案例解析,让你轻松绘制中国地图。

1. ECharts 地图的基本使用

首先,我们需要在 HTML 文件中引入 ECharts 的 JavaScript 文件和地图数据文件。以下是一个简单的示例:

<!DOCTYPE html>
<html style="height: 100%">
<head>
    <meta charset="utf-8">
</head>
<body style="height: 100%; margin: 0">
    <div id="container" style="height: 100%"></div>
    <script src="https://cdn.bootcdn.net/ajax/libs/echarts/5.3.3/echarts.min.js"></script>
    <script src="https://cdn.bootcdn.net/ajax/libs/echarts/5.3.3/map/js/china.js"></script>
    <script type="text/javascript">
        var myChart = echarts.init(document.getElementById('container'));
        var option = {
            title: {
                text: '中国地图示例'
            },
            tooltip: {
                trigger: 'item'
            },
            visualMap: {
                min: 0,
                max: 100,
                left: 'left',
                top: 'bottom',
                text: ['高','低'],           // 文本,默认为数值文本
                calculable: true
            },
            series: [
                {
                    name: '中国',
                    type: 'map',
                    mapType: 'china',
                    roam: false,
                    label: {
                        show: true
                    },
                    data: [
                        {name: '北京',value: Math.round(Math.random()*1000)},
                        {name: '上海',value: Math.round(Math.random()*1000)},
                        // ... 其他城市数据
                    ]
                }
            ]
        };
        myChart.setOption(option);
    </script>
</body>
</html>

在上面的代码中,我们创建了一个名为 container 的 div 元素,并为其设置了高度。然后,我们引入了 ECharts 和中国地图的 JavaScript 文件。接下来,我们使用 echarts.init 方法初始化 ECharts 实例,并设置地图图表的配置项 option。最后,我们调用 setOption 方法将配置项应用到 ECharts 实例上。

2. 案例一:中国地图基础展示

在上面的代码中,我们已经创建了一个简单的中国地图示例。在这个例子中,我们使用 mapType: 'china' 设置地图类型为中国,并使用 series 数组定义了地图的系列。每个系列都可以包含多个数据项,每个数据项都表示地图上的一个区域,如省份、城市等。

3. 案例二:中国地图数据可视化

我们可以通过修改 data 数组中的数据项来改变地图上的颜色和数值。以下是一个示例:

data: [
    {name: '北京',value: Math.round(Math.random()*1000)},
    {name: '上海',value: Math.round(Math.random()*1000)},
    // ... 其他城市数据
]

在上面的代码中,我们使用 Math.round(Math.random()*1000) 生成一个随机数作为每个城市的数值。这样,地图上的每个区域都会根据其数值显示不同的颜色。

4. 案例三:中国地图交互效果

ECharts 地图支持多种交互效果,如点击、鼠标悬停等。以下是一个示例:

tooltip: {
    trigger: 'item',
    formatter: function(params) {
        return params.name + ':' + params.value;
    }
},

在上面的代码中,我们设置了 tooltip 配置项,当鼠标悬停在地图上的某个区域时,会显示该区域的名称和数值。

5. 案例四:中国地图自定义样式

ECharts 地图支持自定义样式,如颜色、字体等。以下是一个示例:

label: {
    show: true,
    position: 'inside',
    color: '#fff',
    fontSize: 10
},

在上面的代码中,我们设置了 label 配置项,使地图上的标签显示在区域内,并设置了标签的颜色和字体大小。

6. 案例五:中国地图与热力图结合

ECharts 地图可以与其他图表类型结合使用,如热力图。以下是一个示例:

series: [
    {
        name: '中国',
        type: 'map',
        mapType: 'china',
        roam: false,
        label: {
            show: true
        },
        data: [
            {name: '北京',value: Math.round(Math.random()*1000)},
            {name: '上海',value: Math.round(Math.random()*1000)},
            // ... 其他城市数据
        ]
    },
    {
        name: '热力图',
        type: 'heatmap',
        coordinateSystem: 'geo',
        data: [
            {name: '北京',value: [116.46,39.92]},
            {name: '上海',value: [121.48,31.22]},
            // ... 其他城市数据
        ]
    }
]

在上面的代码中,我们添加了一个名为 热力图 的系列,并设置了其类型为 heatmap。这样,地图上就会显示热力图效果。

通过以上 5 个案例,相信你已经对 ECharts 地图有了基本的了解。在实际应用中,你可以根据自己的需求进行修改和扩展。希望这篇文章能帮助你快速上手 ECharts 地图,并轻松绘制出漂亮的中国地图!