@tsparticles/updater-gradient 3.0.2 → 3.1.0

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.
@@ -1,14 +1,15 @@
1
- import { executeOnSingleOrMultiple, getHslAnimationFromHsl, getRandom, getRangeMax, getRangeMin, getRangeValue, getStyleFromHsl, itemFromSingleOrMultiple, randomInRange, rangeColorToHsl, } from "@tsparticles/engine";
1
+ import { executeOnSingleOrMultiple, getHslAnimationFromHsl, getRandom, getRangeMax, getRangeMin, getRangeValue, getStyleFromHsl, halfRandom, itemFromSingleOrMultiple, millisecondsToSeconds, percentDenominator, randomInRange, rangeColorToHsl, } from "@tsparticles/engine";
2
2
  import { AnimatableGradient } from "./Options/Classes/AnimatableGradient.js";
3
3
  import { updateGradient } from "./Utils.js";
4
+ const double = 2, doublePI = Math.PI * double;
4
5
  export class GradientUpdater {
5
6
  getColorStyles(particle, context, radius, opacity) {
6
7
  const gradient = particle.gradient;
7
8
  if (!gradient) {
8
9
  return {};
9
10
  }
10
- const gradientAngle = gradient.angle.value, fillGradient = gradient.type === "radial"
11
- ? context.createRadialGradient(0, 0, 0, 0, 0, radius)
11
+ const gradientAngle = gradient.angle.value, origin = { x: 0, y: 0 }, minRadius = 0, fillGradient = gradient.type === "radial"
12
+ ? context.createRadialGradient(origin.x, origin.y, minRadius, origin.x, origin.y, radius)
12
13
  : context.createLinearGradient(Math.cos(gradientAngle) * -radius, Math.sin(gradientAngle) * -radius, Math.cos(gradientAngle) * radius, Math.sin(gradientAngle) * radius);
13
14
  for (const { stop, value, opacity: cOpacity } of gradient.colors) {
14
15
  fillGradient.addColorStop(stop, getStyleFromHsl({
@@ -24,14 +25,16 @@ export class GradientUpdater {
24
25
  if (!gradient) {
25
26
  return;
26
27
  }
27
- const { angle } = gradient;
28
+ const { angle } = gradient, speedFactor = 360, delayOffset = 1;
28
29
  particle.gradient = {
29
30
  angle: {
30
31
  value: getRangeValue(angle.value),
31
32
  enable: angle.animation.enable,
32
- velocity: (getRangeValue(angle.animation.speed) / 360) * particle.container.retina.reduceFactor,
33
- decay: 1 - getRangeValue(angle.animation.decay),
34
- delayTime: getRangeValue(angle.animation.delay) * 1000,
33
+ velocity: (getRangeValue(angle.animation.speed) / speedFactor) * particle.container.retina.reduceFactor,
34
+ decay: delayOffset - getRangeValue(angle.animation.decay),
35
+ delayTime: getRangeValue(angle.animation.delay) * millisecondsToSeconds,
36
+ max: doublePI,
37
+ min: 0,
35
38
  time: 0,
36
39
  },
37
40
  type: gradient.type,
@@ -39,7 +42,7 @@ export class GradientUpdater {
39
42
  };
40
43
  let rotateDirection = gradient.angle.direction;
41
44
  if (rotateDirection === "random") {
42
- rotateDirection = getRandom() > 0.5 ? "counter-clockwise" : "clockwise";
45
+ rotateDirection = getRandom() > halfRandom ? "counter-clockwise" : "clockwise";
43
46
  }
44
47
  switch (rotateDirection) {
45
48
  case "counter-clockwise":
@@ -66,10 +69,10 @@ export class GradientUpdater {
66
69
  min: getRangeMin(grColor.opacity.value),
67
70
  status: "increasing",
68
71
  value: getRangeValue(grColor.opacity.value),
69
- velocity: (getRangeValue(grColor.opacity.animation.speed) / 100) *
72
+ velocity: (getRangeValue(grColor.opacity.animation.speed) / percentDenominator) *
70
73
  particle.container.retina.reduceFactor,
71
- decay: 1 - getRangeValue(grColor.opacity.animation.decay),
72
- delayTime: getRangeValue(grColor.opacity.animation.delay) * 1000,
74
+ decay: delayOffset - getRangeValue(grColor.opacity.animation.decay),
75
+ delayTime: getRangeValue(grColor.opacity.animation.delay) * millisecondsToSeconds,
73
76
  time: 0,
74
77
  }
75
78
  : undefined,
@@ -93,7 +96,7 @@ export class GradientUpdater {
93
96
  default:
94
97
  addOpacity.value = randomInRange(addOpacity);
95
98
  addOpacity.status =
96
- getRandom() >= 0.5 ? "increasing" : "decreasing";
99
+ getRandom() >= halfRandom ? "increasing" : "decreasing";
97
100
  break;
98
101
  }
99
102
  }
@@ -103,7 +106,7 @@ export class GradientUpdater {
103
106
  isEnabled(particle) {
104
107
  return (!particle.destroyed &&
105
108
  !particle.spawning &&
106
- (particle.gradient?.angle.enable ||
109
+ (!!particle.gradient?.angle.enable ||
107
110
  (particle.gradient?.colors.some((c) => c.value.h.enable || c.value.s.enable || c.value.l.enable) ??
108
111
  false)));
109
112
  }
package/browser/Utils.js CHANGED
@@ -1,107 +1,14 @@
1
- function updateColorOpacity(delta, value) {
2
- if (!value.enable) {
3
- return;
4
- }
5
- const decay = value.decay ?? 1;
6
- switch (value.status) {
7
- case "increasing":
8
- if (value.value >= value.max) {
9
- value.status = "decreasing";
10
- }
11
- else {
12
- value.value += (value.velocity ?? 0) * delta.factor;
13
- }
14
- break;
15
- case "decreasing":
16
- if (value.value <= value.min) {
17
- value.status = "increasing";
18
- }
19
- else {
20
- value.value -= (value.velocity ?? 0) * delta.factor;
21
- }
22
- break;
23
- }
24
- if (value.velocity && decay !== 1) {
25
- value.velocity *= decay;
26
- }
27
- }
28
- function updateColorValue(delta, colorValue, max, decrease) {
29
- if (!colorValue || !colorValue.enable) {
30
- return;
31
- }
32
- if (!colorValue.time) {
33
- colorValue.time = 0;
34
- }
35
- if ((colorValue.delayTime ?? 0) > 0 && colorValue.time < (colorValue.delayTime ?? 0)) {
36
- colorValue.time += delta.value;
37
- }
38
- if ((colorValue.delayTime ?? 0) > 0 && colorValue.time < (colorValue.delayTime ?? 0)) {
39
- return;
40
- }
41
- const velocity = (colorValue.velocity ?? 0) * delta.factor, decay = colorValue.decay ?? 1;
42
- if (!decrease || colorValue.status === "increasing") {
43
- colorValue.value += velocity;
44
- if (decrease && colorValue.value > max) {
45
- colorValue.status = "decreasing";
46
- colorValue.value -= colorValue.value % max;
47
- }
48
- }
49
- else {
50
- colorValue.value -= velocity;
51
- if (colorValue.value < 0) {
52
- colorValue.status = "increasing";
53
- colorValue.value += colorValue.value;
54
- }
55
- }
56
- if (colorValue.value > max) {
57
- colorValue.value %= max;
58
- }
59
- if (colorValue.velocity && decay !== 1) {
60
- colorValue.velocity *= decay;
61
- }
62
- }
63
- function updateAngle(delta, angle) {
64
- const speed = (angle.velocity ?? 0) * delta.factor, max = 2 * Math.PI, decay = angle.decay ?? 1;
65
- if (!angle.enable) {
66
- return;
67
- }
68
- switch (angle.status) {
69
- case "increasing":
70
- angle.value += speed;
71
- if (angle.value > max) {
72
- angle.value -= max;
73
- }
74
- break;
75
- case "decreasing":
76
- default:
77
- angle.value -= speed;
78
- if (angle.value < 0) {
79
- angle.value += max;
80
- }
81
- break;
82
- }
83
- if (angle.velocity && decay !== 1) {
84
- angle.velocity *= decay;
85
- }
86
- }
1
+ import { updateAnimation, updateColor } from "@tsparticles/engine";
87
2
  export function updateGradient(particle, delta) {
88
3
  const { gradient } = particle;
89
4
  if (!gradient) {
90
5
  return;
91
6
  }
92
- updateAngle(delta, gradient.angle);
7
+ updateAnimation(particle, gradient.angle, false, "none", delta);
93
8
  for (const color of gradient.colors) {
94
- if (particle.color?.h !== undefined) {
95
- updateColorValue(delta, color.value.h, 360, false);
96
- }
97
- if (particle.color?.s !== undefined) {
98
- updateColorValue(delta, color.value.s, 100, true);
99
- }
100
- if (particle.color?.l !== undefined) {
101
- updateColorValue(delta, color.value.l, 100, true);
102
- }
9
+ updateColor(color.value, delta);
103
10
  if (color.opacity) {
104
- updateColorOpacity(delta, color.opacity);
11
+ updateAnimation(particle, color.opacity, true, "none", delta);
105
12
  }
106
13
  }
107
14
  }
@@ -4,14 +4,15 @@ exports.GradientUpdater = void 0;
4
4
  const engine_1 = require("@tsparticles/engine");
5
5
  const AnimatableGradient_js_1 = require("./Options/Classes/AnimatableGradient.js");
6
6
  const Utils_js_1 = require("./Utils.js");
7
+ const double = 2, doublePI = Math.PI * double;
7
8
  class GradientUpdater {
8
9
  getColorStyles(particle, context, radius, opacity) {
9
10
  const gradient = particle.gradient;
10
11
  if (!gradient) {
11
12
  return {};
12
13
  }
13
- const gradientAngle = gradient.angle.value, fillGradient = gradient.type === "radial"
14
- ? context.createRadialGradient(0, 0, 0, 0, 0, radius)
14
+ const gradientAngle = gradient.angle.value, origin = { x: 0, y: 0 }, minRadius = 0, fillGradient = gradient.type === "radial"
15
+ ? context.createRadialGradient(origin.x, origin.y, minRadius, origin.x, origin.y, radius)
15
16
  : context.createLinearGradient(Math.cos(gradientAngle) * -radius, Math.sin(gradientAngle) * -radius, Math.cos(gradientAngle) * radius, Math.sin(gradientAngle) * radius);
16
17
  for (const { stop, value, opacity: cOpacity } of gradient.colors) {
17
18
  fillGradient.addColorStop(stop, (0, engine_1.getStyleFromHsl)({
@@ -27,14 +28,16 @@ class GradientUpdater {
27
28
  if (!gradient) {
28
29
  return;
29
30
  }
30
- const { angle } = gradient;
31
+ const { angle } = gradient, speedFactor = 360, delayOffset = 1;
31
32
  particle.gradient = {
32
33
  angle: {
33
34
  value: (0, engine_1.getRangeValue)(angle.value),
34
35
  enable: angle.animation.enable,
35
- velocity: ((0, engine_1.getRangeValue)(angle.animation.speed) / 360) * particle.container.retina.reduceFactor,
36
- decay: 1 - (0, engine_1.getRangeValue)(angle.animation.decay),
37
- delayTime: (0, engine_1.getRangeValue)(angle.animation.delay) * 1000,
36
+ velocity: ((0, engine_1.getRangeValue)(angle.animation.speed) / speedFactor) * particle.container.retina.reduceFactor,
37
+ decay: delayOffset - (0, engine_1.getRangeValue)(angle.animation.decay),
38
+ delayTime: (0, engine_1.getRangeValue)(angle.animation.delay) * engine_1.millisecondsToSeconds,
39
+ max: doublePI,
40
+ min: 0,
38
41
  time: 0,
39
42
  },
40
43
  type: gradient.type,
@@ -42,7 +45,7 @@ class GradientUpdater {
42
45
  };
43
46
  let rotateDirection = gradient.angle.direction;
44
47
  if (rotateDirection === "random") {
45
- rotateDirection = (0, engine_1.getRandom)() > 0.5 ? "counter-clockwise" : "clockwise";
48
+ rotateDirection = (0, engine_1.getRandom)() > engine_1.halfRandom ? "counter-clockwise" : "clockwise";
46
49
  }
47
50
  switch (rotateDirection) {
48
51
  case "counter-clockwise":
@@ -69,10 +72,10 @@ class GradientUpdater {
69
72
  min: (0, engine_1.getRangeMin)(grColor.opacity.value),
70
73
  status: "increasing",
71
74
  value: (0, engine_1.getRangeValue)(grColor.opacity.value),
72
- velocity: ((0, engine_1.getRangeValue)(grColor.opacity.animation.speed) / 100) *
75
+ velocity: ((0, engine_1.getRangeValue)(grColor.opacity.animation.speed) / engine_1.percentDenominator) *
73
76
  particle.container.retina.reduceFactor,
74
- decay: 1 - (0, engine_1.getRangeValue)(grColor.opacity.animation.decay),
75
- delayTime: (0, engine_1.getRangeValue)(grColor.opacity.animation.delay) * 1000,
77
+ decay: delayOffset - (0, engine_1.getRangeValue)(grColor.opacity.animation.decay),
78
+ delayTime: (0, engine_1.getRangeValue)(grColor.opacity.animation.delay) * engine_1.millisecondsToSeconds,
76
79
  time: 0,
77
80
  }
78
81
  : undefined,
@@ -96,7 +99,7 @@ class GradientUpdater {
96
99
  default:
97
100
  addOpacity.value = (0, engine_1.randomInRange)(addOpacity);
98
101
  addOpacity.status =
99
- (0, engine_1.getRandom)() >= 0.5 ? "increasing" : "decreasing";
102
+ (0, engine_1.getRandom)() >= engine_1.halfRandom ? "increasing" : "decreasing";
100
103
  break;
101
104
  }
102
105
  }
@@ -106,7 +109,7 @@ class GradientUpdater {
106
109
  isEnabled(particle) {
107
110
  return (!particle.destroyed &&
108
111
  !particle.spawning &&
109
- (particle.gradient?.angle.enable ||
112
+ (!!particle.gradient?.angle.enable ||
110
113
  (particle.gradient?.colors.some((c) => c.value.h.enable || c.value.s.enable || c.value.l.enable) ??
111
114
  false)));
112
115
  }
package/cjs/Utils.js CHANGED
@@ -1,110 +1,17 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.updateGradient = void 0;
4
- function updateColorOpacity(delta, value) {
5
- if (!value.enable) {
6
- return;
7
- }
8
- const decay = value.decay ?? 1;
9
- switch (value.status) {
10
- case "increasing":
11
- if (value.value >= value.max) {
12
- value.status = "decreasing";
13
- }
14
- else {
15
- value.value += (value.velocity ?? 0) * delta.factor;
16
- }
17
- break;
18
- case "decreasing":
19
- if (value.value <= value.min) {
20
- value.status = "increasing";
21
- }
22
- else {
23
- value.value -= (value.velocity ?? 0) * delta.factor;
24
- }
25
- break;
26
- }
27
- if (value.velocity && decay !== 1) {
28
- value.velocity *= decay;
29
- }
30
- }
31
- function updateColorValue(delta, colorValue, max, decrease) {
32
- if (!colorValue || !colorValue.enable) {
33
- return;
34
- }
35
- if (!colorValue.time) {
36
- colorValue.time = 0;
37
- }
38
- if ((colorValue.delayTime ?? 0) > 0 && colorValue.time < (colorValue.delayTime ?? 0)) {
39
- colorValue.time += delta.value;
40
- }
41
- if ((colorValue.delayTime ?? 0) > 0 && colorValue.time < (colorValue.delayTime ?? 0)) {
42
- return;
43
- }
44
- const velocity = (colorValue.velocity ?? 0) * delta.factor, decay = colorValue.decay ?? 1;
45
- if (!decrease || colorValue.status === "increasing") {
46
- colorValue.value += velocity;
47
- if (decrease && colorValue.value > max) {
48
- colorValue.status = "decreasing";
49
- colorValue.value -= colorValue.value % max;
50
- }
51
- }
52
- else {
53
- colorValue.value -= velocity;
54
- if (colorValue.value < 0) {
55
- colorValue.status = "increasing";
56
- colorValue.value += colorValue.value;
57
- }
58
- }
59
- if (colorValue.value > max) {
60
- colorValue.value %= max;
61
- }
62
- if (colorValue.velocity && decay !== 1) {
63
- colorValue.velocity *= decay;
64
- }
65
- }
66
- function updateAngle(delta, angle) {
67
- const speed = (angle.velocity ?? 0) * delta.factor, max = 2 * Math.PI, decay = angle.decay ?? 1;
68
- if (!angle.enable) {
69
- return;
70
- }
71
- switch (angle.status) {
72
- case "increasing":
73
- angle.value += speed;
74
- if (angle.value > max) {
75
- angle.value -= max;
76
- }
77
- break;
78
- case "decreasing":
79
- default:
80
- angle.value -= speed;
81
- if (angle.value < 0) {
82
- angle.value += max;
83
- }
84
- break;
85
- }
86
- if (angle.velocity && decay !== 1) {
87
- angle.velocity *= decay;
88
- }
89
- }
4
+ const engine_1 = require("@tsparticles/engine");
90
5
  function updateGradient(particle, delta) {
91
6
  const { gradient } = particle;
92
7
  if (!gradient) {
93
8
  return;
94
9
  }
95
- updateAngle(delta, gradient.angle);
10
+ (0, engine_1.updateAnimation)(particle, gradient.angle, false, "none", delta);
96
11
  for (const color of gradient.colors) {
97
- if (particle.color?.h !== undefined) {
98
- updateColorValue(delta, color.value.h, 360, false);
99
- }
100
- if (particle.color?.s !== undefined) {
101
- updateColorValue(delta, color.value.s, 100, true);
102
- }
103
- if (particle.color?.l !== undefined) {
104
- updateColorValue(delta, color.value.l, 100, true);
105
- }
12
+ (0, engine_1.updateColor)(color.value, delta);
106
13
  if (color.opacity) {
107
- updateColorOpacity(delta, color.opacity);
14
+ (0, engine_1.updateAnimation)(particle, color.opacity, true, "none", delta);
108
15
  }
109
16
  }
110
17
  }
@@ -1,14 +1,15 @@
1
- import { executeOnSingleOrMultiple, getHslAnimationFromHsl, getRandom, getRangeMax, getRangeMin, getRangeValue, getStyleFromHsl, itemFromSingleOrMultiple, randomInRange, rangeColorToHsl, } from "@tsparticles/engine";
1
+ import { executeOnSingleOrMultiple, getHslAnimationFromHsl, getRandom, getRangeMax, getRangeMin, getRangeValue, getStyleFromHsl, halfRandom, itemFromSingleOrMultiple, millisecondsToSeconds, percentDenominator, randomInRange, rangeColorToHsl, } from "@tsparticles/engine";
2
2
  import { AnimatableGradient } from "./Options/Classes/AnimatableGradient.js";
3
3
  import { updateGradient } from "./Utils.js";
4
+ const double = 2, doublePI = Math.PI * double;
4
5
  export class GradientUpdater {
5
6
  getColorStyles(particle, context, radius, opacity) {
6
7
  const gradient = particle.gradient;
7
8
  if (!gradient) {
8
9
  return {};
9
10
  }
10
- const gradientAngle = gradient.angle.value, fillGradient = gradient.type === "radial"
11
- ? context.createRadialGradient(0, 0, 0, 0, 0, radius)
11
+ const gradientAngle = gradient.angle.value, origin = { x: 0, y: 0 }, minRadius = 0, fillGradient = gradient.type === "radial"
12
+ ? context.createRadialGradient(origin.x, origin.y, minRadius, origin.x, origin.y, radius)
12
13
  : context.createLinearGradient(Math.cos(gradientAngle) * -radius, Math.sin(gradientAngle) * -radius, Math.cos(gradientAngle) * radius, Math.sin(gradientAngle) * radius);
13
14
  for (const { stop, value, opacity: cOpacity } of gradient.colors) {
14
15
  fillGradient.addColorStop(stop, getStyleFromHsl({
@@ -24,14 +25,16 @@ export class GradientUpdater {
24
25
  if (!gradient) {
25
26
  return;
26
27
  }
27
- const { angle } = gradient;
28
+ const { angle } = gradient, speedFactor = 360, delayOffset = 1;
28
29
  particle.gradient = {
29
30
  angle: {
30
31
  value: getRangeValue(angle.value),
31
32
  enable: angle.animation.enable,
32
- velocity: (getRangeValue(angle.animation.speed) / 360) * particle.container.retina.reduceFactor,
33
- decay: 1 - getRangeValue(angle.animation.decay),
34
- delayTime: getRangeValue(angle.animation.delay) * 1000,
33
+ velocity: (getRangeValue(angle.animation.speed) / speedFactor) * particle.container.retina.reduceFactor,
34
+ decay: delayOffset - getRangeValue(angle.animation.decay),
35
+ delayTime: getRangeValue(angle.animation.delay) * millisecondsToSeconds,
36
+ max: doublePI,
37
+ min: 0,
35
38
  time: 0,
36
39
  },
37
40
  type: gradient.type,
@@ -39,7 +42,7 @@ export class GradientUpdater {
39
42
  };
40
43
  let rotateDirection = gradient.angle.direction;
41
44
  if (rotateDirection === "random") {
42
- rotateDirection = getRandom() > 0.5 ? "counter-clockwise" : "clockwise";
45
+ rotateDirection = getRandom() > halfRandom ? "counter-clockwise" : "clockwise";
43
46
  }
44
47
  switch (rotateDirection) {
45
48
  case "counter-clockwise":
@@ -66,10 +69,10 @@ export class GradientUpdater {
66
69
  min: getRangeMin(grColor.opacity.value),
67
70
  status: "increasing",
68
71
  value: getRangeValue(grColor.opacity.value),
69
- velocity: (getRangeValue(grColor.opacity.animation.speed) / 100) *
72
+ velocity: (getRangeValue(grColor.opacity.animation.speed) / percentDenominator) *
70
73
  particle.container.retina.reduceFactor,
71
- decay: 1 - getRangeValue(grColor.opacity.animation.decay),
72
- delayTime: getRangeValue(grColor.opacity.animation.delay) * 1000,
74
+ decay: delayOffset - getRangeValue(grColor.opacity.animation.decay),
75
+ delayTime: getRangeValue(grColor.opacity.animation.delay) * millisecondsToSeconds,
73
76
  time: 0,
74
77
  }
75
78
  : undefined,
@@ -93,7 +96,7 @@ export class GradientUpdater {
93
96
  default:
94
97
  addOpacity.value = randomInRange(addOpacity);
95
98
  addOpacity.status =
96
- getRandom() >= 0.5 ? "increasing" : "decreasing";
99
+ getRandom() >= halfRandom ? "increasing" : "decreasing";
97
100
  break;
98
101
  }
99
102
  }
@@ -103,7 +106,7 @@ export class GradientUpdater {
103
106
  isEnabled(particle) {
104
107
  return (!particle.destroyed &&
105
108
  !particle.spawning &&
106
- (particle.gradient?.angle.enable ||
109
+ (!!particle.gradient?.angle.enable ||
107
110
  (particle.gradient?.colors.some((c) => c.value.h.enable || c.value.s.enable || c.value.l.enable) ??
108
111
  false)));
109
112
  }
package/esm/Utils.js CHANGED
@@ -1,107 +1,14 @@
1
- function updateColorOpacity(delta, value) {
2
- if (!value.enable) {
3
- return;
4
- }
5
- const decay = value.decay ?? 1;
6
- switch (value.status) {
7
- case "increasing":
8
- if (value.value >= value.max) {
9
- value.status = "decreasing";
10
- }
11
- else {
12
- value.value += (value.velocity ?? 0) * delta.factor;
13
- }
14
- break;
15
- case "decreasing":
16
- if (value.value <= value.min) {
17
- value.status = "increasing";
18
- }
19
- else {
20
- value.value -= (value.velocity ?? 0) * delta.factor;
21
- }
22
- break;
23
- }
24
- if (value.velocity && decay !== 1) {
25
- value.velocity *= decay;
26
- }
27
- }
28
- function updateColorValue(delta, colorValue, max, decrease) {
29
- if (!colorValue || !colorValue.enable) {
30
- return;
31
- }
32
- if (!colorValue.time) {
33
- colorValue.time = 0;
34
- }
35
- if ((colorValue.delayTime ?? 0) > 0 && colorValue.time < (colorValue.delayTime ?? 0)) {
36
- colorValue.time += delta.value;
37
- }
38
- if ((colorValue.delayTime ?? 0) > 0 && colorValue.time < (colorValue.delayTime ?? 0)) {
39
- return;
40
- }
41
- const velocity = (colorValue.velocity ?? 0) * delta.factor, decay = colorValue.decay ?? 1;
42
- if (!decrease || colorValue.status === "increasing") {
43
- colorValue.value += velocity;
44
- if (decrease && colorValue.value > max) {
45
- colorValue.status = "decreasing";
46
- colorValue.value -= colorValue.value % max;
47
- }
48
- }
49
- else {
50
- colorValue.value -= velocity;
51
- if (colorValue.value < 0) {
52
- colorValue.status = "increasing";
53
- colorValue.value += colorValue.value;
54
- }
55
- }
56
- if (colorValue.value > max) {
57
- colorValue.value %= max;
58
- }
59
- if (colorValue.velocity && decay !== 1) {
60
- colorValue.velocity *= decay;
61
- }
62
- }
63
- function updateAngle(delta, angle) {
64
- const speed = (angle.velocity ?? 0) * delta.factor, max = 2 * Math.PI, decay = angle.decay ?? 1;
65
- if (!angle.enable) {
66
- return;
67
- }
68
- switch (angle.status) {
69
- case "increasing":
70
- angle.value += speed;
71
- if (angle.value > max) {
72
- angle.value -= max;
73
- }
74
- break;
75
- case "decreasing":
76
- default:
77
- angle.value -= speed;
78
- if (angle.value < 0) {
79
- angle.value += max;
80
- }
81
- break;
82
- }
83
- if (angle.velocity && decay !== 1) {
84
- angle.velocity *= decay;
85
- }
86
- }
1
+ import { updateAnimation, updateColor } from "@tsparticles/engine";
87
2
  export function updateGradient(particle, delta) {
88
3
  const { gradient } = particle;
89
4
  if (!gradient) {
90
5
  return;
91
6
  }
92
- updateAngle(delta, gradient.angle);
7
+ updateAnimation(particle, gradient.angle, false, "none", delta);
93
8
  for (const color of gradient.colors) {
94
- if (particle.color?.h !== undefined) {
95
- updateColorValue(delta, color.value.h, 360, false);
96
- }
97
- if (particle.color?.s !== undefined) {
98
- updateColorValue(delta, color.value.s, 100, true);
99
- }
100
- if (particle.color?.l !== undefined) {
101
- updateColorValue(delta, color.value.l, 100, true);
102
- }
9
+ updateColor(color.value, delta);
103
10
  if (color.opacity) {
104
- updateColorOpacity(delta, color.opacity);
11
+ updateAnimation(particle, color.opacity, true, "none", delta);
105
12
  }
106
13
  }
107
14
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tsparticles/updater-gradient",
3
- "version": "3.0.2",
3
+ "version": "3.1.0",
4
4
  "description": "tsParticles particles gradient updater",
5
5
  "homepage": "https://particles.js.org",
6
6
  "repository": {
@@ -101,7 +101,7 @@
101
101
  "./package.json": "./package.json"
102
102
  },
103
103
  "dependencies": {
104
- "@tsparticles/engine": "^3.0.2"
104
+ "@tsparticles/engine": "^3.1.0"
105
105
  },
106
106
  "publishConfig": {
107
107
  "access": "public"
package/report.html CHANGED
@@ -3,7 +3,7 @@
3
3
  <head>
4
4
  <meta charset="UTF-8"/>
5
5
  <meta name="viewport" content="width=device-width, initial-scale=1"/>
6
- <title>@tsparticles/updater-gradient [6 Dec 2023 at 17:46]</title>
6
+ <title>@tsparticles/updater-gradient [13 Jan 2024 at 23:08]</title>
7
7
  <link rel="shortcut icon" href="" type="image/x-icon" />
8
8
 
9
9
  <script>
@@ -31,7 +31,7 @@
31
31
  <body>
32
32
  <div id="app"></div>
33
33
  <script>
34
- window.chartData = [{"label":"tsparticles.updater.gradient.js","isAsset":true,"statSize":12013,"parsedSize":16172,"gzipSize":3575,"groups":[{"label":"dist/browser","path":"./dist/browser","statSize":11971,"groups":[{"id":397,"label":"index.js + 8 modules (concatenated)","path":"./dist/browser/index.js + 8 modules (concatenated)","statSize":11971,"parsedSize":16172,"gzipSize":3575,"concatenated":true,"groups":[{"label":"dist/browser","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser","statSize":11971,"groups":[{"id":null,"label":"index.js","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser/index.js","statSize":210,"parsedSize":283,"gzipSize":62,"inaccurateSizes":true},{"id":null,"label":"GradientUpdater.js","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser/GradientUpdater.js","statSize":4901,"parsedSize":6620,"gzipSize":1463,"inaccurateSizes":true},{"label":"Options/Classes","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser/Options/Classes","statSize":4021,"groups":[{"id":null,"label":"AnimatableGradient.js","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser/Options/Classes/AnimatableGradient.js","statSize":614,"parsedSize":829,"gzipSize":183,"inaccurateSizes":true},{"id":null,"label":"GradientAngle.js","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser/Options/Classes/GradientAngle.js","statSize":550,"parsedSize":743,"gzipSize":164,"inaccurateSizes":true},{"id":null,"label":"AnimatableGradientColor.js","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser/Options/Classes/AnimatableGradientColor.js","statSize":679,"parsedSize":917,"gzipSize":202,"inaccurateSizes":true},{"id":null,"label":"GradientAngleAnimation.js","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser/Options/Classes/GradientAngleAnimation.js","statSize":796,"parsedSize":1075,"gzipSize":237,"inaccurateSizes":true},{"id":null,"label":"GradientColorOpacity.js","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser/Options/Classes/GradientColorOpacity.js","statSize":459,"parsedSize":620,"gzipSize":137,"inaccurateSizes":true},{"id":null,"label":"GradientColorOpacityAnimation.js","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser/Options/Classes/GradientColorOpacityAnimation.js","statSize":923,"parsedSize":1246,"gzipSize":275,"inaccurateSizes":true}],"parsedSize":5432,"gzipSize":1200,"inaccurateSizes":true},{"id":null,"label":"Utils.js","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser/Utils.js","statSize":2839,"parsedSize":3835,"gzipSize":847,"inaccurateSizes":true}],"parsedSize":16172,"gzipSize":3575,"inaccurateSizes":true}]}],"parsedSize":16172,"gzipSize":3575},{"label":"engine\",\"commonjs2\":\"@tsparticles/engine\",\"amd\":\"@tsparticles","path":"./engine\",\"commonjs2\":\"@tsparticles/engine\",\"amd\":\"@tsparticles","statSize":42,"groups":[{"id":533,"label":"engine\",\"root\":\"window\"}","path":"./engine\",\"commonjs2\":\"@tsparticles/engine\",\"amd\":\"@tsparticles/engine\",\"root\":\"window\"}","statSize":42}],"parsedSize":0,"gzipSize":0}],"isInitialByEntrypoint":{"tsparticles.updater.gradient":true}}];
34
+ window.chartData = [{"label":"tsparticles.updater.gradient.js","isAsset":true,"statSize":10014,"parsedSize":14255,"gzipSize":3280,"groups":[{"label":"dist/browser","path":"./dist/browser","statSize":9972,"groups":[{"id":453,"label":"index.js + 8 modules (concatenated)","path":"./dist/browser/index.js + 8 modules (concatenated)","statSize":9972,"parsedSize":14255,"gzipSize":3280,"concatenated":true,"groups":[{"label":"dist/browser","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser","statSize":9972,"groups":[{"id":null,"label":"index.js","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser/index.js","statSize":210,"parsedSize":300,"gzipSize":69,"inaccurateSizes":true},{"id":null,"label":"GradientUpdater.js","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser/GradientUpdater.js","statSize":5299,"parsedSize":7574,"gzipSize":1742,"inaccurateSizes":true},{"label":"Options/Classes","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser/Options/Classes","statSize":4021,"groups":[{"id":null,"label":"AnimatableGradient.js","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser/Options/Classes/AnimatableGradient.js","statSize":614,"parsedSize":877,"gzipSize":201,"inaccurateSizes":true},{"id":null,"label":"GradientAngle.js","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser/Options/Classes/GradientAngle.js","statSize":550,"parsedSize":786,"gzipSize":180,"inaccurateSizes":true},{"id":null,"label":"AnimatableGradientColor.js","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser/Options/Classes/AnimatableGradientColor.js","statSize":679,"parsedSize":970,"gzipSize":223,"inaccurateSizes":true},{"id":null,"label":"GradientAngleAnimation.js","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser/Options/Classes/GradientAngleAnimation.js","statSize":796,"parsedSize":1137,"gzipSize":261,"inaccurateSizes":true},{"id":null,"label":"GradientColorOpacity.js","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser/Options/Classes/GradientColorOpacity.js","statSize":459,"parsedSize":656,"gzipSize":150,"inaccurateSizes":true},{"id":null,"label":"GradientColorOpacityAnimation.js","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser/Options/Classes/GradientColorOpacityAnimation.js","statSize":923,"parsedSize":1319,"gzipSize":303,"inaccurateSizes":true}],"parsedSize":5748,"gzipSize":1322,"inaccurateSizes":true},{"id":null,"label":"Utils.js","path":"./dist/browser/index.js + 8 modules (concatenated)/dist/browser/Utils.js","statSize":442,"parsedSize":631,"gzipSize":145,"inaccurateSizes":true}],"parsedSize":14255,"gzipSize":3280,"inaccurateSizes":true}]}],"parsedSize":14255,"gzipSize":3280},{"label":"engine\",\"commonjs2\":\"@tsparticles/engine\",\"amd\":\"@tsparticles","path":"./engine\",\"commonjs2\":\"@tsparticles/engine\",\"amd\":\"@tsparticles","statSize":42,"groups":[{"id":533,"label":"engine\",\"root\":\"window\"}","path":"./engine\",\"commonjs2\":\"@tsparticles/engine\",\"amd\":\"@tsparticles/engine\",\"root\":\"window\"}","statSize":42}],"parsedSize":0,"gzipSize":0}],"isInitialByEntrypoint":{"tsparticles.updater.gradient":true}}];
35
35
  window.entrypoints = ["tsparticles.updater.gradient","tsparticles.updater.gradient.min"];
36
36
  window.defaultSizes = "parsed";
37
37
  </script>
@@ -4,7 +4,7 @@
4
4
  * Demo / Generator : https://particles.js.org/
5
5
  * GitHub : https://www.github.com/matteobruni/tsparticles
6
6
  * How to use? : Check the GitHub README
7
- * v3.0.2
7
+ * v3.1.0
8
8
  */
9
9
  (function webpackUniversalModuleDefinition(root, factory) {
10
10
  if(typeof exports === 'object' && typeof module === 'object')
@@ -263,92 +263,7 @@ class AnimatableGradient {
263
263
  }
264
264
  }
265
265
  ;// CONCATENATED MODULE: ./dist/browser/Utils.js
266
- function updateColorOpacity(delta, value) {
267
- if (!value.enable) {
268
- return;
269
- }
270
- const decay = value.decay ?? 1;
271
- switch (value.status) {
272
- case "increasing":
273
- if (value.value >= value.max) {
274
- value.status = "decreasing";
275
- } else {
276
- value.value += (value.velocity ?? 0) * delta.factor;
277
- }
278
- break;
279
- case "decreasing":
280
- if (value.value <= value.min) {
281
- value.status = "increasing";
282
- } else {
283
- value.value -= (value.velocity ?? 0) * delta.factor;
284
- }
285
- break;
286
- }
287
- if (value.velocity && decay !== 1) {
288
- value.velocity *= decay;
289
- }
290
- }
291
- function updateColorValue(delta, colorValue, max, decrease) {
292
- if (!colorValue || !colorValue.enable) {
293
- return;
294
- }
295
- if (!colorValue.time) {
296
- colorValue.time = 0;
297
- }
298
- if ((colorValue.delayTime ?? 0) > 0 && colorValue.time < (colorValue.delayTime ?? 0)) {
299
- colorValue.time += delta.value;
300
- }
301
- if ((colorValue.delayTime ?? 0) > 0 && colorValue.time < (colorValue.delayTime ?? 0)) {
302
- return;
303
- }
304
- const velocity = (colorValue.velocity ?? 0) * delta.factor,
305
- decay = colorValue.decay ?? 1;
306
- if (!decrease || colorValue.status === "increasing") {
307
- colorValue.value += velocity;
308
- if (decrease && colorValue.value > max) {
309
- colorValue.status = "decreasing";
310
- colorValue.value -= colorValue.value % max;
311
- }
312
- } else {
313
- colorValue.value -= velocity;
314
- if (colorValue.value < 0) {
315
- colorValue.status = "increasing";
316
- colorValue.value += colorValue.value;
317
- }
318
- }
319
- if (colorValue.value > max) {
320
- colorValue.value %= max;
321
- }
322
- if (colorValue.velocity && decay !== 1) {
323
- colorValue.velocity *= decay;
324
- }
325
- }
326
- function updateAngle(delta, angle) {
327
- const speed = (angle.velocity ?? 0) * delta.factor,
328
- max = 2 * Math.PI,
329
- decay = angle.decay ?? 1;
330
- if (!angle.enable) {
331
- return;
332
- }
333
- switch (angle.status) {
334
- case "increasing":
335
- angle.value += speed;
336
- if (angle.value > max) {
337
- angle.value -= max;
338
- }
339
- break;
340
- case "decreasing":
341
- default:
342
- angle.value -= speed;
343
- if (angle.value < 0) {
344
- angle.value += max;
345
- }
346
- break;
347
- }
348
- if (angle.velocity && decay !== 1) {
349
- angle.velocity *= decay;
350
- }
351
- }
266
+
352
267
  function updateGradient(particle, delta) {
353
268
  const {
354
269
  gradient
@@ -356,19 +271,11 @@ function updateGradient(particle, delta) {
356
271
  if (!gradient) {
357
272
  return;
358
273
  }
359
- updateAngle(delta, gradient.angle);
274
+ (0,engine_root_window_.updateAnimation)(particle, gradient.angle, false, "none", delta);
360
275
  for (const color of gradient.colors) {
361
- if (particle.color?.h !== undefined) {
362
- updateColorValue(delta, color.value.h, 360, false);
363
- }
364
- if (particle.color?.s !== undefined) {
365
- updateColorValue(delta, color.value.s, 100, true);
366
- }
367
- if (particle.color?.l !== undefined) {
368
- updateColorValue(delta, color.value.l, 100, true);
369
- }
276
+ (0,engine_root_window_.updateColor)(color.value, delta);
370
277
  if (color.opacity) {
371
- updateColorOpacity(delta, color.opacity);
278
+ (0,engine_root_window_.updateAnimation)(particle, color.opacity, true, "none", delta);
372
279
  }
373
280
  }
374
281
  }
@@ -376,6 +283,8 @@ function updateGradient(particle, delta) {
376
283
 
377
284
 
378
285
 
286
+ const GradientUpdater_double = 2,
287
+ doublePI = Math.PI * GradientUpdater_double;
379
288
  class GradientUpdater {
380
289
  getColorStyles(particle, context, radius, opacity) {
381
290
  const gradient = particle.gradient;
@@ -383,7 +292,12 @@ class GradientUpdater {
383
292
  return {};
384
293
  }
385
294
  const gradientAngle = gradient.angle.value,
386
- fillGradient = gradient.type === "radial" ? context.createRadialGradient(0, 0, 0, 0, 0, radius) : context.createLinearGradient(Math.cos(gradientAngle) * -radius, Math.sin(gradientAngle) * -radius, Math.cos(gradientAngle) * radius, Math.sin(gradientAngle) * radius);
295
+ origin = {
296
+ x: 0,
297
+ y: 0
298
+ },
299
+ minRadius = 0,
300
+ fillGradient = gradient.type === "radial" ? context.createRadialGradient(origin.x, origin.y, minRadius, origin.x, origin.y, radius) : context.createLinearGradient(Math.cos(gradientAngle) * -radius, Math.sin(gradientAngle) * -radius, Math.cos(gradientAngle) * radius, Math.sin(gradientAngle) * radius);
387
301
  for (const {
388
302
  stop,
389
303
  value,
@@ -405,15 +319,19 @@ class GradientUpdater {
405
319
  return;
406
320
  }
407
321
  const {
408
- angle
409
- } = gradient;
322
+ angle
323
+ } = gradient,
324
+ speedFactor = 360,
325
+ delayOffset = 1;
410
326
  particle.gradient = {
411
327
  angle: {
412
328
  value: (0,engine_root_window_.getRangeValue)(angle.value),
413
329
  enable: angle.animation.enable,
414
- velocity: (0,engine_root_window_.getRangeValue)(angle.animation.speed) / 360 * particle.container.retina.reduceFactor,
415
- decay: 1 - (0,engine_root_window_.getRangeValue)(angle.animation.decay),
416
- delayTime: (0,engine_root_window_.getRangeValue)(angle.animation.delay) * 1000,
330
+ velocity: (0,engine_root_window_.getRangeValue)(angle.animation.speed) / speedFactor * particle.container.retina.reduceFactor,
331
+ decay: delayOffset - (0,engine_root_window_.getRangeValue)(angle.animation.decay),
332
+ delayTime: (0,engine_root_window_.getRangeValue)(angle.animation.delay) * engine_root_window_.millisecondsToSeconds,
333
+ max: doublePI,
334
+ min: 0,
417
335
  time: 0
418
336
  },
419
337
  type: gradient.type,
@@ -421,7 +339,7 @@ class GradientUpdater {
421
339
  };
422
340
  let rotateDirection = gradient.angle.direction;
423
341
  if (rotateDirection === "random") {
424
- rotateDirection = (0,engine_root_window_.getRandom)() > 0.5 ? "counter-clockwise" : "clockwise";
342
+ rotateDirection = (0,engine_root_window_.getRandom)() > engine_root_window_.halfRandom ? "counter-clockwise" : "clockwise";
425
343
  }
426
344
  switch (rotateDirection) {
427
345
  case "counter-clockwise":
@@ -448,9 +366,9 @@ class GradientUpdater {
448
366
  min: (0,engine_root_window_.getRangeMin)(grColor.opacity.value),
449
367
  status: "increasing",
450
368
  value: (0,engine_root_window_.getRangeValue)(grColor.opacity.value),
451
- velocity: (0,engine_root_window_.getRangeValue)(grColor.opacity.animation.speed) / 100 * particle.container.retina.reduceFactor,
452
- decay: 1 - (0,engine_root_window_.getRangeValue)(grColor.opacity.animation.decay),
453
- delayTime: (0,engine_root_window_.getRangeValue)(grColor.opacity.animation.delay) * 1000,
369
+ velocity: (0,engine_root_window_.getRangeValue)(grColor.opacity.animation.speed) / engine_root_window_.percentDenominator * particle.container.retina.reduceFactor,
370
+ decay: delayOffset - (0,engine_root_window_.getRangeValue)(grColor.opacity.animation.decay),
371
+ delayTime: (0,engine_root_window_.getRangeValue)(grColor.opacity.animation.delay) * engine_root_window_.millisecondsToSeconds,
454
372
  time: 0
455
373
  } : undefined
456
374
  };
@@ -474,7 +392,7 @@ class GradientUpdater {
474
392
  case "random":
475
393
  default:
476
394
  addOpacity.value = (0,engine_root_window_.randomInRange)(addOpacity);
477
- addOpacity.status = (0,engine_root_window_.getRandom)() >= 0.5 ? "increasing" : "decreasing";
395
+ addOpacity.status = (0,engine_root_window_.getRandom)() >= engine_root_window_.halfRandom ? "increasing" : "decreasing";
478
396
  break;
479
397
  }
480
398
  }
@@ -482,7 +400,7 @@ class GradientUpdater {
482
400
  }
483
401
  }
484
402
  isEnabled(particle) {
485
- return !particle.destroyed && !particle.spawning && (particle.gradient?.angle.enable || (particle.gradient?.colors.some(c => c.value.h.enable || c.value.s.enable || c.value.l.enable) ?? false));
403
+ return !particle.destroyed && !particle.spawning && (!!particle.gradient?.angle.enable || (particle.gradient?.colors.some(c => c.value.h.enable || c.value.s.enable || c.value.l.enable) ?? false));
486
404
  }
487
405
  loadOptions(options, ...sources) {
488
406
  for (const source of sources) {
@@ -1,2 +1,2 @@
1
1
  /*! For license information please see tsparticles.updater.gradient.min.js.LICENSE.txt */
2
- !function(e,a){if("object"==typeof exports&&"object"==typeof module)module.exports=a(require("@tsparticles/engine"));else if("function"==typeof define&&define.amd)define(["@tsparticles/engine"],a);else{var t="object"==typeof exports?a(require("@tsparticles/engine")):a(e.window);for(var i in t)("object"==typeof exports?exports:e)[i]=t[i]}}(this,(e=>(()=>{"use strict";var a={533:a=>{a.exports=e}},t={};function i(e){var n=t[e];if(void 0!==n)return n.exports;var o=t[e]={exports:{}};return a[e](o,o.exports,i),o.exports}i.d=(e,a)=>{for(var t in a)i.o(a,t)&&!i.o(e,t)&&Object.defineProperty(e,t,{enumerable:!0,get:a[t]})},i.o=(e,a)=>Object.prototype.hasOwnProperty.call(e,a),i.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var n={};return(()=>{i.r(n),i.d(n,{loadGradientUpdater:()=>y});var e=i(533);class a{constructor(){this.count=0,this.enable=!1,this.speed=0,this.decay=0,this.delay=0,this.sync=!1,this.startValue="random"}load(a){a&&(void 0!==a.count&&(this.count=(0,e.setRangeValue)(a.count)),void 0!==a.enable&&(this.enable=a.enable),void 0!==a.speed&&(this.speed=(0,e.setRangeValue)(a.speed)),void 0!==a.sync&&(this.sync=a.sync),void 0!==a.startValue&&(this.startValue=a.startValue),void 0!==a.decay&&(this.decay=(0,e.setRangeValue)(a.decay)),void 0!==a.delay&&(this.delay=(0,e.setRangeValue)(a.delay)))}}class t{constructor(){this.value=0,this.animation=new a}load(a){a&&(this.animation.load(a.animation),void 0!==a.value&&(this.value=(0,e.setRangeValue)(a.value)))}}class o{constructor(){this.stop=0,this.value=new e.AnimatableColor}load(a){a&&(void 0!==a.stop&&(this.stop=a.stop),this.value=e.AnimatableColor.create(this.value,a.value),void 0!==a.opacity&&(this.opacity=new t,(0,e.isNumber)(a.opacity)?this.opacity.value=a.opacity:this.opacity.load(a.opacity)))}}class s{constructor(){this.count=0,this.enable=!1,this.speed=0,this.decay=0,this.delay=0,this.sync=!1}load(a){a&&(void 0!==a.count&&(this.count=(0,e.setRangeValue)(a.count)),void 0!==a.enable&&(this.enable=a.enable),void 0!==a.speed&&(this.speed=(0,e.setRangeValue)(a.speed)),void 0!==a.decay&&(this.decay=(0,e.setRangeValue)(a.decay)),void 0!==a.delay&&(this.delay=(0,e.setRangeValue)(a.delay)),void 0!==a.sync&&(this.sync=a.sync))}}class l{constructor(){this.value=0,this.animation=new s,this.direction="clockwise"}load(a){a&&(this.animation.load(a.animation),void 0!==a.value&&(this.value=(0,e.setRangeValue)(a.value)),void 0!==a.direction&&(this.direction=a.direction))}}class c{constructor(){this.angle=new l,this.colors=[],this.type="random"}load(e){e&&(this.angle.load(e.angle),void 0!==e.colors&&(this.colors=e.colors.map((e=>{const a=new o;return a.load(e),a}))),void 0!==e.type&&(this.type=e.type))}}function r(e,a){if(!a.enable)return;const t=a.decay??1;switch(a.status){case"increasing":a.value>=a.max?a.status="decreasing":a.value+=(a.velocity??0)*e.factor;break;case"decreasing":a.value<=a.min?a.status="increasing":a.value-=(a.velocity??0)*e.factor}a.velocity&&1!==t&&(a.velocity*=t)}function u(e,a,t,i){if(!a||!a.enable)return;if(a.time||(a.time=0),(a.delayTime??0)>0&&a.time<(a.delayTime??0)&&(a.time+=e.value),(a.delayTime??0)>0&&a.time<(a.delayTime??0))return;const n=(a.velocity??0)*e.factor,o=a.decay??1;i&&"increasing"!==a.status?(a.value-=n,a.value<0&&(a.status="increasing",a.value+=a.value)):(a.value+=n,i&&a.value>t&&(a.status="decreasing",a.value-=a.value%t)),a.value>t&&(a.value%=t),a.velocity&&1!==o&&(a.velocity*=o)}function d(e,a){const{gradient:t}=e;if(t){!function(e,a){const t=(a.velocity??0)*e.factor,i=2*Math.PI,n=a.decay??1;a.enable&&("increasing"===a.status?(a.value+=t,a.value>i&&(a.value-=i)):(a.value-=t,a.value<0&&(a.value+=i)),a.velocity&&1!==n&&(a.velocity*=n))}(a,t.angle);for(const i of t.colors)void 0!==e.color?.h&&u(a,i.value.h,360,!1),void 0!==e.color?.s&&u(a,i.value.s,100,!0),void 0!==e.color?.l&&u(a,i.value.l,100,!0),i.opacity&&r(a,i.opacity)}}class v{getColorStyles(a,t,i,n){const o=a.gradient;if(!o)return{};const s=o.angle.value,l="radial"===o.type?t.createRadialGradient(0,0,0,0,0,i):t.createLinearGradient(Math.cos(s)*-i,Math.sin(s)*-i,Math.cos(s)*i,Math.sin(s)*i);for(const{stop:a,value:t,opacity:i}of o.colors)l.addColorStop(a,(0,e.getStyleFromHsl)({h:t.h.value,s:t.s.value,l:t.l.value},i?.value??n));return{fill:l}}init(a){const t=(0,e.itemFromSingleOrMultiple)(a.options.gradient);if(!t)return;const{angle:i}=t;a.gradient={angle:{value:(0,e.getRangeValue)(i.value),enable:i.animation.enable,velocity:(0,e.getRangeValue)(i.animation.speed)/360*a.container.retina.reduceFactor,decay:1-(0,e.getRangeValue)(i.animation.decay),delayTime:1e3*(0,e.getRangeValue)(i.animation.delay),time:0},type:t.type,colors:[]};let n=t.angle.direction;switch("random"===n&&(n=(0,e.getRandom)()>.5?"counter-clockwise":"clockwise"),n){case"counter-clockwise":case"counterClockwise":a.gradient.angle.status="decreasing";break;case"clockwise":a.gradient.angle.status="increasing"}const o=a.options.reduceDuplicates;for(const i of t.colors){const t=(0,e.rangeColorToHsl)(i.value,a.id,o);if(!t)continue;const n=(0,e.getHslAnimationFromHsl)(t,i.value.animation,a.container.retina.reduceFactor),s={stop:i.stop,value:n,opacity:i.opacity?{enable:i.opacity.animation.enable,max:(0,e.getRangeMax)(i.opacity.value),min:(0,e.getRangeMin)(i.opacity.value),status:"increasing",value:(0,e.getRangeValue)(i.opacity.value),velocity:(0,e.getRangeValue)(i.opacity.animation.speed)/100*a.container.retina.reduceFactor,decay:1-(0,e.getRangeValue)(i.opacity.animation.decay),delayTime:1e3*(0,e.getRangeValue)(i.opacity.animation.delay),time:0}:void 0},{opacity:l}=s;if(i.opacity&&l){const a=i.opacity.value;l.min=(0,e.getRangeMin)(a),l.max=(0,e.getRangeMax)(a);switch(i.opacity.animation.startValue){case"min":l.value=l.min,l.status="increasing";break;case"max":l.value=l.max,l.status="decreasing";break;default:l.value=(0,e.randomInRange)(l),l.status=(0,e.getRandom)()>=.5?"increasing":"decreasing"}}a.gradient.colors.push(s)}}isEnabled(e){return!e.destroyed&&!e.spawning&&(e.gradient?.angle.enable||(e.gradient?.colors.some((e=>e.value.h.enable||e.value.s.enable||e.value.l.enable))??!1))}loadOptions(a,...t){for(const i of t){if(!i?.gradient)continue;const t=i.gradient;t&&(a.gradient=(0,e.executeOnSingleOrMultiple)(t,(e=>{const a=new c;return a.load(e),a})))}}update(e,a){d(e,a)}}async function y(e,a=!0){await e.addParticleUpdater("gradient",(()=>new v),a)}})(),n})()));
2
+ !function(e,a){if("object"==typeof exports&&"object"==typeof module)module.exports=a(require("@tsparticles/engine"));else if("function"==typeof define&&define.amd)define(["@tsparticles/engine"],a);else{var t="object"==typeof exports?a(require("@tsparticles/engine")):a(e.window);for(var n in t)("object"==typeof exports?exports:e)[n]=t[n]}}(this,(e=>(()=>{"use strict";var a={533:a=>{a.exports=e}},t={};function n(e){var i=t[e];if(void 0!==i)return i.exports;var o=t[e]={exports:{}};return a[e](o,o.exports,n),o.exports}n.d=(e,a)=>{for(var t in a)n.o(a,t)&&!n.o(e,t)&&Object.defineProperty(e,t,{enumerable:!0,get:a[t]})},n.o=(e,a)=>Object.prototype.hasOwnProperty.call(e,a),n.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var i={};return(()=>{n.r(i),n.d(i,{loadGradientUpdater:()=>u});var e=n(533);class a{constructor(){this.count=0,this.enable=!1,this.speed=0,this.decay=0,this.delay=0,this.sync=!1,this.startValue="random"}load(a){a&&(void 0!==a.count&&(this.count=(0,e.setRangeValue)(a.count)),void 0!==a.enable&&(this.enable=a.enable),void 0!==a.speed&&(this.speed=(0,e.setRangeValue)(a.speed)),void 0!==a.sync&&(this.sync=a.sync),void 0!==a.startValue&&(this.startValue=a.startValue),void 0!==a.decay&&(this.decay=(0,e.setRangeValue)(a.decay)),void 0!==a.delay&&(this.delay=(0,e.setRangeValue)(a.delay)))}}class t{constructor(){this.value=0,this.animation=new a}load(a){a&&(this.animation.load(a.animation),void 0!==a.value&&(this.value=(0,e.setRangeValue)(a.value)))}}class o{constructor(){this.stop=0,this.value=new e.AnimatableColor}load(a){a&&(void 0!==a.stop&&(this.stop=a.stop),this.value=e.AnimatableColor.create(this.value,a.value),void 0!==a.opacity&&(this.opacity=new t,(0,e.isNumber)(a.opacity)?this.opacity.value=a.opacity:this.opacity.load(a.opacity)))}}class s{constructor(){this.count=0,this.enable=!1,this.speed=0,this.decay=0,this.delay=0,this.sync=!1}load(a){a&&(void 0!==a.count&&(this.count=(0,e.setRangeValue)(a.count)),void 0!==a.enable&&(this.enable=a.enable),void 0!==a.speed&&(this.speed=(0,e.setRangeValue)(a.speed)),void 0!==a.decay&&(this.decay=(0,e.setRangeValue)(a.decay)),void 0!==a.delay&&(this.delay=(0,e.setRangeValue)(a.delay)),void 0!==a.sync&&(this.sync=a.sync))}}class l{constructor(){this.value=0,this.animation=new s,this.direction="clockwise"}load(a){a&&(this.animation.load(a.animation),void 0!==a.value&&(this.value=(0,e.setRangeValue)(a.value)),void 0!==a.direction&&(this.direction=a.direction))}}class c{constructor(){this.angle=new l,this.colors=[],this.type="random"}load(e){e&&(this.angle.load(e.angle),void 0!==e.colors&&(this.colors=e.colors.map((e=>{const a=new o;return a.load(e),a}))),void 0!==e.type&&(this.type=e.type))}}const r=2*Math.PI;class d{getColorStyles(a,t,n,i){const o=a.gradient;if(!o)return{};const s=o.angle.value,l=0,c=0,r="radial"===o.type?t.createRadialGradient(l,c,0,l,c,n):t.createLinearGradient(Math.cos(s)*-n,Math.sin(s)*-n,Math.cos(s)*n,Math.sin(s)*n);for(const{stop:a,value:t,opacity:n}of o.colors)r.addColorStop(a,(0,e.getStyleFromHsl)({h:t.h.value,s:t.s.value,l:t.l.value},n?.value??i));return{fill:r}}init(a){const t=(0,e.itemFromSingleOrMultiple)(a.options.gradient);if(!t)return;const{angle:n}=t;a.gradient={angle:{value:(0,e.getRangeValue)(n.value),enable:n.animation.enable,velocity:(0,e.getRangeValue)(n.animation.speed)/360*a.container.retina.reduceFactor,decay:1-(0,e.getRangeValue)(n.animation.decay),delayTime:(0,e.getRangeValue)(n.animation.delay)*e.millisecondsToSeconds,max:r,min:0,time:0},type:t.type,colors:[]};let i=t.angle.direction;switch("random"===i&&(i=(0,e.getRandom)()>e.halfRandom?"counter-clockwise":"clockwise"),i){case"counter-clockwise":case"counterClockwise":a.gradient.angle.status="decreasing";break;case"clockwise":a.gradient.angle.status="increasing"}const o=a.options.reduceDuplicates;for(const n of t.colors){const t=(0,e.rangeColorToHsl)(n.value,a.id,o);if(!t)continue;const i=(0,e.getHslAnimationFromHsl)(t,n.value.animation,a.container.retina.reduceFactor),s={stop:n.stop,value:i,opacity:n.opacity?{enable:n.opacity.animation.enable,max:(0,e.getRangeMax)(n.opacity.value),min:(0,e.getRangeMin)(n.opacity.value),status:"increasing",value:(0,e.getRangeValue)(n.opacity.value),velocity:(0,e.getRangeValue)(n.opacity.animation.speed)/e.percentDenominator*a.container.retina.reduceFactor,decay:1-(0,e.getRangeValue)(n.opacity.animation.decay),delayTime:(0,e.getRangeValue)(n.opacity.animation.delay)*e.millisecondsToSeconds,time:0}:void 0},{opacity:l}=s;if(n.opacity&&l){const a=n.opacity.value;l.min=(0,e.getRangeMin)(a),l.max=(0,e.getRangeMax)(a);switch(n.opacity.animation.startValue){case"min":l.value=l.min,l.status="increasing";break;case"max":l.value=l.max,l.status="decreasing";break;default:l.value=(0,e.randomInRange)(l),l.status=(0,e.getRandom)()>=e.halfRandom?"increasing":"decreasing"}}a.gradient.colors.push(s)}}isEnabled(e){return!e.destroyed&&!e.spawning&&(!!e.gradient?.angle.enable||(e.gradient?.colors.some((e=>e.value.h.enable||e.value.s.enable||e.value.l.enable))??!1))}loadOptions(a,...t){for(const n of t){if(!n?.gradient)continue;const t=n.gradient;t&&(a.gradient=(0,e.executeOnSingleOrMultiple)(t,(e=>{const a=new c;return a.load(e),a})))}}update(a,t){!function(a,t){const{gradient:n}=a;if(n){(0,e.updateAnimation)(a,n.angle,!1,"none",t);for(const i of n.colors)(0,e.updateColor)(i.value,t),i.opacity&&(0,e.updateAnimation)(a,i.opacity,!0,"none",t)}}(a,t)}}async function u(e,a=!0){await e.addParticleUpdater("gradient",(()=>new d),a)}})(),i})()));
@@ -1 +1 @@
1
- /*! tsParticles Gradient Updater v3.0.2 by Matteo Bruni */
1
+ /*! tsParticles Gradient Updater v3.1.0 by Matteo Bruni */
package/types/Types.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- import type { GradientType, IParticleHslAnimation, IParticleNumericValueAnimation, IParticleValueAnimation, IParticlesOptions, Particle, ParticlesOptions, SingleOrMultiple } from "@tsparticles/engine";
1
+ import type { GradientType, IParticleHslAnimation, IParticleNumericValueAnimation, IParticlesOptions, Particle, ParticlesOptions, SingleOrMultiple } from "@tsparticles/engine";
2
2
  import type { AnimatableGradient } from "./Options/Classes/AnimatableGradient.js";
3
3
  import type { IAnimatableGradient } from "./Options/Interfaces/IAnimatableGradient.js";
4
4
  export interface IParticleGradientColorAnimation {
@@ -7,7 +7,7 @@ export interface IParticleGradientColorAnimation {
7
7
  value: IParticleHslAnimation;
8
8
  }
9
9
  export interface IParticleGradientAnimation {
10
- angle: IParticleValueAnimation<number>;
10
+ angle: IParticleNumericValueAnimation;
11
11
  colors: IParticleGradientColorAnimation[];
12
12
  type: GradientType;
13
13
  }
@@ -13,14 +13,15 @@
13
13
  const engine_1 = require("@tsparticles/engine");
14
14
  const AnimatableGradient_js_1 = require("./Options/Classes/AnimatableGradient.js");
15
15
  const Utils_js_1 = require("./Utils.js");
16
+ const double = 2, doublePI = Math.PI * double;
16
17
  class GradientUpdater {
17
18
  getColorStyles(particle, context, radius, opacity) {
18
19
  const gradient = particle.gradient;
19
20
  if (!gradient) {
20
21
  return {};
21
22
  }
22
- const gradientAngle = gradient.angle.value, fillGradient = gradient.type === "radial"
23
- ? context.createRadialGradient(0, 0, 0, 0, 0, radius)
23
+ const gradientAngle = gradient.angle.value, origin = { x: 0, y: 0 }, minRadius = 0, fillGradient = gradient.type === "radial"
24
+ ? context.createRadialGradient(origin.x, origin.y, minRadius, origin.x, origin.y, radius)
24
25
  : context.createLinearGradient(Math.cos(gradientAngle) * -radius, Math.sin(gradientAngle) * -radius, Math.cos(gradientAngle) * radius, Math.sin(gradientAngle) * radius);
25
26
  for (const { stop, value, opacity: cOpacity } of gradient.colors) {
26
27
  fillGradient.addColorStop(stop, (0, engine_1.getStyleFromHsl)({
@@ -36,14 +37,16 @@
36
37
  if (!gradient) {
37
38
  return;
38
39
  }
39
- const { angle } = gradient;
40
+ const { angle } = gradient, speedFactor = 360, delayOffset = 1;
40
41
  particle.gradient = {
41
42
  angle: {
42
43
  value: (0, engine_1.getRangeValue)(angle.value),
43
44
  enable: angle.animation.enable,
44
- velocity: ((0, engine_1.getRangeValue)(angle.animation.speed) / 360) * particle.container.retina.reduceFactor,
45
- decay: 1 - (0, engine_1.getRangeValue)(angle.animation.decay),
46
- delayTime: (0, engine_1.getRangeValue)(angle.animation.delay) * 1000,
45
+ velocity: ((0, engine_1.getRangeValue)(angle.animation.speed) / speedFactor) * particle.container.retina.reduceFactor,
46
+ decay: delayOffset - (0, engine_1.getRangeValue)(angle.animation.decay),
47
+ delayTime: (0, engine_1.getRangeValue)(angle.animation.delay) * engine_1.millisecondsToSeconds,
48
+ max: doublePI,
49
+ min: 0,
47
50
  time: 0,
48
51
  },
49
52
  type: gradient.type,
@@ -51,7 +54,7 @@
51
54
  };
52
55
  let rotateDirection = gradient.angle.direction;
53
56
  if (rotateDirection === "random") {
54
- rotateDirection = (0, engine_1.getRandom)() > 0.5 ? "counter-clockwise" : "clockwise";
57
+ rotateDirection = (0, engine_1.getRandom)() > engine_1.halfRandom ? "counter-clockwise" : "clockwise";
55
58
  }
56
59
  switch (rotateDirection) {
57
60
  case "counter-clockwise":
@@ -78,10 +81,10 @@
78
81
  min: (0, engine_1.getRangeMin)(grColor.opacity.value),
79
82
  status: "increasing",
80
83
  value: (0, engine_1.getRangeValue)(grColor.opacity.value),
81
- velocity: ((0, engine_1.getRangeValue)(grColor.opacity.animation.speed) / 100) *
84
+ velocity: ((0, engine_1.getRangeValue)(grColor.opacity.animation.speed) / engine_1.percentDenominator) *
82
85
  particle.container.retina.reduceFactor,
83
- decay: 1 - (0, engine_1.getRangeValue)(grColor.opacity.animation.decay),
84
- delayTime: (0, engine_1.getRangeValue)(grColor.opacity.animation.delay) * 1000,
86
+ decay: delayOffset - (0, engine_1.getRangeValue)(grColor.opacity.animation.decay),
87
+ delayTime: (0, engine_1.getRangeValue)(grColor.opacity.animation.delay) * engine_1.millisecondsToSeconds,
85
88
  time: 0,
86
89
  }
87
90
  : undefined,
@@ -105,7 +108,7 @@
105
108
  default:
106
109
  addOpacity.value = (0, engine_1.randomInRange)(addOpacity);
107
110
  addOpacity.status =
108
- (0, engine_1.getRandom)() >= 0.5 ? "increasing" : "decreasing";
111
+ (0, engine_1.getRandom)() >= engine_1.halfRandom ? "increasing" : "decreasing";
109
112
  break;
110
113
  }
111
114
  }
@@ -115,7 +118,7 @@
115
118
  isEnabled(particle) {
116
119
  return (!particle.destroyed &&
117
120
  !particle.spawning &&
118
- (particle.gradient?.angle.enable ||
121
+ (!!particle.gradient?.angle.enable ||
119
122
  (particle.gradient?.colors.some((c) => c.value.h.enable || c.value.s.enable || c.value.l.enable) ??
120
123
  false)));
121
124
  }
package/umd/Utils.js CHANGED
@@ -4,116 +4,23 @@
4
4
  if (v !== undefined) module.exports = v;
5
5
  }
6
6
  else if (typeof define === "function" && define.amd) {
7
- define(["require", "exports"], factory);
7
+ define(["require", "exports", "@tsparticles/engine"], factory);
8
8
  }
9
9
  })(function (require, exports) {
10
10
  "use strict";
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.updateGradient = void 0;
13
- function updateColorOpacity(delta, value) {
14
- if (!value.enable) {
15
- return;
16
- }
17
- const decay = value.decay ?? 1;
18
- switch (value.status) {
19
- case "increasing":
20
- if (value.value >= value.max) {
21
- value.status = "decreasing";
22
- }
23
- else {
24
- value.value += (value.velocity ?? 0) * delta.factor;
25
- }
26
- break;
27
- case "decreasing":
28
- if (value.value <= value.min) {
29
- value.status = "increasing";
30
- }
31
- else {
32
- value.value -= (value.velocity ?? 0) * delta.factor;
33
- }
34
- break;
35
- }
36
- if (value.velocity && decay !== 1) {
37
- value.velocity *= decay;
38
- }
39
- }
40
- function updateColorValue(delta, colorValue, max, decrease) {
41
- if (!colorValue || !colorValue.enable) {
42
- return;
43
- }
44
- if (!colorValue.time) {
45
- colorValue.time = 0;
46
- }
47
- if ((colorValue.delayTime ?? 0) > 0 && colorValue.time < (colorValue.delayTime ?? 0)) {
48
- colorValue.time += delta.value;
49
- }
50
- if ((colorValue.delayTime ?? 0) > 0 && colorValue.time < (colorValue.delayTime ?? 0)) {
51
- return;
52
- }
53
- const velocity = (colorValue.velocity ?? 0) * delta.factor, decay = colorValue.decay ?? 1;
54
- if (!decrease || colorValue.status === "increasing") {
55
- colorValue.value += velocity;
56
- if (decrease && colorValue.value > max) {
57
- colorValue.status = "decreasing";
58
- colorValue.value -= colorValue.value % max;
59
- }
60
- }
61
- else {
62
- colorValue.value -= velocity;
63
- if (colorValue.value < 0) {
64
- colorValue.status = "increasing";
65
- colorValue.value += colorValue.value;
66
- }
67
- }
68
- if (colorValue.value > max) {
69
- colorValue.value %= max;
70
- }
71
- if (colorValue.velocity && decay !== 1) {
72
- colorValue.velocity *= decay;
73
- }
74
- }
75
- function updateAngle(delta, angle) {
76
- const speed = (angle.velocity ?? 0) * delta.factor, max = 2 * Math.PI, decay = angle.decay ?? 1;
77
- if (!angle.enable) {
78
- return;
79
- }
80
- switch (angle.status) {
81
- case "increasing":
82
- angle.value += speed;
83
- if (angle.value > max) {
84
- angle.value -= max;
85
- }
86
- break;
87
- case "decreasing":
88
- default:
89
- angle.value -= speed;
90
- if (angle.value < 0) {
91
- angle.value += max;
92
- }
93
- break;
94
- }
95
- if (angle.velocity && decay !== 1) {
96
- angle.velocity *= decay;
97
- }
98
- }
13
+ const engine_1 = require("@tsparticles/engine");
99
14
  function updateGradient(particle, delta) {
100
15
  const { gradient } = particle;
101
16
  if (!gradient) {
102
17
  return;
103
18
  }
104
- updateAngle(delta, gradient.angle);
19
+ (0, engine_1.updateAnimation)(particle, gradient.angle, false, "none", delta);
105
20
  for (const color of gradient.colors) {
106
- if (particle.color?.h !== undefined) {
107
- updateColorValue(delta, color.value.h, 360, false);
108
- }
109
- if (particle.color?.s !== undefined) {
110
- updateColorValue(delta, color.value.s, 100, true);
111
- }
112
- if (particle.color?.l !== undefined) {
113
- updateColorValue(delta, color.value.l, 100, true);
114
- }
21
+ (0, engine_1.updateColor)(color.value, delta);
115
22
  if (color.opacity) {
116
- updateColorOpacity(delta, color.opacity);
23
+ (0, engine_1.updateAnimation)(particle, color.opacity, true, "none", delta);
117
24
  }
118
25
  }
119
26
  }