123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177 |
- import { __extends } from "tslib";
- import * as graphic from '../../util/graphic.js';
- import MapDraw from '../../component/helper/MapDraw.js';
- import ChartView from '../../view/Chart.js';
- import { setLabelStyle, getLabelStatesModels } from '../../label/labelStyle.js';
- import { setStatesFlag, Z2_EMPHASIS_LIFT } from '../../util/states.js';
- var MapView = function (_super) {
- __extends(MapView, _super);
- function MapView() {
- var _this = _super !== null && _super.apply(this, arguments) || this;
- _this.type = MapView.type;
- return _this;
- }
- MapView.prototype.render = function (mapModel, ecModel, api, payload) {
-
- if (payload && payload.type === 'mapToggleSelect' && payload.from === this.uid) {
- return;
- }
- var group = this.group;
- group.removeAll();
- if (mapModel.getHostGeoModel()) {
- return;
- }
- if (this._mapDraw && payload && payload.type === 'geoRoam') {
- this._mapDraw.resetForLabelLayout();
- }
-
- if (!(payload && payload.type === 'geoRoam' && payload.componentType === 'series' && payload.seriesId === mapModel.id)) {
- if (mapModel.needsDrawMap) {
- var mapDraw = this._mapDraw || new MapDraw(api);
- group.add(mapDraw.group);
- mapDraw.draw(mapModel, ecModel, api, this, payload);
- this._mapDraw = mapDraw;
- } else {
-
- this._mapDraw && this._mapDraw.remove();
- this._mapDraw = null;
- }
- } else {
- var mapDraw = this._mapDraw;
- mapDraw && group.add(mapDraw.group);
- }
- mapModel.get('showLegendSymbol') && ecModel.getComponent('legend') && this._renderSymbols(mapModel, ecModel, api);
- };
- MapView.prototype.remove = function () {
- this._mapDraw && this._mapDraw.remove();
- this._mapDraw = null;
- this.group.removeAll();
- };
- MapView.prototype.dispose = function () {
- this._mapDraw && this._mapDraw.remove();
- this._mapDraw = null;
- };
- MapView.prototype._renderSymbols = function (mapModel, ecModel, api) {
- var originalData = mapModel.originalData;
- var group = this.group;
- originalData.each(originalData.mapDimension('value'), function (value, originalDataIndex) {
- if (isNaN(value)) {
- return;
- }
- var layout = originalData.getItemLayout(originalDataIndex);
- if (!layout || !layout.point) {
-
- return;
- }
- var point = layout.point;
- var offset = layout.offset;
- var circle = new graphic.Circle({
- style: {
-
-
-
-
-
-
- fill: mapModel.getData().getVisual('style').fill
- },
- shape: {
- cx: point[0] + offset * 9,
- cy: point[1],
- r: 3
- },
- silent: true,
-
- z2: 8 + (!offset ? Z2_EMPHASIS_LIFT + 1 : 0)
- });
-
-
-
-
-
-
-
-
-
- if (!offset) {
- var fullData = mapModel.mainSeries.getData();
- var name_1 = originalData.getName(originalDataIndex);
- var fullIndex_1 = fullData.indexOfName(name_1);
- var itemModel = originalData.getItemModel(originalDataIndex);
- var labelModel = itemModel.getModel('label');
- var regionGroup = fullData.getItemGraphicEl(fullIndex_1);
-
-
-
-
-
-
-
- setLabelStyle(circle, getLabelStatesModels(itemModel), {
- labelFetcher: {
- getFormattedLabel: function (idx, state) {
- return mapModel.getFormattedLabel(fullIndex_1, state);
- }
- },
- defaultText: name_1
- });
- circle.disableLabelAnimation = true;
- if (!labelModel.get('position')) {
- circle.setTextConfig({
- position: 'bottom'
- });
- }
- regionGroup.onHoverStateChange = function (toState) {
- setStatesFlag(circle, toState);
- };
- }
- group.add(circle);
- });
- };
- MapView.type = 'map';
- return MapView;
- }(ChartView);
- export default MapView;
|