<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport"
content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.chart {
width: 1200px;
height: 800px;
margin: 0 auto;
}
</style>
</head>
<body>
<div class="chart"></div>
<script src="https://cdn.jsdelivr.net/npm/echarts/dist/echarts.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/echarts-gl/dist/echarts-gl.min.js"></script>
<!-- 这里为了方便直接把源json文件改成js文件 -->
<script src="./linyi.js"></script>
<script>
// 注册自定义城市边界信息
echarts.registerMap('Linyi', Linyi);
// 图表实例
let chart = echarts.init(document.querySelector('.chart'));
// map3D视角控制参数
let viewControl = {
beta: 35,
alpha: 45,
distance: 120,
// zoomSensitivity: 0, // 是否允许放大
// rotateSensitivity: 0,// 是否允许旋转
};
// 标注点数据
// 这里的name需要和城市边界信息中的name对应才能显示出来,因为没有坐标信息,name是唯一可以对应起来的
let pointData = [{
name: '兰山区',
value: 10
},
{
name: '河东区',
value: 20
},
{
name: '罗庄区',
value: 99
}
]
let label = {
show: true,
formatter(params) {
if (params.value) {
return `{radiusBg|${params.value}}`
} else {
return null;
}
},
rich: {
radiusBg: {
color: "#fff",
align: 'center',
width: 50,
height: 50,
fontSize: 22,
},
},
textStyle: {
width: 50,
height: 64,
backgroundColor: {
image: ''
}
}
};
chart.setOption({
series: [{
zlevel: 10,
viewControl,
map: 'Linyi',
type: "map3D",
regionHeight: 10,
label: {
show: true,
color: '#fff',
fontWeight: 'bold',
fontSize: 14,
textShadowBlur: 2,
textShadowOffsetY: 2,
textShadowColor: 'rgba(0, 0, 0, 0.5)'
},
itemStyle: {
opacity: 1,
borderWidth: 2,
color: '#428BF4',
borderColor: '#61CFF8',
},
emphasis: {
label: {
show: true,
textStyle: {
color: '#fff'
}
},
itemStyle: {
color: '#007EE8',
borderWidth: 10,
borderColor: '#6BECF5'
}
},
light: {
ambient: {
color: '#fff',
intensity: 0.4
}
},
},
{
zlevel: 20,
viewControl,
map: 'Linyi',
type: "map3D",
regionHeight: 10,
itemStyle: {
color: 'transparent'
},
emphasis: {
itemStyle: {
color: 'transparent'
}
},
data: pointData.map(v => {
v.label = label;
v.emphasis = {
label
}
return v
})
}
]
});
</script>
</body>
</html>