@visactor/vrender-animate 0.22.4 → 0.23.0-alpha.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (198) hide show
  1. package/cjs/animate-extension.d.ts +11 -3
  2. package/cjs/animate-extension.js +26 -11
  3. package/cjs/animate-extension.js.map +1 -1
  4. package/cjs/animate.js +5 -3
  5. package/cjs/animate.js.map +1 -1
  6. package/cjs/component/component-animate-extension.d.ts +1 -0
  7. package/cjs/component/component-animate-extension.js +1 -0
  8. package/cjs/component/component-animate-extension.js.map +1 -0
  9. package/cjs/component/component-animator.d.ts +21 -0
  10. package/cjs/component/component-animator.js +81 -0
  11. package/cjs/component/component-animator.js.map +1 -0
  12. package/cjs/component/index.d.ts +1 -0
  13. package/cjs/component/index.js +21 -0
  14. package/cjs/component/index.js.map +1 -0
  15. package/cjs/custom/common.js +9 -6
  16. package/cjs/custom/common.js.map +1 -1
  17. package/cjs/custom/custom-animate.d.ts +6 -0
  18. package/cjs/custom/custom-animate.js +12 -1
  19. package/cjs/custom/custom-animate.js.map +1 -1
  20. package/cjs/custom/group-fade.js +1 -2
  21. package/cjs/custom/growAngle.d.ts +8 -3
  22. package/cjs/custom/growAngle.js +29 -15
  23. package/cjs/custom/growAngle.js.map +1 -1
  24. package/cjs/custom/growCenter.js +9 -6
  25. package/cjs/custom/growCenter.js.map +1 -1
  26. package/cjs/custom/growHeight.js +11 -7
  27. package/cjs/custom/growHeight.js.map +1 -1
  28. package/cjs/custom/growPoints.js +13 -11
  29. package/cjs/custom/growPoints.js.map +1 -1
  30. package/cjs/custom/growRadius.js +13 -11
  31. package/cjs/custom/growRadius.js.map +1 -1
  32. package/cjs/custom/growWidth.js +9 -6
  33. package/cjs/custom/growWidth.js.map +1 -1
  34. package/cjs/custom/label-animate.d.ts +4 -0
  35. package/cjs/custom/label-animate.js +48 -0
  36. package/cjs/custom/label-animate.js.map +1 -0
  37. package/cjs/custom/label-item-animate.d.ts +7 -0
  38. package/cjs/custom/label-item-animate.js +219 -0
  39. package/cjs/custom/label-item-animate.js.map +1 -0
  40. package/cjs/custom/poptip-animate.d.ts +7 -0
  41. package/cjs/custom/poptip-animate.js +106 -0
  42. package/cjs/custom/poptip-animate.js.map +1 -0
  43. package/cjs/custom/register.js +8 -2
  44. package/cjs/custom/register.js.map +1 -1
  45. package/cjs/custom/scale.d.ts +4 -0
  46. package/cjs/custom/scale.js +30 -21
  47. package/cjs/custom/scale.js.map +1 -1
  48. package/cjs/custom/tag-points.js +1 -2
  49. package/cjs/custom/update.d.ts +0 -1
  50. package/cjs/custom/update.js +1 -1
  51. package/cjs/custom/update.js.map +1 -1
  52. package/cjs/executor/animate-executor.d.ts +2 -2
  53. package/cjs/executor/animate-executor.js +43 -27
  54. package/cjs/executor/animate-executor.js.map +1 -1
  55. package/cjs/executor/executor.d.ts +3 -0
  56. package/cjs/executor/executor.js.map +1 -1
  57. package/cjs/index.d.ts +2 -0
  58. package/cjs/index.js +1 -1
  59. package/cjs/index.js.map +1 -1
  60. package/cjs/interpolate/store.d.ts +2 -0
  61. package/cjs/interpolate/store.js +5 -2
  62. package/cjs/interpolate/store.js.map +1 -1
  63. package/cjs/intreface/animate.d.ts +1 -0
  64. package/cjs/intreface/animate.js.map +1 -1
  65. package/cjs/intreface/ticker.js +2 -1
  66. package/cjs/register.js +1 -5
  67. package/cjs/register.js.map +1 -1
  68. package/cjs/state/animation-state.d.ts +18 -0
  69. package/cjs/state/animation-state.js +45 -1
  70. package/cjs/state/animation-state.js.map +1 -1
  71. package/cjs/state/graphic-extension.d.ts +6 -0
  72. package/cjs/state/graphic-extension.js +20 -0
  73. package/cjs/state/graphic-extension.js.map +1 -1
  74. package/cjs/step.d.ts +1 -0
  75. package/cjs/step.js +14 -8
  76. package/cjs/step.js.map +1 -1
  77. package/cjs/ticker/default-ticker.d.ts +8 -3
  78. package/cjs/ticker/default-ticker.js +22 -22
  79. package/cjs/ticker/default-ticker.js.map +1 -1
  80. package/cjs/utils/easing-func.js +1 -2
  81. package/dist/index.es.js +853 -184
  82. package/es/animate-extension.d.ts +11 -3
  83. package/es/animate-extension.js +27 -10
  84. package/es/animate-extension.js.map +1 -1
  85. package/es/animate.js +5 -3
  86. package/es/animate.js.map +1 -1
  87. package/es/component/component-animate-extension.d.ts +1 -0
  88. package/es/component/component-animate-extension.js +1 -0
  89. package/es/component/component-animate-extension.js.map +1 -0
  90. package/es/component/component-animator.d.ts +21 -0
  91. package/es/component/component-animator.js +73 -0
  92. package/es/component/component-animator.js.map +1 -0
  93. package/es/component/index.d.ts +1 -0
  94. package/es/component/index.js +2 -0
  95. package/es/component/index.js.map +1 -0
  96. package/es/custom/common.js +9 -6
  97. package/es/custom/common.js.map +1 -1
  98. package/es/custom/custom-animate.d.ts +6 -0
  99. package/es/custom/custom-animate.js +9 -0
  100. package/es/custom/custom-animate.js.map +1 -1
  101. package/es/custom/group-fade.js +1 -2
  102. package/es/custom/growAngle.d.ts +8 -3
  103. package/es/custom/growAngle.js +27 -13
  104. package/es/custom/growAngle.js.map +1 -1
  105. package/es/custom/growCenter.js +9 -6
  106. package/es/custom/growCenter.js.map +1 -1
  107. package/es/custom/growHeight.js +11 -7
  108. package/es/custom/growHeight.js.map +1 -1
  109. package/es/custom/growPoints.js +12 -11
  110. package/es/custom/growPoints.js.map +1 -1
  111. package/es/custom/growRadius.js +13 -11
  112. package/es/custom/growRadius.js.map +1 -1
  113. package/es/custom/growWidth.js +9 -6
  114. package/es/custom/growWidth.js.map +1 -1
  115. package/es/custom/label-animate.d.ts +4 -0
  116. package/es/custom/label-animate.js +42 -0
  117. package/es/custom/label-animate.js.map +1 -0
  118. package/es/custom/label-item-animate.d.ts +7 -0
  119. package/es/custom/label-item-animate.js +213 -0
  120. package/es/custom/label-item-animate.js.map +1 -0
  121. package/es/custom/poptip-animate.d.ts +7 -0
  122. package/es/custom/poptip-animate.js +100 -0
  123. package/es/custom/poptip-animate.js.map +1 -0
  124. package/es/custom/register.js +24 -12
  125. package/es/custom/register.js.map +1 -1
  126. package/es/custom/scale.d.ts +4 -0
  127. package/es/custom/scale.js +30 -21
  128. package/es/custom/scale.js.map +1 -1
  129. package/es/custom/tag-points.js +1 -2
  130. package/es/custom/update.d.ts +0 -1
  131. package/es/custom/update.js +1 -1
  132. package/es/custom/update.js.map +1 -1
  133. package/es/executor/animate-executor.d.ts +2 -2
  134. package/es/executor/animate-executor.js +43 -27
  135. package/es/executor/animate-executor.js.map +1 -1
  136. package/es/executor/executor.d.ts +3 -0
  137. package/es/executor/executor.js.map +1 -1
  138. package/es/index.d.ts +2 -0
  139. package/es/index.js +2 -0
  140. package/es/index.js.map +1 -1
  141. package/es/interpolate/store.d.ts +2 -0
  142. package/es/interpolate/store.js +5 -3
  143. package/es/interpolate/store.js.map +1 -1
  144. package/es/intreface/animate.d.ts +1 -0
  145. package/es/intreface/animate.js.map +1 -1
  146. package/es/intreface/ticker.js +2 -1
  147. package/es/register.js +0 -8
  148. package/es/register.js.map +1 -1
  149. package/es/state/animation-state.d.ts +18 -0
  150. package/es/state/animation-state.js +44 -0
  151. package/es/state/animation-state.js.map +1 -1
  152. package/es/state/graphic-extension.d.ts +6 -0
  153. package/es/state/graphic-extension.js +20 -0
  154. package/es/state/graphic-extension.js.map +1 -1
  155. package/es/step.d.ts +1 -0
  156. package/es/step.js +14 -8
  157. package/es/step.js.map +1 -1
  158. package/es/ticker/default-ticker.d.ts +8 -3
  159. package/es/ticker/default-ticker.js +22 -22
  160. package/es/ticker/default-ticker.js.map +1 -1
  161. package/es/utils/easing-func.js +1 -2
  162. package/package.json +15 -15
  163. package/cjs/custom/scale-in.d.ts +0 -13
  164. package/cjs/custom/scale-in.js +0 -57
  165. package/cjs/custom/scale-in.js.map +0 -1
  166. package/cjs/interpolate/executor.d.ts +0 -66
  167. package/cjs/interpolate/executor.js +0 -6
  168. package/cjs/interpolate/executor.js.map +0 -1
  169. package/cjs/intreface/state.d.ts +0 -35
  170. package/cjs/intreface/state.js +0 -6
  171. package/cjs/intreface/state.js.map +0 -1
  172. package/cjs/state/animation-state-machine.d.ts +0 -22
  173. package/cjs/state/animation-state-machine.js +0 -53
  174. package/cjs/state/animation-state-machine.js.map +0 -1
  175. package/cjs/state/animation-state-queue.d.ts +0 -24
  176. package/cjs/state/animation-state-queue.js +0 -66
  177. package/cjs/state/animation-state-queue.js.map +0 -1
  178. package/cjs/state/animation-state-registry.d.ts +0 -14
  179. package/cjs/state/animation-state-registry.js +0 -53
  180. package/cjs/state/animation-state-registry.js.map +0 -1
  181. package/es/custom/scale-in.d.ts +0 -13
  182. package/es/custom/scale-in.js +0 -49
  183. package/es/custom/scale-in.js.map +0 -1
  184. package/es/interpolate/executor.d.ts +0 -66
  185. package/es/interpolate/executor.js +0 -2
  186. package/es/interpolate/executor.js.map +0 -1
  187. package/es/intreface/state.d.ts +0 -35
  188. package/es/intreface/state.js +0 -2
  189. package/es/intreface/state.js.map +0 -1
  190. package/es/state/animation-state-machine.d.ts +0 -22
  191. package/es/state/animation-state-machine.js +0 -47
  192. package/es/state/animation-state-machine.js.map +0 -1
  193. package/es/state/animation-state-queue.d.ts +0 -24
  194. package/es/state/animation-state-queue.js +0 -58
  195. package/es/state/animation-state-queue.js.map +0 -1
  196. package/es/state/animation-state-registry.d.ts +0 -14
  197. package/es/state/animation-state-registry.js +0 -45
  198. package/es/state/animation-state-registry.js.map +0 -1
@@ -7,12 +7,16 @@ export declare class DefaultTicker extends EventEmitter implements ITicker {
7
7
  protected tickerHandler: ITickHandler;
8
8
  protected status: STATUS;
9
9
  protected lastFrameTime: number;
10
- protected lastExecutionTime: number;
11
10
  protected tickCounts: number;
12
11
  protected stage: IStage;
13
12
  timelines: ITimeline[];
14
13
  autoStop: boolean;
14
+ protected _jitter: number;
15
+ protected timeOffset: number;
16
+ _lastTickTime: number;
17
+ protected frameTimeHistory: number[];
15
18
  constructor(stage: IStage);
19
+ computeTimeOffsetAndJitter(): void;
16
20
  init(): void;
17
21
  addTimeline(timeline: ITimeline): void;
18
22
  remTimeline(timeline: ITimeline): void;
@@ -32,8 +36,9 @@ export declare class DefaultTicker extends EventEmitter implements ITicker {
32
36
  stop(): void;
33
37
  trySyncTickStatus(): void;
34
38
  release(): void;
39
+ protected checkSkip: (delta: number) => boolean;
35
40
  protected handleTick: (handler: ITickHandler, params?: {
36
41
  once?: boolean;
37
- }) => void;
38
- protected _handlerTick: () => void;
42
+ }) => boolean;
43
+ protected _handlerTick: (delta: number) => void;
39
44
  }
@@ -12,7 +12,7 @@ class RAFTickHandler {
12
12
  }
13
13
  tick(interval, cb) {
14
14
  performanceRAF.addAnimationFrameCb((() => {
15
- this.released || cb(this);
15
+ if (!this.released) return cb(this);
16
16
  }));
17
17
  }
18
18
  release() {
@@ -25,22 +25,25 @@ class RAFTickHandler {
25
25
 
26
26
  class DefaultTicker extends vutils_1.EventEmitter {
27
27
  constructor(stage) {
28
- super(), this.interval = 16, this.lastFrameTime = -1, this.lastExecutionTime = -1,
29
- this.tickCounts = 0, this.timelines = [], this.autoStop = !0, this.handleTick = (handler, params) => {
28
+ super(), this.timelines = [], this.frameTimeHistory = [], this.checkSkip = delta => delta < this.interval + 2 * (Math.random() - .5) * this._jitter,
29
+ this.handleTick = (handler, params) => {
30
30
  const {once: once = !1} = null != params ? params : {};
31
- if (this.ifCanStop()) return void this.stop();
31
+ if (this.ifCanStop()) return this.stop(), !1;
32
32
  const currentTime = handler.getTime();
33
- (this.lastExecutionTime < 0 ? this.interval : currentTime - this.lastExecutionTime) >= this.interval && (this._handlerTick(),
34
- this.lastExecutionTime = currentTime), once || handler.tick(this.interval, this.handleTick);
35
- }, this._handlerTick = () => {
36
- const time = this.tickerHandler.getTime();
37
- let delta = 0;
38
- this.lastFrameTime >= 0 && (delta = time - this.lastFrameTime), this.lastFrameTime = time,
33
+ this._lastTickTime = currentTime, this.lastFrameTime < 0 && (this.lastFrameTime = currentTime - this.interval + this.timeOffset,
34
+ this.frameTimeHistory.push(this.lastFrameTime));
35
+ const delta = currentTime - this.lastFrameTime, skip = this.checkSkip(delta);
36
+ return skip || (this._handlerTick(delta), this.lastFrameTime = currentTime, this.frameTimeHistory.push(this.lastFrameTime)),
37
+ once || handler.tick(this.interval, this.handleTick), !skip;
38
+ }, this._handlerTick = delta => {
39
39
  this.status === ticker_1.STATUS.RUNNING && (this.tickCounts++, this.timelines.forEach((timeline => {
40
40
  timeline.tick(delta);
41
41
  })), this.emit("tick", delta));
42
- }, this.init(), this.lastFrameTime = -1, this.lastExecutionTime = -1, this.tickCounts = 0,
43
- this.stage = stage, this.autoStop = !0;
42
+ }, this.init(), this.lastFrameTime = -1, this.tickCounts = 0, this.stage = stage,
43
+ this.autoStop = !0, this.interval = 16, this.computeTimeOffsetAndJitter();
44
+ }
45
+ computeTimeOffsetAndJitter() {
46
+ this.timeOffset = Math.floor(Math.random() * this.interval), this._jitter = Math.min(Math.max(.2 * this.interval, 6), .7 * this.interval);
44
47
  }
45
48
  init() {
46
49
  this.interval = 16, this.status = ticker_1.STATUS.INITIAL, vrender_core_1.application.global.hooks.onSetEnv.tap("graph-ticker", (() => {
@@ -65,23 +68,21 @@ class DefaultTicker extends vutils_1.EventEmitter {
65
68
  !0;
66
69
  }
67
70
  setInterval(interval) {
68
- this.interval = interval;
71
+ this.interval = interval, this.computeTimeOffsetAndJitter();
69
72
  }
70
73
  getInterval() {
71
74
  return this.interval;
72
75
  }
73
76
  setFPS(fps) {
74
- this.setInterval(1e3 / fps);
77
+ this.setInterval(Math.floor(1e3 / fps));
75
78
  }
76
79
  getFPS() {
77
80
  return 1e3 / this.interval;
78
81
  }
79
82
  tick(interval) {
80
- this.tickerHandler.tick(interval, (handler => {
81
- this.handleTick(handler, {
82
- once: !0
83
- });
84
- }));
83
+ this.tickerHandler.tick(interval, (handler => this.handleTick(handler, {
84
+ once: !0
85
+ })));
85
86
  }
86
87
  tickTo(t) {
87
88
  this.tickerHandler.tickTo && this.tickerHandler.tickTo(t, (handler => {
@@ -116,8 +117,7 @@ class DefaultTicker extends vutils_1.EventEmitter {
116
117
  !0;
117
118
  }
118
119
  stop() {
119
- this.status = ticker_1.STATUS.INITIAL, this.setupTickHandler(), this.lastFrameTime = -1,
120
- this.lastExecutionTime = -1;
120
+ this.status = ticker_1.STATUS.INITIAL, this.setupTickHandler(), this.lastFrameTime = -1;
121
121
  }
122
122
  trySyncTickStatus() {
123
123
  this.status === ticker_1.STATUS.INITIAL && this.timelines.some((timeline => timeline.isRunning())) ? this.start() : this.status === ticker_1.STATUS.RUNNING && this.timelines.every((timeline => !timeline.isRunning())) && this.stop();
@@ -125,7 +125,7 @@ class DefaultTicker extends vutils_1.EventEmitter {
125
125
  release() {
126
126
  var _a;
127
127
  this.stop(), this.timelines = [], null === (_a = this.tickerHandler) || void 0 === _a || _a.release(),
128
- this.tickerHandler = null, this.lastExecutionTime = -1;
128
+ this.tickerHandler = null, this.lastFrameTime = -1;
129
129
  }
130
130
  }
131
131
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/ticker/default-ticker.ts"],"names":[],"mappings":";;;AAAA,6CAAgD;AAEhD,yDAAqE;AACrE,gDAA8E;AAG9E,MAAM,cAAc,GAAG,IAAI,6BAAc,EAAE,CAAC;AAE5C,MAAM,cAAc;IAApB;QACY,aAAQ,GAAY,KAAK,CAAC;IAkBtC,CAAC;IAhBC,IAAI,CAAC,QAAgB,EAAE,EAAmC;QACxD,cAAc,CAAC,mBAAmB,CAAC,GAAG,EAAE;YACtC,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,OAAO;aACR;YACD,EAAE,CAAC,IAAI,CAAC,CAAC;QACX,CAAC,CAAC,CAAC;IACL,CAAC;IAED,OAAO;QACL,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;IACvB,CAAC;IAED,OAAO;QACL,OAAO,IAAI,CAAC,GAAG,EAAE,CAAC;IACpB,CAAC;CACF;AAMD,MAAa,aAAc,SAAQ,qBAAY;IAW7C,YAAY,KAAa;QACvB,KAAK,EAAE,CAAC;QAXA,aAAQ,GAAW,EAAE,CAAC;QAGtB,kBAAa,GAAW,CAAC,CAAC,CAAC;QAC3B,sBAAiB,GAAW,CAAC,CAAC,CAAC;QAC/B,eAAU,GAAW,CAAC,CAAC;QAEjC,cAAS,GAAgB,EAAE,CAAC;QAC5B,aAAQ,GAAY,IAAI,CAAC;QAqKf,eAAU,GAAG,CAAC,OAAqB,EAAE,MAA2B,EAAQ,EAAE;YAClF,MAAM,EAAE,IAAI,GAAG,KAAK,EAAE,GAAG,MAAM,aAAN,MAAM,cAAN,MAAM,GAAI,EAAE,CAAC;YAGtC,IAAI,IAAI,CAAC,SAAS,EAAE,EAAE;gBACpB,IAAI,CAAC,IAAI,EAAE,CAAC;gBACZ,OAAO;aACR;YAED,MAAM,WAAW,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;YAGtC,MAAM,qBAAqB,GAAG,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAiB,CAAC;YAGhH,IAAI,qBAAqB,IAAI,IAAI,CAAC,QAAQ,EAAE;gBAC1C,IAAI,CAAC,YAAY,EAAE,CAAC;gBACpB,IAAI,CAAC,iBAAiB,GAAG,WAAW,CAAC;aACtC;YAED,IAAI,CAAC,IAAI,EAAE;gBACT,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;aAC9C;QACH,CAAC,CAAC;QAEQ,iBAAY,GAAG,GAAS,EAAE;YAElC,MAAM,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;YACzC,MAAM,IAAI,GAAG,aAAa,CAAC,OAAO,EAAE,CAAC;YAGrC,IAAI,KAAK,GAAG,CAAC,CAAC;YACd,IAAI,IAAI,CAAC,aAAa,IAAI,CAAC,EAAE;gBAC3B,KAAK,GAAG,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC;aACnC;YACD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;YAE1B,IAAI,IAAI,CAAC,MAAM,KAAK,eAAM,CAAC,OAAO,EAAE;gBAClC,OAAO;aACR;YAED,IAAI,CAAC,UAAU,EAAE,CAAC;YAGlB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE;gBAChC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACvB,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAC3B,CAAC,CAAC;QAlNA,IAAI,CAAC,IAAI,EAAE,CAAC;QACZ,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC;QACxB,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC,CAAC;QAC5B,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;QACpB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;IACvB,CAAC;IAED,IAAI;QACF,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;QACnB,IAAI,CAAC,MAAM,GAAG,eAAM,CAAC,OAAO,CAAC;QAC7B,0BAAW,CAAC,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,cAAc,EAAE,GAAG,EAAE;YACzD,IAAI,CAAC,WAAW,EAAE,CAAC;QACrB,CAAC,CAAC,CAAC;QACH,IAAI,0BAAW,CAAC,MAAM,CAAC,GAAG,EAAE;YAC1B,IAAI,CAAC,WAAW,EAAE,CAAC;SACpB;IACH,CAAC;IAED,WAAW,CAAC,QAAmB;QAC7B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAChC,CAAC;IAED,WAAW,CAAC,QAAmB;QAC7B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,QAAQ,CAAC,CAAC;IAC9D,CAAC;IAED,YAAY;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAES,WAAW;QACnB,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAMS,gBAAgB;QACxB,MAAM,OAAO,GAAiB,IAAI,cAAc,EAAE,CAAC;QAGnD,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC;SAC9B;QAED,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC;QAC7B,OAAO,IAAI,CAAC;IACd,CAAC;IAED,WAAW,CAAC,QAAgB;QAC1B,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC3B,CAAC;IAED,WAAW;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED,MAAM,CAAC,GAAW;QAChB,IAAI,CAAC,WAAW,CAAC,IAAI,GAAG,GAAG,CAAC,CAAC;IAC/B,CAAC;IAED,MAAM;QACJ,OAAO,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC;IAC9B,CAAC;IAED,IAAI,CAAC,QAAgB;QACnB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,OAAqB,EAAE,EAAE;YAC1D,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;QAC3C,CAAC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,CAAC,CAAS;QACd,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE;YAC9B,OAAO;SACR;QACD,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,OAAqB,EAAE,EAAE;YACrD,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;QAC3C,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK;QACH,IAAI,IAAI,CAAC,MAAM,KAAK,eAAM,CAAC,OAAO,EAAE;YAClC,OAAO,KAAK,CAAC;SACd;QACD,IAAI,CAAC,MAAM,GAAG,eAAM,CAAC,KAAK,CAAC;QAC3B,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM;QACJ,IAAI,IAAI,CAAC,MAAM,KAAK,eAAM,CAAC,OAAO,EAAE;YAClC,OAAO,KAAK,CAAC;SACd;QACD,IAAI,CAAC,MAAM,GAAG,eAAM,CAAC,OAAO,CAAC;QAC7B,OAAO,IAAI,CAAC;IACd,CAAC;IAED,SAAS;QACP,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE;gBAC1B,OAAO,IAAI,CAAC;aACb;YACD,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC,EAAE;gBAC3D,OAAO,IAAI,CAAC;aACb;SACF;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,KAAK,CAAC,QAAiB,KAAK;QAC1B,IAAI,IAAI,CAAC,MAAM,KAAK,eAAM,CAAC,OAAO,EAAE;YAClC,OAAO,KAAK,CAAC;SACd;QACD,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;YACvB,OAAO,KAAK,CAAC;SACd;QAGD,IAAI,CAAC,KAAK,EAAE;YACV,IAAI,IAAI,CAAC,MAAM,KAAK,eAAM,CAAC,KAAK,EAAE;gBAChC,OAAO,KAAK,CAAC;aACd;YACD,IAAI,IAAI,CAAC,SAAS,EAAE,EAAE;gBACpB,OAAO,KAAK,CAAC;aACd;SACF;QAED,IAAI,CAAC,MAAM,GAAG,eAAM,CAAC,OAAO,CAAC;QAC7B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;QAC5C,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAI;QAEF,IAAI,CAAC,MAAM,GAAG,eAAM,CAAC,OAAO,CAAC;QAC7B,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC;QACxB,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC,CAAC;IAC9B,CAAC;IAMD,iBAAiB;QACf,IAAI,IAAI,CAAC,MAAM,KAAK,eAAM,CAAC,OAAO,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC,EAAE;YAC3F,IAAI,CAAC,KAAK,EAAE,CAAC;SACd;aAAM,IAAI,IAAI,CAAC,MAAM,KAAK,eAAM,CAAC,OAAO,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC,EAAE;YACpG,IAAI,CAAC,IAAI,EAAE,CAAC;SACb;IACH,CAAC;IAED,OAAO;;QACL,IAAI,CAAC,IAAI,EAAE,CAAC;QACZ,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;QACpB,MAAA,IAAI,CAAC,aAAa,0CAAE,OAAO,EAAE,CAAC;QAC9B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC1B,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC,CAAC;IAC9B,CAAC;CAoDF;AAhOD,sCAgOC","file":"default-ticker.js","sourcesContent":["import { EventEmitter } from '@visactor/vutils';\nimport type { IStage } from '@visactor/vrender-core';\nimport { application, PerformanceRAF } from '@visactor/vrender-core';\nimport { type ITickHandler, type ITicker, STATUS } from '../intreface/ticker';\nimport type { ITimeline } from '../intreface/timeline';\n\nconst performanceRAF = new PerformanceRAF();\n\nclass RAFTickHandler implements ITickHandler {\n protected released: boolean = false;\n\n tick(interval: number, cb: (handler: ITickHandler) => void): void {\n performanceRAF.addAnimationFrameCb(() => {\n if (this.released) {\n return;\n }\n cb(this);\n });\n }\n\n release(): void {\n this.released = true;\n }\n\n getTime(): number {\n return Date.now();\n }\n}\n\n/**\n * Graph-based Ticker implementation\n * This ticker works directly with GraphManager instances without needing timeline adapters\n */\nexport class DefaultTicker extends EventEmitter implements ITicker {\n protected interval: number = 16;\n protected tickerHandler: ITickHandler;\n protected status: STATUS;\n protected lastFrameTime: number = -1;\n protected lastExecutionTime: number = -1; // Track the last time we actually executed a frame\n protected tickCounts: number = 0;\n protected stage: IStage;\n timelines: ITimeline[] = [];\n autoStop: boolean = true;\n\n constructor(stage: IStage) {\n super();\n this.init();\n this.lastFrameTime = -1;\n this.lastExecutionTime = -1;\n this.tickCounts = 0;\n this.stage = stage;\n this.autoStop = true;\n }\n\n init(): void {\n this.interval = 16;\n this.status = STATUS.INITIAL;\n application.global.hooks.onSetEnv.tap('graph-ticker', () => {\n this.initHandler();\n });\n if (application.global.env) {\n this.initHandler();\n }\n }\n\n addTimeline(timeline: ITimeline): void {\n this.timelines.push(timeline);\n }\n\n remTimeline(timeline: ITimeline): void {\n this.timelines = this.timelines.filter(t => t !== timeline);\n }\n\n getTimelines(): ITimeline[] {\n return this.timelines;\n }\n\n protected initHandler() {\n this.setupTickHandler();\n }\n\n /**\n * Set up the tick handler\n * @returns true if setup was successful, false otherwise\n */\n protected setupTickHandler(): boolean {\n const handler: ITickHandler = new RAFTickHandler();\n\n // Destroy the previous tick handler\n if (this.tickerHandler) {\n this.tickerHandler.release();\n }\n\n this.tickerHandler = handler;\n return true;\n }\n\n setInterval(interval: number): void {\n this.interval = interval;\n }\n\n getInterval(): number {\n return this.interval;\n }\n\n setFPS(fps: number): void {\n this.setInterval(1000 / fps);\n }\n\n getFPS(): number {\n return 1000 / this.interval;\n }\n\n tick(interval: number): void {\n this.tickerHandler.tick(interval, (handler: ITickHandler) => {\n this.handleTick(handler, { once: true });\n });\n }\n\n tickTo(t: number): void {\n if (!this.tickerHandler.tickTo) {\n return;\n }\n this.tickerHandler.tickTo(t, (handler: ITickHandler) => {\n this.handleTick(handler, { once: true });\n });\n }\n\n pause(): boolean {\n if (this.status === STATUS.INITIAL) {\n return false;\n }\n this.status = STATUS.PAUSE;\n return true;\n }\n\n resume(): boolean {\n if (this.status === STATUS.INITIAL) {\n return false;\n }\n this.status = STATUS.RUNNING;\n return true;\n }\n\n ifCanStop(): boolean {\n if (this.autoStop) {\n if (!this.timelines.length) {\n return true;\n }\n if (this.timelines.every(timeline => !timeline.isRunning())) {\n return true;\n }\n }\n return false;\n }\n\n start(force: boolean = false): boolean {\n if (this.status === STATUS.RUNNING) {\n return false;\n }\n if (!this.tickerHandler) {\n return false;\n }\n\n // 暂停中、或者应该停止的时候,就不执行\n if (!force) {\n if (this.status === STATUS.PAUSE) {\n return false;\n }\n if (this.ifCanStop()) {\n return false;\n }\n }\n\n this.status = STATUS.RUNNING;\n this.tickerHandler.tick(0, this.handleTick);\n return true;\n }\n\n stop(): void {\n // Reset the tick handler\n this.status = STATUS.INITIAL;\n this.setupTickHandler();\n this.lastFrameTime = -1;\n this.lastExecutionTime = -1;\n }\n\n /**\n * 用于自动启动或停止\n * 基于当前的graph managers检查是否需要启动或停止\n */\n trySyncTickStatus(): void {\n if (this.status === STATUS.INITIAL && this.timelines.some(timeline => timeline.isRunning())) {\n this.start();\n } else if (this.status === STATUS.RUNNING && this.timelines.every(timeline => !timeline.isRunning())) {\n this.stop();\n }\n }\n\n release(): void {\n this.stop();\n this.timelines = [];\n this.tickerHandler?.release();\n this.tickerHandler = null;\n this.lastExecutionTime = -1;\n }\n\n protected handleTick = (handler: ITickHandler, params?: { once?: boolean }): void => {\n const { once = false } = params ?? {};\n\n // 尝试停止\n if (this.ifCanStop()) {\n this.stop();\n return;\n }\n\n const currentTime = handler.getTime();\n\n // Check if enough time has passed since last execution based on the interval (FPS limit)\n const timeFromLastExecution = this.lastExecutionTime < 0 ? this.interval : currentTime - this.lastExecutionTime;\n\n // Only execute the frame if enough time has passed according to our interval/FPS setting\n if (timeFromLastExecution >= this.interval) {\n this._handlerTick();\n this.lastExecutionTime = currentTime;\n }\n\n if (!once) {\n handler.tick(this.interval, this.handleTick);\n }\n };\n\n protected _handlerTick = (): void => {\n // Specific execution function\n const tickerHandler = this.tickerHandler;\n const time = tickerHandler.getTime();\n\n // Time passed since last frame\n let delta = 0;\n if (this.lastFrameTime >= 0) {\n delta = time - this.lastFrameTime;\n }\n this.lastFrameTime = time;\n\n if (this.status !== STATUS.RUNNING) {\n return;\n }\n\n this.tickCounts++;\n\n // Update all graph managers\n this.timelines.forEach(timeline => {\n timeline.tick(delta);\n });\n\n this.emit('tick', delta);\n };\n}\n"]}
1
+ {"version":3,"sources":["../src/ticker/default-ticker.ts"],"names":[],"mappings":"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","file":"default-ticker.js","sourcesContent":["import { EventEmitter } from '@visactor/vutils';\nimport type { IStage } from '@visactor/vrender-core';\nimport { application, PerformanceRAF } from '@visactor/vrender-core';\nimport { type ITickHandler, type ITicker, STATUS } from '../intreface/ticker';\nimport type { ITimeline } from '../intreface/timeline';\n\nconst performanceRAF = new PerformanceRAF();\n\nclass RAFTickHandler implements ITickHandler {\n protected released: boolean = false;\n\n tick(interval: number, cb: (handler: ITickHandler) => void | boolean): void {\n performanceRAF.addAnimationFrameCb(() => {\n if (this.released) {\n return;\n }\n return cb(this);\n });\n }\n\n release(): void {\n this.released = true;\n }\n\n getTime(): number {\n return Date.now();\n }\n}\n\n/**\n * Graph-based Ticker implementation\n * This ticker works directly with GraphManager instances without needing timeline adapters\n */\nexport class DefaultTicker extends EventEmitter implements ITicker {\n protected interval: number;\n protected tickerHandler: ITickHandler;\n protected status: STATUS;\n protected lastFrameTime: number;\n protected tickCounts: number;\n protected stage: IStage;\n timelines: ITimeline[] = [];\n autoStop: boolean;\n // 随机扰动(每次都对interval进行随机的扰动,避免所有tick都发生在同一帧)\n protected _jitter: number;\n protected timeOffset: number;\n declare _lastTickTime: number;\n protected frameTimeHistory: number[] = [];\n\n constructor(stage: IStage) {\n super();\n this.init();\n this.lastFrameTime = -1;\n this.tickCounts = 0;\n this.stage = stage;\n this.autoStop = true;\n this.interval = 16;\n this.computeTimeOffsetAndJitter();\n }\n\n /**\n * 计算时间偏移和随机扰动\n */\n computeTimeOffsetAndJitter(): void {\n this.timeOffset = Math.floor(Math.random() * this.interval);\n this._jitter = Math.min(Math.max(this.interval * 0.2, 6), this.interval * 0.7);\n }\n\n init(): void {\n this.interval = 16;\n this.status = STATUS.INITIAL;\n application.global.hooks.onSetEnv.tap('graph-ticker', () => {\n this.initHandler();\n });\n if (application.global.env) {\n this.initHandler();\n }\n }\n\n addTimeline(timeline: ITimeline): void {\n this.timelines.push(timeline);\n }\n\n remTimeline(timeline: ITimeline): void {\n this.timelines = this.timelines.filter(t => t !== timeline);\n }\n\n getTimelines(): ITimeline[] {\n return this.timelines;\n }\n\n protected initHandler() {\n this.setupTickHandler();\n }\n\n /**\n * Set up the tick handler\n * @returns true if setup was successful, false otherwise\n */\n protected setupTickHandler(): boolean {\n const handler: ITickHandler = new RAFTickHandler();\n\n // Destroy the previous tick handler\n if (this.tickerHandler) {\n this.tickerHandler.release();\n }\n\n this.tickerHandler = handler;\n return true;\n }\n\n setInterval(interval: number): void {\n this.interval = interval;\n this.computeTimeOffsetAndJitter();\n }\n\n getInterval(): number {\n return this.interval;\n }\n\n setFPS(fps: number): void {\n this.setInterval(Math.floor(1000 / fps));\n }\n\n getFPS(): number {\n return 1000 / this.interval;\n }\n\n tick(interval: number): void {\n this.tickerHandler.tick(interval, (handler: ITickHandler) => {\n return this.handleTick(handler, { once: true });\n });\n }\n\n tickTo(t: number): void {\n if (!this.tickerHandler.tickTo) {\n return;\n }\n this.tickerHandler.tickTo(t, (handler: ITickHandler) => {\n this.handleTick(handler, { once: true });\n });\n }\n\n pause(): boolean {\n if (this.status === STATUS.INITIAL) {\n return false;\n }\n this.status = STATUS.PAUSE;\n return true;\n }\n\n resume(): boolean {\n if (this.status === STATUS.INITIAL) {\n return false;\n }\n this.status = STATUS.RUNNING;\n return true;\n }\n\n ifCanStop(): boolean {\n if (this.autoStop) {\n if (!this.timelines.length) {\n return true;\n }\n if (this.timelines.every(timeline => !timeline.isRunning())) {\n return true;\n }\n }\n return false;\n }\n\n start(force: boolean = false): boolean {\n if (this.status === STATUS.RUNNING) {\n return false;\n }\n if (!this.tickerHandler) {\n return false;\n }\n\n // 暂停中、或者应该停止的时候,就不执行\n if (!force) {\n if (this.status === STATUS.PAUSE) {\n return false;\n }\n if (this.ifCanStop()) {\n return false;\n }\n }\n\n this.status = STATUS.RUNNING;\n this.tickerHandler.tick(0, this.handleTick);\n return true;\n }\n\n stop(): void {\n // Reset the tick handler\n this.status = STATUS.INITIAL;\n this.setupTickHandler();\n this.lastFrameTime = -1;\n }\n\n /**\n * 用于自动启动或停止\n * 基于当前的graph managers检查是否需要启动或停止\n */\n trySyncTickStatus(): void {\n if (this.status === STATUS.INITIAL && this.timelines.some(timeline => timeline.isRunning())) {\n this.start();\n } else if (this.status === STATUS.RUNNING && this.timelines.every(timeline => !timeline.isRunning())) {\n this.stop();\n }\n }\n\n release(): void {\n this.stop();\n this.timelines = [];\n this.tickerHandler?.release();\n this.tickerHandler = null;\n this.lastFrameTime = -1;\n }\n\n protected checkSkip = (delta: number): boolean => {\n // 随机扰动(每次都对interval进行随机的扰动,避免所有tick都发生在同一帧)\n const skip = delta < this.interval + (Math.random() - 0.5) * 2 * this._jitter;\n return skip;\n };\n\n protected handleTick = (handler: ITickHandler, params?: { once?: boolean }): boolean => {\n const { once = false } = params ?? {};\n\n // 尝试停止\n if (this.ifCanStop()) {\n this.stop();\n return false;\n }\n\n const currentTime = handler.getTime();\n this._lastTickTime = currentTime;\n\n if (this.lastFrameTime < 0) {\n this.lastFrameTime = currentTime - this.interval + this.timeOffset;\n this.frameTimeHistory.push(this.lastFrameTime);\n }\n\n const delta = currentTime - this.lastFrameTime;\n\n const skip = this.checkSkip(delta);\n\n if (!skip) {\n this._handlerTick(delta);\n this.lastFrameTime = currentTime;\n this.frameTimeHistory.push(this.lastFrameTime);\n }\n\n if (!once) {\n handler.tick(this.interval, this.handleTick);\n }\n\n return !skip;\n };\n\n protected _handlerTick = (delta: number): void => {\n if (this.status !== STATUS.RUNNING) {\n return;\n }\n\n this.tickCounts++;\n\n // Update all graph managers\n this.timelines.forEach(timeline => {\n timeline.tick(delta);\n });\n\n this.emit('tick', delta);\n };\n}\n"]}
@@ -12,5 +12,4 @@ function generatorPathEasingFunc(path) {
12
12
  x => customPath.getYAt(x);
13
13
  }
14
14
 
15
- exports.generatorPathEasingFunc = generatorPathEasingFunc;
16
- //# sourceMappingURL=easing-func.js.map
15
+ exports.generatorPathEasingFunc = generatorPathEasingFunc;