| <!DOCTYPE html> | 
 | <!-- | 
 | Licensed to the Apache Software Foundation (ASF) under one | 
 | or more contributor license agreements.  See the NOTICE file | 
 | distributed with this work for additional information | 
 | regarding copyright ownership.  The ASF licenses this file | 
 | to you under the Apache License, Version 2.0 (the | 
 | "License"); you may not use this file except in compliance | 
 | with the License.  You may obtain a copy of the License at | 
 |  | 
 |    http://www.apache.org/licenses/LICENSE-2.0 | 
 |  | 
 | Unless required by applicable law or agreed to in writing, | 
 | software distributed under the License is distributed on an | 
 | "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY | 
 | KIND, either express or implied.  See the License for the | 
 | specific language governing permissions and limitations | 
 | under the License. | 
 | --> | 
 |  | 
 |  | 
 | <html> | 
 |     <head> | 
 |         <meta charset="utf-8"> | 
 |         <meta name="viewport" content="width=device-width, initial-scale=1" /> | 
 |         <script src="lib/simpleRequire.js"></script> | 
 |         <script src="lib/config.js"></script> | 
 |         <script src="lib/jquery.min.js"></script> | 
 |         <script src="lib/facePrint.js"></script> | 
 |         <script src="lib/testHelper.js"></script> | 
 |         <link rel="stylesheet" href="lib/reset.css"> | 
 |     </head> | 
 |     <body> | 
 |         <style> | 
 |             .test-title { | 
 |                 background: #146402; | 
 |                 color: #fff; | 
 |             } | 
 |         </style> | 
 |  | 
 |  | 
 |         <div id="main0"></div> | 
 |  | 
 |  | 
 |         <script> | 
 |  | 
 |             require([ | 
 |                 'echarts', 'map/js/china' | 
 |             ], function (echarts) { | 
 |  | 
 |                 var 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.4651,36.3373], | 
 |                     '韶关': [113.7964,24.7028] | 
 |                 }; | 
 |  | 
 |                 var BJData = [ | 
 |                     [{name:'北京'}, {name:'上海',value:95}], | 
 |                     [{name:'北京'}, {name:'广州',value:90}], | 
 |                     [{name:'北京'}, {name:'大连',value:80}], | 
 |                     [{name:'北京'}, {name:'南宁',value:70}], | 
 |                     [{name:'北京'}, {name:'南昌',value:60}], | 
 |                     [{name:'北京'}, {name:'拉萨',value:50}], | 
 |                     [{name:'北京'}, {name:'长春',value:40}], | 
 |                     [{name:'北京'}, {name:'包头',value:30}], | 
 |                     [{name:'北京'}, {name:'重庆',value:20}], | 
 |                     [{name:'北京'}, {name:'常州',value:10}] | 
 |                 ]; | 
 |  | 
 |                 var SHData = [ | 
 |                     [{name:'上海'},{name:'包头',value:95}], | 
 |                     [{name:'上海'},{name:'昆明',value:90}], | 
 |                     [{name:'上海'},{name:'广州',value:80}], | 
 |                     [{name:'上海'},{name:'郑州',value:70}], | 
 |                     [{name:'上海'},{name:'长春',value:60}], | 
 |                     [{name:'上海'},{name:'重庆',value:50}], | 
 |                     [{name:'上海'},{name:'长沙',value:40}], | 
 |                     [{name:'上海'},{name:'北京',value:30}], | 
 |                     [{name:'上海'},{name:'丹东',value:20}], | 
 |                     [{name:'上海'},{name:'大连',value:10}] | 
 |                 ]; | 
 |  | 
 |                 var GZData = [ | 
 |                     [{name:'广州'},{name:'福州',value:95}], | 
 |                     [{name:'广州'},{name:'太原',value:90}], | 
 |                     [{name:'广州'},{name:'长春',value:80}], | 
 |                     [{name:'广州'},{name:'重庆',value:70}], | 
 |                     [{name:'广州'},{name:'西安',value:60}], | 
 |                     [{name:'广州'},{name:'成都',value:50}], | 
 |                     [{name:'广州'},{name:'常州',value:40}], | 
 |                     [{name:'广州'},{name:'北京',value:30}], | 
 |                     [{name:'广州'},{name:'北海',value:20}], | 
 |                     [{name:'广州'},{name:'海口',value:10}] | 
 |                 ]; | 
 |  | 
 |                 var planePath = 'path://M1705.06,1318.313v-89.254l-319.9-221.799l0.073-208.063c0.521-84.662-26.629-121.796-63.961-121.491c-37.332-0.305-64.482,36.829-63.961,121.491l0.073,208.063l-319.9,221.799v89.254l330.343-157.288l12.238,241.308l-134.449,92.931l0.531,42.034l175.125-42.917l175.125,42.917l0.531-42.034l-134.449-92.931l12.238-241.308L1705.06,1318.313z'; | 
 |  | 
 |                 var convertData = function (data) { | 
 |                     var res = []; | 
 |                     for (var i = 0; i < data.length; i++) { | 
 |                         var dataItem = data[i]; | 
 |                         var fromCoord = geoCoordMap[dataItem[0].name]; | 
 |                         var toCoord = geoCoordMap[dataItem[1].name]; | 
 |                         if (fromCoord && toCoord) { | 
 |                             res.push({ | 
 |                                 fromName: dataItem[0].name, | 
 |                                 toName: dataItem[1].name, | 
 |                                 coords: [fromCoord, toCoord] | 
 |                             }); | 
 |                         } | 
 |                     } | 
 |                     return res; | 
 |                 }; | 
 |  | 
 |                 var color = ['#a6c84c', '#ffa022', '#46bee9']; | 
 |                 var series = []; | 
 |                 [['北京', BJData], ['上海', SHData], ['广州', GZData]].forEach(function (item, i) { | 
 |                     series.push({ | 
 |                         name: item[0] + ' Top10', | 
 |                         type: 'lines', | 
 |                         zlevel: 1, | 
 |                         effect: { | 
 |                             show: true, | 
 |                             period: 1, | 
 |                             trailLength: 0.7, | 
 |                             color: '#fff', | 
 |                             symbol: 'line', | 
 |                             symbolSize: 3 | 
 |                         }, | 
 |                         lineStyle: { | 
 |                             normal: { | 
 |                                 color: color[i], | 
 |                                 width: 0, | 
 |                                 curveness: 0.2 | 
 |                             } | 
 |                         }, | 
 |                         data: convertData(item[1]) | 
 |                     }, | 
 |                     { | 
 |                         name: item[0] + ' Top10', | 
 |                         type: 'lines', | 
 |                         zlevel: 2, | 
 |                         symbol: ['none', 'arrow'], | 
 |                         symbolSize: 10, | 
 |                         effect: { | 
 |                             show: true, | 
 |                             period: 1, | 
 |                             trailLength: 0, | 
 |                             symbol: planePath, | 
 |                             symbolSize: 15 | 
 |                         }, | 
 |                         lineStyle: { | 
 |                             normal: { | 
 |                                 color: color[i], | 
 |                                 width: 1, | 
 |                                 opacity: 0.6, | 
 |                                 curveness: 0.2 | 
 |                             } | 
 |                         }, | 
 |                         data: convertData(item[1]) | 
 |                     }, | 
 |                     { | 
 |                         name: item[0] + ' Top10', | 
 |                         type: 'effectScatter', | 
 |                         coordinateSystem: 'geo', | 
 |                         zlevel: 2, | 
 |                         rippleEffect: { | 
 |                             brushType: 'stroke' | 
 |                         }, | 
 |                         label: { | 
 |                             normal: { | 
 |                                 show: true, | 
 |                                 position: 'right', | 
 |                                 formatter: '{b}' | 
 |                             } | 
 |                         }, | 
 |                         symbolSize: function (val) { | 
 |                             return val[2] / 8; | 
 |                         }, | 
 |                         itemStyle: { | 
 |                             normal: { | 
 |                                 color: color[i] | 
 |                             } | 
 |                         }, | 
 |                         data: item[1].map(function (dataItem) { | 
 |                             return { | 
 |                                 name: dataItem[1].name, | 
 |                                 value: geoCoordMap[dataItem[1].name].concat([dataItem[1].value]) | 
 |                             }; | 
 |                         }) | 
 |                     }); | 
 |                 }); | 
 |  | 
 |                 var option = { | 
 |                     backgroundColor: '#404a59', | 
 |                     title : { | 
 |                         text: '模拟迁徙', | 
 |                         subtext: '数据纯属虚构', | 
 |                         left: 'center', | 
 |                         textStyle : { | 
 |                             color: '#fff' | 
 |                         } | 
 |                     }, | 
 |                     tooltip : { | 
 |                         trigger: 'item' | 
 |                     }, | 
 |                     legend: { | 
 |                         orient: 'vertical', | 
 |                         top: 'bottom', | 
 |                         left: 'right', | 
 |                         data:['北京 Top10', '上海 Top10', '广州 Top10'], | 
 |                         textStyle: { | 
 |                             color: '#fff' | 
 |                         }, | 
 |                         selectedMode: 'single' | 
 |                     }, | 
 |                     geo: { | 
 |                         map: 'china', | 
 |                         label: { | 
 |                             emphasis: { | 
 |                                 show: false | 
 |                             } | 
 |                         }, | 
 |                         roam: true, | 
 |                         itemStyle: { | 
 |                             normal: { | 
 |                                 areaColor: '#323c48', | 
 |                                 borderColor: '#404a59' | 
 |                             }, | 
 |                             emphasis: { | 
 |                                 areaColor: '#2a333d' | 
 |                             } | 
 |                         } | 
 |                     }, | 
 |                     series: series | 
 |                 }; | 
 |  | 
 |                 testHelper.create(echarts, 'main0', { | 
 |                     option: option | 
 |                 }); | 
 |             }); | 
 |  | 
 |         </script> | 
 |     </body> | 
 | </html> |