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