@tsparticles/updater-wobble 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.
- package/browser/Utils.js +4 -1
- package/browser/WobbleUpdater.js +6 -4
- package/cjs/Utils.js +4 -1
- package/cjs/WobbleUpdater.js +6 -4
- package/esm/Utils.js +4 -1
- package/esm/WobbleUpdater.js +6 -4
- package/package.json +2 -2
- package/report.html +2 -2
- package/tsparticles.updater.wobble.js +17 -7
- package/tsparticles.updater.wobble.min.js +1 -1
- package/tsparticles.updater.wobble.min.js.LICENSE.txt +1 -1
- package/types/Utils.d.ts +1 -1
- package/umd/Utils.js +5 -2
- package/umd/WobbleUpdater.js +6 -4
package/browser/Utils.js
CHANGED
|
@@ -1,9 +1,12 @@
|
|
|
1
|
+
import { millisecondsToSeconds } from "@tsparticles/engine";
|
|
2
|
+
const defaultDistance = 0, double = 2, doublePI = Math.PI * double, distanceFactor = 60;
|
|
1
3
|
export function updateWobble(particle, delta) {
|
|
2
4
|
const { wobble: wobbleOptions } = particle.options, { wobble } = particle;
|
|
3
5
|
if (!wobbleOptions?.enable || !wobble) {
|
|
4
6
|
return;
|
|
5
7
|
}
|
|
6
|
-
const angleSpeed = wobble.angleSpeed * delta.factor, moveSpeed = wobble.moveSpeed * delta.factor, distance = (moveSpeed * ((particle.retina.wobbleDistance ??
|
|
8
|
+
const angleSpeed = wobble.angleSpeed * delta.factor, moveSpeed = wobble.moveSpeed * delta.factor, distance = (moveSpeed * ((particle.retina.wobbleDistance ?? defaultDistance) * delta.factor)) /
|
|
9
|
+
(millisecondsToSeconds / distanceFactor), max = doublePI, { position } = particle;
|
|
7
10
|
wobble.angle += angleSpeed;
|
|
8
11
|
if (wobble.angle > max) {
|
|
9
12
|
wobble.angle -= max;
|
package/browser/WobbleUpdater.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { getRandom, getRangeValue, } from "@tsparticles/engine";
|
|
2
2
|
import { Wobble } from "./Options/Classes/Wobble.js";
|
|
3
3
|
import { updateWobble } from "./Utils.js";
|
|
4
|
+
const double = 2, doublePI = Math.PI * double, maxAngle = 360, moveSpeedFactor = 10, defaultDistance = 0;
|
|
4
5
|
export class WobbleUpdater {
|
|
5
6
|
constructor(container) {
|
|
6
7
|
this.container = container;
|
|
@@ -9,9 +10,9 @@ export class WobbleUpdater {
|
|
|
9
10
|
const wobbleOpt = particle.options.wobble;
|
|
10
11
|
if (wobbleOpt?.enable) {
|
|
11
12
|
particle.wobble = {
|
|
12
|
-
angle: getRandom() *
|
|
13
|
-
angleSpeed: getRangeValue(wobbleOpt.speed.angle) /
|
|
14
|
-
moveSpeed: getRangeValue(wobbleOpt.speed.move) /
|
|
13
|
+
angle: getRandom() * doublePI,
|
|
14
|
+
angleSpeed: getRangeValue(wobbleOpt.speed.angle) / maxAngle,
|
|
15
|
+
moveSpeed: getRangeValue(wobbleOpt.speed.move) / moveSpeedFactor,
|
|
15
16
|
};
|
|
16
17
|
}
|
|
17
18
|
else {
|
|
@@ -21,7 +22,8 @@ export class WobbleUpdater {
|
|
|
21
22
|
moveSpeed: 0,
|
|
22
23
|
};
|
|
23
24
|
}
|
|
24
|
-
particle.retina.wobbleDistance =
|
|
25
|
+
particle.retina.wobbleDistance =
|
|
26
|
+
getRangeValue(wobbleOpt?.distance ?? defaultDistance) * this.container.retina.pixelRatio;
|
|
25
27
|
}
|
|
26
28
|
isEnabled(particle) {
|
|
27
29
|
return !particle.destroyed && !particle.spawning && !!particle.options.wobble?.enable;
|
package/cjs/Utils.js
CHANGED
|
@@ -1,12 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.updateWobble = void 0;
|
|
4
|
+
const engine_1 = require("@tsparticles/engine");
|
|
5
|
+
const defaultDistance = 0, double = 2, doublePI = Math.PI * double, distanceFactor = 60;
|
|
4
6
|
function updateWobble(particle, delta) {
|
|
5
7
|
const { wobble: wobbleOptions } = particle.options, { wobble } = particle;
|
|
6
8
|
if (!wobbleOptions?.enable || !wobble) {
|
|
7
9
|
return;
|
|
8
10
|
}
|
|
9
|
-
const angleSpeed = wobble.angleSpeed * delta.factor, moveSpeed = wobble.moveSpeed * delta.factor, distance = (moveSpeed * ((particle.retina.wobbleDistance ??
|
|
11
|
+
const angleSpeed = wobble.angleSpeed * delta.factor, moveSpeed = wobble.moveSpeed * delta.factor, distance = (moveSpeed * ((particle.retina.wobbleDistance ?? defaultDistance) * delta.factor)) /
|
|
12
|
+
(engine_1.millisecondsToSeconds / distanceFactor), max = doublePI, { position } = particle;
|
|
10
13
|
wobble.angle += angleSpeed;
|
|
11
14
|
if (wobble.angle > max) {
|
|
12
15
|
wobble.angle -= max;
|
package/cjs/WobbleUpdater.js
CHANGED
|
@@ -4,6 +4,7 @@ exports.WobbleUpdater = void 0;
|
|
|
4
4
|
const engine_1 = require("@tsparticles/engine");
|
|
5
5
|
const Wobble_js_1 = require("./Options/Classes/Wobble.js");
|
|
6
6
|
const Utils_js_1 = require("./Utils.js");
|
|
7
|
+
const double = 2, doublePI = Math.PI * double, maxAngle = 360, moveSpeedFactor = 10, defaultDistance = 0;
|
|
7
8
|
class WobbleUpdater {
|
|
8
9
|
constructor(container) {
|
|
9
10
|
this.container = container;
|
|
@@ -12,9 +13,9 @@ class WobbleUpdater {
|
|
|
12
13
|
const wobbleOpt = particle.options.wobble;
|
|
13
14
|
if (wobbleOpt?.enable) {
|
|
14
15
|
particle.wobble = {
|
|
15
|
-
angle: (0, engine_1.getRandom)() *
|
|
16
|
-
angleSpeed: (0, engine_1.getRangeValue)(wobbleOpt.speed.angle) /
|
|
17
|
-
moveSpeed: (0, engine_1.getRangeValue)(wobbleOpt.speed.move) /
|
|
16
|
+
angle: (0, engine_1.getRandom)() * doublePI,
|
|
17
|
+
angleSpeed: (0, engine_1.getRangeValue)(wobbleOpt.speed.angle) / maxAngle,
|
|
18
|
+
moveSpeed: (0, engine_1.getRangeValue)(wobbleOpt.speed.move) / moveSpeedFactor,
|
|
18
19
|
};
|
|
19
20
|
}
|
|
20
21
|
else {
|
|
@@ -24,7 +25,8 @@ class WobbleUpdater {
|
|
|
24
25
|
moveSpeed: 0,
|
|
25
26
|
};
|
|
26
27
|
}
|
|
27
|
-
particle.retina.wobbleDistance =
|
|
28
|
+
particle.retina.wobbleDistance =
|
|
29
|
+
(0, engine_1.getRangeValue)(wobbleOpt?.distance ?? defaultDistance) * this.container.retina.pixelRatio;
|
|
28
30
|
}
|
|
29
31
|
isEnabled(particle) {
|
|
30
32
|
return !particle.destroyed && !particle.spawning && !!particle.options.wobble?.enable;
|
package/esm/Utils.js
CHANGED
|
@@ -1,9 +1,12 @@
|
|
|
1
|
+
import { millisecondsToSeconds } from "@tsparticles/engine";
|
|
2
|
+
const defaultDistance = 0, double = 2, doublePI = Math.PI * double, distanceFactor = 60;
|
|
1
3
|
export function updateWobble(particle, delta) {
|
|
2
4
|
const { wobble: wobbleOptions } = particle.options, { wobble } = particle;
|
|
3
5
|
if (!wobbleOptions?.enable || !wobble) {
|
|
4
6
|
return;
|
|
5
7
|
}
|
|
6
|
-
const angleSpeed = wobble.angleSpeed * delta.factor, moveSpeed = wobble.moveSpeed * delta.factor, distance = (moveSpeed * ((particle.retina.wobbleDistance ??
|
|
8
|
+
const angleSpeed = wobble.angleSpeed * delta.factor, moveSpeed = wobble.moveSpeed * delta.factor, distance = (moveSpeed * ((particle.retina.wobbleDistance ?? defaultDistance) * delta.factor)) /
|
|
9
|
+
(millisecondsToSeconds / distanceFactor), max = doublePI, { position } = particle;
|
|
7
10
|
wobble.angle += angleSpeed;
|
|
8
11
|
if (wobble.angle > max) {
|
|
9
12
|
wobble.angle -= max;
|
package/esm/WobbleUpdater.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { getRandom, getRangeValue, } from "@tsparticles/engine";
|
|
2
2
|
import { Wobble } from "./Options/Classes/Wobble.js";
|
|
3
3
|
import { updateWobble } from "./Utils.js";
|
|
4
|
+
const double = 2, doublePI = Math.PI * double, maxAngle = 360, moveSpeedFactor = 10, defaultDistance = 0;
|
|
4
5
|
export class WobbleUpdater {
|
|
5
6
|
constructor(container) {
|
|
6
7
|
this.container = container;
|
|
@@ -9,9 +10,9 @@ export class WobbleUpdater {
|
|
|
9
10
|
const wobbleOpt = particle.options.wobble;
|
|
10
11
|
if (wobbleOpt?.enable) {
|
|
11
12
|
particle.wobble = {
|
|
12
|
-
angle: getRandom() *
|
|
13
|
-
angleSpeed: getRangeValue(wobbleOpt.speed.angle) /
|
|
14
|
-
moveSpeed: getRangeValue(wobbleOpt.speed.move) /
|
|
13
|
+
angle: getRandom() * doublePI,
|
|
14
|
+
angleSpeed: getRangeValue(wobbleOpt.speed.angle) / maxAngle,
|
|
15
|
+
moveSpeed: getRangeValue(wobbleOpt.speed.move) / moveSpeedFactor,
|
|
15
16
|
};
|
|
16
17
|
}
|
|
17
18
|
else {
|
|
@@ -21,7 +22,8 @@ export class WobbleUpdater {
|
|
|
21
22
|
moveSpeed: 0,
|
|
22
23
|
};
|
|
23
24
|
}
|
|
24
|
-
particle.retina.wobbleDistance =
|
|
25
|
+
particle.retina.wobbleDistance =
|
|
26
|
+
getRangeValue(wobbleOpt?.distance ?? defaultDistance) * this.container.retina.pixelRatio;
|
|
25
27
|
}
|
|
26
28
|
isEnabled(particle) {
|
|
27
29
|
return !particle.destroyed && !particle.spawning && !!particle.options.wobble?.enable;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tsparticles/updater-wobble",
|
|
3
|
-
"version": "3.0
|
|
3
|
+
"version": "3.1.0",
|
|
4
4
|
"description": "tsParticles particles wobble updater",
|
|
5
5
|
"homepage": "https://particles.js.org",
|
|
6
6
|
"repository": {
|
|
@@ -87,7 +87,7 @@
|
|
|
87
87
|
"./package.json": "./package.json"
|
|
88
88
|
},
|
|
89
89
|
"dependencies": {
|
|
90
|
-
"@tsparticles/engine": "^3.0
|
|
90
|
+
"@tsparticles/engine": "^3.1.0"
|
|
91
91
|
},
|
|
92
92
|
"publishConfig": {
|
|
93
93
|
"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-wobble [
|
|
6
|
+
<title>@tsparticles/updater-wobble [13 Jan 2024 at 23:09]</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.wobble.js","isAsset":true,"statSize":
|
|
34
|
+
window.chartData = [{"label":"tsparticles.updater.wobble.js","isAsset":true,"statSize":3718,"parsedSize":7643,"gzipSize":2235,"groups":[{"label":"dist/browser","path":"./dist/browser","statSize":3676,"groups":[{"id":661,"label":"index.js + 4 modules (concatenated)","path":"./dist/browser/index.js + 4 modules (concatenated)","statSize":3676,"parsedSize":7643,"gzipSize":2235,"concatenated":true,"groups":[{"label":"dist/browser","path":"./dist/browser/index.js + 4 modules (concatenated)/dist/browser","statSize":3676,"groups":[{"id":null,"label":"index.js","path":"./dist/browser/index.js + 4 modules (concatenated)/dist/browser/index.js","statSize":216,"parsedSize":449,"gzipSize":131,"inaccurateSizes":true},{"id":null,"label":"WobbleUpdater.js","path":"./dist/browser/index.js + 4 modules (concatenated)/dist/browser/WobbleUpdater.js","statSize":1365,"parsedSize":2838,"gzipSize":829,"inaccurateSizes":true},{"label":"Options/Classes","path":"./dist/browser/index.js + 4 modules (concatenated)/dist/browser/Options/Classes","statSize":1228,"groups":[{"id":null,"label":"Wobble.js","path":"./dist/browser/index.js + 4 modules (concatenated)/dist/browser/Options/Classes/Wobble.js","statSize":855,"parsedSize":1777,"gzipSize":519,"inaccurateSizes":true},{"id":null,"label":"WobbleSpeed.js","path":"./dist/browser/index.js + 4 modules (concatenated)/dist/browser/Options/Classes/WobbleSpeed.js","statSize":373,"parsedSize":775,"gzipSize":226,"inaccurateSizes":true}],"parsedSize":2553,"gzipSize":746,"inaccurateSizes":true},{"id":null,"label":"Utils.js","path":"./dist/browser/index.js + 4 modules (concatenated)/dist/browser/Utils.js","statSize":867,"parsedSize":1802,"gzipSize":527,"inaccurateSizes":true}],"parsedSize":7643,"gzipSize":2235,"inaccurateSizes":true}]}],"parsedSize":7643,"gzipSize":2235},{"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.wobble":true}}];
|
|
35
35
|
window.entrypoints = ["tsparticles.updater.wobble","tsparticles.updater.wobble.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
|
|
7
|
+
* v3.1.0
|
|
8
8
|
*/
|
|
9
9
|
(function webpackUniversalModuleDefinition(root, factory) {
|
|
10
10
|
if(typeof exports === 'object' && typeof module === 'object')
|
|
@@ -153,6 +153,11 @@ class Wobble {
|
|
|
153
153
|
}
|
|
154
154
|
}
|
|
155
155
|
;// CONCATENATED MODULE: ./dist/browser/Utils.js
|
|
156
|
+
|
|
157
|
+
const defaultDistance = 0,
|
|
158
|
+
Utils_double = 2,
|
|
159
|
+
doublePI = Math.PI * Utils_double,
|
|
160
|
+
distanceFactor = 60;
|
|
156
161
|
function updateWobble(particle, delta) {
|
|
157
162
|
const {
|
|
158
163
|
wobble: wobbleOptions
|
|
@@ -165,8 +170,8 @@ function updateWobble(particle, delta) {
|
|
|
165
170
|
}
|
|
166
171
|
const angleSpeed = wobble.angleSpeed * delta.factor,
|
|
167
172
|
moveSpeed = wobble.moveSpeed * delta.factor,
|
|
168
|
-
distance = moveSpeed * ((particle.retina.wobbleDistance ??
|
|
169
|
-
max =
|
|
173
|
+
distance = moveSpeed * ((particle.retina.wobbleDistance ?? defaultDistance) * delta.factor) / (engine_root_window_.millisecondsToSeconds / distanceFactor),
|
|
174
|
+
max = doublePI,
|
|
170
175
|
{
|
|
171
176
|
position
|
|
172
177
|
} = particle;
|
|
@@ -181,6 +186,11 @@ function updateWobble(particle, delta) {
|
|
|
181
186
|
|
|
182
187
|
|
|
183
188
|
|
|
189
|
+
const WobbleUpdater_double = 2,
|
|
190
|
+
WobbleUpdater_doublePI = Math.PI * WobbleUpdater_double,
|
|
191
|
+
maxAngle = 360,
|
|
192
|
+
moveSpeedFactor = 10,
|
|
193
|
+
WobbleUpdater_defaultDistance = 0;
|
|
184
194
|
class WobbleUpdater {
|
|
185
195
|
constructor(container) {
|
|
186
196
|
this.container = container;
|
|
@@ -189,9 +199,9 @@ class WobbleUpdater {
|
|
|
189
199
|
const wobbleOpt = particle.options.wobble;
|
|
190
200
|
if (wobbleOpt?.enable) {
|
|
191
201
|
particle.wobble = {
|
|
192
|
-
angle: (0,engine_root_window_.getRandom)() *
|
|
193
|
-
angleSpeed: (0,engine_root_window_.getRangeValue)(wobbleOpt.speed.angle) /
|
|
194
|
-
moveSpeed: (0,engine_root_window_.getRangeValue)(wobbleOpt.speed.move) /
|
|
202
|
+
angle: (0,engine_root_window_.getRandom)() * WobbleUpdater_doublePI,
|
|
203
|
+
angleSpeed: (0,engine_root_window_.getRangeValue)(wobbleOpt.speed.angle) / maxAngle,
|
|
204
|
+
moveSpeed: (0,engine_root_window_.getRangeValue)(wobbleOpt.speed.move) / moveSpeedFactor
|
|
195
205
|
};
|
|
196
206
|
} else {
|
|
197
207
|
particle.wobble = {
|
|
@@ -200,7 +210,7 @@ class WobbleUpdater {
|
|
|
200
210
|
moveSpeed: 0
|
|
201
211
|
};
|
|
202
212
|
}
|
|
203
|
-
particle.retina.wobbleDistance = (0,engine_root_window_.getRangeValue)(wobbleOpt?.distance ??
|
|
213
|
+
particle.retina.wobbleDistance = (0,engine_root_window_.getRangeValue)(wobbleOpt?.distance ?? WobbleUpdater_defaultDistance) * this.container.retina.pixelRatio;
|
|
204
214
|
}
|
|
205
215
|
isEnabled(particle) {
|
|
206
216
|
return !particle.destroyed && !particle.spawning && !!particle.options.wobble?.enable;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/*! For license information please see tsparticles.updater.wobble.min.js.LICENSE.txt */
|
|
2
|
-
!function(e,t){if("object"==typeof exports&&"object"==typeof module)module.exports=t(require("@tsparticles/engine"));else if("function"==typeof define&&define.amd)define(["@tsparticles/engine"],t);else{var o="object"==typeof exports?t(require("@tsparticles/engine")):t(e.window);for(var n in o)("object"==typeof exports?exports:e)[n]=o[n]}}(this,(e=>(()=>{"use strict";var t={533:t=>{t.exports=e}},o={};function n(e){var a=o[e];if(void 0!==a)return a.exports;var s=o[e]={exports:{}};return t[e](s,s.exports,n),s.exports}n.d=(e,t)=>{for(var o in t)n.o(t,o)&&!n.o(e,o)&&Object.defineProperty(e,o,{enumerable:!0,get:t[o]})},n.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),n.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var a={};return(()=>{n.r(a),n.d(a,{loadWobbleUpdater:()=>
|
|
2
|
+
!function(e,t){if("object"==typeof exports&&"object"==typeof module)module.exports=t(require("@tsparticles/engine"));else if("function"==typeof define&&define.amd)define(["@tsparticles/engine"],t);else{var o="object"==typeof exports?t(require("@tsparticles/engine")):t(e.window);for(var n in o)("object"==typeof exports?exports:e)[n]=o[n]}}(this,(e=>(()=>{"use strict";var t={533:t=>{t.exports=e}},o={};function n(e){var a=o[e];if(void 0!==a)return a.exports;var s=o[e]={exports:{}};return t[e](s,s.exports,n),s.exports}n.d=(e,t)=>{for(var o in t)n.o(t,o)&&!n.o(e,o)&&Object.defineProperty(e,o,{enumerable:!0,get:t[o]})},n.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),n.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var a={};return(()=>{n.r(a),n.d(a,{loadWobbleUpdater:()=>r});var e=n(533);class t{constructor(){this.angle=50,this.move=10}load(t){t&&(void 0!==t.angle&&(this.angle=(0,e.setRangeValue)(t.angle)),void 0!==t.move&&(this.move=(0,e.setRangeValue)(t.move)))}}class o{constructor(){this.distance=5,this.enable=!1,this.speed=new t}load(t){if(t&&(void 0!==t.distance&&(this.distance=(0,e.setRangeValue)(t.distance)),void 0!==t.enable&&(this.enable=t.enable),void 0!==t.speed))if((0,e.isNumber)(t.speed))this.speed.load({angle:t.speed});else{const e=t.speed;void 0!==e.min?this.speed.load({angle:e}):this.speed.load(t.speed)}}}const s=2*Math.PI;const i=2*Math.PI;class l{constructor(e){this.container=e}init(t){const o=t.options.wobble;t.wobble=o?.enable?{angle:(0,e.getRandom)()*i,angleSpeed:(0,e.getRangeValue)(o.speed.angle)/360,moveSpeed:(0,e.getRangeValue)(o.speed.move)/10}:{angle:0,angleSpeed:0,moveSpeed:0},t.retina.wobbleDistance=(0,e.getRangeValue)(o?.distance??0)*this.container.retina.pixelRatio}isEnabled(e){return!e.destroyed&&!e.spawning&&!!e.options.wobble?.enable}loadOptions(e,...t){e.wobble||(e.wobble=new o);for(const o of t)e.wobble.load(o?.wobble)}update(t,o){this.isEnabled(t)&&function(t,o){const{wobble:n}=t.options,{wobble:a}=t;if(!n?.enable||!a)return;const i=a.angleSpeed*o.factor,l=a.moveSpeed*o.factor*((t.retina.wobbleDistance??0)*o.factor)/(e.millisecondsToSeconds/60),r=s,{position:d}=t;a.angle+=i,a.angle>r&&(a.angle-=r),d.x+=l*Math.cos(a.angle),d.y+=l*Math.abs(Math.sin(a.angle))}(t,o)}}async function r(e,t=!0){await e.addParticleUpdater("wobble",(e=>new l(e)),t)}})(),a})()));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
/*! tsParticles Wobble Updater v3.0
|
|
1
|
+
/*! tsParticles Wobble Updater v3.1.0 by Matteo Bruni */
|
package/types/Utils.d.ts
CHANGED
package/umd/Utils.js
CHANGED
|
@@ -4,18 +4,21 @@
|
|
|
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.updateWobble = void 0;
|
|
13
|
+
const engine_1 = require("@tsparticles/engine");
|
|
14
|
+
const defaultDistance = 0, double = 2, doublePI = Math.PI * double, distanceFactor = 60;
|
|
13
15
|
function updateWobble(particle, delta) {
|
|
14
16
|
const { wobble: wobbleOptions } = particle.options, { wobble } = particle;
|
|
15
17
|
if (!wobbleOptions?.enable || !wobble) {
|
|
16
18
|
return;
|
|
17
19
|
}
|
|
18
|
-
const angleSpeed = wobble.angleSpeed * delta.factor, moveSpeed = wobble.moveSpeed * delta.factor, distance = (moveSpeed * ((particle.retina.wobbleDistance ??
|
|
20
|
+
const angleSpeed = wobble.angleSpeed * delta.factor, moveSpeed = wobble.moveSpeed * delta.factor, distance = (moveSpeed * ((particle.retina.wobbleDistance ?? defaultDistance) * delta.factor)) /
|
|
21
|
+
(engine_1.millisecondsToSeconds / distanceFactor), max = doublePI, { position } = particle;
|
|
19
22
|
wobble.angle += angleSpeed;
|
|
20
23
|
if (wobble.angle > max) {
|
|
21
24
|
wobble.angle -= max;
|
package/umd/WobbleUpdater.js
CHANGED
|
@@ -13,6 +13,7 @@
|
|
|
13
13
|
const engine_1 = require("@tsparticles/engine");
|
|
14
14
|
const Wobble_js_1 = require("./Options/Classes/Wobble.js");
|
|
15
15
|
const Utils_js_1 = require("./Utils.js");
|
|
16
|
+
const double = 2, doublePI = Math.PI * double, maxAngle = 360, moveSpeedFactor = 10, defaultDistance = 0;
|
|
16
17
|
class WobbleUpdater {
|
|
17
18
|
constructor(container) {
|
|
18
19
|
this.container = container;
|
|
@@ -21,9 +22,9 @@
|
|
|
21
22
|
const wobbleOpt = particle.options.wobble;
|
|
22
23
|
if (wobbleOpt?.enable) {
|
|
23
24
|
particle.wobble = {
|
|
24
|
-
angle: (0, engine_1.getRandom)() *
|
|
25
|
-
angleSpeed: (0, engine_1.getRangeValue)(wobbleOpt.speed.angle) /
|
|
26
|
-
moveSpeed: (0, engine_1.getRangeValue)(wobbleOpt.speed.move) /
|
|
25
|
+
angle: (0, engine_1.getRandom)() * doublePI,
|
|
26
|
+
angleSpeed: (0, engine_1.getRangeValue)(wobbleOpt.speed.angle) / maxAngle,
|
|
27
|
+
moveSpeed: (0, engine_1.getRangeValue)(wobbleOpt.speed.move) / moveSpeedFactor,
|
|
27
28
|
};
|
|
28
29
|
}
|
|
29
30
|
else {
|
|
@@ -33,7 +34,8 @@
|
|
|
33
34
|
moveSpeed: 0,
|
|
34
35
|
};
|
|
35
36
|
}
|
|
36
|
-
particle.retina.wobbleDistance =
|
|
37
|
+
particle.retina.wobbleDistance =
|
|
38
|
+
(0, engine_1.getRangeValue)(wobbleOpt?.distance ?? defaultDistance) * this.container.retina.pixelRatio;
|
|
37
39
|
}
|
|
38
40
|
isEnabled(particle) {
|
|
39
41
|
return !particle.destroyed && !particle.spawning && !!particle.options.wobble?.enable;
|