最近遇到一个新需求,要求展示山东省的地图,并且点击可进入地级市地图。这可是难倒了我,我尝试着用不同的方法,高德地图、百度地图等,发现都有一定的缺陷,最终决定使用echarts实现,下面就来跟大家分享一下我的心路历程。
先来看一下效果:
点击济南市即可进入济南市的地图:
实现步骤如下所示:
1.图中的地图都是需要去网站上自行下载的,包括山东省地图,各个地级市的地图都需要进行下载,网址http://datav.aliyun.com/tools/atlas/,下载格式为.json
2.地图中需要用到的小图标,小图片什么的,需要提前转换成base64格式,百度搜一下,有不少在线转换工具可以直接转换
3.安装echarts,并导入
4.html代码:
<div style="width:400px;height:400px" id="barChart"></div>
5.js代码
//导入地图
import shandong from "../../../../../assets/get/shandongData.json";
......async getLeftBar() {let nc = document.getElementById("barChart");var myChart = this.echarts.init(nc);this.echarts.registerMap("山东", shandong);var cityMap = {济南市: jinan,青岛市: qingdao,烟台市: yantai,潍坊市: weifang,菏泽市: heze,日照市: rizhao,威海市: weihai,枣庄市: zaozhuang,临沂市: linyi,滨州市: bingzhou,东营市: dongying,淄博市: zibo,泰安市: taian,聊城市: liaocheng,济宁市: jining,德州市: dezhou,};var sdGeoCoordMap = {济南市: [117.000923, 36.675807],青岛市: [120.355173, 36.082982],烟台市: [121.391382, 37.539297],潍坊市: [119.107078, 36.70925],菏泽市: [115.469381, 35.246531],日照市: [119.461208, 35.428588],威海市: [122.116394, 37.509691],枣庄市: [117.557964, 34.856424],临沂市: [118.326443, 35.065282],滨州市: [118.016974, 37.383542],东营市: [118.66471, 37.434564],淄博市: [118.047648, 36.814939],泰安市: [117.129063, 36.194968],聊城市: [115.980367, 36.456013],济宁市: [116.587245, 35.415393],德州市: [116.307428, 37.453968],};var sdDatas = [{name1: "济南市",name: "济南市供电局",value: [117.050923, 36.678807, 0.5],},{name1: "济南市",name: "济南市供电局23",value: [117.053923, 36.638807, 3.5],},{name1: "济南市",name: "济南市随便吧",value: [117.653923, 37.038807, 11],},{name1: "青岛市",name: "青岛市供电局",value: [120.385173, 36.042982, 7.5],},];var jinandata = [{name: "东莞市供电局",value: [117.000623, 36.672807, 0.5],},{name: "东莞东城供电分局",value: [117.001923, 36.685807, 1],},{name: "广东电网东莞南城供电局",value: [117.002923, 36.675207, 1],},{name: "沙田供电分局",value: [117.007923, 36.675107, 0.1],},{name: "广东电网(松山湖)",value: [117.040923, 36.625807, 0.4],},{name: "东莞供电局万江供电局",value: [117.100923, 36.695807, 1],},{name: "广东电网公司石龙供电分局",value: [117.003923, 36.673807, 1.4],},{name: "广东电网东莞虎门供电局",value: [117.002913, 36.676607, 0.7],},{name: "广东电网公司中堂供电公司",value: [117.01123, 36.633807, 0.1],},{name: "望牛墩供电公司",value: [117.000333, 36.675557, 0.5],},{name: "东莞供电局石碣供电局",value: [117.000233, 36.674307, 2],},{name: "高埗供电分局",value: [117.445923, 36.874507, 0.9],},{name: "东莞市麻涌供电公司",value: [117.003423, 36.678807, 2],},{name: "东莞市长安供电公司",value: [117.000444, 36.675444, 2],},{name: "东莞市道滘供电公司",value: [117.110923, 36.635807, 0.4],},{name: "东莞市洪梅供电公司",value: [117.0334923, 36.673434, 0.6],},{name: "东莞市厚街供电公司",value: [117.003423, 36.634807, 2],},{name: "东莞市寮步供电公司",value: [117.047923, 36.674807, 2],},{name: "大岭山供电公司",value: [117.046923, 36.635807, 0.1],},{name: "广东电网大朗供电分公司",value: [117.150923, 36.715807, 0.9],},{name: "黄江供电分局",value: [117.003453, 36.672307, 0.5],},{name: "东莞供电局樟木头供电局",value: [117.099923, 36.699807, 2],},{name: "东莞市清溪供电公司",value: [117.089923, 36.689807, 2],},{name: "东莞供电局谢岗分局",value: [117.029923, 36.629807, 2],},{name: "东莞市凤岗镇雁田供电所",value: [117.004443, 36.673337, 0.4],},{name: "东莞常平供电分局",value: [117.004373, 36.6787857, 0.6],},{name: "东莞桥头供电分局",value: [117.003413, 36.623407, 2],},{name: "东莞电网横沥供电分局",value: [117.00032343, 36.6342807, 0.8],},{name: "广东电网公司东莞东坑供电分局",value: [117.0087653, 36.67467807, 0.2],},{name: "塘厦供电局",value: [117.045673, 36.6567307, 2],},{name: "企石供电局",value: [117.003633, 36.6755427, 0.7],},{name: "石排供电公司",value: [117.0456923, 36.645807, 0.1],},{name: "茶山供电分局",value: [117.003453, 36.6345807, 0.2],},];var qingdaodata = [{name: "东莞市供电局",value: [120.345173, 36.0842982, 0.5],},];var yantaidata = [{name: "东莞市供电局",value: [121.393382, 37.53497, 0.5],},];var weifangdata = [{name: "东莞市供电局",value: [119.107078, 36.70925, 0.5],},];var hezedata = [{name: "东莞市供电局",value: [115.489381, 35.286531, 0.5],},];var rizhaodata = [{name: "东莞市供电局",value: [119.491208, 35.499588, 0.5],},];var weihaidata = [{name: "东莞市供电局",value: [122.1199394, 37.599691, 0.5],},];var zaozhuangdata = [{name: "东莞市供电局",value: [117.597964, 34.896424, 0.5],},];var linyidata = [{name: "东莞市供电局",value: [118.386443, 35.085282, 0.5],},];var bingzhoudata = [{name: "东莞市供电局",value: [118.016974, 37.383542, 0.5],},];var dongyingdata = [{name: "东莞市供电局",value: [118.016974, 37.383542, 0.5],},];var zibodata = [{name: "东莞市供电局",value: [118.016974, 37.383542, 0.5],},];var taiandata = [{name: "东莞市供电局",value: [118.016974, 37.383542, 0.5],},];var liaochengdata = [{name: "东莞市供电局",value: [118.016974, 37.383542, 0.5],},];var jiningdata = [{name: "东莞市供电局",value: [118.016974, 37.383542, 0.5],},];var dezhoudata = [{name: "东莞市供电局",value: [118.016974, 37.383542, 0.5],},];var that = this;var opt = {bgColor: "#013954", // 画布背景色mapName: "山东", // 地图名goDown: true, // 是否下钻// 下钻回调callback: async function (name, option, instance) {console.log(name, option, instance);if (name == "山东") {this.ifShow = true;option.series[0].data = converntData(data_tmp);option.series[1].data = data_tmp;myChart.setOption(option, true);setTimeout(() => {// 定时后启动飞线myChart.setOption(option, true);}, 500);} else if (name == "济南市") {that.ifShow = false;that.cityName = "济南市";that.cityCode = "370100";await that.getLonLat();that.getSixData();that.$emit("changeArea", "济南市", "370100");setTimeout(() => {option.series[0] = {type: "effectScatter",coordinateSystem: "geo",zlevel: 2,rippleEffect: {//涟漪特效period: 8, //动画时间,值越小速度越快brushType: "fill", //波纹绘制方式 stroke, fillscale: 0, //波纹圆环最大限制,值越大波纹越大},label: {normal: {show: false,position: "right", //显示位置offset: [5, 0], //偏移设置formatter: function (params) {//圆环显示文字return params.data.name;},fontSize: 19,},emphasis: {show: true,},},itemStyle: {normal: {show: false,color: "#f00",},},data: that.dataArr,};}, 600);option.series[1].data = that.cityFactoryData;option.series[2].data = that.cityFactoryData;console.log("option.series:");console.log(option.series);myChart.setOption(option, true); // 赋值后初始化setTimeout(() => {// 定时后启动飞线myChart.setOption(option, true);}, 600);} else if (name == "青岛市") {that.ifShow = false;that.cityName = "青岛市";that.cityCode = "370200";await that.getLonLat();that.getSixData();that.$emit("changeArea", "青岛市", "370200");setTimeout(() => {option.series[0] = {type: "effectScatter",coordinateSystem: "geo",zlevel: 2,rippleEffect: {//涟漪特效period: 8, //动画时间,值越小速度越快brushType: "fill", //波纹绘制方式 stroke, fillscale: 0, //波纹圆环最大限制,值越大波纹越大},label: {normal: {show: false,position: "right", //显示位置offset: [5, 0], //偏移设置formatter: function (params) {//圆环显示文字return params.data.name;},fontSize: 19,},emphasis: {show: true,},},itemStyle: {normal: {show: false,color: "#f00",},},data: that.dataArr,};}, 600);option.series[1].data = that.cityFactoryData;option.series[2].data = that.cityFactoryData;myChart.setOption(option, true); // 赋值后初始化setTimeout(() => {// 定时后启动飞线myChart.setOption(option, true);}, 600);} else if (name == "烟台市") {that.ifShow = false;that.cityName = "烟台市";that.cityCode = "370600";that.getLonLat();that.getSixData();that.$emit("changeArea", "烟台市", "370600");option.series[0].data = convertData1(yantaidata);option.series[1].data = yantaidata;option.series[2].data = [];myChart.setOption(option, true); // 赋值后初始化setTimeout(() => {// 定时后启动飞线myChart.setOption(option, true);}, 500);} else if (name == "潍坊市") {that.ifShow = false;that.cityName = "潍坊市";that.cityCode = "370700";that.getLonLat();that.getSixData();that.$emit("changeArea", "潍坊市", "370700");option.series[0].data = convertData1(weifangdata);option.series[1].data = weifangdata;option.series[2].data = [];myChart.setOption(option, true); // 赋值后初始化setTimeout(() => {// 定时后启动飞线myChart.setOption(option, true);}, 500);} else if (name == "菏泽市") {that.ifShow = false;that.cityName = "菏泽市";that.cityCode = "371700";that.getLonLat();that.getSixData();that.$emit("changeArea", "菏泽市", "371700");option.series[0].data = convertData1(hezedata);option.series[1].data = hezedata;option.series[2].data = [];myChart.setOption(option, true); // 赋值后初始化setTimeout(() => {// 定时后启动飞线myChart.setOption(option, true);}, 500);} else if (name == "日照市") {that.ifShow = false;that.cityName = "日照市";that.cityCode = "371100";that.getLonLat();that.getSixData();that.$emit("changeArea", "日照市", "371100");option.series[0].data = convertData1(rizhaodata);option.series[1].data = rizhaodata;option.series[2].data = [];myChart.setOption(option, true); // 赋值后初始化setTimeout(() => {// 定时后启动飞线myChart.setOption(option, true);}, 500);} else if (name == "威海市") {that.ifShow = false;that.cityName = "威海市";that.cityCode = "371000";that.getLonLat();that.getSixData();that.$emit("changeArea", "威海市", "371000");option.series[0].data = convertData1(weihaidata);option.series[1].data = weihaidata;option.series[2].data = [];myChart.setOption(option, true); // 赋值后初始化setTimeout(() => {// 定时后启动飞线myChart.setOption(option, true);}, 500);} else if (name == "枣庄市") {that.ifShow = false;that.cityName = "枣庄市";that.cityCode = "370400";that.getLonLat();that.getSixData();that.$emit("changeArea", "枣庄市", "370400");option.series[0].data = convertData1(zaozhuangdata);option.series[1].data = zaozhuangdata;option.series[2].data = [];myChart.setOption(option, true); // 赋值后初始化setTimeout(() => {// 定时后启动飞线myChart.setOption(option, true);}, 500);} else if (name == "临沂市") {that.ifShow = false;that.cityName = "临沂市";that.cityCode = "371300";that.getLonLat();that.getSixData();that.$emit("changeArea", "临沂市", "371300");option.series[0].data = convertData1(linyidata);option.series[1].data = linyidata;option.series[2].data = [];myChart.setOption(option, true); // 赋值后初始化setTimeout(() => {// 定时后启动飞线myChart.setOption(option, true);}, 500);} else if (name == "滨州市") {that.ifShow = false;that.cityName = "滨州市";that.cityCode = "371600";that.getLonLat();that.getSixData();that.$emit("changeArea", "滨州市", "371600");option.series[0].data = convertData1(bingzhoudata);option.series[1].data = bingzhoudata;option.series[2].data = [];myChart.setOption(option, true); // 赋值后初始化setTimeout(() => {// 定时后启动飞线myChart.setOption(option, true);}, 500);} else if (name == "东营市") {that.ifShow = false;that.cityName = "东营市";that.cityCode = "370500";that.getLonLat();that.getSixData();that.$emit("changeArea", "东营市", "370500");option.series[0].data = convertData1(dongyingdata);option.series[1].data = dongyingdata;option.series[2].data = [];myChart.setOption(option, true); // 赋值后初始化setTimeout(() => {// 定时后启动飞线myChart.setOption(option, true);}, 500);} else if (name == "淄博市") {that.ifShow = false;that.cityName = "淄博市";that.cityCode = "370300";that.getLonLat();that.getSixData();that.$emit("changeArea", "淄博市", "370300");option.series[0].data = convertData1(zibodata);option.series[1].data = zibodata;option.series[2].data = [];myChart.setOption(option, true); // 赋值后初始化setTimeout(() => {// 定时后启动飞线myChart.setOption(option, true);}, 500);} else if (name == "泰安市") {that.ifShow = false;that.cityName = "泰安市";that.cityCode = "370900";that.getLonLat();that.getSixData();that.$emit("changeArea", "泰安市", "370900");option.series[0].data = convertData1(taiandata);option.series[1].data = taiandata;option.series[2].data = [];myChart.setOption(option, true); // 赋值后初始化setTimeout(() => {// 定时后启动飞线myChart.setOption(option, true);}, 500);} else if (name == "聊城市") {that.ifShow = false;that.cityName = "聊城市";that.cityCode = "371500";that.getLonLat();that.getSixData();that.$emit("changeArea", "聊城市", "371500");option.series[0].data = convertData1(liaochengdata);option.series[1].data = liaochengdata;option.series[2].data = [];myChart.setOption(option, true); // 赋值后初始化setTimeout(() => {// 定时后启动飞线myChart.setOption(option, true);}, 500);} else if (name == "济宁市") {that.ifShow = false;that.cityName = "济宁市";that.cityCode = "370800";that.getLonLat();that.getSixData();that.$emit("changeArea", "济宁市", "370800");option.series[0].data = convertData1(jiningdata);option.series[1].data = jiningdata;option.series[2].data = [];myChart.setOption(option, true); // 赋值后初始化setTimeout(() => {// 定时后启动飞线myChart.setOption(option, true);}, 500);} else if (name == "德州市") {that.ifShow = false;that.cityName = "德州市";that.cityCode = "371400";that.getLonLat();that.getSixData();that.$emit("changeArea", "德州市", "371400");option.series[0].data = convertData1(dezhoudata);option.series[1].data = dezhoudata;option.series[2].data = [];myChart.setOption(option, true); // 赋值后初始化setTimeout(() => {// 定时后启动飞线myChart.setOption(option, true);}, 500);}},// 数据展示data: [],};var defaultOpt = {mapName: "china", // 地图展示goDown: true, // 是否下钻bgColor: "#013954", // 画布背景色activeArea: [], // 区域高亮,同echarts配置项data: [],// 下钻回调(点击的地图名、实例对象option、实例对象)callback: function () {},// callback: function (name, option, instance) {},};var opt1 = "";if (opt) {opt1 = $.extend(defaultOpt, opt);}// 层级索引var name = [opt1.mapName];var idx = 0;var pos = {//层级位置leftPlus: 55,leftCur: 50,left: 10,top: 10,};var line = [//箭头[0, 0],[8, 11],[0, 22],];// 头部导航style样式var style = {font: '18px "Microsoft YaHei", sans-serif',textColor: "#eee",lineColor: "rgba(147, 235, 248, .8)",};var handleEvents = {/*** i 实例对象* o option* n 地图名**/resetOption: function (i, o, n) {console.log(i);console.log(o);console.log(n);var breadcrumb = this.createBreadcrumb(n);var j = name.indexOf(n);var l = o.graphic.length;if (j < 0) {console.log("jinru1");o.graphic.push(breadcrumb);o.series = series;o.graphic[0].children[0].shape.x2 = 195;o.graphic[0].children[1].shape.x2 = 195;if (o.graphic.length > 2) {for (var x = 0; x < opt1.data.length; x++) {if (n === opt1.data[x].name + "市") {o.series[0].data = handleEvents.initSeriesData(opt1.data[x].data);break;} else o.series[0].data = [];}}name.push(n);idx++;} else {console.log("jinru2", j);o.graphic.splice(j + 2, l);if (o.graphic.length <= 2) {o.graphic[0].children[0].shape.x2 = 85;o.graphic[0].children[1].shape.x2 = 85;o.series[0].data = handleEvents.initSeriesData(data_tmp);o.series[0].symbol = zuanshi;o.series[0].symbolSize = 30;o.series[2].data = handleEvents.initSeriesData(data_tmp);}name.splice(j + 1, l);idx = j;pos.leftCur -= pos.leftPlus * (l - j - 1);}o.geo.map = n;o.geo.zoom = 1;i.clear();i.setOption(o);this.zoomAnimation();opt1.callback(n, o, i);},createBreadcrumb: function (name) {var cityToPinyin = {济南市: "jinan",青岛市: "qingdao",烟台市: "yantai",潍坊市: "weifang",菏泽市: "heze",日照市: "rizhao",威海市: "weihai",枣庄市: "zaozhuang",临沂市: "linyi",滨州市: "bingzhou",东营市: "dongying",淄博市: "zibo",泰安市: "taian",聊城市: "liaocheng",济宁市: "jining",德州市: "dezhou",};var breadcrumb = {type: "group",id: name,left: pos.leftCur + pos.leftPlus,top: pos.top + 3,children: [{type: "polyline",left: -90,top: -5,shape: {points: line,},style: {stroke: "#fff",key: name,},onclick: function () {var name = this.style.key;handleEvents.resetOption(myChart, option, name);},},{type: "text",left: -68,top: "middle",style: {text: name,textAlign: "center",fill: style.textColor,font: style.font,},onclick: function () {var name = this.style.text;handleEvents.resetOption(myChart, option, name);},},{type: "text",left: -68,top: 10,style: {name: name,text: cityToPinyin[name]? cityToPinyin[name].toUpperCase(): "",textAlign: "center",fill: style.textColor,font: '12px "Microsoft YaHei", sans-serif',},onclick: function () {// console.log(this.style);var name = this.style.name;handleEvents.resetOption(myChart, option, name);},},],};pos.leftCur += pos.leftPlus;return breadcrumb;},// 设置effectscatterinitSeriesData: function (data) {console.log(data, "22222222222");var temp = [];for (var i = 0; i < data.length; i++) {var geoCoord = sdGeoCoordMap[data[i].name];if (geoCoord) {temp.push({name: data[i].name,value: geoCoord.concat(data[i].value, data[i].level),});}}return temp;},zoomAnimation: function () {var count = null;var zoom = function (per) {if (!count) count = per;count = count + per;// console.log(per,count);myChart.setOption({geo: {zoom: count,},});if (count < 1)window.requestAnimationFrame(function () {zoom(0.2);});};window.requestAnimationFrame(function () {zoom(0.2);});},};var iconYellow ="image://";var iconGreen ="image://";var iconBlue ="image://";var iconRed ="image://";var mapTextBack ="image://";var zuanshi ="image://";var convertData = function (data) {data.forEach((item) => {item.symbol =item.value[2] < 1? iconYellow: item.value[2] < 6 && item.value[2] >= 1? iconGreen: iconBlue;item.symbolSize = 20;});return data;};var convertData1 = function (data) {data.forEach((item) => {item.symbol = iconYellow;item.symbolSize = 20;});return data;};var symbolFunc = function (data) {var iconColor;data.forEach((item) => {iconColor =item.coalAvaDay < 7? iconRed: item.coalAvaDay > 14? iconGreen: iconYellow;});return iconColor;};var data_tmp = [{ name: "济南市", value: 24 },{ name: "青岛市", value: 48 },{ name: "烟台市", value: 48 },{ name: "潍坊市", value: 61 },{ name: "菏泽市", value: 22 },{ name: "日照市", value: 18 },{ name: "威海市", value: 35 },{ name: "枣庄市", value: 20 },{ name: "临沂市", value: 52 },{ name: "滨州市", value: 88 },{ name: "东营市", value: 30 },{ name: "淄博市", value: 30 },{ name: "泰安市", value: 36 },{ name: "聊城市", value: 46 },{ name: "济宁市", value: 56 },{ name: "德州市", value: 28 },];var converntData = function (data) {var res = [];for (var i = 0; i < data.length; i++) {var geoCoord = sdGeoCoordMap[data[i].name];if (geoCoord) {res.push({name: data[i].name,value: geoCoord.concat(data[i].value),});}}return res;};var series = [];[["济南市", data_tmp]].forEach(function (item, i) {series.push(// 下面圆点{symbol: zuanshi,symbolSize: 30,label: {normal: {formatter: "{b}",position: "right",show: false, //是否显示地名},emphasis: {show: true,},},itemStyle: {normal: {color: "#fff",},},name: "light",type: "scatter",coordinateSystem: "geo",data: converntData(data_tmp.sort(function (a, b) {return b.value - a.value;}).slice(0, 20)),showEffectOn: "render",rippleEffect: {brushType: "stroke",},hoverAnimation: true,},{type: "map",map: "china",geoIndex: 0,aspectScale: 0.75, //长宽比showLegendSymbol: false, // 存在legend时显示label: {normal: {show: false,},emphasis: {show: false,textStyle: {color: "#fff",},},},roam: true,itemStyle: {normal: {areaColor: "#031525",borderColor: "#FFFFFF",},emphasis: {areaColor: "#2B91B7",},},animation: false,data: data_tmp,},// 黄圈圈{name: "Top 5",type: "scatter",coordinateSystem: "geo",symbol: mapTextBack,symbolSize: [70, 30],symbolOffset: [0, -33],label: {normal: {show: true,textStyle: {fontSize: 12,fontFamily: "Adobe Heiti Std",fontWeight: "bold",color: "#FFFFFF",},formatter(value) {if (value.length > 2) {return "值是:" + value.data.value[2];} else {return value.data.name;}},},},itemStyle: {normal: {color: "#dfae10", //标志颜色},},data: converntData(data_tmp.sort(function (a, b) {return b.value - a.value;}).slice(0, 20)), // 流量最大的前showEffectOn: "render",rippleEffect: {brushType: "stroke",},hoverAnimation: true,zlevel: 1,});});console.log("series");console.log(series);var that = this;var option = {tooltip: {trigger: "item",backgroundColor: "rgba(0,0,0,0)",formatter: function (item) {console.log(item, "item!!!!");if (item.componentSubType === "lines") {var tipHtml1 = "";tipHtml1 ='<div style="background:#fff;border-radius:10px;padding-top:10px;box-shadow:0 0 10px #666">' +'<div style="color:#fff;height:20px;border-radius:6px;font-size:12px;line-height:20px;background-color:#5861a2;text-align:center;margin:0 2px;">' +item.data.name +"</div>" +'<div style="text-align:center;color:#494949;padding:8px 6px">' +'<span style="font-size:18px;font-weight:bold;">' +"在运机组数:" +item.data.value +" " +"</span>" +"</div>" +"</div>";return tipHtml1;} else if (item.componentSubType === "effectScatter") {var tipHtml2 = "";tipHtml2 ='<div style="background:#fff;border-radius:10px;padding-top:10px;box-shadow:0 0 10px #666">' +'<div style="color:#fff;height:20px;border-radius:6px;font-size:12px;line-height:20px;background-color:#5861a2;text-align:center;margin:0 2px;">' +item.data.name +"</div>" +'<div style="text-align:center;color:#494949;padding:8px 6px">' +'<span style="font-size:18px;font-weight:bold;">' +"在运机组数:" +item.data.value[2] +" " +"</span>" +"</div>" +"</div>";return tipHtml2;} else if (item.componentSubType === "scatter") {var tipHtml3 = "";tipHtml3 ='<div style="background:#fff;border-radius:10px;padding-top:10px;box-shadow:0 0 10px #666">' +'<div style="color:#fff;height:20px;border-radius:6px;font-size:12px;line-height:20px;background-color:#5861a2;text-align:center;margin:0 2px;">' +item.data.name +"</div>" +'<div style="text-align:center;color:#494949;padding:8px 6px">' +'<span style="font-size:18px;font-weight:bold;">' +"在运机组数:" +item.data.value[2] +" " +"</span>" +"</div>" +"</div>";return tipHtml3;}},},backgroundColor: "rgb(0,0,0,0)", //背景色透明graphic: [{type: "group",left: pos.left,top: pos.top - 4,children: [{type: "line",left: 0,top: -20,shape: {x1: 0,y1: 0,x2: 85,y2: 0,},style: {stroke: style.lineColor,},},{type: "line",left: 0,top: 20,shape: {x1: 0,y1: 0,x2: 85,y2: 0,},style: {stroke: style.lineColor,},},],},{id: name[idx],type: "group",left: pos.left + 2,top: pos.top,children: [{type: "polyline",left: 90,top: -12,shape: {points: line,},style: {stroke: "transparent",key: name[0],},onclick: function () {var name = this.style.key;handleEvents.resetOption(myChart, option, name);},},{type: "text",left: 0,top: "middle",style: {text: name[0] === "山东" ? "山东省" : name[0],textAlign: "center",fill: style.textColor,font: style.font,},onclick: function () {that.ifShow = true;that.$emit("changeArea", "山东省");handleEvents.resetOption(myChart, option, "山东");},},{type: "text",left: 0,top: 10,style: {text: "SHANDONG",textAlign: "center",fill: style.textColor,font: '12px "Microsoft YaHei", sans-serif',},onclick: function () {that.ifShow = true;that.$emit("changeArea", "山东省");handleEvents.resetOption(myChart, option, "山东");},},],},],// 暂时先注释// visualMap: {// //图例值控制// min: 0,// max: 1,// calculable: true,// show: false,// color: ["#f44336", "#fc9700", "#ffde00", "#ffde00", "#00eaff"],// textStyle: {// color: "#fff",// },// },geo: {map: "山东",layoutCenter: ["55%", "50%"],layoutSize: "135%",label: {normal: {show: true,textStyle: {color: "#fff",},},emphasis: {textStyle: {color: "#fff",},},},roam: true, //是否允许缩放mapLocation: {width: "110%",height: "97%",},itemStyle: {normal: {borderColor: "rgba(147, 235, 248, 1)",borderWidth: 1,areaColor: {type: "radial",x: 0.5,y: 0.5,r: 0.8,colorStops: [{offset: 0,color: "rgba(147, 235, 248, 0)", // 0% 处的颜色},{offset: 1,color: "rgba(147, 235, 248, .2)", // 100% 处的颜色},],globalCoord: false, // 缺省为 false},shadowColor: "rgba(128, 217, 248, 1)",// shadowColor: 'rgba(255, 255, 255, 1)',shadowOffsetX: -2,shadowOffsetY: 2,shadowBlur: 10,},emphasis: {itemStyle: {areaColor: "#FFD181",borderColor: "#404a59",borderWidth: 1,},},},},series: series,};myChart.setOption(option);myChart.on("click", function (params) {var _self = this;if (cityMap[params.name]) {var url = cityMap[params.name];echarts.registerMap(params.name, url);handleEvents.resetOption(_self, option, params.name);}});},
代码量比较多,里面有一些冗余代码,大家可以自行选择是否删除
另外,我贴出的代码只包含地图部分,截图中的图例之类的,这里不做解释,欢迎大家留言讨论!