地图
配置项如下
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)
}