echarts实现山东地图可放大缩小可下钻

您所在的位置:网站首页 显示山东省地图的app echarts实现山东地图可放大缩小可下钻

echarts实现山东地图可放大缩小可下钻

2023-12-19 04:39| 来源: 网络整理| 查看: 265

最近遇到一个新需求,要求展示山东省的地图,并且点击可进入地级市地图。这可是难倒了我,我尝试着用不同的方法,高德地图、百度地图等,发现都有一定的缺陷,最终决定使用echarts实现,下面就来跟大家分享一下我的心路历程。 先来看一下效果: 在这里插入图片描述 点击济南市即可进入济南市的地图: 在这里插入图片描述 实现步骤如下所示: 1.图中的地图都是需要去网站上自行下载的,包括山东省地图,各个地级市的地图都需要进行下载,网址http://datav.aliyun.com/tools/atlas/,下载格式为.json 2.地图中需要用到的小图标,小图片什么的,需要提前转换成base64格式,百度搜一下,有不少在线转换工具可以直接转换 3.安装echarts,并导入 4.html代码:

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, fill scale: 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, fill scale: 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 for (var x = 0; x 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 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; }, // 设置effectscatter initSeriesData: function (data) { console.log(data, "22222222222"); var temp = []; for (var i = 0; i 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 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] item.symbol = iconYellow; item.symbolSize = 20; }); return data; }; var symbolFunc = function (data) { var iconColor; data.forEach((item) => { iconColor = 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 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 = '' + '' + item.data.name + "" + '' + '' + "在运机组数:" + item.data.value + " " + "" + "" + ""; return tipHtml1; } else if (item.componentSubType === "effectScatter") { var tipHtml2 = ""; tipHtml2 = '' + '' + item.data.name + "" + '' + '' + "在运机组数:" + item.data.value[2] + " " + "" + "" + ""; return tipHtml2; } else if (item.componentSubType === "scatter") { var tipHtml3 = ""; tipHtml3 = '' + '' + item.data.name + "" + '' + '' + "在运机组数:" + item.data.value[2] + " " + "" + "" + ""; 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); } }); },

代码量比较多,里面有一些冗余代码,大家可以自行选择是否删除 另外,我贴出的代码只包含地图部分,截图中的图例之类的,这里不做解释,欢迎大家留言讨论!



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3