| <!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" /> | 
 |         <link rel="stylesheet" href="lib/reset.css" /> | 
 |         <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> | 
 |         <script src="https://api.map.baidu.com/api?v=3.0&ak=KOmVjPVUAey1G2E8zNhPiuQ6QiEmAwZu&__ec_v__=20200330"></script> | 
 |         <!-- <script src="https://www.echartsjs.com/examples/vendors/echarts/extension/bmap.js?_ec_v__=20200330"></script> --> | 
 |     </head> | 
 |     <body> | 
 |         <div id="main0"></div> | 
 |         <div id="main1"></div> | 
 |  | 
 |         <script> | 
 |             require([ | 
 |                 'echarts', 'extension/bmap' | 
 |             ], function (echarts) { | 
 |                 var symbolIcon = ''; | 
 |                 var option = { | 
 |                     bmap: { | 
 |                         center: [116, 31], | 
 |                         zoom: 7, | 
 |                         roam: true | 
 |                     }, | 
 |                     series: [{ | 
 |                         coordinateSystem: 'bmap', | 
 |                         symbol: 'image://' + symbolIcon, | 
 |                         symbolSize: [15, 30], | 
 |                         symbolRotate: function(value, params) { | 
 |                             return -value[2] | 
 |                         }, | 
 |                         label: { | 
 |                             show: true, | 
 |                             position: 'top', | 
 |                             distance: 15, | 
 |                             formatter: function(params) { | 
 |                                 return params.name + '(' + params.value[2] + 'deg)' | 
 |                             }, | 
 |                             verticalAlign: 'middle', | 
 |                             align: 'center', | 
 |                             borderWidth: 1.25, | 
 |                             borderRadius: 2, | 
 |                             borderColor: '#14c4ba', | 
 |                             backgroundColor: '#fff', | 
 |                             padding: [5, 8, 3, 8], | 
 |                             color: '#000' | 
 |                         }, | 
 |                         data: [ | 
 |                             { | 
 |                                 name: 'car1', | 
 |                                 value: [121.15, 31.89, 30] | 
 |                             }, | 
 |                             { | 
 |                                 name: 'car2', | 
 |                                 value: [117.781327, 32.608266, 120] | 
 |                             }, | 
 |                             { | 
 |                                 name: 'car3', | 
 |                                 value: [117.5, 30.608266, 90] | 
 |                             }, | 
 |                             { | 
 |                                 name: 'car4', | 
 |                                 value: [115.5, 30.2, 180] | 
 |                             } | 
 |                         ], | 
 |                         encode: { | 
 |                             value: 2 | 
 |                         }, | 
 |                         type: 'scatter' | 
 |                     }] | 
 |                 }; | 
 |  | 
 |                 var series = { | 
 |                     name: 'Original', | 
 |                     type: 'scatter', | 
 |                     symbol: 'circle', | 
 |                     data: (function() { | 
 |                         function random(max) { | 
 |                             return +(Math.random() * max).toFixed(3); | 
 |                         } | 
 |                         var seriesData = []; | 
 |                         for (var i = 0; i < 20; i++) { | 
 |                             seriesData.push([random(10), random(10), random(20)]); | 
 |                         } | 
 |                         return seriesData; | 
 |                     })() | 
 |                 }; | 
 |  | 
 |                 var option2 = { | 
 |                     legend: {}, | 
 |                     xAxis: {}, | 
 |                     yAxis: {}, | 
 |                     tooltip: { | 
 |                         formatter: function(params) { | 
 |                             return params.marker + params.seriesName | 
 |                                 + (params.seriesName === 'Offset' ? '<br/>offset: ' + params.value[2] : ''); | 
 |                         } | 
 |                     }, | 
 |                     series: [ | 
 |                         series, | 
 |                         Object.assign({}, series, { | 
 |                             name: 'Offset', | 
 |                             symbol: 'circle', | 
 |                             // symbolOffset: 20, | 
 |                             symbolOffset: function(data) { | 
 |                                 return data[2] | 
 |                             } | 
 |                         }) | 
 |                     ] | 
 |                 }; | 
 |  | 
 |                 var chart = testHelper.create(echarts, 'main0', { | 
 |                     title: 'Rotates the symbol as we need', | 
 |                     option: option | 
 |                 }); | 
 |                 var chart2 = testHelper.create(echarts, 'main1', { | 
 |                     title: 'Symbol should have various offset', | 
 |                     option: option2 | 
 |                 }); | 
 |             }); | 
 |         </script> | 
 |  | 
 |     </body> | 
 | </html> |