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