上海地铁可视化
配置项如下
var uploadedDataURL = "/asset/get/s/data-1547704761530-PZeTnGn7R.json";
const symbol = 'image://';
//image://http://xxx.xxx.xxx/a/b.png
function formatLngLat(str) {
if (str.includes(';')) {
const strArr = str.split(';');
const lnglats = strArr.map(lnglat => {
const ll = lnglat.split(',');
return [parseFloat(ll[0]), parseFloat(ll[1])];
});
return lnglats;
} else {
const ll = str.split(',');
return [parseFloat(ll[0]), parseFloat(ll[1])];
}
}
fetch(uploadedDataURL).then(res => res.json()).then(json => {
console.log(json);
const data = [],
names = [],
colors = [];
let stationData = [];
json.forEach(lines => {
lines.forEach(line => {
const buslines = line.buslines;
buslines.forEach(busline => {
const {
polyline,
name,
color,
stations
} = busline;
const lnglats = formatLngLat(polyline);
data.push({
coords: lnglats,
name: name,
lineStyle: {
normal: {
// color: color,
width: 3
}
}
});
names.push(name);
if (colors.length > 0) {
if (color != colors[colors.length - 1]) {
colors.push(color);
}
} else {
colors.push(color);
}
const sts = stations.map(station => {
const {
location,
name
} = station;
const lnglat = formatLngLat(location);
return {
value: lnglat.concat(20),
name: name
}
})
stationData = stationData.concat(sts);
});
});
});
const option = getOption();
data.forEach(line => {
const serier = {
name: line.name,
type: 'lines',
coordinateSystem: 'bmap',
polyline: true,
data: [line],
};
option.series.push(serier);
});
option.series.push({
name: '地铁站',
type: 'scatter',
coordinateSystem: 'bmap',
symbol: symbol,
symbolSize: 15,
data: stationData
});
names.push('地铁站');
option.legend = {
top: 20,
textStyle: {
color: '#fff',
},
data: names,
};
option.color = colors;
console.log(option);
myChart.setOption(option);
});
function getOption() {
return {
title: {
text: 'ShangHai SubWay'
},
tooltip: {},
bmap: {
center: [121.44780229094795, 31.27769952977698],
zoom: 12,
roam: true,
mapStyle: {
'styleJson': [{
'featureType': 'water',
'elementType': 'all',
'stylers': {
'color': '#031628'
}
}, {
'featureType': 'land',
'elementType': 'geometry',
'stylers': {
'color': '#000102'
}
}, {
'featureType': 'highway',
'elementType': 'all',
'stylers': {
'visibility': 'off'
}
}, {
'featureType': 'arterial',
'elementType': 'geometry.fill',
'stylers': {
'color': '#000000'
}
}, {
'featureType': 'arterial',
'elementType': 'geometry.stroke',
'stylers': {
'color': '#0b3d51'
}
}, {
'featureType': 'local',
'elementType': 'geometry',
'stylers': {
'color': '#000000'
}
}, {
'featureType': 'railway',
'elementType': 'geometry.fill',
'stylers': {
'color': '#000000'
}
}, {
'featureType': 'railway',
'elementType': 'geometry.stroke',
'stylers': {
'color': '#08304b'
}
},
{
'featureType': 'subway',
'elementType': 'geometry',
'stylers': {
'lightness': -70,
'visibility': 'off'
}
},
{
'featureType': 'building',
'elementType': 'geometry.fill',
'stylers': {
'color': '#000000'
}
}, {
'featureType': 'all',
'elementType': 'labels.text.fill',
'stylers': {
'color': '#857f7f'
}
}, {
'featureType': 'all',
'elementType': 'labels.text.stroke',
'stylers': {
'color': '#000000'
}
}, {
'featureType': 'building',
'elementType': 'geometry',
'stylers': {
'color': '#022338'
}
}, {
'featureType': 'green',
'elementType': 'geometry',
'stylers': {
'color': '#062032'
}
}, {
'featureType': 'boundary',
'elementType': 'all',
'stylers': {
'color': '#465b6c'
}
}, {
'featureType': 'manmade',
'elementType': 'all',
'stylers': {
'color': '#022338'
}
}, {
'featureType': 'label',
'elementType': 'all',
'stylers': {
'visibility': 'off'
}
}
]
}
},
series: []
};
}