上海地铁可视化echarts scatter配置项内容和展示

上海地铁可视化

配置项如下
      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: []
    };
}
    
截图如下