You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
209 lines
7.6 KiB
209 lines
7.6 KiB
4 weeks ago
|
|
||
|
/*
|
||
|
* 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;
|