| /* | 
| * 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. | 
| */ | 
|   | 
| // @ts-nocheck | 
| /* global BMap */ | 
|   | 
| import { | 
|     util as zrUtil, | 
|     graphic, | 
|     matrix | 
| } from 'echarts'; | 
|   | 
| function BMapCoordSys(bmap, api) { | 
|     this._bmap = bmap; | 
|     this.dimensions = ['lng', 'lat']; | 
|     this._mapOffset = [0, 0]; | 
|   | 
|     this._api = api; | 
|   | 
|     this._projection = new BMap.MercatorProjection(); | 
| } | 
|   | 
| BMapCoordSys.prototype.type = 'bmap'; | 
|   | 
| BMapCoordSys.prototype.dimensions = ['lng', 'lat']; | 
|   | 
| BMapCoordSys.prototype.setZoom = function (zoom) { | 
|     this._zoom = zoom; | 
| }; | 
|   | 
| BMapCoordSys.prototype.setCenter = function (center) { | 
|     this._center = this._projection.lngLatToPoint(new BMap.Point(center[0], center[1])); | 
| }; | 
|   | 
| BMapCoordSys.prototype.setMapOffset = function (mapOffset) { | 
|     this._mapOffset = mapOffset; | 
| }; | 
|   | 
| BMapCoordSys.prototype.getBMap = function () { | 
|     return this._bmap; | 
| }; | 
|   | 
| BMapCoordSys.prototype.dataToPoint = function (data) { | 
|     const point = new BMap.Point(data[0], data[1]); | 
|     // TODO mercator projection is toooooooo slow | 
|     // let mercatorPoint = this._projection.lngLatToPoint(point); | 
|   | 
|     // let width = this._api.getZr().getWidth(); | 
|     // let height = this._api.getZr().getHeight(); | 
|     // let divider = Math.pow(2, 18 - 10); | 
|     // return [ | 
|     //     Math.round((mercatorPoint.x - this._center.x) / divider + width / 2), | 
|     //     Math.round((this._center.y - mercatorPoint.y) / divider + height / 2) | 
|     // ]; | 
|     const px = this._bmap.pointToOverlayPixel(point); | 
|     const mapOffset = this._mapOffset; | 
|     return [px.x - mapOffset[0], px.y - mapOffset[1]]; | 
| }; | 
|   | 
| BMapCoordSys.prototype.pointToData = function (pt) { | 
|     const mapOffset = this._mapOffset; | 
|     pt = this._bmap.overlayPixelToPoint({ | 
|         x: pt[0] + mapOffset[0], | 
|         y: pt[1] + mapOffset[1] | 
|     }); | 
|     return [pt.lng, pt.lat]; | 
| }; | 
|   | 
| BMapCoordSys.prototype.getViewRect = function () { | 
|     const api = this._api; | 
|     return new graphic.BoundingRect(0, 0, api.getWidth(), api.getHeight()); | 
| }; | 
|   | 
| BMapCoordSys.prototype.getRoamTransform = function () { | 
|     return matrix.create(); | 
| }; | 
|   | 
| BMapCoordSys.prototype.prepareCustoms = function () { | 
|     const rect = this.getViewRect(); | 
|     return { | 
|         coordSys: { | 
|             // The name exposed to user is always 'cartesian2d' but not 'grid'. | 
|             type: 'bmap', | 
|             x: rect.x, | 
|             y: rect.y, | 
|             width: rect.width, | 
|             height: rect.height | 
|         }, | 
|         api: { | 
|             coord: zrUtil.bind(this.dataToPoint, this), | 
|             size: zrUtil.bind(dataToCoordSize, this) | 
|         } | 
|     }; | 
| }; | 
|   | 
| BMapCoordSys.prototype.convertToPixel = function (ecModel, finder, value) { | 
|     // here we ignore finder as only one bmap component is allowed | 
|     return this.dataToPoint(value); | 
| }; | 
|   | 
| BMapCoordSys.prototype.convertFromPixel = function (ecModel, finder, value) { | 
|     return this.pointToData(value); | 
| }; | 
|   | 
| function dataToCoordSize(dataSize, dataItem) { | 
|     dataItem = dataItem || [0, 0]; | 
|     return zrUtil.map([0, 1], function (dimIdx) { | 
|         const val = dataItem[dimIdx]; | 
|         const halfSize = dataSize[dimIdx] / 2; | 
|         const p1 = []; | 
|         const p2 = []; | 
|         p1[dimIdx] = val - halfSize; | 
|         p2[dimIdx] = val + halfSize; | 
|         p1[1 - dimIdx] = p2[1 - dimIdx] = dataItem[1 - dimIdx]; | 
|         return Math.abs(this.dataToPoint(p1)[dimIdx] - this.dataToPoint(p2)[dimIdx]); | 
|     }, this); | 
| } | 
|   | 
| let Overlay; | 
|   | 
| // For deciding which dimensions to use when creating list data | 
| BMapCoordSys.dimensions = BMapCoordSys.prototype.dimensions; | 
|   | 
| function createOverlayCtor() { | 
|     function Overlay(root) { | 
|         this._root = root; | 
|     } | 
|   | 
|     Overlay.prototype = new BMap.Overlay(); | 
|     /** | 
|      * 初始化 | 
|      * | 
|      * @param {BMap.Map} map | 
|      * @override | 
|      */ | 
|     Overlay.prototype.initialize = function (map) { | 
|         map.getPanes().labelPane.appendChild(this._root); | 
|         return this._root; | 
|     }; | 
|     /** | 
|      * @override | 
|      */ | 
|     Overlay.prototype.draw = function () {}; | 
|   | 
|     return Overlay; | 
| } | 
|   | 
| BMapCoordSys.create = function (ecModel, api) { | 
|     let bmapCoordSys; | 
|     const root = api.getDom(); | 
|   | 
|     // TODO Dispose | 
|     ecModel.eachComponent('bmap', function (bmapModel) { | 
|         const painter = api.getZr().painter; | 
|         const viewportRoot = painter.getViewportRoot(); | 
|         if (typeof BMap === 'undefined') { | 
|             throw new Error('BMap api is not loaded'); | 
|         } | 
|         Overlay = Overlay || createOverlayCtor(); | 
|         if (bmapCoordSys) { | 
|             throw new Error('Only one bmap component can exist'); | 
|         } | 
|         let bmap; | 
|         if (!bmapModel.__bmap) { | 
|             // Not support IE8 | 
|             let bmapRoot = root.querySelector('.ec-extension-bmap'); | 
|             if (bmapRoot) { | 
|                 // Reset viewport left and top, which will be changed | 
|                 // in moving handler in BMapView | 
|                 viewportRoot.style.left = '0px'; | 
|                 viewportRoot.style.top = '0px'; | 
|                 root.removeChild(bmapRoot); | 
|             } | 
|             bmapRoot = document.createElement('div'); | 
|             bmapRoot.className = 'ec-extension-bmap'; | 
|             // fix #13424 | 
|             bmapRoot.style.cssText = 'position:absolute;width:100%;height:100%'; | 
|             root.appendChild(bmapRoot); | 
|   | 
|             // initializes bmap | 
|             let mapOptions = bmapModel.get('mapOptions'); | 
|             if (mapOptions) { | 
|                 mapOptions = zrUtil.clone(mapOptions); | 
|                 // Not support `mapType`, use `bmap.setMapType(MapType)` instead. | 
|                 delete mapOptions.mapType; | 
|             } | 
|   | 
|             bmap = bmapModel.__bmap = new BMap.Map(bmapRoot, mapOptions); | 
|   | 
|             const overlay = new Overlay(viewportRoot); | 
|             bmap.addOverlay(overlay); | 
|   | 
|             // Override | 
|             painter.getViewportRootOffset = function () { | 
|                 return {offsetLeft: 0, offsetTop: 0}; | 
|             }; | 
|         } | 
|         bmap = bmapModel.__bmap; | 
|   | 
|         // Set bmap options | 
|         // centerAndZoom before layout and render | 
|         const center = bmapModel.get('center'); | 
|         const zoom = bmapModel.get('zoom'); | 
|         if (center && zoom) { | 
|             const bmapCenter = bmap.getCenter(); | 
|             const bmapZoom = bmap.getZoom(); | 
|             const centerOrZoomChanged = bmapModel.centerOrZoomChanged([bmapCenter.lng, bmapCenter.lat], bmapZoom); | 
|             if (centerOrZoomChanged) { | 
|                 const pt = new BMap.Point(center[0], center[1]); | 
|                 bmap.centerAndZoom(pt, zoom); | 
|             } | 
|         } | 
|   | 
|         bmapCoordSys = new BMapCoordSys(bmap, api); | 
|         bmapCoordSys.setMapOffset(bmapModel.__mapOffset || [0, 0]); | 
|         bmapCoordSys.setZoom(zoom); | 
|         bmapCoordSys.setCenter(center); | 
|   | 
|         bmapModel.coordinateSystem = bmapCoordSys; | 
|     }); | 
|   | 
|     ecModel.eachSeries(function (seriesModel) { | 
|         if (seriesModel.get('coordinateSystem') === 'bmap') { | 
|             seriesModel.coordinateSystem = bmapCoordSys; | 
|         } | 
|     }); | 
|   | 
|     // return created coordinate systems | 
|     return bmapCoordSys && [bmapCoordSys]; | 
| }; | 
|   | 
| export default BMapCoordSys; |