@tsparticles/perlin-noise 3.8.1 → 3.9.1
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/Grad.js +5 -1
- package/browser/PerlinNoise.js +55 -21
- package/cjs/Grad.js +5 -1
- package/cjs/PerlinNoise.js +55 -21
- package/esm/Grad.js +5 -1
- package/esm/PerlinNoise.js +55 -21
- package/package.json +1 -1
- package/report.html +1 -1
- package/tsparticles.perlin.noise.js +4 -4
- package/tsparticles.perlin.noise.min.js +1 -1
- package/tsparticles.perlin.noise.min.js.LICENSE.txt +1 -1
- package/types/Grad.d.ts +3 -1
- package/types/PerlinNoise.d.ts +2 -1
- package/umd/Grad.js +5 -1
- package/umd/PerlinNoise.js +55 -21
package/browser/Grad.js
CHANGED
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
export class Grad {
|
|
2
|
-
constructor(x, y, z) {
|
|
2
|
+
constructor(x, y, z, w) {
|
|
3
3
|
this.x = x;
|
|
4
4
|
this.y = y;
|
|
5
5
|
this.z = z;
|
|
6
|
+
this.w = w;
|
|
6
7
|
}
|
|
7
8
|
dot2(x, y) {
|
|
8
9
|
return this.x * x + this.y * y;
|
|
@@ -10,4 +11,7 @@ export class Grad {
|
|
|
10
11
|
dot3(x, y, z) {
|
|
11
12
|
return this.dot2(x, y) + this.z * z;
|
|
12
13
|
}
|
|
14
|
+
dot4(x, y, z, w) {
|
|
15
|
+
return this.dot3(x, y, z) + this.w * w;
|
|
16
|
+
}
|
|
13
17
|
}
|
package/browser/PerlinNoise.js
CHANGED
|
@@ -1,19 +1,39 @@
|
|
|
1
1
|
import { Grad } from "./Grad.js";
|
|
2
2
|
export class PerlinNoise {
|
|
3
3
|
constructor() {
|
|
4
|
-
this.
|
|
5
|
-
new Grad(1, 1,
|
|
6
|
-
new Grad(
|
|
7
|
-
new Grad(1, -1,
|
|
8
|
-
new Grad(
|
|
9
|
-
new Grad(1,
|
|
10
|
-
new Grad(-1,
|
|
11
|
-
new Grad(
|
|
12
|
-
new Grad(-1,
|
|
13
|
-
new Grad(0, 1, 1),
|
|
14
|
-
new Grad(0,
|
|
15
|
-
new Grad(0, 1,
|
|
16
|
-
new Grad(0, -1, -1),
|
|
4
|
+
this._grad4 = [
|
|
5
|
+
new Grad(0, 1, 1, 1),
|
|
6
|
+
new Grad(0, 1, 1, -1),
|
|
7
|
+
new Grad(0, 1, -1, 1),
|
|
8
|
+
new Grad(0, 1, -1, -1),
|
|
9
|
+
new Grad(0, -1, 1, 1),
|
|
10
|
+
new Grad(0, -1, 1, -1),
|
|
11
|
+
new Grad(0, -1, -1, 1),
|
|
12
|
+
new Grad(0, -1, -1, -1),
|
|
13
|
+
new Grad(1, 0, 1, 1),
|
|
14
|
+
new Grad(1, 0, 1, -1),
|
|
15
|
+
new Grad(1, 0, -1, 1),
|
|
16
|
+
new Grad(1, 0, -1, -1),
|
|
17
|
+
new Grad(-1, 0, 1, 1),
|
|
18
|
+
new Grad(-1, 0, 1, -1),
|
|
19
|
+
new Grad(-1, 0, -1, 1),
|
|
20
|
+
new Grad(-1, 0, -1, -1),
|
|
21
|
+
new Grad(1, 1, 0, 1),
|
|
22
|
+
new Grad(1, 1, 0, -1),
|
|
23
|
+
new Grad(1, -1, 0, 1),
|
|
24
|
+
new Grad(1, -1, 0, -1),
|
|
25
|
+
new Grad(-1, 1, 0, 1),
|
|
26
|
+
new Grad(-1, 1, 0, -1),
|
|
27
|
+
new Grad(-1, -1, 0, 1),
|
|
28
|
+
new Grad(-1, -1, 0, -1),
|
|
29
|
+
new Grad(1, 1, 1, 0),
|
|
30
|
+
new Grad(1, 1, -1, 0),
|
|
31
|
+
new Grad(1, -1, 1, 0),
|
|
32
|
+
new Grad(1, -1, -1, 0),
|
|
33
|
+
new Grad(-1, 1, 1, 0),
|
|
34
|
+
new Grad(-1, 1, -1, 0),
|
|
35
|
+
new Grad(-1, -1, 1, 0),
|
|
36
|
+
new Grad(-1, -1, -1, 0),
|
|
17
37
|
];
|
|
18
38
|
this._p = [
|
|
19
39
|
151,
|
|
@@ -279,12 +299,11 @@ export class PerlinNoise {
|
|
|
279
299
|
noise2d(x, y) {
|
|
280
300
|
const { _gradP, _perm } = this;
|
|
281
301
|
let X = Math.floor(x), Y = Math.floor(y);
|
|
282
|
-
x
|
|
283
|
-
y
|
|
284
|
-
X
|
|
285
|
-
Y
|
|
286
|
-
const n00 = _gradP[X + _perm[Y]].dot2(x, y), n01 = _gradP[X + _perm[Y + 1]].dot2(x, y - 1), n10 = _gradP[X + 1 + _perm[Y]].dot2(x - 1, y), n11 = _gradP[X + 1 + _perm[Y + 1]].dot2(x - 1, y - 1);
|
|
287
|
-
const u = this._fade(x);
|
|
302
|
+
x -= X;
|
|
303
|
+
y -= Y;
|
|
304
|
+
X &= 255;
|
|
305
|
+
Y &= 255;
|
|
306
|
+
const n00 = _gradP[X + _perm[Y]].dot2(x, y), n01 = _gradP[X + _perm[Y + 1]].dot2(x, y - 1), n10 = _gradP[X + 1 + _perm[Y]].dot2(x - 1, y), n11 = _gradP[X + 1 + _perm[Y + 1]].dot2(x - 1, y - 1), u = this._fade(x);
|
|
288
307
|
return this._lerp(this._lerp(n00, n10, u), this._lerp(n01, n11, u), this._fade(y));
|
|
289
308
|
}
|
|
290
309
|
noise3d(x, y, z) {
|
|
@@ -299,8 +318,22 @@ export class PerlinNoise {
|
|
|
299
318
|
const n000 = gradP[X + perm[Y + perm[Z]]].dot3(x, y, z), n001 = gradP[X + perm[Y + perm[Z + 1]]].dot3(x, y, z - 1), n010 = gradP[X + perm[Y + 1 + perm[Z]]].dot3(x, y - 1, z), n011 = gradP[X + perm[Y + 1 + perm[Z + 1]]].dot3(x, y - 1, z - 1), n100 = gradP[X + 1 + perm[Y + perm[Z]]].dot3(x - 1, y, z), n101 = gradP[X + 1 + perm[Y + perm[Z + 1]]].dot3(x - 1, y, z - 1), n110 = gradP[X + 1 + perm[Y + 1 + perm[Z]]].dot3(x - 1, y - 1, z), n111 = gradP[X + 1 + perm[Y + 1 + perm[Z + 1]]].dot3(x - 1, y - 1, z - 1), u = this._fade(x), v = this._fade(y), w = this._fade(z);
|
|
300
319
|
return this._lerp(this._lerp(this._lerp(n000, n100, u), this._lerp(n001, n101, u), w), this._lerp(this._lerp(n010, n110, u), this._lerp(n011, n111, u), w), v);
|
|
301
320
|
}
|
|
321
|
+
noise4d(x, y, z, w) {
|
|
322
|
+
const { _gradP: gradP, _perm: perm } = this;
|
|
323
|
+
let X = Math.floor(x), Y = Math.floor(y), Z = Math.floor(z), W = Math.floor(w);
|
|
324
|
+
x -= X;
|
|
325
|
+
y -= Y;
|
|
326
|
+
z -= Z;
|
|
327
|
+
w -= W;
|
|
328
|
+
X &= 255;
|
|
329
|
+
Y &= 255;
|
|
330
|
+
Z &= 255;
|
|
331
|
+
W &= 255;
|
|
332
|
+
const u = this._fade(x), v = this._fade(y), s = this._fade(z), t = this._fade(w), gi = (i, j, k, l) => gradP[X + i + perm[Y + j + perm[Z + k + perm[W + l]]]], n0000 = gi(0, 0, 0, 0).dot4(x, y, z, w), n0001 = gi(0, 0, 0, 1).dot4(x, y, z, w - 1), n0010 = gi(0, 0, 1, 0).dot4(x, y, z - 1, w), n0011 = gi(0, 0, 1, 1).dot4(x, y, z - 1, w - 1), n0100 = gi(0, 1, 0, 0).dot4(x, y - 1, z, w), n0101 = gi(0, 1, 0, 1).dot4(x, y - 1, z, w - 1), n0110 = gi(0, 1, 1, 0).dot4(x, y - 1, z - 1, w), n0111 = gi(0, 1, 1, 1).dot4(x, y - 1, z - 1, w - 1), n1000 = gi(1, 0, 0, 0).dot4(x - 1, y, z, w), n1001 = gi(1, 0, 0, 1).dot4(x - 1, y, z, w - 1), n1010 = gi(1, 0, 1, 0).dot4(x - 1, y, z - 1, w), n1011 = gi(1, 0, 1, 1).dot4(x - 1, y, z - 1, w - 1), n1100 = gi(1, 1, 0, 0).dot4(x - 1, y - 1, z, w), n1101 = gi(1, 1, 0, 1).dot4(x - 1, y - 1, z, w - 1), n1110 = gi(1, 1, 1, 0).dot4(x - 1, y - 1, z - 1, w), n1111 = gi(1, 1, 1, 1).dot4(x - 1, y - 1, z - 1, w - 1), x00 = this._lerp(n0000, n1000, u), x01 = this._lerp(n0001, n1001, u), x10 = this._lerp(n0010, n1010, u), x11 = this._lerp(n0011, n1011, u), y00 = this._lerp(x00, x10, s), y01 = this._lerp(x01, x11, s), x20 = this._lerp(n0100, n1100, u), x21 = this._lerp(n0101, n1101, u), x30 = this._lerp(n0110, n1110, u), x31 = this._lerp(n0111, n1111, u), y10 = this._lerp(x20, x30, s), y11 = this._lerp(x21, x31, s), z0 = this._lerp(y00, y10, v), z1 = this._lerp(y01, y11, v);
|
|
333
|
+
return this._lerp(z0, z1, t);
|
|
334
|
+
}
|
|
302
335
|
seed(inputSeed) {
|
|
303
|
-
const {
|
|
336
|
+
const { _grad4: grad4, _gradP: gradP, _perm: perm, _p: p } = this;
|
|
304
337
|
let seed = inputSeed;
|
|
305
338
|
if (seed > 0 && seed < 1) {
|
|
306
339
|
seed *= 65536;
|
|
@@ -309,10 +342,11 @@ export class PerlinNoise {
|
|
|
309
342
|
if (seed < 256) {
|
|
310
343
|
seed |= seed << 8;
|
|
311
344
|
}
|
|
345
|
+
const grad4Length = grad4.length;
|
|
312
346
|
for (let i = 0; i < 256; i++) {
|
|
313
347
|
const v = i & 1 ? p[i] ^ (seed & 255) : p[i] ^ ((seed >> 8) & 255);
|
|
314
348
|
perm[i] = perm[i + 256] = v;
|
|
315
|
-
gradP[i] = gradP[i + 256] =
|
|
349
|
+
gradP[i] = gradP[i + 256] = grad4[v % grad4Length];
|
|
316
350
|
}
|
|
317
351
|
}
|
|
318
352
|
_fade(t) {
|
package/cjs/Grad.js
CHANGED
|
@@ -2,10 +2,11 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.Grad = void 0;
|
|
4
4
|
class Grad {
|
|
5
|
-
constructor(x, y, z) {
|
|
5
|
+
constructor(x, y, z, w) {
|
|
6
6
|
this.x = x;
|
|
7
7
|
this.y = y;
|
|
8
8
|
this.z = z;
|
|
9
|
+
this.w = w;
|
|
9
10
|
}
|
|
10
11
|
dot2(x, y) {
|
|
11
12
|
return this.x * x + this.y * y;
|
|
@@ -13,5 +14,8 @@ class Grad {
|
|
|
13
14
|
dot3(x, y, z) {
|
|
14
15
|
return this.dot2(x, y) + this.z * z;
|
|
15
16
|
}
|
|
17
|
+
dot4(x, y, z, w) {
|
|
18
|
+
return this.dot3(x, y, z) + this.w * w;
|
|
19
|
+
}
|
|
16
20
|
}
|
|
17
21
|
exports.Grad = Grad;
|
package/cjs/PerlinNoise.js
CHANGED
|
@@ -4,19 +4,39 @@ exports.PerlinNoise = void 0;
|
|
|
4
4
|
const Grad_js_1 = require("./Grad.js");
|
|
5
5
|
class PerlinNoise {
|
|
6
6
|
constructor() {
|
|
7
|
-
this.
|
|
8
|
-
new Grad_js_1.Grad(1, 1,
|
|
9
|
-
new Grad_js_1.Grad(
|
|
10
|
-
new Grad_js_1.Grad(1, -1,
|
|
11
|
-
new Grad_js_1.Grad(
|
|
12
|
-
new Grad_js_1.Grad(1,
|
|
13
|
-
new Grad_js_1.Grad(-1,
|
|
14
|
-
new Grad_js_1.Grad(
|
|
15
|
-
new Grad_js_1.Grad(-1,
|
|
16
|
-
new Grad_js_1.Grad(0, 1, 1),
|
|
17
|
-
new Grad_js_1.Grad(0,
|
|
18
|
-
new Grad_js_1.Grad(0, 1,
|
|
19
|
-
new Grad_js_1.Grad(0, -1, -1),
|
|
7
|
+
this._grad4 = [
|
|
8
|
+
new Grad_js_1.Grad(0, 1, 1, 1),
|
|
9
|
+
new Grad_js_1.Grad(0, 1, 1, -1),
|
|
10
|
+
new Grad_js_1.Grad(0, 1, -1, 1),
|
|
11
|
+
new Grad_js_1.Grad(0, 1, -1, -1),
|
|
12
|
+
new Grad_js_1.Grad(0, -1, 1, 1),
|
|
13
|
+
new Grad_js_1.Grad(0, -1, 1, -1),
|
|
14
|
+
new Grad_js_1.Grad(0, -1, -1, 1),
|
|
15
|
+
new Grad_js_1.Grad(0, -1, -1, -1),
|
|
16
|
+
new Grad_js_1.Grad(1, 0, 1, 1),
|
|
17
|
+
new Grad_js_1.Grad(1, 0, 1, -1),
|
|
18
|
+
new Grad_js_1.Grad(1, 0, -1, 1),
|
|
19
|
+
new Grad_js_1.Grad(1, 0, -1, -1),
|
|
20
|
+
new Grad_js_1.Grad(-1, 0, 1, 1),
|
|
21
|
+
new Grad_js_1.Grad(-1, 0, 1, -1),
|
|
22
|
+
new Grad_js_1.Grad(-1, 0, -1, 1),
|
|
23
|
+
new Grad_js_1.Grad(-1, 0, -1, -1),
|
|
24
|
+
new Grad_js_1.Grad(1, 1, 0, 1),
|
|
25
|
+
new Grad_js_1.Grad(1, 1, 0, -1),
|
|
26
|
+
new Grad_js_1.Grad(1, -1, 0, 1),
|
|
27
|
+
new Grad_js_1.Grad(1, -1, 0, -1),
|
|
28
|
+
new Grad_js_1.Grad(-1, 1, 0, 1),
|
|
29
|
+
new Grad_js_1.Grad(-1, 1, 0, -1),
|
|
30
|
+
new Grad_js_1.Grad(-1, -1, 0, 1),
|
|
31
|
+
new Grad_js_1.Grad(-1, -1, 0, -1),
|
|
32
|
+
new Grad_js_1.Grad(1, 1, 1, 0),
|
|
33
|
+
new Grad_js_1.Grad(1, 1, -1, 0),
|
|
34
|
+
new Grad_js_1.Grad(1, -1, 1, 0),
|
|
35
|
+
new Grad_js_1.Grad(1, -1, -1, 0),
|
|
36
|
+
new Grad_js_1.Grad(-1, 1, 1, 0),
|
|
37
|
+
new Grad_js_1.Grad(-1, 1, -1, 0),
|
|
38
|
+
new Grad_js_1.Grad(-1, -1, 1, 0),
|
|
39
|
+
new Grad_js_1.Grad(-1, -1, -1, 0),
|
|
20
40
|
];
|
|
21
41
|
this._p = [
|
|
22
42
|
151,
|
|
@@ -282,12 +302,11 @@ class PerlinNoise {
|
|
|
282
302
|
noise2d(x, y) {
|
|
283
303
|
const { _gradP, _perm } = this;
|
|
284
304
|
let X = Math.floor(x), Y = Math.floor(y);
|
|
285
|
-
x
|
|
286
|
-
y
|
|
287
|
-
X
|
|
288
|
-
Y
|
|
289
|
-
const n00 = _gradP[X + _perm[Y]].dot2(x, y), n01 = _gradP[X + _perm[Y + 1]].dot2(x, y - 1), n10 = _gradP[X + 1 + _perm[Y]].dot2(x - 1, y), n11 = _gradP[X + 1 + _perm[Y + 1]].dot2(x - 1, y - 1);
|
|
290
|
-
const u = this._fade(x);
|
|
305
|
+
x -= X;
|
|
306
|
+
y -= Y;
|
|
307
|
+
X &= 255;
|
|
308
|
+
Y &= 255;
|
|
309
|
+
const n00 = _gradP[X + _perm[Y]].dot2(x, y), n01 = _gradP[X + _perm[Y + 1]].dot2(x, y - 1), n10 = _gradP[X + 1 + _perm[Y]].dot2(x - 1, y), n11 = _gradP[X + 1 + _perm[Y + 1]].dot2(x - 1, y - 1), u = this._fade(x);
|
|
291
310
|
return this._lerp(this._lerp(n00, n10, u), this._lerp(n01, n11, u), this._fade(y));
|
|
292
311
|
}
|
|
293
312
|
noise3d(x, y, z) {
|
|
@@ -302,8 +321,22 @@ class PerlinNoise {
|
|
|
302
321
|
const n000 = gradP[X + perm[Y + perm[Z]]].dot3(x, y, z), n001 = gradP[X + perm[Y + perm[Z + 1]]].dot3(x, y, z - 1), n010 = gradP[X + perm[Y + 1 + perm[Z]]].dot3(x, y - 1, z), n011 = gradP[X + perm[Y + 1 + perm[Z + 1]]].dot3(x, y - 1, z - 1), n100 = gradP[X + 1 + perm[Y + perm[Z]]].dot3(x - 1, y, z), n101 = gradP[X + 1 + perm[Y + perm[Z + 1]]].dot3(x - 1, y, z - 1), n110 = gradP[X + 1 + perm[Y + 1 + perm[Z]]].dot3(x - 1, y - 1, z), n111 = gradP[X + 1 + perm[Y + 1 + perm[Z + 1]]].dot3(x - 1, y - 1, z - 1), u = this._fade(x), v = this._fade(y), w = this._fade(z);
|
|
303
322
|
return this._lerp(this._lerp(this._lerp(n000, n100, u), this._lerp(n001, n101, u), w), this._lerp(this._lerp(n010, n110, u), this._lerp(n011, n111, u), w), v);
|
|
304
323
|
}
|
|
324
|
+
noise4d(x, y, z, w) {
|
|
325
|
+
const { _gradP: gradP, _perm: perm } = this;
|
|
326
|
+
let X = Math.floor(x), Y = Math.floor(y), Z = Math.floor(z), W = Math.floor(w);
|
|
327
|
+
x -= X;
|
|
328
|
+
y -= Y;
|
|
329
|
+
z -= Z;
|
|
330
|
+
w -= W;
|
|
331
|
+
X &= 255;
|
|
332
|
+
Y &= 255;
|
|
333
|
+
Z &= 255;
|
|
334
|
+
W &= 255;
|
|
335
|
+
const u = this._fade(x), v = this._fade(y), s = this._fade(z), t = this._fade(w), gi = (i, j, k, l) => gradP[X + i + perm[Y + j + perm[Z + k + perm[W + l]]]], n0000 = gi(0, 0, 0, 0).dot4(x, y, z, w), n0001 = gi(0, 0, 0, 1).dot4(x, y, z, w - 1), n0010 = gi(0, 0, 1, 0).dot4(x, y, z - 1, w), n0011 = gi(0, 0, 1, 1).dot4(x, y, z - 1, w - 1), n0100 = gi(0, 1, 0, 0).dot4(x, y - 1, z, w), n0101 = gi(0, 1, 0, 1).dot4(x, y - 1, z, w - 1), n0110 = gi(0, 1, 1, 0).dot4(x, y - 1, z - 1, w), n0111 = gi(0, 1, 1, 1).dot4(x, y - 1, z - 1, w - 1), n1000 = gi(1, 0, 0, 0).dot4(x - 1, y, z, w), n1001 = gi(1, 0, 0, 1).dot4(x - 1, y, z, w - 1), n1010 = gi(1, 0, 1, 0).dot4(x - 1, y, z - 1, w), n1011 = gi(1, 0, 1, 1).dot4(x - 1, y, z - 1, w - 1), n1100 = gi(1, 1, 0, 0).dot4(x - 1, y - 1, z, w), n1101 = gi(1, 1, 0, 1).dot4(x - 1, y - 1, z, w - 1), n1110 = gi(1, 1, 1, 0).dot4(x - 1, y - 1, z - 1, w), n1111 = gi(1, 1, 1, 1).dot4(x - 1, y - 1, z - 1, w - 1), x00 = this._lerp(n0000, n1000, u), x01 = this._lerp(n0001, n1001, u), x10 = this._lerp(n0010, n1010, u), x11 = this._lerp(n0011, n1011, u), y00 = this._lerp(x00, x10, s), y01 = this._lerp(x01, x11, s), x20 = this._lerp(n0100, n1100, u), x21 = this._lerp(n0101, n1101, u), x30 = this._lerp(n0110, n1110, u), x31 = this._lerp(n0111, n1111, u), y10 = this._lerp(x20, x30, s), y11 = this._lerp(x21, x31, s), z0 = this._lerp(y00, y10, v), z1 = this._lerp(y01, y11, v);
|
|
336
|
+
return this._lerp(z0, z1, t);
|
|
337
|
+
}
|
|
305
338
|
seed(inputSeed) {
|
|
306
|
-
const {
|
|
339
|
+
const { _grad4: grad4, _gradP: gradP, _perm: perm, _p: p } = this;
|
|
307
340
|
let seed = inputSeed;
|
|
308
341
|
if (seed > 0 && seed < 1) {
|
|
309
342
|
seed *= 65536;
|
|
@@ -312,10 +345,11 @@ class PerlinNoise {
|
|
|
312
345
|
if (seed < 256) {
|
|
313
346
|
seed |= seed << 8;
|
|
314
347
|
}
|
|
348
|
+
const grad4Length = grad4.length;
|
|
315
349
|
for (let i = 0; i < 256; i++) {
|
|
316
350
|
const v = i & 1 ? p[i] ^ (seed & 255) : p[i] ^ ((seed >> 8) & 255);
|
|
317
351
|
perm[i] = perm[i + 256] = v;
|
|
318
|
-
gradP[i] = gradP[i + 256] =
|
|
352
|
+
gradP[i] = gradP[i + 256] = grad4[v % grad4Length];
|
|
319
353
|
}
|
|
320
354
|
}
|
|
321
355
|
_fade(t) {
|
package/esm/Grad.js
CHANGED
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
export class Grad {
|
|
2
|
-
constructor(x, y, z) {
|
|
2
|
+
constructor(x, y, z, w) {
|
|
3
3
|
this.x = x;
|
|
4
4
|
this.y = y;
|
|
5
5
|
this.z = z;
|
|
6
|
+
this.w = w;
|
|
6
7
|
}
|
|
7
8
|
dot2(x, y) {
|
|
8
9
|
return this.x * x + this.y * y;
|
|
@@ -10,4 +11,7 @@ export class Grad {
|
|
|
10
11
|
dot3(x, y, z) {
|
|
11
12
|
return this.dot2(x, y) + this.z * z;
|
|
12
13
|
}
|
|
14
|
+
dot4(x, y, z, w) {
|
|
15
|
+
return this.dot3(x, y, z) + this.w * w;
|
|
16
|
+
}
|
|
13
17
|
}
|
package/esm/PerlinNoise.js
CHANGED
|
@@ -1,19 +1,39 @@
|
|
|
1
1
|
import { Grad } from "./Grad.js";
|
|
2
2
|
export class PerlinNoise {
|
|
3
3
|
constructor() {
|
|
4
|
-
this.
|
|
5
|
-
new Grad(1, 1,
|
|
6
|
-
new Grad(
|
|
7
|
-
new Grad(1, -1,
|
|
8
|
-
new Grad(
|
|
9
|
-
new Grad(1,
|
|
10
|
-
new Grad(-1,
|
|
11
|
-
new Grad(
|
|
12
|
-
new Grad(-1,
|
|
13
|
-
new Grad(0, 1, 1),
|
|
14
|
-
new Grad(0,
|
|
15
|
-
new Grad(0, 1,
|
|
16
|
-
new Grad(0, -1, -1),
|
|
4
|
+
this._grad4 = [
|
|
5
|
+
new Grad(0, 1, 1, 1),
|
|
6
|
+
new Grad(0, 1, 1, -1),
|
|
7
|
+
new Grad(0, 1, -1, 1),
|
|
8
|
+
new Grad(0, 1, -1, -1),
|
|
9
|
+
new Grad(0, -1, 1, 1),
|
|
10
|
+
new Grad(0, -1, 1, -1),
|
|
11
|
+
new Grad(0, -1, -1, 1),
|
|
12
|
+
new Grad(0, -1, -1, -1),
|
|
13
|
+
new Grad(1, 0, 1, 1),
|
|
14
|
+
new Grad(1, 0, 1, -1),
|
|
15
|
+
new Grad(1, 0, -1, 1),
|
|
16
|
+
new Grad(1, 0, -1, -1),
|
|
17
|
+
new Grad(-1, 0, 1, 1),
|
|
18
|
+
new Grad(-1, 0, 1, -1),
|
|
19
|
+
new Grad(-1, 0, -1, 1),
|
|
20
|
+
new Grad(-1, 0, -1, -1),
|
|
21
|
+
new Grad(1, 1, 0, 1),
|
|
22
|
+
new Grad(1, 1, 0, -1),
|
|
23
|
+
new Grad(1, -1, 0, 1),
|
|
24
|
+
new Grad(1, -1, 0, -1),
|
|
25
|
+
new Grad(-1, 1, 0, 1),
|
|
26
|
+
new Grad(-1, 1, 0, -1),
|
|
27
|
+
new Grad(-1, -1, 0, 1),
|
|
28
|
+
new Grad(-1, -1, 0, -1),
|
|
29
|
+
new Grad(1, 1, 1, 0),
|
|
30
|
+
new Grad(1, 1, -1, 0),
|
|
31
|
+
new Grad(1, -1, 1, 0),
|
|
32
|
+
new Grad(1, -1, -1, 0),
|
|
33
|
+
new Grad(-1, 1, 1, 0),
|
|
34
|
+
new Grad(-1, 1, -1, 0),
|
|
35
|
+
new Grad(-1, -1, 1, 0),
|
|
36
|
+
new Grad(-1, -1, -1, 0),
|
|
17
37
|
];
|
|
18
38
|
this._p = [
|
|
19
39
|
151,
|
|
@@ -279,12 +299,11 @@ export class PerlinNoise {
|
|
|
279
299
|
noise2d(x, y) {
|
|
280
300
|
const { _gradP, _perm } = this;
|
|
281
301
|
let X = Math.floor(x), Y = Math.floor(y);
|
|
282
|
-
x
|
|
283
|
-
y
|
|
284
|
-
X
|
|
285
|
-
Y
|
|
286
|
-
const n00 = _gradP[X + _perm[Y]].dot2(x, y), n01 = _gradP[X + _perm[Y + 1]].dot2(x, y - 1), n10 = _gradP[X + 1 + _perm[Y]].dot2(x - 1, y), n11 = _gradP[X + 1 + _perm[Y + 1]].dot2(x - 1, y - 1);
|
|
287
|
-
const u = this._fade(x);
|
|
302
|
+
x -= X;
|
|
303
|
+
y -= Y;
|
|
304
|
+
X &= 255;
|
|
305
|
+
Y &= 255;
|
|
306
|
+
const n00 = _gradP[X + _perm[Y]].dot2(x, y), n01 = _gradP[X + _perm[Y + 1]].dot2(x, y - 1), n10 = _gradP[X + 1 + _perm[Y]].dot2(x - 1, y), n11 = _gradP[X + 1 + _perm[Y + 1]].dot2(x - 1, y - 1), u = this._fade(x);
|
|
288
307
|
return this._lerp(this._lerp(n00, n10, u), this._lerp(n01, n11, u), this._fade(y));
|
|
289
308
|
}
|
|
290
309
|
noise3d(x, y, z) {
|
|
@@ -299,8 +318,22 @@ export class PerlinNoise {
|
|
|
299
318
|
const n000 = gradP[X + perm[Y + perm[Z]]].dot3(x, y, z), n001 = gradP[X + perm[Y + perm[Z + 1]]].dot3(x, y, z - 1), n010 = gradP[X + perm[Y + 1 + perm[Z]]].dot3(x, y - 1, z), n011 = gradP[X + perm[Y + 1 + perm[Z + 1]]].dot3(x, y - 1, z - 1), n100 = gradP[X + 1 + perm[Y + perm[Z]]].dot3(x - 1, y, z), n101 = gradP[X + 1 + perm[Y + perm[Z + 1]]].dot3(x - 1, y, z - 1), n110 = gradP[X + 1 + perm[Y + 1 + perm[Z]]].dot3(x - 1, y - 1, z), n111 = gradP[X + 1 + perm[Y + 1 + perm[Z + 1]]].dot3(x - 1, y - 1, z - 1), u = this._fade(x), v = this._fade(y), w = this._fade(z);
|
|
300
319
|
return this._lerp(this._lerp(this._lerp(n000, n100, u), this._lerp(n001, n101, u), w), this._lerp(this._lerp(n010, n110, u), this._lerp(n011, n111, u), w), v);
|
|
301
320
|
}
|
|
321
|
+
noise4d(x, y, z, w) {
|
|
322
|
+
const { _gradP: gradP, _perm: perm } = this;
|
|
323
|
+
let X = Math.floor(x), Y = Math.floor(y), Z = Math.floor(z), W = Math.floor(w);
|
|
324
|
+
x -= X;
|
|
325
|
+
y -= Y;
|
|
326
|
+
z -= Z;
|
|
327
|
+
w -= W;
|
|
328
|
+
X &= 255;
|
|
329
|
+
Y &= 255;
|
|
330
|
+
Z &= 255;
|
|
331
|
+
W &= 255;
|
|
332
|
+
const u = this._fade(x), v = this._fade(y), s = this._fade(z), t = this._fade(w), gi = (i, j, k, l) => gradP[X + i + perm[Y + j + perm[Z + k + perm[W + l]]]], n0000 = gi(0, 0, 0, 0).dot4(x, y, z, w), n0001 = gi(0, 0, 0, 1).dot4(x, y, z, w - 1), n0010 = gi(0, 0, 1, 0).dot4(x, y, z - 1, w), n0011 = gi(0, 0, 1, 1).dot4(x, y, z - 1, w - 1), n0100 = gi(0, 1, 0, 0).dot4(x, y - 1, z, w), n0101 = gi(0, 1, 0, 1).dot4(x, y - 1, z, w - 1), n0110 = gi(0, 1, 1, 0).dot4(x, y - 1, z - 1, w), n0111 = gi(0, 1, 1, 1).dot4(x, y - 1, z - 1, w - 1), n1000 = gi(1, 0, 0, 0).dot4(x - 1, y, z, w), n1001 = gi(1, 0, 0, 1).dot4(x - 1, y, z, w - 1), n1010 = gi(1, 0, 1, 0).dot4(x - 1, y, z - 1, w), n1011 = gi(1, 0, 1, 1).dot4(x - 1, y, z - 1, w - 1), n1100 = gi(1, 1, 0, 0).dot4(x - 1, y - 1, z, w), n1101 = gi(1, 1, 0, 1).dot4(x - 1, y - 1, z, w - 1), n1110 = gi(1, 1, 1, 0).dot4(x - 1, y - 1, z - 1, w), n1111 = gi(1, 1, 1, 1).dot4(x - 1, y - 1, z - 1, w - 1), x00 = this._lerp(n0000, n1000, u), x01 = this._lerp(n0001, n1001, u), x10 = this._lerp(n0010, n1010, u), x11 = this._lerp(n0011, n1011, u), y00 = this._lerp(x00, x10, s), y01 = this._lerp(x01, x11, s), x20 = this._lerp(n0100, n1100, u), x21 = this._lerp(n0101, n1101, u), x30 = this._lerp(n0110, n1110, u), x31 = this._lerp(n0111, n1111, u), y10 = this._lerp(x20, x30, s), y11 = this._lerp(x21, x31, s), z0 = this._lerp(y00, y10, v), z1 = this._lerp(y01, y11, v);
|
|
333
|
+
return this._lerp(z0, z1, t);
|
|
334
|
+
}
|
|
302
335
|
seed(inputSeed) {
|
|
303
|
-
const {
|
|
336
|
+
const { _grad4: grad4, _gradP: gradP, _perm: perm, _p: p } = this;
|
|
304
337
|
let seed = inputSeed;
|
|
305
338
|
if (seed > 0 && seed < 1) {
|
|
306
339
|
seed *= 65536;
|
|
@@ -309,10 +342,11 @@ export class PerlinNoise {
|
|
|
309
342
|
if (seed < 256) {
|
|
310
343
|
seed |= seed << 8;
|
|
311
344
|
}
|
|
345
|
+
const grad4Length = grad4.length;
|
|
312
346
|
for (let i = 0; i < 256; i++) {
|
|
313
347
|
const v = i & 1 ? p[i] ^ (seed & 255) : p[i] ^ ((seed >> 8) & 255);
|
|
314
348
|
perm[i] = perm[i + 256] = v;
|
|
315
|
-
gradP[i] = gradP[i + 256] =
|
|
349
|
+
gradP[i] = gradP[i + 256] = grad4[v % grad4Length];
|
|
316
350
|
}
|
|
317
351
|
}
|
|
318
352
|
_fade(t) {
|
package/package.json
CHANGED
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/perlin-noise [
|
|
6
|
+
<title>@tsparticles/perlin-noise [3 Aug 2025 at 23:25]</title>
|
|
7
7
|
<link rel="shortcut icon" href="" type="image/x-icon" />
|
|
8
8
|
|
|
9
9
|
<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.
|
|
7
|
+
* v3.9.1
|
|
8
8
|
*/
|
|
9
9
|
/*
|
|
10
10
|
* ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development").
|
|
@@ -34,7 +34,7 @@ return /******/ (() => { // webpackBootstrap
|
|
|
34
34
|
\******************************/
|
|
35
35
|
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
36
36
|
|
|
37
|
-
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Grad: () => (/* binding */ Grad)\n/* harmony export */ });\nclass Grad {\n constructor(x, y, z) {\n this.x = x;\n this.y = y;\n this.z = z;\n }\n dot2(x, y) {\n return this.x * x + this.y * y;\n }\n dot3(x, y, z) {\n return this.dot2(x, y) + this.z * z;\n }\n}\n\n//# sourceURL=webpack://@tsparticles/perlin-noise/./dist/browser/Grad.js
|
|
37
|
+
eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Grad: () => (/* binding */ Grad)\n/* harmony export */ });\nclass Grad {\n constructor(x, y, z, w) {\n this.x = x;\n this.y = y;\n this.z = z;\n this.w = w;\n }\n dot2(x, y) {\n return this.x * x + this.y * y;\n }\n dot3(x, y, z) {\n return this.dot2(x, y) + this.z * z;\n }\n dot4(x, y, z, w) {\n return this.dot3(x, y, z) + this.w * w;\n }\n}\n\n//# sourceURL=webpack://@tsparticles/perlin-noise/./dist/browser/Grad.js?\n}");
|
|
38
38
|
|
|
39
39
|
/***/ }),
|
|
40
40
|
|
|
@@ -44,7 +44,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
|
|
|
44
44
|
\*************************************/
|
|
45
45
|
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
46
46
|
|
|
47
|
-
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ PerlinNoise: () => (/* binding */ PerlinNoise)\n/* harmony export */ });\n/* harmony import */ var _Grad_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./Grad.js */ \"./dist/browser/Grad.js\");\n\nclass PerlinNoise {\n constructor() {\n this.
|
|
47
|
+
eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ PerlinNoise: () => (/* binding */ PerlinNoise)\n/* harmony export */ });\n/* harmony import */ var _Grad_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./Grad.js */ \"./dist/browser/Grad.js\");\n\nclass PerlinNoise {\n constructor() {\n this._grad4 = [new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(0, 1, 1, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(0, 1, 1, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(0, 1, -1, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(0, 1, -1, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(0, -1, 1, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(0, -1, 1, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(0, -1, -1, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(0, -1, -1, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, 0, 1, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, 0, 1, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, 0, -1, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, 0, -1, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, 0, 1, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, 0, 1, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, 0, -1, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, 0, -1, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, 1, 0, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, 1, 0, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, -1, 0, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, -1, 0, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, 1, 0, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, 1, 0, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, -1, 0, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, -1, 0, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, 1, 1, 0), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, 1, -1, 0), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, -1, 1, 0), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, -1, -1, 0), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, 1, 1, 0), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, 1, -1, 0), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, -1, 1, 0), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, -1, -1, 0)];\n this._p = [151, 160, 137, 91, 90, 15, 131, 13, 201, 95, 96, 53, 194, 233, 7, 225, 140, 36, 103, 30, 69, 142, 8, 99, 37, 240, 21, 10, 23, 190, 6, 148, 247, 120, 234, 75, 0, 26, 197, 62, 94, 252, 219, 203, 117, 35, 11, 32, 57, 177, 33, 88, 237, 149, 56, 87, 174, 20, 125, 136, 171, 168, 68, 175, 74, 165, 71, 134, 139, 48, 27, 166, 77, 146, 158, 231, 83, 111, 229, 122, 60, 211, 133, 230, 220, 105, 92, 41, 55, 46, 245, 40, 244, 102, 143, 54, 65, 25, 63, 161, 1, 216, 80, 73, 209, 76, 132, 187, 208, 89, 18, 169, 200, 196, 135, 130, 116, 188, 159, 86, 164, 100, 109, 198, 173, 186, 3, 64, 52, 217, 226, 250, 124, 123, 5, 202, 38, 147, 118, 126, 255, 82, 85, 212, 207, 206, 59, 227, 47, 16, 58, 17, 182, 189, 28, 42, 223, 183, 170, 213, 119, 248, 152, 2, 44, 154, 163, 70, 221, 153, 101, 155, 167, 43, 172, 9, 129, 22, 39, 253, 19, 98, 108, 110, 79, 113, 224, 232, 178, 185, 112, 104, 218, 246, 97, 228, 251, 34, 242, 193, 238, 210, 144, 12, 191, 179, 162, 241, 81, 51, 145, 235, 249, 14, 239, 107, 49, 192, 214, 31, 181, 199, 106, 157, 184, 84, 204, 176, 115, 121, 50, 45, 127, 4, 150, 254, 138, 236, 205, 93, 222, 114, 67, 29, 24, 72, 243, 141, 128, 195, 78, 66, 215, 61, 156, 180];\n this._gradP = new Array(512);\n this._perm = new Array(512);\n }\n noise2d(x, y) {\n const {\n _gradP,\n _perm\n } = this;\n let X = Math.floor(x),\n Y = Math.floor(y);\n x -= X;\n y -= Y;\n X &= 255;\n Y &= 255;\n const n00 = _gradP[X + _perm[Y]].dot2(x, y),\n n01 = _gradP[X + _perm[Y + 1]].dot2(x, y - 1),\n n10 = _gradP[X + 1 + _perm[Y]].dot2(x - 1, y),\n n11 = _gradP[X + 1 + _perm[Y + 1]].dot2(x - 1, y - 1),\n u = this._fade(x);\n return this._lerp(this._lerp(n00, n10, u), this._lerp(n01, n11, u), this._fade(y));\n }\n noise3d(x, y, z) {\n const {\n _gradP: gradP,\n _perm: perm\n } = this;\n let X = Math.floor(x),\n Y = Math.floor(y),\n Z = Math.floor(z);\n x = x - X;\n y = y - Y;\n z = z - Z;\n X = X & 255;\n Y = Y & 255;\n Z = Z & 255;\n const n000 = gradP[X + perm[Y + perm[Z]]].dot3(x, y, z),\n n001 = gradP[X + perm[Y + perm[Z + 1]]].dot3(x, y, z - 1),\n n010 = gradP[X + perm[Y + 1 + perm[Z]]].dot3(x, y - 1, z),\n n011 = gradP[X + perm[Y + 1 + perm[Z + 1]]].dot3(x, y - 1, z - 1),\n n100 = gradP[X + 1 + perm[Y + perm[Z]]].dot3(x - 1, y, z),\n n101 = gradP[X + 1 + perm[Y + perm[Z + 1]]].dot3(x - 1, y, z - 1),\n n110 = gradP[X + 1 + perm[Y + 1 + perm[Z]]].dot3(x - 1, y - 1, z),\n n111 = gradP[X + 1 + perm[Y + 1 + perm[Z + 1]]].dot3(x - 1, y - 1, z - 1),\n u = this._fade(x),\n v = this._fade(y),\n w = this._fade(z);\n return this._lerp(this._lerp(this._lerp(n000, n100, u), this._lerp(n001, n101, u), w), this._lerp(this._lerp(n010, n110, u), this._lerp(n011, n111, u), w), v);\n }\n noise4d(x, y, z, w) {\n const {\n _gradP: gradP,\n _perm: perm\n } = this;\n let X = Math.floor(x),\n Y = Math.floor(y),\n Z = Math.floor(z),\n W = Math.floor(w);\n x -= X;\n y -= Y;\n z -= Z;\n w -= W;\n X &= 255;\n Y &= 255;\n Z &= 255;\n W &= 255;\n const u = this._fade(x),\n v = this._fade(y),\n s = this._fade(z),\n t = this._fade(w),\n gi = (i, j, k, l) => gradP[X + i + perm[Y + j + perm[Z + k + perm[W + l]]]],\n n0000 = gi(0, 0, 0, 0).dot4(x, y, z, w),\n n0001 = gi(0, 0, 0, 1).dot4(x, y, z, w - 1),\n n0010 = gi(0, 0, 1, 0).dot4(x, y, z - 1, w),\n n0011 = gi(0, 0, 1, 1).dot4(x, y, z - 1, w - 1),\n n0100 = gi(0, 1, 0, 0).dot4(x, y - 1, z, w),\n n0101 = gi(0, 1, 0, 1).dot4(x, y - 1, z, w - 1),\n n0110 = gi(0, 1, 1, 0).dot4(x, y - 1, z - 1, w),\n n0111 = gi(0, 1, 1, 1).dot4(x, y - 1, z - 1, w - 1),\n n1000 = gi(1, 0, 0, 0).dot4(x - 1, y, z, w),\n n1001 = gi(1, 0, 0, 1).dot4(x - 1, y, z, w - 1),\n n1010 = gi(1, 0, 1, 0).dot4(x - 1, y, z - 1, w),\n n1011 = gi(1, 0, 1, 1).dot4(x - 1, y, z - 1, w - 1),\n n1100 = gi(1, 1, 0, 0).dot4(x - 1, y - 1, z, w),\n n1101 = gi(1, 1, 0, 1).dot4(x - 1, y - 1, z, w - 1),\n n1110 = gi(1, 1, 1, 0).dot4(x - 1, y - 1, z - 1, w),\n n1111 = gi(1, 1, 1, 1).dot4(x - 1, y - 1, z - 1, w - 1),\n x00 = this._lerp(n0000, n1000, u),\n x01 = this._lerp(n0001, n1001, u),\n x10 = this._lerp(n0010, n1010, u),\n x11 = this._lerp(n0011, n1011, u),\n y00 = this._lerp(x00, x10, s),\n y01 = this._lerp(x01, x11, s),\n x20 = this._lerp(n0100, n1100, u),\n x21 = this._lerp(n0101, n1101, u),\n x30 = this._lerp(n0110, n1110, u),\n x31 = this._lerp(n0111, n1111, u),\n y10 = this._lerp(x20, x30, s),\n y11 = this._lerp(x21, x31, s),\n z0 = this._lerp(y00, y10, v),\n z1 = this._lerp(y01, y11, v);\n return this._lerp(z0, z1, t);\n }\n seed(inputSeed) {\n const {\n _grad4: grad4,\n _gradP: gradP,\n _perm: perm,\n _p: p\n } = this;\n let seed = inputSeed;\n if (seed > 0 && seed < 1) {\n seed *= 65536;\n }\n seed = Math.floor(seed);\n if (seed < 256) {\n seed |= seed << 8;\n }\n const grad4Length = grad4.length;\n for (let i = 0; i < 256; i++) {\n const v = i & 1 ? p[i] ^ seed & 255 : p[i] ^ seed >> 8 & 255;\n perm[i] = perm[i + 256] = v;\n gradP[i] = gradP[i + 256] = grad4[v % grad4Length];\n }\n }\n _fade(t) {\n return t * t * t * (t * (t * 6 - 15) + 10);\n }\n _lerp(a, b, t) {\n return (1 - t) * a + t * b;\n }\n}\n\n//# sourceURL=webpack://@tsparticles/perlin-noise/./dist/browser/PerlinNoise.js?\n}");
|
|
48
48
|
|
|
49
49
|
/***/ }),
|
|
50
50
|
|
|
@@ -54,7 +54,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
|
|
|
54
54
|
\*******************************/
|
|
55
55
|
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
56
56
|
|
|
57
|
-
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ PerlinNoise: () => (/* reexport safe */ _PerlinNoise_js__WEBPACK_IMPORTED_MODULE_0__.PerlinNoise)\n/* harmony export */ });\n/* harmony import */ var _PerlinNoise_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./PerlinNoise.js */ \"./dist/browser/PerlinNoise.js\");\n\n\n//# sourceURL=webpack://@tsparticles/perlin-noise/./dist/browser/index.js
|
|
57
|
+
eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ PerlinNoise: () => (/* reexport safe */ _PerlinNoise_js__WEBPACK_IMPORTED_MODULE_0__.PerlinNoise)\n/* harmony export */ });\n/* harmony import */ var _PerlinNoise_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./PerlinNoise.js */ \"./dist/browser/PerlinNoise.js\");\n\n\n//# sourceURL=webpack://@tsparticles/perlin-noise/./dist/browser/index.js?\n}");
|
|
58
58
|
|
|
59
59
|
/***/ })
|
|
60
60
|
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/*! For license information please see tsparticles.perlin.noise.min.js.LICENSE.txt */
|
|
2
|
-
!function(e
|
|
2
|
+
!function(t,e){if("object"==typeof exports&&"object"==typeof module)module.exports=e();else if("function"==typeof define&&define.amd)define([],e);else{var o=e();for(var r in o)("object"==typeof exports?exports:t)[r]=o[r]}}(this,(()=>(()=>{var t={d:(e,o)=>{for(var r in o)t.o(o,r)&&!t.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:o[r]})},o:(t,e)=>Object.prototype.hasOwnProperty.call(t,e),r:t=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})}},e={};t.r(e),t.d(e,{PerlinNoise:()=>r});class o{constructor(t,e,o,r){this.x=t,this.y=e,this.z=o,this.w=r}dot2(t,e){return this.x*t+this.y*e}dot3(t,e,o){return this.dot2(t,e)+this.z*o}dot4(t,e,o,r){return this.dot3(t,e,o)+this.w*r}}class r{constructor(){this._grad4=[new o(0,1,1,1),new o(0,1,1,-1),new o(0,1,-1,1),new o(0,1,-1,-1),new o(0,-1,1,1),new o(0,-1,1,-1),new o(0,-1,-1,1),new o(0,-1,-1,-1),new o(1,0,1,1),new o(1,0,1,-1),new o(1,0,-1,1),new o(1,0,-1,-1),new o(-1,0,1,1),new o(-1,0,1,-1),new o(-1,0,-1,1),new o(-1,0,-1,-1),new o(1,1,0,1),new o(1,1,0,-1),new o(1,-1,0,1),new o(1,-1,0,-1),new o(-1,1,0,1),new o(-1,1,0,-1),new o(-1,-1,0,1),new o(-1,-1,0,-1),new o(1,1,1,0),new o(1,1,-1,0),new o(1,-1,1,0),new o(1,-1,-1,0),new o(-1,1,1,0),new o(-1,1,-1,0),new o(-1,-1,1,0),new o(-1,-1,-1,0)],this._p=[151,160,137,91,90,15,131,13,201,95,96,53,194,233,7,225,140,36,103,30,69,142,8,99,37,240,21,10,23,190,6,148,247,120,234,75,0,26,197,62,94,252,219,203,117,35,11,32,57,177,33,88,237,149,56,87,174,20,125,136,171,168,68,175,74,165,71,134,139,48,27,166,77,146,158,231,83,111,229,122,60,211,133,230,220,105,92,41,55,46,245,40,244,102,143,54,65,25,63,161,1,216,80,73,209,76,132,187,208,89,18,169,200,196,135,130,116,188,159,86,164,100,109,198,173,186,3,64,52,217,226,250,124,123,5,202,38,147,118,126,255,82,85,212,207,206,59,227,47,16,58,17,182,189,28,42,223,183,170,213,119,248,152,2,44,154,163,70,221,153,101,155,167,43,172,9,129,22,39,253,19,98,108,110,79,113,224,232,178,185,112,104,218,246,97,228,251,34,242,193,238,210,144,12,191,179,162,241,81,51,145,235,249,14,239,107,49,192,214,31,181,199,106,157,184,84,204,176,115,121,50,45,127,4,150,254,138,236,205,93,222,114,67,29,24,72,243,141,128,195,78,66,215,61,156,180],this._gradP=new Array(512),this._perm=new Array(512)}noise2d(t,e){const{_gradP:o,_perm:r}=this;let s=Math.floor(t),n=Math.floor(e);t-=s,e-=n,s&=255,n&=255;const i=o[s+r[n]].dot2(t,e),d=o[s+r[n+1]].dot2(t,e-1),h=o[s+1+r[n]].dot2(t-1,e),l=o[s+1+r[n+1]].dot2(t-1,e-1),_=this._fade(t);return this._lerp(this._lerp(i,h,_),this._lerp(d,l,_),this._fade(e))}noise3d(t,e,o){const{_gradP:r,_perm:s}=this;let n=Math.floor(t),i=Math.floor(e),d=Math.floor(o);t-=n,e-=i,o-=d,n&=255,i&=255,d&=255;const h=r[n+s[i+s[d]]].dot3(t,e,o),l=r[n+s[i+s[d+1]]].dot3(t,e,o-1),_=r[n+s[i+1+s[d]]].dot3(t,e-1,o),p=r[n+s[i+1+s[d+1]]].dot3(t,e-1,o-1),a=r[n+1+s[i+s[d]]].dot3(t-1,e,o),f=r[n+1+s[i+s[d+1]]].dot3(t-1,e,o-1),w=r[n+1+s[i+1+s[d]]].dot3(t-1,e-1,o),c=r[n+1+s[i+1+s[d+1]]].dot3(t-1,e-1,o-1),u=this._fade(t),y=this._fade(e),g=this._fade(o);return this._lerp(this._lerp(this._lerp(h,a,u),this._lerp(l,f,u),g),this._lerp(this._lerp(_,w,u),this._lerp(p,c,u),g),y)}noise4d(t,e,o,r){const{_gradP:s,_perm:n}=this;let i=Math.floor(t),d=Math.floor(e),h=Math.floor(o),l=Math.floor(r);t-=i,e-=d,o-=h,r-=l,i&=255,d&=255,h&=255,l&=255;const _=this._fade(t),p=this._fade(e),a=this._fade(o),f=this._fade(r),w=(t,e,o,r)=>s[i+t+n[d+e+n[h+o+n[l+r]]]],c=w(0,0,0,0).dot4(t,e,o,r),u=w(0,0,0,1).dot4(t,e,o,r-1),y=w(0,0,1,0).dot4(t,e,o-1,r),g=w(0,0,1,1).dot4(t,e,o-1,r-1),m=w(0,1,0,0).dot4(t,e-1,o,r),M=w(0,1,0,1).dot4(t,e-1,o,r-1),b=w(0,1,1,0).dot4(t,e-1,o-1,r),P=w(0,1,1,1).dot4(t,e-1,o-1,r-1),j=w(1,0,0,0).dot4(t-1,e,o,r),v=w(1,0,0,1).dot4(t-1,e,o,r-1),x=w(1,0,1,0).dot4(t-1,e,o-1,r),O=w(1,0,1,1).dot4(t-1,e,o-1,r-1),S=w(1,1,0,0).dot4(t-1,e-1,o,r),z=w(1,1,0,1).dot4(t-1,e-1,o,r-1),A=w(1,1,1,0).dot4(t-1,e-1,o-1,r),T=w(1,1,1,1).dot4(t-1,e-1,o-1,r-1),N=this._lerp(c,j,_),k=this._lerp(u,v,_),q=this._lerp(y,x,_),B=this._lerp(g,O,_),C=this._lerp(N,q,a),D=this._lerp(k,B,a),E=this._lerp(m,S,_),F=this._lerp(M,z,_),G=this._lerp(b,A,_),H=this._lerp(P,T,_),I=this._lerp(E,G,a),J=this._lerp(F,H,a),K=this._lerp(C,I,p),L=this._lerp(D,J,p);return this._lerp(K,L,f)}seed(t){const{_grad4:e,_gradP:o,_perm:r,_p:s}=this;let n=t;n>0&&n<1&&(n*=65536),n=Math.floor(n),n<256&&(n|=n<<8);const i=e.length;for(let t=0;t<256;t++){const d=1&t?s[t]^255&n:s[t]^n>>8&255;r[t]=r[t+256]=d,o[t]=o[t+256]=e[d%i]}}_fade(t){return t*t*t*(t*(6*t-15)+10)}_lerp(t,e,o){return(1-o)*t+o*e}}return e})()));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
/*! tsParticles Perlin Noise v3.
|
|
1
|
+
/*! tsParticles Perlin Noise v3.9.1 by Matteo Bruni */
|
package/types/Grad.d.ts
CHANGED
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
export declare class Grad {
|
|
2
|
+
readonly w: number;
|
|
2
3
|
readonly x: number;
|
|
3
4
|
readonly y: number;
|
|
4
5
|
readonly z: number;
|
|
5
|
-
constructor(x: number, y: number, z: number);
|
|
6
|
+
constructor(x: number, y: number, z: number, w: number);
|
|
6
7
|
dot2(x: number, y: number): number;
|
|
7
8
|
dot3(x: number, y: number, z: number): number;
|
|
9
|
+
dot4(x: number, y: number, z: number, w: number): number;
|
|
8
10
|
}
|
package/types/PerlinNoise.d.ts
CHANGED
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
export declare class PerlinNoise {
|
|
2
|
-
private readonly
|
|
2
|
+
private readonly _grad4;
|
|
3
3
|
private readonly _gradP;
|
|
4
4
|
private readonly _p;
|
|
5
5
|
private readonly _perm;
|
|
6
6
|
constructor();
|
|
7
7
|
noise2d(x: number, y: number): number;
|
|
8
8
|
noise3d(x: number, y: number, z: number): number;
|
|
9
|
+
noise4d(x: number, y: number, z: number, w: number): number;
|
|
9
10
|
seed(inputSeed: number): void;
|
|
10
11
|
private _fade;
|
|
11
12
|
private _lerp;
|
package/umd/Grad.js
CHANGED
|
@@ -11,10 +11,11 @@
|
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.Grad = void 0;
|
|
13
13
|
class Grad {
|
|
14
|
-
constructor(x, y, z) {
|
|
14
|
+
constructor(x, y, z, w) {
|
|
15
15
|
this.x = x;
|
|
16
16
|
this.y = y;
|
|
17
17
|
this.z = z;
|
|
18
|
+
this.w = w;
|
|
18
19
|
}
|
|
19
20
|
dot2(x, y) {
|
|
20
21
|
return this.x * x + this.y * y;
|
|
@@ -22,6 +23,9 @@
|
|
|
22
23
|
dot3(x, y, z) {
|
|
23
24
|
return this.dot2(x, y) + this.z * z;
|
|
24
25
|
}
|
|
26
|
+
dot4(x, y, z, w) {
|
|
27
|
+
return this.dot3(x, y, z) + this.w * w;
|
|
28
|
+
}
|
|
25
29
|
}
|
|
26
30
|
exports.Grad = Grad;
|
|
27
31
|
});
|
package/umd/PerlinNoise.js
CHANGED
|
@@ -13,19 +13,39 @@
|
|
|
13
13
|
const Grad_js_1 = require("./Grad.js");
|
|
14
14
|
class PerlinNoise {
|
|
15
15
|
constructor() {
|
|
16
|
-
this.
|
|
17
|
-
new Grad_js_1.Grad(1, 1,
|
|
18
|
-
new Grad_js_1.Grad(
|
|
19
|
-
new Grad_js_1.Grad(1, -1,
|
|
20
|
-
new Grad_js_1.Grad(
|
|
21
|
-
new Grad_js_1.Grad(1,
|
|
22
|
-
new Grad_js_1.Grad(-1,
|
|
23
|
-
new Grad_js_1.Grad(
|
|
24
|
-
new Grad_js_1.Grad(-1,
|
|
25
|
-
new Grad_js_1.Grad(0, 1, 1),
|
|
26
|
-
new Grad_js_1.Grad(0,
|
|
27
|
-
new Grad_js_1.Grad(0, 1,
|
|
28
|
-
new Grad_js_1.Grad(0, -1, -1),
|
|
16
|
+
this._grad4 = [
|
|
17
|
+
new Grad_js_1.Grad(0, 1, 1, 1),
|
|
18
|
+
new Grad_js_1.Grad(0, 1, 1, -1),
|
|
19
|
+
new Grad_js_1.Grad(0, 1, -1, 1),
|
|
20
|
+
new Grad_js_1.Grad(0, 1, -1, -1),
|
|
21
|
+
new Grad_js_1.Grad(0, -1, 1, 1),
|
|
22
|
+
new Grad_js_1.Grad(0, -1, 1, -1),
|
|
23
|
+
new Grad_js_1.Grad(0, -1, -1, 1),
|
|
24
|
+
new Grad_js_1.Grad(0, -1, -1, -1),
|
|
25
|
+
new Grad_js_1.Grad(1, 0, 1, 1),
|
|
26
|
+
new Grad_js_1.Grad(1, 0, 1, -1),
|
|
27
|
+
new Grad_js_1.Grad(1, 0, -1, 1),
|
|
28
|
+
new Grad_js_1.Grad(1, 0, -1, -1),
|
|
29
|
+
new Grad_js_1.Grad(-1, 0, 1, 1),
|
|
30
|
+
new Grad_js_1.Grad(-1, 0, 1, -1),
|
|
31
|
+
new Grad_js_1.Grad(-1, 0, -1, 1),
|
|
32
|
+
new Grad_js_1.Grad(-1, 0, -1, -1),
|
|
33
|
+
new Grad_js_1.Grad(1, 1, 0, 1),
|
|
34
|
+
new Grad_js_1.Grad(1, 1, 0, -1),
|
|
35
|
+
new Grad_js_1.Grad(1, -1, 0, 1),
|
|
36
|
+
new Grad_js_1.Grad(1, -1, 0, -1),
|
|
37
|
+
new Grad_js_1.Grad(-1, 1, 0, 1),
|
|
38
|
+
new Grad_js_1.Grad(-1, 1, 0, -1),
|
|
39
|
+
new Grad_js_1.Grad(-1, -1, 0, 1),
|
|
40
|
+
new Grad_js_1.Grad(-1, -1, 0, -1),
|
|
41
|
+
new Grad_js_1.Grad(1, 1, 1, 0),
|
|
42
|
+
new Grad_js_1.Grad(1, 1, -1, 0),
|
|
43
|
+
new Grad_js_1.Grad(1, -1, 1, 0),
|
|
44
|
+
new Grad_js_1.Grad(1, -1, -1, 0),
|
|
45
|
+
new Grad_js_1.Grad(-1, 1, 1, 0),
|
|
46
|
+
new Grad_js_1.Grad(-1, 1, -1, 0),
|
|
47
|
+
new Grad_js_1.Grad(-1, -1, 1, 0),
|
|
48
|
+
new Grad_js_1.Grad(-1, -1, -1, 0),
|
|
29
49
|
];
|
|
30
50
|
this._p = [
|
|
31
51
|
151,
|
|
@@ -291,12 +311,11 @@
|
|
|
291
311
|
noise2d(x, y) {
|
|
292
312
|
const { _gradP, _perm } = this;
|
|
293
313
|
let X = Math.floor(x), Y = Math.floor(y);
|
|
294
|
-
x
|
|
295
|
-
y
|
|
296
|
-
X
|
|
297
|
-
Y
|
|
298
|
-
const n00 = _gradP[X + _perm[Y]].dot2(x, y), n01 = _gradP[X + _perm[Y + 1]].dot2(x, y - 1), n10 = _gradP[X + 1 + _perm[Y]].dot2(x - 1, y), n11 = _gradP[X + 1 + _perm[Y + 1]].dot2(x - 1, y - 1);
|
|
299
|
-
const u = this._fade(x);
|
|
314
|
+
x -= X;
|
|
315
|
+
y -= Y;
|
|
316
|
+
X &= 255;
|
|
317
|
+
Y &= 255;
|
|
318
|
+
const n00 = _gradP[X + _perm[Y]].dot2(x, y), n01 = _gradP[X + _perm[Y + 1]].dot2(x, y - 1), n10 = _gradP[X + 1 + _perm[Y]].dot2(x - 1, y), n11 = _gradP[X + 1 + _perm[Y + 1]].dot2(x - 1, y - 1), u = this._fade(x);
|
|
300
319
|
return this._lerp(this._lerp(n00, n10, u), this._lerp(n01, n11, u), this._fade(y));
|
|
301
320
|
}
|
|
302
321
|
noise3d(x, y, z) {
|
|
@@ -311,8 +330,22 @@
|
|
|
311
330
|
const n000 = gradP[X + perm[Y + perm[Z]]].dot3(x, y, z), n001 = gradP[X + perm[Y + perm[Z + 1]]].dot3(x, y, z - 1), n010 = gradP[X + perm[Y + 1 + perm[Z]]].dot3(x, y - 1, z), n011 = gradP[X + perm[Y + 1 + perm[Z + 1]]].dot3(x, y - 1, z - 1), n100 = gradP[X + 1 + perm[Y + perm[Z]]].dot3(x - 1, y, z), n101 = gradP[X + 1 + perm[Y + perm[Z + 1]]].dot3(x - 1, y, z - 1), n110 = gradP[X + 1 + perm[Y + 1 + perm[Z]]].dot3(x - 1, y - 1, z), n111 = gradP[X + 1 + perm[Y + 1 + perm[Z + 1]]].dot3(x - 1, y - 1, z - 1), u = this._fade(x), v = this._fade(y), w = this._fade(z);
|
|
312
331
|
return this._lerp(this._lerp(this._lerp(n000, n100, u), this._lerp(n001, n101, u), w), this._lerp(this._lerp(n010, n110, u), this._lerp(n011, n111, u), w), v);
|
|
313
332
|
}
|
|
333
|
+
noise4d(x, y, z, w) {
|
|
334
|
+
const { _gradP: gradP, _perm: perm } = this;
|
|
335
|
+
let X = Math.floor(x), Y = Math.floor(y), Z = Math.floor(z), W = Math.floor(w);
|
|
336
|
+
x -= X;
|
|
337
|
+
y -= Y;
|
|
338
|
+
z -= Z;
|
|
339
|
+
w -= W;
|
|
340
|
+
X &= 255;
|
|
341
|
+
Y &= 255;
|
|
342
|
+
Z &= 255;
|
|
343
|
+
W &= 255;
|
|
344
|
+
const u = this._fade(x), v = this._fade(y), s = this._fade(z), t = this._fade(w), gi = (i, j, k, l) => gradP[X + i + perm[Y + j + perm[Z + k + perm[W + l]]]], n0000 = gi(0, 0, 0, 0).dot4(x, y, z, w), n0001 = gi(0, 0, 0, 1).dot4(x, y, z, w - 1), n0010 = gi(0, 0, 1, 0).dot4(x, y, z - 1, w), n0011 = gi(0, 0, 1, 1).dot4(x, y, z - 1, w - 1), n0100 = gi(0, 1, 0, 0).dot4(x, y - 1, z, w), n0101 = gi(0, 1, 0, 1).dot4(x, y - 1, z, w - 1), n0110 = gi(0, 1, 1, 0).dot4(x, y - 1, z - 1, w), n0111 = gi(0, 1, 1, 1).dot4(x, y - 1, z - 1, w - 1), n1000 = gi(1, 0, 0, 0).dot4(x - 1, y, z, w), n1001 = gi(1, 0, 0, 1).dot4(x - 1, y, z, w - 1), n1010 = gi(1, 0, 1, 0).dot4(x - 1, y, z - 1, w), n1011 = gi(1, 0, 1, 1).dot4(x - 1, y, z - 1, w - 1), n1100 = gi(1, 1, 0, 0).dot4(x - 1, y - 1, z, w), n1101 = gi(1, 1, 0, 1).dot4(x - 1, y - 1, z, w - 1), n1110 = gi(1, 1, 1, 0).dot4(x - 1, y - 1, z - 1, w), n1111 = gi(1, 1, 1, 1).dot4(x - 1, y - 1, z - 1, w - 1), x00 = this._lerp(n0000, n1000, u), x01 = this._lerp(n0001, n1001, u), x10 = this._lerp(n0010, n1010, u), x11 = this._lerp(n0011, n1011, u), y00 = this._lerp(x00, x10, s), y01 = this._lerp(x01, x11, s), x20 = this._lerp(n0100, n1100, u), x21 = this._lerp(n0101, n1101, u), x30 = this._lerp(n0110, n1110, u), x31 = this._lerp(n0111, n1111, u), y10 = this._lerp(x20, x30, s), y11 = this._lerp(x21, x31, s), z0 = this._lerp(y00, y10, v), z1 = this._lerp(y01, y11, v);
|
|
345
|
+
return this._lerp(z0, z1, t);
|
|
346
|
+
}
|
|
314
347
|
seed(inputSeed) {
|
|
315
|
-
const {
|
|
348
|
+
const { _grad4: grad4, _gradP: gradP, _perm: perm, _p: p } = this;
|
|
316
349
|
let seed = inputSeed;
|
|
317
350
|
if (seed > 0 && seed < 1) {
|
|
318
351
|
seed *= 65536;
|
|
@@ -321,10 +354,11 @@
|
|
|
321
354
|
if (seed < 256) {
|
|
322
355
|
seed |= seed << 8;
|
|
323
356
|
}
|
|
357
|
+
const grad4Length = grad4.length;
|
|
324
358
|
for (let i = 0; i < 256; i++) {
|
|
325
359
|
const v = i & 1 ? p[i] ^ (seed & 255) : p[i] ^ ((seed >> 8) & 255);
|
|
326
360
|
perm[i] = perm[i + 256] = v;
|
|
327
|
-
gradP[i] = gradP[i + 256] =
|
|
361
|
+
gradP[i] = gradP[i + 256] = grad4[v % grad4Length];
|
|
328
362
|
}
|
|
329
363
|
}
|
|
330
364
|
_fade(t) {
|