| /* |
| * 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; |