123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252 |
- /*
- * 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.
- */
- /**
- * AUTO-GENERATED FILE. DO NOT MODIFY.
- */
- /*
- * 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.
- */
- import { __extends } from "tslib";
- import * as zrUtil from 'zrender/lib/core/util.js';
- import BoundingRect from 'zrender/lib/core/BoundingRect.js';
- import View from '../View.js';
- import geoSourceManager from './geoSourceManager.js';
- import { SINGLE_REFERRING } from '../../util/model.js';
- import { warn } from '../../util/log.js';
- var GEO_DEFAULT_PARAMS = {
- 'geoJSON': {
- aspectScale: 0.75,
- invertLongitute: true
- },
- 'geoSVG': {
- aspectScale: 1,
- invertLongitute: false
- }
- };
- export var geo2DDimensions = ['lng', 'lat'];
- var Geo =
- /** @class */
- function (_super) {
- __extends(Geo, _super);
- function Geo(name, map, opt) {
- var _this = _super.call(this, name) || this;
- _this.dimensions = geo2DDimensions;
- _this.type = 'geo'; // Only store specified name coord via `addGeoCoord`.
- _this._nameCoordMap = zrUtil.createHashMap();
- _this.map = map;
- var projection = opt.projection;
- var source = geoSourceManager.load(map, opt.nameMap, opt.nameProperty);
- var resource = geoSourceManager.getGeoResource(map);
- var resourceType = _this.resourceType = resource ? resource.type : null;
- var regions = _this.regions = source.regions;
- var defaultParams = GEO_DEFAULT_PARAMS[resource.type];
- _this._regionsMap = source.regionsMap;
- _this.regions = source.regions;
- if (process.env.NODE_ENV !== 'production' && projection) {
- // Do some check
- if (resourceType === 'geoSVG') {
- if (process.env.NODE_ENV !== 'production') {
- warn("Map " + map + " with SVG source can't use projection. Only GeoJSON source supports projection.");
- }
- projection = null;
- }
- if (!(projection.project && projection.unproject)) {
- if (process.env.NODE_ENV !== 'production') {
- warn('project and unproject must be both provided in the projeciton.');
- }
- projection = null;
- }
- }
- _this.projection = projection;
- var boundingRect;
- if (projection) {
- // Can't reuse the raw bounding rect
- for (var i = 0; i < regions.length; i++) {
- var regionRect = regions[i].getBoundingRect(projection);
- boundingRect = boundingRect || regionRect.clone();
- boundingRect.union(regionRect);
- }
- } else {
- boundingRect = source.boundingRect;
- }
- _this.setBoundingRect(boundingRect.x, boundingRect.y, boundingRect.width, boundingRect.height); // aspectScale and invertLongitute actually is the parameters default raw projection.
- // So we ignore them if projection is given.
- // Ignore default aspect scale if projection exits.
- _this.aspectScale = projection ? 1 : zrUtil.retrieve2(opt.aspectScale, defaultParams.aspectScale); // Not invert longitude if projection exits.
- _this._invertLongitute = projection ? false : defaultParams.invertLongitute;
- return _this;
- }
- Geo.prototype._transformTo = function (x, y, width, height) {
- var rect = this.getBoundingRect();
- var invertLongitute = this._invertLongitute;
- rect = rect.clone();
- if (invertLongitute) {
- // Longitude is inverted.
- rect.y = -rect.y - rect.height;
- }
- var rawTransformable = this._rawTransformable;
- rawTransformable.transform = rect.calculateTransform(new BoundingRect(x, y, width, height));
- var rawParent = rawTransformable.parent;
- rawTransformable.parent = null;
- rawTransformable.decomposeTransform();
- rawTransformable.parent = rawParent;
- if (invertLongitute) {
- rawTransformable.scaleY = -rawTransformable.scaleY;
- }
- this._updateTransform();
- };
- Geo.prototype.getRegion = function (name) {
- return this._regionsMap.get(name);
- };
- Geo.prototype.getRegionByCoord = function (coord) {
- var regions = this.regions;
- for (var i = 0; i < regions.length; i++) {
- var region = regions[i];
- if (region.type === 'geoJSON' && region.contain(coord)) {
- return regions[i];
- }
- }
- };
- /**
- * Add geoCoord for indexing by name
- */
- Geo.prototype.addGeoCoord = function (name, geoCoord) {
- this._nameCoordMap.set(name, geoCoord);
- };
- /**
- * Get geoCoord by name
- */
- Geo.prototype.getGeoCoord = function (name) {
- var region = this._regionsMap.get(name); // Calculate center only on demand.
- return this._nameCoordMap.get(name) || region && region.getCenter();
- };
- Geo.prototype.dataToPoint = function (data, noRoam, out) {
- if (zrUtil.isString(data)) {
- // Map area name to geoCoord
- data = this.getGeoCoord(data);
- }
- if (data) {
- var projection = this.projection;
- if (projection) {
- // projection may return null point.
- data = projection.project(data);
- }
- return data && this.projectedToPoint(data, noRoam, out);
- }
- };
- Geo.prototype.pointToData = function (point) {
- var projection = this.projection;
- if (projection) {
- // projection may return null point.
- point = projection.unproject(point);
- }
- return point && this.pointToProjected(point);
- };
- /**
- * Point to projected data. Same with pointToData when projection is used.
- */
- Geo.prototype.pointToProjected = function (point) {
- return _super.prototype.pointToData.call(this, point);
- };
- Geo.prototype.projectedToPoint = function (projected, noRoam, out) {
- return _super.prototype.dataToPoint.call(this, projected, noRoam, out);
- };
- Geo.prototype.convertToPixel = function (ecModel, finder, value) {
- var coordSys = getCoordSys(finder);
- return coordSys === this ? coordSys.dataToPoint(value) : null;
- };
- Geo.prototype.convertFromPixel = function (ecModel, finder, pixel) {
- var coordSys = getCoordSys(finder);
- return coordSys === this ? coordSys.pointToData(pixel) : null;
- };
- return Geo;
- }(View);
- ;
- zrUtil.mixin(Geo, View);
- function getCoordSys(finder) {
- var geoModel = finder.geoModel;
- var seriesModel = finder.seriesModel;
- return geoModel ? geoModel.coordinateSystem : seriesModel ? seriesModel.coordinateSystem // For map series.
- || (seriesModel.getReferringComponents('geo', SINGLE_REFERRING).models[0] || {}).coordinateSystem : null;
- }
- export default Geo;
|