eharts 中国地图添加城市(散点图实现,含获取城市坐标、图片转base64、自定义散点样式)_d3


如上图所示,青岛不是省份、直辖市或特别行政区,所以默认的中国地图上,无法标注青岛,那本图是如何实现的呢?

实现思路

  1. 隐藏地图坐标默认的地名标签
: {
map: "china",
label: {
emphasis: {
// 高亮地区时,隐藏区域标签
show: false,
},
},
},
  1. 使用散点图来标注地点
    (1)地图默认已有的省份、直辖市和特别行政区名称直接从地图数据中获取,无需手动添加
let dataList = [];
/*获取地图中已有的省、直辖市和特别行政区*/
echarts.getMap("china").geoJson.features.forEach((item) => {
dataList.push({
// 地区名称
name: item.properties.name,
// 地区经纬度
value: item.properties.cp,
});
});

(2)地图中没有的城市,手动添加城市名和城市坐标

城市坐标可以通过下方网站查询

​http://life.chacuo.net/postion/​

eharts 中国地图添加城市(散点图实现,含获取城市坐标、图片转base64、自定义散点样式)_echarts_02

// 添加城市——参照青岛的格式,可以添加其他城市
newCityList: [
{
name: "青岛",
value: [120.4, 36],
},
],
// 添加城市
return dataList.concat(this.newCityList);

完整范例代码如下

china.js 的百度网盘下载链接:
​​​https://pan.baidu.com/s/1K0wlmb3Yt223XAykMXpALA​​ 提取码:w160

<template>
<div class="mapBox">
<div style="height: 100%;width:" ref="myChart"></div>
</div>
</template>

<script>import echarts from "echarts";
import "@/components/charts/chinaMap/china.js";

export default {
data() {
return {
dataList: [],
// 添加城市——参照青岛的格式,可以添加其他城市
newCityList: [
{
name: "青岛",
value: [120.4, 36],
},
],
};
},
methods: {
initData() {
let dataList = [];
/*获取地图中已有的省、直辖市和特别行政区*/
echarts.getMap("china").geoJson.features.forEach((item) => {
dataList.push({
// 地区名称
name: item.properties.name,
// 地区经纬度
value: item.properties.cp,
});
});
// 添加城市
return dataList.concat(this.newCityList);
},
initEchartMap() {
let myChart = echarts.init(this.$refs.myChart);

let options = {
geo: {
map: "china",
label: {
emphasis: {
// 高亮地区时,隐藏区域标签
show: false,
},
},
},
series: [
{
name: "散点",
type: "scatter",
coordinateSystem: "geo",
data: this.dataList,
label: {
show: true,
// 标签格式化,获取数据中的name
formatter: "{b}",
// 标签偏移量 -- 水平偏移,垂直偏移,原点为散点的位置
offset: [0, -18],
color: "black",
},
emphasis: {
label: {
show: true,
formatter: "{b}",
offset: [0, -20],
color: "red",
fontSize: 18,
},
},
},
],
};

myChart.setOption(options);

// 添加窗口大小改变监听事件,当窗口大小改变时,图表会重新绘制,自适应窗口大小
window.addEventListener("resize", function() {
myChart.resize();
});
},
},

mounted() {
this.$nextTick(() => {
this.dataList = this.initData();
this.initEchartMap();
});
},
};</script>
<style scoped>.mapBox {
background: #020933;
position: absolute;
top: 0;
bottom: 0;
left: 0;
right: 0;
padding: 30px;
box-sizing: border-boxs;
}</style>

地图优化——自定义散点样式

eharts 中国地图添加城市(散点图实现,含获取城市坐标、图片转base64、自定义散点样式)_echarts_03


修改symbol的配置即可实现,上图中使用的是自定义图片

eharts 中国地图添加城市(散点图实现,含获取城市坐标、图片转base64、自定义散点样式)_f5_04


需先使用下方网站将图片转换成base64格式

​http://tool.chinaz.com/tools/imgtobase/​

eharts 中国地图添加城市(散点图实现,含获取城市坐标、图片转base64、自定义散点样式)_d3_05


eharts 中国地图添加城市(散点图实现,含获取城市坐标、图片转base64、自定义散点样式)_echarts_06


作为symbol的属性值,还需在base64的数据前添加 image://

完整范例代码如下:

<template>
<div class="mapBox">
<div style="height: 100%;width:" ref="myChart"></div>
</div>
</template>

<script>import echarts from "echarts";
import "@/components/charts/chinaMap/china.js";

export default {
data() {
return {
dataList: [],
// 添加城市——参照青岛的格式,可以添加其他城市
newCityList: [
{
name: "青岛",
value: [120.4, 36],
},
],
};
},
methods: {
initData() {
let dataList = [];
/*获取地图中已有的省、直辖市和特别行政区*/
echarts.getMap("china").geoJson.features.forEach((item) => {
dataList.push({
// 地区名称
name: item.properties.name,
// 地区经纬度
value: item.properties.cp,
});
});
// 添加城市
return dataList.concat(this.newCityList);
},
initEchartMap() {
let myMark =
"image://";

let myChart = echarts.init(this.$refs.myChart);

let options = {
geo: {
map: "china",
label: {
emphasis: {
// 高亮地区时,隐藏区域标签
show: false,
},
},
},
series: [
{
symbol: myMark,
symbolSize: 15,
name: "散点",
type: "scatter",
coordinateSystem: "geo",
data: this.dataList,
label: {
show: true,
// 标签格式化,获取数据中的name
formatter: "{b}",
// 标签偏移量 -- 水平偏移,垂直偏移,原点为散点的位置
offset: [0, -18],
color: "black",
},
emphasis: {
label: {
show: true,
formatter: "{b}",
offset: [0, -20],
color: "red",
fontSize: 18,
},
},
},
],
};

myChart.setOption(options);

// 添加窗口大小改变监听事件,当窗口大小改变时,图表会重新绘制,自适应窗口大小
window.addEventListener("resize", function() {
myChart.resize();
});
},
},

mounted() {
this.$nextTick(() => {
this.dataList = this.initData();
this.initEchartMap();
});
},
};</script>
<style scoped>.mapBox {
background: #020933;
position: absolute;
top: 0;
bottom: 0;
left: 0;
right: 0;
padding: 30px;
box-sizing: border-boxs;
}</style>