地图画线echarts lines配置项内容和展示

备忘录

配置项如下
       // 地图
 let geoCoordMap = {
     '上海': [121.4648, 31.2891],
     '东莞': [113.8953, 22.901],
     '东营': [118.7073, 37.5513],
     '中山': [113.4229, 22.478],
     '临汾': [111.4783, 36.1615],
     '临沂': [118.3118, 35.2936],
     '丹东': [124.541, 40.4242],
     '丽水': [119.5642, 28.1854],
     '乌鲁木齐': [87.9236, 43.5883],
     '佛山': [112.8955, 23.1097],
     '保定': [115.0488, 39.0948],
     '兰州': [103.5901, 36.3043],
     '包头': [110.3467, 41.4899],
     '北京': [116.4551, 40.2539],
     '北海': [109.314, 21.6211],
     '南京': [118.8062, 31.9208],
     '南宁': [108.479, 23.1152],
     '南昌': [116.0046, 28.6633],
     '南通': [121.1023, 32.1625],
     '厦门': [118.1689, 24.6478],
     '台州': [121.1353, 28.6688],
     '合肥': [117.29, 32.0581],
     '呼和浩特': [111.4124, 40.4901],
     '咸阳': [108.4131, 34.8706],
     '哈尔滨': [127.9688, 45.368],
     '唐山': [118.4766, 39.6826],
     '嘉兴': [120.9155, 30.6354],
     '大同': [113.7854, 39.8035],
     '大连': [122.2229, 39.4409],
     '天津': [117.4219, 39.4189],
     '太原': [112.3352, 37.9413],
     '威海': [121.9482, 37.1393],
     '宁波': [121.5967, 29.6466],
     '宝鸡': [107.1826, 34.3433],
     '宿迁': [118.5535, 33.7775],
     '常州': [119.4543, 31.5582],
     '广州': [113.5107, 23.2196],
     '廊坊': [116.521, 39.0509],
     '延安': [109.1052, 36.4252],
     '张家口': [115.1477, 40.8527],
     '徐州': [117.5208, 34.3268],
     '德州': [116.6858, 37.2107],
     '惠州': [114.6204, 23.1647],
     '成都': [103.9526, 30.7617],
     '扬州': [119.4653, 32.8162],
     '承德': [117.5757, 41.4075],
     '拉萨': [91.1865, 30.1465],
     '无锡': [120.3442, 31.5527],
     '日照': [119.2786, 35.5023],
     '昆明': [102.9199, 25.4663],
     '杭州': [119.5313, 29.8773],
     '枣庄': [117.323, 34.8926],
     '柳州': [109.3799, 24.9774],
     '株洲': [113.5327, 27.0319],
     '武汉': [114.3896, 30.6628],
     '汕头': [117.1692, 23.3405],
     '江门': [112.6318, 22.1484],
     '沈阳': [123.1238, 42.1216],
     '沧州': [116.8286, 38.2104],
     '河源': [114.917, 23.9722],
     '泉州': [118.3228, 25.1147],
     '泰安': [117.0264, 36.0516],
     '泰州': [120.0586, 32.5525],
     '济南': [117.1582, 36.8701],
     '济宁': [116.8286, 35.3375],
     '海口': [110.3893, 19.8516],
     '淄博': [118.0371, 36.6064],
     '淮安': [118.927, 33.4039],
     '深圳': [114.5435, 22.5439],
     '清远': [112.9175, 24.3292],
     '温州': [120.498, 27.8119],
     '渭南': [109.7864, 35.0299],
     '湖州': [119.8608, 30.7782],
     '湘潭': [112.5439, 27.7075],
     '滨州': [117.8174, 37.4963],
     '潍坊': [119.0918, 36.524],
     '烟台': [120.7397, 37.5128],
     '玉溪': [101.9312, 23.8898],
     '珠海': [113.7305, 22.1155],
     '盐城': [120.2234, 33.5577],
     '盘锦': [121.9482, 41.0449],
     '石家庄': [114.4995, 38.1006],
     '福州': [119.4543, 25.9222],
     '秦皇岛': [119.2126, 40.0232],
     '绍兴': [120.564, 29.7565],
     '聊城': [115.9167, 36.4032],
     '肇庆': [112.1265, 23.5822],
     '舟山': [122.2559, 30.2234],
     '苏州': [120.6519, 31.3989],
     '莱芜': [117.6526, 36.2714],
     '菏泽': [115.6201, 35.2057],
     '营口': [122.4316, 40.4297],
     '葫芦岛': [120.1575, 40.578],
     '衡水': [115.8838, 37.7161],
     '衢州': [118.6853, 28.8666],
     '西宁': [101.4038, 36.8207],
     '西安': [109.1162, 34.2004],
     '贵阳': [106.6992, 26.7682],
     '连云港': [119.1248, 34.552],
     '邢台': [114.8071, 37.2821],
     '邯郸': [114.4775, 36.535],
     '郑州': [113.4668, 34.6234],
     '鄂尔多斯': [108.9734, 39.2487],
     '重庆': [107.7539, 30.1904],
     '金华': [120.0037, 29.1028],
     '铜川': [109.0393, 35.1947],
     '银川': [106.3586, 38.1775],
     '镇江': [119.4763, 31.9702],
     '长春': [125.8154, 44.2584],
     '长沙': [113.0823, 28.2568],
     '长治': [112.8625, 36.4746],
     '阳泉': [113.4778, 38.0951],
     '青岛': [120.38, 36.07],
     '韶关': [113.7964, 24.7028],
     '敦煌': [94.71, 40.13],
     '库尔勒': [86.17369, 41.72643],
     '奎屯': [84.90167, 44.42689],
     '昌吉': [87.30822, 44.01117],
     '克拉玛依': [84.8697, 45.5905],

     '武威': [102.63, 37.93],
     '瓜州': [95.7832282721, 40.5319295174],
     '双塔水库': [95.8618987044, 40.5488634768],
     '哈密': [93.5219246754, 42.8243728820],
     '鄯善': [90.2207332610, 42.8731928218],
     '吐鲁番': [89.1960521828, 42.9572578648],
     '焉耆': [86.5807573704, 42.0652104472],
     '阿克苏': [80.2665024939, 41.1745589469],

     '托克马克': [75.2833, 42.8333],
     '撒马尔罕': [66.965159, 39.651099],
     '古佐尔': [66.258211, 38.612865],
     '巴米扬': [67.832346, 34.821217],
     '喀布尔': [69.189511, 34.562135],
     '白沙瓦': [71.555907, 34.011312],
     '斯利那加': [74.795235, 34.128023],
     '卢迪亚纳': [75.855612, 30.906297],
     '卡瑙杰': [79.919299, 27.065225],
     '那烂陀寺': [85.457013, 25.121574],


     '陕州': [111.103453, 34.720437],
     '洛阳': [112.454331, 34.618038],
     '开封': [114.307571, 34.797395],
     '冲绳岛那霸市': [127.680613, 26.226334],
     '奄美市': [129.493458, 28.376662],
     '屋久岛': [130.394543, 30.371910],
     '佐多岬': [130.659499, 30.997713],
     '南萨摩市鹿儿岛县': [130.318799, 31.418862],
     '长崎': [129.875784, 32.751862],
     '太宰府': [130.521372, 33.515718],
     '难波': [135.500393, 34.667345],
     '奈良东大寺': [135.839815, 34.689066],
 };

 let colors = ['lightskyblue', 'orange', 'greenyellow', 'limegreen',
     'mediumturquoise', 'mediumpurple'
 ];
 let scale = .63;
 option = {
     backgroundColor: 'midnightblue',
     geo: {
         map: 'world',
         roam: true,
         center: [103.1492, 36.2776],
         zoom: 5.554,
         itemStyle: {
             areaColor: 'rgba(255,255,255,.13)',
             borderColor: 'rgba(255,255,255,.33)'
         },
         emphasis: {
             itemStyle: {
                 areaColor: 'rgba(255,255,255,.33)'
             },
         }
     },
     series: [{
         name: '玄奘取经路线(去)',
         type: 'lines',
         polyline: false,
         lineStyle: {
             color: colors[0]
         },
         effect: {
             show: true,
             symbolSize: 8 * scale,
             constantSpeed: 50 * scale,
             trailLength: 0.5 * scale
         },
         data: []
     }, {
         name: '玄奘取经路线(去)',
         type: 'scatter',
         symbol: 'pin',
         symbolSize: 24 * scale,
         label: {
             show: true,
             formatter: param => {
                 return param.value[2].oldName;
             },
             fontSize: 16 * scale,
             position: 'top'
         },
         tooltip: {
             formatter: param => {
                 return `${param.value[2].oldName}<br>
                                    今 ${param.value[2].name}
                                    <br>${param.value[2].remark || ''}`;
             },
         },
         itemStyle: {
             color: colors[0]
         },
         data: []
     }, {
         name: '鉴真东渡路线',
         type: 'lines',
         polyline: true,
         lineStyle: {
             color: colors[1]
         },
         effect: {
             show: true,
             symbolSize: 8 * scale,
             constantSpeed: 50 * scale,
             trailLength: 0.5 * scale
         },
         data: []
     }, {
         name: '鉴真东渡路线',
         type: 'scatter',
         symbol: 'pin',
         symbolSize: 24 * scale,
         label: {
             show: true,
             formatter: param => {
                 return param.value[2].oldName;
             },
             fontSize: 16 * scale,
             position: 'top'
         },
         tooltip: {
             formatter: param => {
                 return `${param.value[2].oldName}<br>
                                    今 ${param.value[2].name}
                                    <br>${param.value[2].remark || ''}`;
             },
         },
         itemStyle: {
             color: colors[1]
         },
         data: []
     }, {
         name: '我去过的地方',
         type: 'scatter',
         symbol: 'arrow',
         symbolSize: 18 * scale,
         label: {
             show: true,
             formatter: param => {
                 return param.value[2].name;
             },
             fontSize: 16 * scale,
             position: 'bottom'
         },
         tooltip: {
             formatter: param => {
                 return `${param.value[2].name}<br>
                                    ${param.value[2].remark}`
             },
         },
         itemStyle: {
             color: colors[2]
         },
         data: []
     }].map(item => {
         return $.extend(true, item, {
             coordinateSystem: 'geo',
             zlevel: 1,
         })
     })
 };

 let xuanZangToPoints = [{
         name: '西安',
         oldName: '长安'
     },
     {
         name: '兰州',
         oldName: '兰州'
     },
     {
         name: '武威',
         oldName: '凉州',
         remark: '武威市凉州区'
     },
 ];
 let xuanZangToline = xuanZangToPoints.map(item => geoCoordMap[item.name]).filter(item => item);
 xuanZangToPoints = xuanZangToPoints.map(item => {
     if (!geoCoordMap[item.name]) return false;
     item = geoCoordMap[item.name].concat(item);
     return item
 }).filter(item => item);
 option.series[0].data = [{
     coords: xuanZangToline
 }];



 let xuanZangToPoints1 = [{
         name: '西安',
     },
     {
         name: '陕州',
     },
     {
         name: '长崎',
     },
 ];
 let xuanZangToline1 = xuanZangToPoints1.map(item => geoCoordMap[item.name]).filter(item => item);
 xuanZangToPoints1 = xuanZangToPoints1.map(item => {
     if (!geoCoordMap[item.name]) return false;
     item = geoCoordMap[item.name].concat(item);
     return item
 }).filter(item => item);

 option.series[2].data = [{
     coords: xuanZangToPoints1
 }];
    
截图如下