| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207 | 
/** 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 { createSymbol, normalizeSymbolOffset, normalizeSymbolSize } from '../../util/symbol.js';import { Group } from '../../util/graphic.js';import { enterEmphasis, leaveEmphasis, toggleHoverEmphasis } from '../../util/states.js';import SymbolClz from './Symbol.js';function updateRipplePath(rippleGroup, effectCfg) {  var color = effectCfg.rippleEffectColor || effectCfg.color;  rippleGroup.eachChild(function (ripplePath) {    ripplePath.attr({      z: effectCfg.z,      zlevel: effectCfg.zlevel,      style: {        stroke: effectCfg.brushType === 'stroke' ? color : null,        fill: effectCfg.brushType === 'fill' ? color : null      }    });  });}var EffectSymbol = /** @class */function (_super) {  __extends(EffectSymbol, _super);  function EffectSymbol(data, idx) {    var _this = _super.call(this) || this;    var symbol = new SymbolClz(data, idx);    var rippleGroup = new Group();    _this.add(symbol);    _this.add(rippleGroup);    _this.updateData(data, idx);    return _this;  }  EffectSymbol.prototype.stopEffectAnimation = function () {    this.childAt(1).removeAll();  };  EffectSymbol.prototype.startEffectAnimation = function (effectCfg) {    var symbolType = effectCfg.symbolType;    var color = effectCfg.color;    var rippleNumber = effectCfg.rippleNumber;    var rippleGroup = this.childAt(1);    for (var i = 0; i < rippleNumber; i++) {      // If width/height are set too small (e.g., set to 1) on ios10      // and macOS Sierra, a circle stroke become a rect, no matter what      // the scale is set. So we set width/height as 2. See #4136.      var ripplePath = createSymbol(symbolType, -1, -1, 2, 2, color);      ripplePath.attr({        style: {          strokeNoScale: true        },        z2: 99,        silent: true,        scaleX: 0.5,        scaleY: 0.5      });      var delay = -i / rippleNumber * effectCfg.period + effectCfg.effectOffset;      ripplePath.animate('', true).when(effectCfg.period, {        scaleX: effectCfg.rippleScale / 2,        scaleY: effectCfg.rippleScale / 2      }).delay(delay).start();      ripplePath.animateStyle(true).when(effectCfg.period, {        opacity: 0      }).delay(delay).start();      rippleGroup.add(ripplePath);    }    updateRipplePath(rippleGroup, effectCfg);  };  /**   * Update effect symbol   */  EffectSymbol.prototype.updateEffectAnimation = function (effectCfg) {    var oldEffectCfg = this._effectCfg;    var rippleGroup = this.childAt(1);    // Must reinitialize effect if following configuration changed    var DIFFICULT_PROPS = ['symbolType', 'period', 'rippleScale', 'rippleNumber'];    for (var i = 0; i < DIFFICULT_PROPS.length; i++) {      var propName = DIFFICULT_PROPS[i];      if (oldEffectCfg[propName] !== effectCfg[propName]) {        this.stopEffectAnimation();        this.startEffectAnimation(effectCfg);        return;      }    }    updateRipplePath(rippleGroup, effectCfg);  };  /**   * Highlight symbol   */  EffectSymbol.prototype.highlight = function () {    enterEmphasis(this);  };  /**   * Downplay symbol   */  EffectSymbol.prototype.downplay = function () {    leaveEmphasis(this);  };  EffectSymbol.prototype.getSymbolType = function () {    var symbol = this.childAt(0);    return symbol && symbol.getSymbolType();  };  /**   * Update symbol properties   */  EffectSymbol.prototype.updateData = function (data, idx) {    var _this = this;    var seriesModel = data.hostModel;    this.childAt(0).updateData(data, idx);    var rippleGroup = this.childAt(1);    var itemModel = data.getItemModel(idx);    var symbolType = data.getItemVisual(idx, 'symbol');    var symbolSize = normalizeSymbolSize(data.getItemVisual(idx, 'symbolSize'));    var symbolStyle = data.getItemVisual(idx, 'style');    var color = symbolStyle && symbolStyle.fill;    var emphasisModel = itemModel.getModel('emphasis');    rippleGroup.setScale(symbolSize);    rippleGroup.traverse(function (ripplePath) {      ripplePath.setStyle('fill', color);    });    var symbolOffset = normalizeSymbolOffset(data.getItemVisual(idx, 'symbolOffset'), symbolSize);    if (symbolOffset) {      rippleGroup.x = symbolOffset[0];      rippleGroup.y = symbolOffset[1];    }    var symbolRotate = data.getItemVisual(idx, 'symbolRotate');    rippleGroup.rotation = (symbolRotate || 0) * Math.PI / 180 || 0;    var effectCfg = {};    effectCfg.showEffectOn = seriesModel.get('showEffectOn');    effectCfg.rippleScale = itemModel.get(['rippleEffect', 'scale']);    effectCfg.brushType = itemModel.get(['rippleEffect', 'brushType']);    effectCfg.period = itemModel.get(['rippleEffect', 'period']) * 1000;    effectCfg.effectOffset = idx / data.count();    effectCfg.z = seriesModel.getShallow('z') || 0;    effectCfg.zlevel = seriesModel.getShallow('zlevel') || 0;    effectCfg.symbolType = symbolType;    effectCfg.color = color;    effectCfg.rippleEffectColor = itemModel.get(['rippleEffect', 'color']);    effectCfg.rippleNumber = itemModel.get(['rippleEffect', 'number']);    if (effectCfg.showEffectOn === 'render') {      this._effectCfg ? this.updateEffectAnimation(effectCfg) : this.startEffectAnimation(effectCfg);      this._effectCfg = effectCfg;    } else {      // Not keep old effect config      this._effectCfg = null;      this.stopEffectAnimation();      this.onHoverStateChange = function (toState) {        if (toState === 'emphasis') {          if (effectCfg.showEffectOn !== 'render') {            _this.startEffectAnimation(effectCfg);          }        } else if (toState === 'normal') {          if (effectCfg.showEffectOn !== 'render') {            _this.stopEffectAnimation();          }        }      };    }    this._effectCfg = effectCfg;    toggleHoverEmphasis(this, emphasisModel.get('focus'), emphasisModel.get('blurScope'), emphasisModel.get('disabled'));  };  ;  EffectSymbol.prototype.fadeOut = function (cb) {    cb && cb();  };  ;  return EffectSymbol;}(Group);export default EffectSymbol;
 |