Toggle navigation
By
绿***绿
2020-10-17 05:58:27
脚本
16
21
作品使用的第三方脚本
/dep/echarts/map/js/china.js
数据管理
上传数据
支持小于 5M 任意格式(csv, xlsx, json, xml, ...)的数据文件
上传后可以通过生成的文件链接异步获取托管的数据。
历史数据
0 条
无历史数据
代码修改记录
信息提示
保存作品
对当前截图不满意?你还可以
上传本地截图
重新截图
作品名称
作品描述
标签
geo
grid
legend
markLine
markPoint
bar
effectScatter
line
lines
map
timeline
title
toolbox
tooltip
visualMap
作品默认版本
最新
16
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
20:11:45
图表已生成
整理代码
刷新
代码
let iconRQ = "image://" let effectScattersymbol = 'image://' let data = [{ name: "北京", value: [116.24, 39.55, 100], label: { position: [15, -5], }, symbolSize: 15, symbol: effectScattersymbol }, { name: "深圳", value: [114.271522, 22.753644], label: { position: [15, 10], }, symbolSize: 15, symbol: effectScattersymbol }, { name: "重庆", value: [106.54, 29.59], label: { position: [-25, 25], }, symbolSize: 15, symbol: effectScattersymbol }, { name: "南京", value: [118.78, 32.04], label: { position: [10, -20], }, symbolSize: 15, symbol: effectScattersymbol }, { name: "上海", value: [121.445, 31.213], label: { position: [15, 0], }, symbolSize: 8, symbol: 'circle' }, { name: "西安", value: [108.969, 34.285], label: { position: [-15, -30], }, symbolSize: 8, symbol: 'circle' }, { name: "珠海", value: [112.065, 21.948], label: { position: [-45, 0], }, symbolSize: 8, symbol: 'circle' }, { name: "成都", value: [104.071, 30.67], label: { position: [-22, -25], }, symbolSize: 8, symbol: 'circle' }, ]; let LableData = [{ name: "北京", value: [122.24, 39.0], lable: [10, 1] }, /* { name: "深圳", value: [116.271522, 20.753644], lable: [10, 1] },*/ { name: "重庆", value: [100.54, 27.0], lable: [10, 1] }, { name: "南京", value: [124.4, 32.5], lable: [10, 1] }, { name: "深圳", value: [120.3, 21.5], lable: [10, 1] }, ]; option = { backgroundColor: '#000f1e', xAxis: [], yAxis: [], grid: [], geo: { map: 'china', aspectScale: 0.85, layoutCenter: ["50%", "50%"], //地图位置 layoutSize: '140%', itemStyle: { normal: { shadowColor: '#276fce', shadowOffsetX: 0, shadowOffsetY: 15, opacity: 0.5, }, emphasis: { areaColor: '#276fce', } }, regions: [{ name: '南海诸岛', itemStyle: { areaColor: 'rgba(0, 10, 52, 1)', borderColor: 'rgba(0, 10, 52, 1)', normal: { opacity: 0, label: { show: false, color: "#009cc9", } }, }, label: { show: false, color: '#FFFFFF', fontSize: 12, }, }], }, series: [ // 常规地图 { type: 'map', mapType: 'china', aspectScale: 0.85, layoutCenter: ["50%", "50%"], //地图位置 layoutSize: '140%', zoom: 1, //当前视角的缩放比例 // roam: true, //是否开启平游或缩放 scaleLimit: { //滚轮缩放的极限控制 min: 1, max: 2 }, itemStyle: { normal: { areaColor: '#0c274b', borderColor: '#1cccff', borderWidth: 1.5 }, emphasis: { areaColor: '#0c274b', borderColor: '#1cccff', borderWidth: 2, opacity: 1, label: { show: false, color: "#fff" } } }, }, { //首都星图标 name: '首都', type: 'scatter', coordinateSystem: 'geo', data: [{ name: '首都', value: [116.24, 41.55, 100], }, ], symbol: iconRQ, symbolSize: 20, label: { normal: { show: false, }, emphasis: { show: false } }, }, // 区域散点图 { type: 'effectScatter', coordinateSystem: 'geo', zlevel: 2, // symbolSize: 8, rippleEffect: { //坐标点动画 period: 3, scale: 5, brushType: 'fill', color: '#808080' }, label: { normal: { show: true, formatter: '{b}', color: '#fff', fontWeight: "bold", fontSize: 18 } }, data: data, itemStyle: { //坐标点颜色 normal: { show: true, color: '#a9aaab', shadowBlur: 20, // shadowColor: '#808080' }, }, }, // 线 和 点 { type: 'lines', zlevel: 1, //设置这个才会有轨迹线的小尾巴 polyline: true, effect: { show: true, period: 10, trailLength: 0.7, color: '#fff', //流动点颜色 symbol: 'arrow', symbolSize: 6 }, lineStyle: { normal: { color: '#fff', //线条颜色 width: 0.5, curveness: 0.2, shadowColor: '#fff', } }, data: [{ fromName: "深圳", toName: "北京", coords: [ [114.271522, 22.753644], [116.24, 39.55], ] }, { fromName: "深圳", toName: "南京", coords: [ [114.271522, 22.753644], [118.78, 32.04], ] }, { fromName: "重庆", toName: "南京", coords: [ [106.54, 29.59], [118.78, 32.04], ] }, { fromName: "南京", toName: "北京", coords: [ [118.78, 32.04], [116.24, 39.55], ] }, { fromName: "北京", toName: "重庆", coords: [ [116.24, 39.55], [106.54, 29.59], ] }, { fromName: "深圳", toName: "重庆", coords: [ [114.271522, 22.753644], [106.54, 29.59], ] }, /* { fromName: "西安", toName: "北京", coords: [ [108.969, 34.285], [116.24, 39.55, 100], ] }, { fromName: "西安", toName: "成都", coords: [ [108.969, 34.285], [104.071,30.67], ] }, { fromName: "重庆", toName: "成都", coords: [ [106.54, 29.59], [104.071,30.67], ] }, { fromName: "珠海", toName: "深圳", coords: [ [112.065,21.948], [114.271522, 22.753644], ] }, { fromName: "珠海", toName: "重庆", coords: [ [112.065,21.948], [106.54, 29.59], ] }, { fromName: "上海", toName: "深圳", coords: [ [121.445,31.213], [114.271522, 22.753644], ] }, { fromName: "上海", toName: "南京", coords: [ [121.445,31.213], [118.78, 32.04], ] }, { fromName: "深圳", toName: "西安", coords: [ [114.271522, 22.753644], [108.969, 34.285], ] },*/ ], }, { //lable name: 'lable', type: 'scatter', coordinateSystem: 'geo', symbol: 'pin', symbolSize: [50, 20], hoverAnimation: true, zlevel: 2, label: { normal: { show: true, textStyle: { color: "#ffe500", fontSize: 16, fontWeight: 'bold', lineHeight: 15, }, formatter: function(params) { return params.data.lable[0] + "G" + '/' + params.data.lable[1] + "G" } } }, itemStyle: { normal: { color: 'transparent', //标志颜色 opacity: 1, } }, showEffectOn: 'render', rippleEffect: { brushType: 'stroke' }, data: LableData, }, ] }; myChart.on('mouseover', function(params) { let option = myChart.getOption(); if (params.name == '深圳') { option.series[2].data[1].symbolSize = 50; // option.series[2].data[1].symbol = effectScattersymbol; option.series[2].data[1].symbolRotate = 60; myChart.setOption(option); } else if (params.name == '北京') { option.series[2].data[0].symbolSize = 50; option.series[2].data[1].symbolRotate = 60; myChart.setOption(option); } else if (params.name == '南京') { option.series[2].data[3].symbolSize = 50; myChart.setOption(option); } else if (params.name == '重庆') { option.series[2].data[2].symbolSize = 50; myChart.setOption(option); } }); myChart.on('mouseout', function(params) { let option = myChart.getOption(); for (let i = 0; i < 4; i++) { if (option.series[2].data[i].symbolSize == 50) { option.series[2].data[i].symbolSize = 15; // option.series[2].data[1].symbol = 'circle' } } myChart.setOption(option); }); myChart.on('dblclick', function (params) { if (params.name == "深圳") { window.location.href='http://192.168.2.122:8082/'; }else if (params.name == "重庆") { window.location.href='http://113.105.80.199:8012'; }else if (params.name == "南京") { window.location.href='http://113.105.80.199:8012'; }else if (params.name == "北京") { window.location.href='http://113.105.80.199:8012'; }else if (params.name == "上海") { window.location.href='http://113.105.80.199:8012'; }else if (params.name == "西安") { window.location.href='http://113.105.80.199:8012'; }else if (params.name == "珠海") { window.location.href='http://113.105.80.199:8012'; }else if (params.name == "成都") { window.location.href='http://113.105.80.199:8012'; } }); myChart.on('click', function (params) { let option = ChartMap.getOption(); for(let i=0;i<4;i++){ if (option.series[2].data[i].symbolSize == 50) { option.series[2].data[i].symbolSize = 15; // option.series[2].data[1].symbol = 'circle' } } myChart.setOption(option); if (params.name == '深圳') { option.series[2].data[1].symbolSize = 50; // option.series[2].data[1].symbol = effectScattersymbol; option.series[2].data[1].symbolRotate = 60; myChart.setOption(option); } else if (params.name == '北京') { option.series[2].data[0].symbolSize = 50; option.series[2].data[1].symbolRotate = 60; myChart.setOption(option); } else if (params.name == '南京') { option.series[2].data[3].symbolSize = 50; myChart.setOption(option); } else if (params.name == '重庆') { option.series[2].data[2].symbolSize = 50; myChart.setOption(option); } }); setInMap() function setInMap() { /** 数据实时刷新 */ setIntervalMap = setInterval(function() { let option = myChart.getOption(); for (let i = 0; i < option.series[4].data.length; i++) { option.series[4].data[i].lable[1] = getRandom(10, 100, 0); option.series[4].data[i].lable[0] = getRandom(1, 10, 0); } myChart.setOption(option); }, 10000); } function getRandom(start, end, fixed) { let differ = end - start; let random = Math.random(); return (start + differ * random).toFixed(fixed) }