echarts合并地图,把中国各个省份分成华北,东北,华东,华中,华南,西南,西北七个大区...
最近公司有个需求是按照大区,即把中国分成华北','东北','华东','华中','华南','西南','西北'七个大区,
但是echarts地图只有省市,还没有大区,只能自己网上找资料再按需求写了
echarts地图合并关键点是把coordinates和encodeOffsets合并,而且这两个必须都合并,且最多只能合并到二维数组,合并到三维数组就不行了。
实例结果截图
代码:
<!DOCTYPE html>
<html lang="zh">
<head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta http-equiv="X-UA-Compatible" content="ie=edge" /><title>echarts地图合并-生成中国大区</title>
</head>
<body>
<div class="echarts-map">
<div class="echarts-map-box" id="echartsMapBox" style="width: 1000px;height: 400px;"></div>
<script type="text/javascript" src="js/jquery-1.12.4.min.js"></script>
<script type="text/javascript" src="js/echarts.min.js"></script>
<script type="text/javascript" src="js/china.js"></script>
<script type="text/javascript">
$(document).ready(function(){repRegionStrategy();
})
var mergeProvinces = function(chinaJson, names, properties) {//合并大区里省份的coordinatesvar features = chinaJson.features;var polygons = [];var polygons2 = [];for(var i = 0; i < names.leng
echarts合并地图,把中国各个省份分成华北,东北,华东,华中,华南,西南,西北七个大区...
最近公司有个需求是按照大区,即把中国分成华北','东北','华东','华中','华南','西南','西北'七个大区,
但是echarts地图只有省市,还没有大区,只能自己网上找资料再按需求写了
echarts地图合并关键点是把coordinates和encodeOffsets合并,而且这两个必须都合并,且最多只能合并到二维数组,合并到三维数组就不行了。
实例结果截图
代码:
<!DOCTYPE html>
<html lang="zh">
<head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta http-equiv="X-UA-Compatible" content="ie=edge" /><title>echarts地图合并-生成中国大区</title>
</head>
<body>
<div class="echarts-map">
<div class="echarts-map-box" id="echartsMapBox" style="width: 1000px;height: 400px;"></div>
<script type="text/javascript" src="js/jquery-1.12.4.min.js"></script>
<script type="text/javascript" src="js/echarts.min.js"></script>
<script type="text/javascript" src="js/china.js"></script>
<script type="text/javascript">
$(document).ready(function(){repRegionStrategy();
})
var mergeProvinces = function(chinaJson, names, properties) {//合并大区里省份的coordinatesvar features = chinaJson.features;var polygons = [];var polygons2 = [];for(var i = 0; i < names.leng