123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227 |
- /*
- * 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.
- */
- var echarts = require("../../echarts");
- var zrUtil = require("zrender/lib/core/util");
- var graphic = require("../../util/graphic");
- var MapDraw = require("../../component/helper/MapDraw");
- /*
- * 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.
- */
- var HIGH_DOWN_PROP = '__seriesMapHighDown';
- var RECORD_VERSION_PROP = '__seriesMapCallKey';
- var _default = echarts.extendChartView({
- type: 'map',
- render: function (mapModel, ecModel, api, payload) {
- // Not render if it is an toggleSelect action from self
- if (payload && payload.type === 'mapToggleSelect' && payload.from === this.uid) {
- return;
- }
- var group = this.group;
- group.removeAll();
- if (mapModel.getHostGeoModel()) {
- return;
- } // Not update map if it is an roam action from self
- if (!(payload && payload.type === 'geoRoam' && payload.componentType === 'series' && payload.seriesId === mapModel.id)) {
- if (mapModel.needsDrawMap) {
- var mapDraw = this._mapDraw || new MapDraw(api, true);
- group.add(mapDraw.group);
- mapDraw.draw(mapModel, ecModel, api, this, payload);
- this._mapDraw = mapDraw;
- } else {
- // Remove drawed map
- 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);
- },
- remove: function () {
- this._mapDraw && this._mapDraw.remove();
- this._mapDraw = null;
- this.group.removeAll();
- },
- dispose: function () {
- this._mapDraw && this._mapDraw.remove();
- this._mapDraw = null;
- },
- _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) {
- // Not exists in map
- return;
- }
- var point = layout.point;
- var offset = layout.offset;
- var circle = new graphic.Circle({
- style: {
- // Because the special of map draw.
- // Which needs statistic of multiple series and draw on one map.
- // And each series also need a symbol with legend color
- //
- // Layout and visual are put one the different data
- fill: mapModel.getData().getVisual('color')
- },
- shape: {
- cx: point[0] + offset * 9,
- cy: point[1],
- r: 3
- },
- silent: true,
- // Do not overlap the first series, on which labels are displayed.
- z2: 8 + (!offset ? graphic.Z2_EMPHASIS_LIFT + 1 : 0)
- }); // Only the series that has the first value on the same region is in charge of rendering the label.
- // But consider the case:
- // series: [
- // {id: 'X', type: 'map', map: 'm', {data: [{name: 'A', value: 11}, {name: 'B', {value: 22}]},
- // {id: 'Y', type: 'map', map: 'm', {data: [{name: 'A', value: 21}, {name: 'C', {value: 33}]}
- // ]
- // The offset `0` of item `A` is at series `X`, but of item `C` is at series `Y`.
- // For backward compatibility, we follow the rule that render label `A` by the
- // settings on series `X` but render label `C` by the settings on series `Y`.
- if (!offset) {
- var fullData = mapModel.mainSeries.getData();
- var name = originalData.getName(originalDataIndex);
- var fullIndex = fullData.indexOfName(name);
- var itemModel = originalData.getItemModel(originalDataIndex);
- var labelModel = itemModel.getModel('label');
- var hoverLabelModel = itemModel.getModel('emphasis.label');
- var regionGroup = fullData.getItemGraphicEl(fullIndex); // `getFormattedLabel` needs to use `getData` inside. Here
- // `mapModel.getData()` is shallow cloned from `mainSeries.getData()`.
- // FIXME
- // If this is not the `mainSeries`, the item model (like label formatter)
- // set on original data item will never get. But it has been working
- // like that from the begining, and this scenario is rarely encountered.
- // So it won't be fixed until have to.
- var normalText = zrUtil.retrieve2(mapModel.getFormattedLabel(fullIndex, 'normal'), name);
- var emphasisText = zrUtil.retrieve2(mapModel.getFormattedLabel(fullIndex, 'emphasis'), normalText);
- var highDownRecord = regionGroup[HIGH_DOWN_PROP];
- var recordVersion = Math.random(); // Prevent from register listeners duplicatedly when roaming.
- if (!highDownRecord) {
- highDownRecord = regionGroup[HIGH_DOWN_PROP] = {};
- var onEmphasis = zrUtil.curry(onRegionHighDown, true);
- var onNormal = zrUtil.curry(onRegionHighDown, false);
- regionGroup.on('mouseover', onEmphasis).on('mouseout', onNormal).on('emphasis', onEmphasis).on('normal', onNormal);
- } // Prevent removed regions effect current grapics.
- regionGroup[RECORD_VERSION_PROP] = recordVersion;
- zrUtil.extend(highDownRecord, {
- recordVersion: recordVersion,
- circle: circle,
- labelModel: labelModel,
- hoverLabelModel: hoverLabelModel,
- emphasisText: emphasisText,
- normalText: normalText
- }); // FIXME
- // Consider set option when emphasis.
- enterRegionHighDown(highDownRecord, false);
- }
- group.add(circle);
- });
- }
- });
- function onRegionHighDown(toHighOrDown) {
- var highDownRecord = this[HIGH_DOWN_PROP];
- if (highDownRecord && highDownRecord.recordVersion === this[RECORD_VERSION_PROP]) {
- enterRegionHighDown(highDownRecord, toHighOrDown);
- }
- }
- function enterRegionHighDown(highDownRecord, toHighOrDown) {
- var circle = highDownRecord.circle;
- var labelModel = highDownRecord.labelModel;
- var hoverLabelModel = highDownRecord.hoverLabelModel;
- var emphasisText = highDownRecord.emphasisText;
- var normalText = highDownRecord.normalText;
- if (toHighOrDown) {
- circle.style.extendFrom(graphic.setTextStyle({}, hoverLabelModel, {
- text: hoverLabelModel.get('show') ? emphasisText : null
- }, {
- isRectText: true,
- useInsideStyle: false
- }, true)); // Make label upper than others if overlaps.
- circle.__mapOriginalZ2 = circle.z2;
- circle.z2 += graphic.Z2_EMPHASIS_LIFT;
- } else {
- graphic.setTextStyle(circle.style, labelModel, {
- text: labelModel.get('show') ? normalText : null,
- textPosition: labelModel.getShallow('position') || 'bottom'
- }, {
- isRectText: true,
- useInsideStyle: false
- }); // Trigger normalize style like padding.
- circle.dirty(false);
- if (circle.__mapOriginalZ2 != null) {
- circle.z2 = circle.__mapOriginalZ2;
- circle.__mapOriginalZ2 = null;
- }
- }
- }
- module.exports = _default;
|