@tsparticles/path-svg 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/SVGPathGenerator.js +19 -18
- package/cjs/SVGPathGenerator.js +18 -17
- package/esm/SVGPathGenerator.js +19 -18
- package/package.json +2 -2
- package/report.html +2 -2
- package/tsparticles.path.svg.js +28 -20
- package/tsparticles.path.svg.min.js +1 -1
- package/tsparticles.path.svg.min.js.LICENSE.txt +1 -1
- package/types/SVGPathGenerator.d.ts +0 -5
- package/umd/SVGPathGenerator.js +18 -17
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import { Vector, getPosition, getRandom, randomInRange, } from "@tsparticles/engine";
|
|
1
|
+
import { Vector, getPosition, getRandom, halfRandom, randomInRange, } from "@tsparticles/engine";
|
|
2
|
+
const defaultSpeed = 1, half = 0.5, minStep = 0, minIndex = 0, minWidth = 0, minScale = 1;
|
|
2
3
|
export class SVGPathGenerator {
|
|
3
4
|
constructor() {
|
|
4
5
|
this._paths = [];
|
|
@@ -11,21 +12,21 @@ export class SVGPathGenerator {
|
|
|
11
12
|
generate(particle, delta) {
|
|
12
13
|
const container = particle.container, pxRatio = container.retina.pixelRatio;
|
|
13
14
|
if (particle.svgDirection === undefined) {
|
|
14
|
-
particle.svgDirection = getRandom() >
|
|
15
|
+
particle.svgDirection = getRandom() > halfRandom ? 0 : 1;
|
|
15
16
|
}
|
|
16
17
|
if (particle.svgPathIndex === undefined) {
|
|
17
18
|
particle.svgPathIndex = Math.floor(Math.random() * this._paths.length);
|
|
18
19
|
}
|
|
19
20
|
if (particle.svgSpeed === undefined) {
|
|
20
|
-
particle.svgSpeed = particle.velocity.mult((particle.retina.moveSpeed ??
|
|
21
|
+
particle.svgSpeed = particle.velocity.mult((particle.retina.moveSpeed ?? defaultSpeed) * half).length;
|
|
21
22
|
}
|
|
22
23
|
if (particle.svgStep === undefined) {
|
|
23
24
|
particle.svgStep = randomInRange({ min: 0, max: this._paths[particle.svgPathIndex].length }) * pxRatio;
|
|
24
25
|
}
|
|
25
26
|
if (particle.svgOffset === undefined) {
|
|
26
27
|
particle.svgOffset = {
|
|
27
|
-
width: randomInRange({ min: -this._width
|
|
28
|
-
height: randomInRange({ min: -this._width
|
|
28
|
+
width: randomInRange({ min: -this._width * half, max: this._width * half }) * pxRatio,
|
|
29
|
+
height: randomInRange({ min: -this._width * half, max: this._width * half }) * pxRatio,
|
|
29
30
|
};
|
|
30
31
|
}
|
|
31
32
|
if (particle.svgInitialPosition === undefined) {
|
|
@@ -41,12 +42,12 @@ export class SVGPathGenerator {
|
|
|
41
42
|
}
|
|
42
43
|
let path = this._paths[particle.svgPathIndex];
|
|
43
44
|
if (path) {
|
|
44
|
-
const pathLength = path.length;
|
|
45
|
+
const pathLength = path.length, indexOffset = 1;
|
|
45
46
|
if (particle.svgStep >= pathLength) {
|
|
46
|
-
particle.svgPathIndex = particle.svgPathIndex +
|
|
47
|
+
particle.svgPathIndex = particle.svgPathIndex + indexOffset;
|
|
47
48
|
if (particle.svgPathIndex >= this._paths.length) {
|
|
48
49
|
if (this._reverse) {
|
|
49
|
-
particle.svgPathIndex = this._paths.length -
|
|
50
|
+
particle.svgPathIndex = this._paths.length - indexOffset;
|
|
50
51
|
particle.svgDirection = 1;
|
|
51
52
|
}
|
|
52
53
|
else {
|
|
@@ -55,15 +56,15 @@ export class SVGPathGenerator {
|
|
|
55
56
|
}
|
|
56
57
|
}
|
|
57
58
|
}
|
|
58
|
-
else if (particle.svgStep <=
|
|
59
|
-
particle.svgPathIndex = particle.svgPathIndex -
|
|
60
|
-
if (particle.svgPathIndex <
|
|
59
|
+
else if (particle.svgStep <= minStep) {
|
|
60
|
+
particle.svgPathIndex = particle.svgPathIndex - indexOffset;
|
|
61
|
+
if (particle.svgPathIndex < minIndex) {
|
|
61
62
|
if (this._reverse) {
|
|
62
63
|
particle.svgPathIndex = 0;
|
|
63
64
|
particle.svgDirection = 0;
|
|
64
65
|
}
|
|
65
66
|
else {
|
|
66
|
-
particle.svgPathIndex = this._paths.length -
|
|
67
|
+
particle.svgPathIndex = this._paths.length - indexOffset;
|
|
67
68
|
path = this._paths[particle.svgPathIndex];
|
|
68
69
|
particle.svgStep = path.length;
|
|
69
70
|
}
|
|
@@ -74,12 +75,12 @@ export class SVGPathGenerator {
|
|
|
74
75
|
if (path) {
|
|
75
76
|
const pathElement = path.element, pos = pathElement.getPointAtLength(particle.svgStep), canvasSize = particle.container.canvas.size, offset = getPosition(this._offset, canvasSize), scale = this._scale * pxRatio;
|
|
76
77
|
particle.position.x =
|
|
77
|
-
(pos.x - this._size.width
|
|
78
|
+
(pos.x - this._size.width * half) * scale +
|
|
78
79
|
particle.svgInitialPosition.x +
|
|
79
80
|
offset.x +
|
|
80
81
|
particle.svgOffset.width;
|
|
81
82
|
particle.position.y =
|
|
82
|
-
(pos.y - this._size.height
|
|
83
|
+
(pos.y - this._size.height * half) * scale +
|
|
83
84
|
particle.svgInitialPosition.y +
|
|
84
85
|
offset.y +
|
|
85
86
|
particle.svgOffset.height;
|
|
@@ -89,16 +90,16 @@ export class SVGPathGenerator {
|
|
|
89
90
|
init(container) {
|
|
90
91
|
const options = container.actualOptions.particles.move.path.options, position = options.position ?? this._offset;
|
|
91
92
|
this._reverse = options.reverse ?? this._reverse;
|
|
92
|
-
this._scale = options.scale ??
|
|
93
|
+
this._scale = options.scale ?? minScale;
|
|
93
94
|
this._offset.x = position.x;
|
|
94
95
|
this._offset.y = position.y;
|
|
95
96
|
this._offset.mode = position.mode;
|
|
96
|
-
this._width = options.width ??
|
|
97
|
+
this._width = options.width ?? minWidth;
|
|
97
98
|
if (options.url && !options.path) {
|
|
98
99
|
const url = options.url;
|
|
99
|
-
(async () => {
|
|
100
|
+
void (async () => {
|
|
100
101
|
const response = await fetch(url), data = await response.text();
|
|
101
|
-
const parser = new DOMParser(), doc = parser.parseFromString(data, "image/svg+xml"), svg = doc.getElementsByTagName("svg")[
|
|
102
|
+
const parser = new DOMParser(), doc = parser.parseFromString(data, "image/svg+xml"), firstIndex = 0, svg = doc.getElementsByTagName("svg")[firstIndex];
|
|
102
103
|
let svgPaths = svg.getElementsByTagName("path");
|
|
103
104
|
if (!svgPaths.length) {
|
|
104
105
|
svgPaths = doc.getElementsByTagName("path");
|
package/cjs/SVGPathGenerator.js
CHANGED
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.SVGPathGenerator = void 0;
|
|
4
4
|
const engine_1 = require("@tsparticles/engine");
|
|
5
|
+
const defaultSpeed = 1, half = 0.5, minStep = 0, minIndex = 0, minWidth = 0, minScale = 1;
|
|
5
6
|
class SVGPathGenerator {
|
|
6
7
|
constructor() {
|
|
7
8
|
this._paths = [];
|
|
@@ -14,21 +15,21 @@ class SVGPathGenerator {
|
|
|
14
15
|
generate(particle, delta) {
|
|
15
16
|
const container = particle.container, pxRatio = container.retina.pixelRatio;
|
|
16
17
|
if (particle.svgDirection === undefined) {
|
|
17
|
-
particle.svgDirection = (0, engine_1.getRandom)() >
|
|
18
|
+
particle.svgDirection = (0, engine_1.getRandom)() > engine_1.halfRandom ? 0 : 1;
|
|
18
19
|
}
|
|
19
20
|
if (particle.svgPathIndex === undefined) {
|
|
20
21
|
particle.svgPathIndex = Math.floor(Math.random() * this._paths.length);
|
|
21
22
|
}
|
|
22
23
|
if (particle.svgSpeed === undefined) {
|
|
23
|
-
particle.svgSpeed = particle.velocity.mult((particle.retina.moveSpeed ??
|
|
24
|
+
particle.svgSpeed = particle.velocity.mult((particle.retina.moveSpeed ?? defaultSpeed) * half).length;
|
|
24
25
|
}
|
|
25
26
|
if (particle.svgStep === undefined) {
|
|
26
27
|
particle.svgStep = (0, engine_1.randomInRange)({ min: 0, max: this._paths[particle.svgPathIndex].length }) * pxRatio;
|
|
27
28
|
}
|
|
28
29
|
if (particle.svgOffset === undefined) {
|
|
29
30
|
particle.svgOffset = {
|
|
30
|
-
width: (0, engine_1.randomInRange)({ min: -this._width
|
|
31
|
-
height: (0, engine_1.randomInRange)({ min: -this._width
|
|
31
|
+
width: (0, engine_1.randomInRange)({ min: -this._width * half, max: this._width * half }) * pxRatio,
|
|
32
|
+
height: (0, engine_1.randomInRange)({ min: -this._width * half, max: this._width * half }) * pxRatio,
|
|
32
33
|
};
|
|
33
34
|
}
|
|
34
35
|
if (particle.svgInitialPosition === undefined) {
|
|
@@ -44,12 +45,12 @@ class SVGPathGenerator {
|
|
|
44
45
|
}
|
|
45
46
|
let path = this._paths[particle.svgPathIndex];
|
|
46
47
|
if (path) {
|
|
47
|
-
const pathLength = path.length;
|
|
48
|
+
const pathLength = path.length, indexOffset = 1;
|
|
48
49
|
if (particle.svgStep >= pathLength) {
|
|
49
|
-
particle.svgPathIndex = particle.svgPathIndex +
|
|
50
|
+
particle.svgPathIndex = particle.svgPathIndex + indexOffset;
|
|
50
51
|
if (particle.svgPathIndex >= this._paths.length) {
|
|
51
52
|
if (this._reverse) {
|
|
52
|
-
particle.svgPathIndex = this._paths.length -
|
|
53
|
+
particle.svgPathIndex = this._paths.length - indexOffset;
|
|
53
54
|
particle.svgDirection = 1;
|
|
54
55
|
}
|
|
55
56
|
else {
|
|
@@ -58,15 +59,15 @@ class SVGPathGenerator {
|
|
|
58
59
|
}
|
|
59
60
|
}
|
|
60
61
|
}
|
|
61
|
-
else if (particle.svgStep <=
|
|
62
|
-
particle.svgPathIndex = particle.svgPathIndex -
|
|
63
|
-
if (particle.svgPathIndex <
|
|
62
|
+
else if (particle.svgStep <= minStep) {
|
|
63
|
+
particle.svgPathIndex = particle.svgPathIndex - indexOffset;
|
|
64
|
+
if (particle.svgPathIndex < minIndex) {
|
|
64
65
|
if (this._reverse) {
|
|
65
66
|
particle.svgPathIndex = 0;
|
|
66
67
|
particle.svgDirection = 0;
|
|
67
68
|
}
|
|
68
69
|
else {
|
|
69
|
-
particle.svgPathIndex = this._paths.length -
|
|
70
|
+
particle.svgPathIndex = this._paths.length - indexOffset;
|
|
70
71
|
path = this._paths[particle.svgPathIndex];
|
|
71
72
|
particle.svgStep = path.length;
|
|
72
73
|
}
|
|
@@ -77,12 +78,12 @@ class SVGPathGenerator {
|
|
|
77
78
|
if (path) {
|
|
78
79
|
const pathElement = path.element, pos = pathElement.getPointAtLength(particle.svgStep), canvasSize = particle.container.canvas.size, offset = (0, engine_1.getPosition)(this._offset, canvasSize), scale = this._scale * pxRatio;
|
|
79
80
|
particle.position.x =
|
|
80
|
-
(pos.x - this._size.width
|
|
81
|
+
(pos.x - this._size.width * half) * scale +
|
|
81
82
|
particle.svgInitialPosition.x +
|
|
82
83
|
offset.x +
|
|
83
84
|
particle.svgOffset.width;
|
|
84
85
|
particle.position.y =
|
|
85
|
-
(pos.y - this._size.height
|
|
86
|
+
(pos.y - this._size.height * half) * scale +
|
|
86
87
|
particle.svgInitialPosition.y +
|
|
87
88
|
offset.y +
|
|
88
89
|
particle.svgOffset.height;
|
|
@@ -92,16 +93,16 @@ class SVGPathGenerator {
|
|
|
92
93
|
init(container) {
|
|
93
94
|
const options = container.actualOptions.particles.move.path.options, position = options.position ?? this._offset;
|
|
94
95
|
this._reverse = options.reverse ?? this._reverse;
|
|
95
|
-
this._scale = options.scale ??
|
|
96
|
+
this._scale = options.scale ?? minScale;
|
|
96
97
|
this._offset.x = position.x;
|
|
97
98
|
this._offset.y = position.y;
|
|
98
99
|
this._offset.mode = position.mode;
|
|
99
|
-
this._width = options.width ??
|
|
100
|
+
this._width = options.width ?? minWidth;
|
|
100
101
|
if (options.url && !options.path) {
|
|
101
102
|
const url = options.url;
|
|
102
|
-
(async () => {
|
|
103
|
+
void (async () => {
|
|
103
104
|
const response = await fetch(url), data = await response.text();
|
|
104
|
-
const parser = new DOMParser(), doc = parser.parseFromString(data, "image/svg+xml"), svg = doc.getElementsByTagName("svg")[
|
|
105
|
+
const parser = new DOMParser(), doc = parser.parseFromString(data, "image/svg+xml"), firstIndex = 0, svg = doc.getElementsByTagName("svg")[firstIndex];
|
|
105
106
|
let svgPaths = svg.getElementsByTagName("path");
|
|
106
107
|
if (!svgPaths.length) {
|
|
107
108
|
svgPaths = doc.getElementsByTagName("path");
|
package/esm/SVGPathGenerator.js
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import { Vector, getPosition, getRandom, randomInRange, } from "@tsparticles/engine";
|
|
1
|
+
import { Vector, getPosition, getRandom, halfRandom, randomInRange, } from "@tsparticles/engine";
|
|
2
|
+
const defaultSpeed = 1, half = 0.5, minStep = 0, minIndex = 0, minWidth = 0, minScale = 1;
|
|
2
3
|
export class SVGPathGenerator {
|
|
3
4
|
constructor() {
|
|
4
5
|
this._paths = [];
|
|
@@ -11,21 +12,21 @@ export class SVGPathGenerator {
|
|
|
11
12
|
generate(particle, delta) {
|
|
12
13
|
const container = particle.container, pxRatio = container.retina.pixelRatio;
|
|
13
14
|
if (particle.svgDirection === undefined) {
|
|
14
|
-
particle.svgDirection = getRandom() >
|
|
15
|
+
particle.svgDirection = getRandom() > halfRandom ? 0 : 1;
|
|
15
16
|
}
|
|
16
17
|
if (particle.svgPathIndex === undefined) {
|
|
17
18
|
particle.svgPathIndex = Math.floor(Math.random() * this._paths.length);
|
|
18
19
|
}
|
|
19
20
|
if (particle.svgSpeed === undefined) {
|
|
20
|
-
particle.svgSpeed = particle.velocity.mult((particle.retina.moveSpeed ??
|
|
21
|
+
particle.svgSpeed = particle.velocity.mult((particle.retina.moveSpeed ?? defaultSpeed) * half).length;
|
|
21
22
|
}
|
|
22
23
|
if (particle.svgStep === undefined) {
|
|
23
24
|
particle.svgStep = randomInRange({ min: 0, max: this._paths[particle.svgPathIndex].length }) * pxRatio;
|
|
24
25
|
}
|
|
25
26
|
if (particle.svgOffset === undefined) {
|
|
26
27
|
particle.svgOffset = {
|
|
27
|
-
width: randomInRange({ min: -this._width
|
|
28
|
-
height: randomInRange({ min: -this._width
|
|
28
|
+
width: randomInRange({ min: -this._width * half, max: this._width * half }) * pxRatio,
|
|
29
|
+
height: randomInRange({ min: -this._width * half, max: this._width * half }) * pxRatio,
|
|
29
30
|
};
|
|
30
31
|
}
|
|
31
32
|
if (particle.svgInitialPosition === undefined) {
|
|
@@ -41,12 +42,12 @@ export class SVGPathGenerator {
|
|
|
41
42
|
}
|
|
42
43
|
let path = this._paths[particle.svgPathIndex];
|
|
43
44
|
if (path) {
|
|
44
|
-
const pathLength = path.length;
|
|
45
|
+
const pathLength = path.length, indexOffset = 1;
|
|
45
46
|
if (particle.svgStep >= pathLength) {
|
|
46
|
-
particle.svgPathIndex = particle.svgPathIndex +
|
|
47
|
+
particle.svgPathIndex = particle.svgPathIndex + indexOffset;
|
|
47
48
|
if (particle.svgPathIndex >= this._paths.length) {
|
|
48
49
|
if (this._reverse) {
|
|
49
|
-
particle.svgPathIndex = this._paths.length -
|
|
50
|
+
particle.svgPathIndex = this._paths.length - indexOffset;
|
|
50
51
|
particle.svgDirection = 1;
|
|
51
52
|
}
|
|
52
53
|
else {
|
|
@@ -55,15 +56,15 @@ export class SVGPathGenerator {
|
|
|
55
56
|
}
|
|
56
57
|
}
|
|
57
58
|
}
|
|
58
|
-
else if (particle.svgStep <=
|
|
59
|
-
particle.svgPathIndex = particle.svgPathIndex -
|
|
60
|
-
if (particle.svgPathIndex <
|
|
59
|
+
else if (particle.svgStep <= minStep) {
|
|
60
|
+
particle.svgPathIndex = particle.svgPathIndex - indexOffset;
|
|
61
|
+
if (particle.svgPathIndex < minIndex) {
|
|
61
62
|
if (this._reverse) {
|
|
62
63
|
particle.svgPathIndex = 0;
|
|
63
64
|
particle.svgDirection = 0;
|
|
64
65
|
}
|
|
65
66
|
else {
|
|
66
|
-
particle.svgPathIndex = this._paths.length -
|
|
67
|
+
particle.svgPathIndex = this._paths.length - indexOffset;
|
|
67
68
|
path = this._paths[particle.svgPathIndex];
|
|
68
69
|
particle.svgStep = path.length;
|
|
69
70
|
}
|
|
@@ -74,12 +75,12 @@ export class SVGPathGenerator {
|
|
|
74
75
|
if (path) {
|
|
75
76
|
const pathElement = path.element, pos = pathElement.getPointAtLength(particle.svgStep), canvasSize = particle.container.canvas.size, offset = getPosition(this._offset, canvasSize), scale = this._scale * pxRatio;
|
|
76
77
|
particle.position.x =
|
|
77
|
-
(pos.x - this._size.width
|
|
78
|
+
(pos.x - this._size.width * half) * scale +
|
|
78
79
|
particle.svgInitialPosition.x +
|
|
79
80
|
offset.x +
|
|
80
81
|
particle.svgOffset.width;
|
|
81
82
|
particle.position.y =
|
|
82
|
-
(pos.y - this._size.height
|
|
83
|
+
(pos.y - this._size.height * half) * scale +
|
|
83
84
|
particle.svgInitialPosition.y +
|
|
84
85
|
offset.y +
|
|
85
86
|
particle.svgOffset.height;
|
|
@@ -89,16 +90,16 @@ export class SVGPathGenerator {
|
|
|
89
90
|
init(container) {
|
|
90
91
|
const options = container.actualOptions.particles.move.path.options, position = options.position ?? this._offset;
|
|
91
92
|
this._reverse = options.reverse ?? this._reverse;
|
|
92
|
-
this._scale = options.scale ??
|
|
93
|
+
this._scale = options.scale ?? minScale;
|
|
93
94
|
this._offset.x = position.x;
|
|
94
95
|
this._offset.y = position.y;
|
|
95
96
|
this._offset.mode = position.mode;
|
|
96
|
-
this._width = options.width ??
|
|
97
|
+
this._width = options.width ?? minWidth;
|
|
97
98
|
if (options.url && !options.path) {
|
|
98
99
|
const url = options.url;
|
|
99
|
-
(async () => {
|
|
100
|
+
void (async () => {
|
|
100
101
|
const response = await fetch(url), data = await response.text();
|
|
101
|
-
const parser = new DOMParser(), doc = parser.parseFromString(data, "image/svg+xml"), svg = doc.getElementsByTagName("svg")[
|
|
102
|
+
const parser = new DOMParser(), doc = parser.parseFromString(data, "image/svg+xml"), firstIndex = 0, svg = doc.getElementsByTagName("svg")[firstIndex];
|
|
102
103
|
let svgPaths = svg.getElementsByTagName("path");
|
|
103
104
|
if (!svgPaths.length) {
|
|
104
105
|
svgPaths = doc.getElementsByTagName("path");
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tsparticles/path-svg",
|
|
3
|
-
"version": "3.0
|
|
3
|
+
"version": "3.1.0",
|
|
4
4
|
"description": "tsParticles svg path",
|
|
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
|
|
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/path-svg [
|
|
6
|
+
<title>@tsparticles/path-svg [13 Jan 2024 at 23:01]</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.path.svg.js","isAsset":true,"statSize":
|
|
34
|
+
window.chartData = [{"label":"tsparticles.path.svg.js","isAsset":true,"statSize":5707,"parsedSize":9627,"gzipSize":2738,"groups":[{"label":"dist/browser","path":"./dist/browser","statSize":5665,"groups":[{"id":715,"label":"index.js + 1 modules (concatenated)","path":"./dist/browser/index.js + 1 modules (concatenated)","statSize":5665,"parsedSize":9627,"gzipSize":2738,"concatenated":true,"groups":[{"label":"dist/browser","path":"./dist/browser/index.js + 1 modules (concatenated)/dist/browser","statSize":5665,"groups":[{"id":null,"label":"index.js","path":"./dist/browser/index.js + 1 modules (concatenated)/dist/browser/index.js","statSize":245,"parsedSize":416,"gzipSize":118,"inaccurateSizes":true},{"id":null,"label":"SVGPathGenerator.js","path":"./dist/browser/index.js + 1 modules (concatenated)/dist/browser/SVGPathGenerator.js","statSize":5420,"parsedSize":9210,"gzipSize":2619,"inaccurateSizes":true}],"parsedSize":9627,"gzipSize":2738,"inaccurateSizes":true}]}],"parsedSize":9627,"gzipSize":2738},{"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.path.svg":true}}];
|
|
35
35
|
window.entrypoints = ["tsparticles.path.svg","tsparticles.path.svg.min"];
|
|
36
36
|
window.defaultSizes = "parsed";
|
|
37
37
|
</script>
|
package/tsparticles.path.svg.js
CHANGED
|
@@ -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')
|
|
@@ -99,6 +99,12 @@ __webpack_require__.d(__webpack_exports__, {
|
|
|
99
99
|
var engine_root_window_ = __webpack_require__(533);
|
|
100
100
|
;// CONCATENATED MODULE: ./dist/browser/SVGPathGenerator.js
|
|
101
101
|
|
|
102
|
+
const defaultSpeed = 1,
|
|
103
|
+
half = 0.5,
|
|
104
|
+
minStep = 0,
|
|
105
|
+
minIndex = 0,
|
|
106
|
+
minWidth = 0,
|
|
107
|
+
minScale = 1;
|
|
102
108
|
class SVGPathGenerator {
|
|
103
109
|
constructor() {
|
|
104
110
|
this._paths = [];
|
|
@@ -119,13 +125,13 @@ class SVGPathGenerator {
|
|
|
119
125
|
const container = particle.container,
|
|
120
126
|
pxRatio = container.retina.pixelRatio;
|
|
121
127
|
if (particle.svgDirection === undefined) {
|
|
122
|
-
particle.svgDirection = (0,engine_root_window_.getRandom)() >
|
|
128
|
+
particle.svgDirection = (0,engine_root_window_.getRandom)() > engine_root_window_.halfRandom ? 0 : 1;
|
|
123
129
|
}
|
|
124
130
|
if (particle.svgPathIndex === undefined) {
|
|
125
131
|
particle.svgPathIndex = Math.floor(Math.random() * this._paths.length);
|
|
126
132
|
}
|
|
127
133
|
if (particle.svgSpeed === undefined) {
|
|
128
|
-
particle.svgSpeed = particle.velocity.mult((particle.retina.moveSpeed ??
|
|
134
|
+
particle.svgSpeed = particle.velocity.mult((particle.retina.moveSpeed ?? defaultSpeed) * half).length;
|
|
129
135
|
}
|
|
130
136
|
if (particle.svgStep === undefined) {
|
|
131
137
|
particle.svgStep = (0,engine_root_window_.randomInRange)({
|
|
@@ -136,12 +142,12 @@ class SVGPathGenerator {
|
|
|
136
142
|
if (particle.svgOffset === undefined) {
|
|
137
143
|
particle.svgOffset = {
|
|
138
144
|
width: (0,engine_root_window_.randomInRange)({
|
|
139
|
-
min: -this._width
|
|
140
|
-
max: this._width
|
|
145
|
+
min: -this._width * half,
|
|
146
|
+
max: this._width * half
|
|
141
147
|
}) * pxRatio,
|
|
142
148
|
height: (0,engine_root_window_.randomInRange)({
|
|
143
|
-
min: -this._width
|
|
144
|
-
max: this._width
|
|
149
|
+
min: -this._width * half,
|
|
150
|
+
max: this._width * half
|
|
145
151
|
}) * pxRatio
|
|
146
152
|
};
|
|
147
153
|
}
|
|
@@ -159,26 +165,27 @@ class SVGPathGenerator {
|
|
|
159
165
|
}
|
|
160
166
|
let path = this._paths[particle.svgPathIndex];
|
|
161
167
|
if (path) {
|
|
162
|
-
const pathLength = path.length
|
|
168
|
+
const pathLength = path.length,
|
|
169
|
+
indexOffset = 1;
|
|
163
170
|
if (particle.svgStep >= pathLength) {
|
|
164
|
-
particle.svgPathIndex = particle.svgPathIndex +
|
|
171
|
+
particle.svgPathIndex = particle.svgPathIndex + indexOffset;
|
|
165
172
|
if (particle.svgPathIndex >= this._paths.length) {
|
|
166
173
|
if (this._reverse) {
|
|
167
|
-
particle.svgPathIndex = this._paths.length -
|
|
174
|
+
particle.svgPathIndex = this._paths.length - indexOffset;
|
|
168
175
|
particle.svgDirection = 1;
|
|
169
176
|
} else {
|
|
170
177
|
particle.svgPathIndex = 0;
|
|
171
178
|
particle.svgStep = 0;
|
|
172
179
|
}
|
|
173
180
|
}
|
|
174
|
-
} else if (particle.svgStep <=
|
|
175
|
-
particle.svgPathIndex = particle.svgPathIndex -
|
|
176
|
-
if (particle.svgPathIndex <
|
|
181
|
+
} else if (particle.svgStep <= minStep) {
|
|
182
|
+
particle.svgPathIndex = particle.svgPathIndex - indexOffset;
|
|
183
|
+
if (particle.svgPathIndex < minIndex) {
|
|
177
184
|
if (this._reverse) {
|
|
178
185
|
particle.svgPathIndex = 0;
|
|
179
186
|
particle.svgDirection = 0;
|
|
180
187
|
} else {
|
|
181
|
-
particle.svgPathIndex = this._paths.length -
|
|
188
|
+
particle.svgPathIndex = this._paths.length - indexOffset;
|
|
182
189
|
path = this._paths[particle.svgPathIndex];
|
|
183
190
|
particle.svgStep = path.length;
|
|
184
191
|
}
|
|
@@ -192,8 +199,8 @@ class SVGPathGenerator {
|
|
|
192
199
|
canvasSize = particle.container.canvas.size,
|
|
193
200
|
offset = (0,engine_root_window_.getPosition)(this._offset, canvasSize),
|
|
194
201
|
scale = this._scale * pxRatio;
|
|
195
|
-
particle.position.x = (pos.x - this._size.width
|
|
196
|
-
particle.position.y = (pos.y - this._size.height
|
|
202
|
+
particle.position.x = (pos.x - this._size.width * half) * scale + particle.svgInitialPosition.x + offset.x + particle.svgOffset.width;
|
|
203
|
+
particle.position.y = (pos.y - this._size.height * half) * scale + particle.svgInitialPosition.y + offset.y + particle.svgOffset.height;
|
|
197
204
|
}
|
|
198
205
|
return engine_root_window_.Vector.origin;
|
|
199
206
|
}
|
|
@@ -201,19 +208,20 @@ class SVGPathGenerator {
|
|
|
201
208
|
const options = container.actualOptions.particles.move.path.options,
|
|
202
209
|
position = options.position ?? this._offset;
|
|
203
210
|
this._reverse = options.reverse ?? this._reverse;
|
|
204
|
-
this._scale = options.scale ??
|
|
211
|
+
this._scale = options.scale ?? minScale;
|
|
205
212
|
this._offset.x = position.x;
|
|
206
213
|
this._offset.y = position.y;
|
|
207
214
|
this._offset.mode = position.mode;
|
|
208
|
-
this._width = options.width ??
|
|
215
|
+
this._width = options.width ?? minWidth;
|
|
209
216
|
if (options.url && !options.path) {
|
|
210
217
|
const url = options.url;
|
|
211
|
-
(async () => {
|
|
218
|
+
void (async () => {
|
|
212
219
|
const response = await fetch(url),
|
|
213
220
|
data = await response.text();
|
|
214
221
|
const parser = new DOMParser(),
|
|
215
222
|
doc = parser.parseFromString(data, "image/svg+xml"),
|
|
216
|
-
|
|
223
|
+
firstIndex = 0,
|
|
224
|
+
svg = doc.getElementsByTagName("svg")[firstIndex];
|
|
217
225
|
let svgPaths = svg.getElementsByTagName("path");
|
|
218
226
|
if (!svgPaths.length) {
|
|
219
227
|
svgPaths = doc.getElementsByTagName("path");
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/*! For license information please see tsparticles.path.svg.min.js.LICENSE.txt */
|
|
2
|
-
!function(t,e){if("object"==typeof exports&&"object"==typeof module)module.exports=e(require("@tsparticles/engine"));else if("function"==typeof define&&define.amd)define(["@tsparticles/engine"],e);else{var s="object"==typeof exports?e(require("@tsparticles/engine")):e(t.window);for(var i in s)("object"==typeof exports?exports:t)[i]=s[i]}}(this,(t=>(()=>{"use strict";var e={533:e=>{e.exports=t}},s={};function i(t){var n=s[t];if(void 0!==n)return n.exports;var h=s[t]={exports:{}};return e[t](h,h.exports,i),h.exports}i.d=(t,e)=>{for(var s in e)i.o(e,s)&&!i.o(t,s)&&Object.defineProperty(t,s,{enumerable:!0,get:e[s]})},i.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),i.r=t=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})};var n={};return(()=>{i.r(n),i.d(n,{loadSVGPath:()=>
|
|
2
|
+
!function(t,e){if("object"==typeof exports&&"object"==typeof module)module.exports=e(require("@tsparticles/engine"));else if("function"==typeof define&&define.amd)define(["@tsparticles/engine"],e);else{var s="object"==typeof exports?e(require("@tsparticles/engine")):e(t.window);for(var i in s)("object"==typeof exports?exports:t)[i]=s[i]}}(this,(t=>(()=>{"use strict";var e={533:e=>{e.exports=t}},s={};function i(t){var n=s[t];if(void 0!==n)return n.exports;var h=s[t]={exports:{}};return e[t](h,h.exports,i),h.exports}i.d=(t,e)=>{for(var s in e)i.o(e,s)&&!i.o(t,s)&&Object.defineProperty(t,s,{enumerable:!0,get:e[s]})},i.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),i.r=t=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})};var n={};return(()=>{i.r(n),i.d(n,{loadSVGPath:()=>o,svgPathName:()=>h});var t=i(533);const e=.5;class s{constructor(){this._paths=[],this._reverse=!1,this._size={width:0,height:0},this._scale=1,this._offset={x:0,y:0,mode:"percent"},this._width=0}generate(s,i){const n=s.container.retina.pixelRatio;void 0===s.svgDirection&&(s.svgDirection=(0,t.getRandom)()>t.halfRandom?0:1),void 0===s.svgPathIndex&&(s.svgPathIndex=Math.floor(Math.random()*this._paths.length)),void 0===s.svgSpeed&&(s.svgSpeed=s.velocity.mult((s.retina.moveSpeed??1)*e).length),void 0===s.svgStep&&(s.svgStep=(0,t.randomInRange)({min:0,max:this._paths[s.svgPathIndex].length})*n),void 0===s.svgOffset&&(s.svgOffset={width:(0,t.randomInRange)({min:-this._width*e,max:this._width*e})*n,height:(0,t.randomInRange)({min:-this._width*e,max:this._width*e})*n}),void 0===s.svgInitialPosition&&(s.svgInitialPosition={...s.position}),s.velocity.x=0,s.velocity.y=0,0===s.svgDirection?s.svgStep+=s.svgSpeed*i.factor:s.svgStep-=s.svgSpeed*i.factor;let h=this._paths[s.svgPathIndex];if(h){const t=h.length,e=1;s.svgStep>=t?(s.svgPathIndex=s.svgPathIndex+e,s.svgPathIndex>=this._paths.length&&(this._reverse?(s.svgPathIndex=this._paths.length-e,s.svgDirection=1):(s.svgPathIndex=0,s.svgStep=0))):s.svgStep<=0&&(s.svgPathIndex=s.svgPathIndex-e,s.svgPathIndex<0&&(this._reverse?(s.svgPathIndex=0,s.svgDirection=0):(s.svgPathIndex=this._paths.length-e,h=this._paths[s.svgPathIndex],s.svgStep=h.length))),h=this._paths[s.svgPathIndex]}if(h){const i=h.element.getPointAtLength(s.svgStep),o=s.container.canvas.size,a=(0,t.getPosition)(this._offset,o),r=this._scale*n;s.position.x=(i.x-this._size.width*e)*r+s.svgInitialPosition.x+a.x+s.svgOffset.width,s.position.y=(i.y-this._size.height*e)*r+s.svgInitialPosition.y+a.y+s.svgOffset.height}return t.Vector.origin}init(t){const e=t.actualOptions.particles.move.path.options,s=e.position??this._offset;if(this._reverse=e.reverse??this._reverse,this._scale=e.scale??1,this._offset.x=s.x,this._offset.y=s.y,this._offset.mode=s.mode,this._width=e.width??0,e.url&&!e.path){const t=e.url;(async()=>{const e=await fetch(t),s=await e.text(),i=(new DOMParser).parseFromString(s,"image/svg+xml"),n=i.getElementsByTagName("svg")[0];let h=n.getElementsByTagName("path");h.length||(h=i.getElementsByTagName("path")),this._paths=[];for(let t=0;t<h.length;t++){const e=h.item(t);e&&this._paths.push({element:e,length:e.getTotalLength()})}this._size.height=parseFloat(n.getAttribute("height")??"0"),this._size.width=parseFloat(n.getAttribute("width")??"0")})()}else if(e.path){const t=e.path;this._paths=[];for(const e of t.data){const t=document.createElementNS("http://www.w3.org/2000/svg","path");t.setAttribute("d",e),this._paths.push({element:t,length:t.getTotalLength()})}this._size.height=t.size.height,this._size.width=t.size.width}}reset(){}update(){}}const h="svgPathGenerator";async function o(t,e=!0){await t.addPathGenerator(h,new s,e)}})(),n})()));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
/*! tsParticles SVG Path v3.0
|
|
1
|
+
/*! tsParticles SVG Path v3.1.0 by Matteo Bruni */
|
|
@@ -1,9 +1,4 @@
|
|
|
1
1
|
import { type Container, type ICoordinates, type IDelta, type IDimension, type IMovePathGenerator, type Particle, Vector } from "@tsparticles/engine";
|
|
2
|
-
declare global {
|
|
3
|
-
interface Window {
|
|
4
|
-
[key: string]: unknown;
|
|
5
|
-
}
|
|
6
|
-
}
|
|
7
2
|
declare const enum SVGPathDirection {
|
|
8
3
|
normal = 0,
|
|
9
4
|
reverse = 1
|
package/umd/SVGPathGenerator.js
CHANGED
|
@@ -11,6 +11,7 @@
|
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.SVGPathGenerator = void 0;
|
|
13
13
|
const engine_1 = require("@tsparticles/engine");
|
|
14
|
+
const defaultSpeed = 1, half = 0.5, minStep = 0, minIndex = 0, minWidth = 0, minScale = 1;
|
|
14
15
|
class SVGPathGenerator {
|
|
15
16
|
constructor() {
|
|
16
17
|
this._paths = [];
|
|
@@ -23,21 +24,21 @@
|
|
|
23
24
|
generate(particle, delta) {
|
|
24
25
|
const container = particle.container, pxRatio = container.retina.pixelRatio;
|
|
25
26
|
if (particle.svgDirection === undefined) {
|
|
26
|
-
particle.svgDirection = (0, engine_1.getRandom)() >
|
|
27
|
+
particle.svgDirection = (0, engine_1.getRandom)() > engine_1.halfRandom ? 0 : 1;
|
|
27
28
|
}
|
|
28
29
|
if (particle.svgPathIndex === undefined) {
|
|
29
30
|
particle.svgPathIndex = Math.floor(Math.random() * this._paths.length);
|
|
30
31
|
}
|
|
31
32
|
if (particle.svgSpeed === undefined) {
|
|
32
|
-
particle.svgSpeed = particle.velocity.mult((particle.retina.moveSpeed ??
|
|
33
|
+
particle.svgSpeed = particle.velocity.mult((particle.retina.moveSpeed ?? defaultSpeed) * half).length;
|
|
33
34
|
}
|
|
34
35
|
if (particle.svgStep === undefined) {
|
|
35
36
|
particle.svgStep = (0, engine_1.randomInRange)({ min: 0, max: this._paths[particle.svgPathIndex].length }) * pxRatio;
|
|
36
37
|
}
|
|
37
38
|
if (particle.svgOffset === undefined) {
|
|
38
39
|
particle.svgOffset = {
|
|
39
|
-
width: (0, engine_1.randomInRange)({ min: -this._width
|
|
40
|
-
height: (0, engine_1.randomInRange)({ min: -this._width
|
|
40
|
+
width: (0, engine_1.randomInRange)({ min: -this._width * half, max: this._width * half }) * pxRatio,
|
|
41
|
+
height: (0, engine_1.randomInRange)({ min: -this._width * half, max: this._width * half }) * pxRatio,
|
|
41
42
|
};
|
|
42
43
|
}
|
|
43
44
|
if (particle.svgInitialPosition === undefined) {
|
|
@@ -53,12 +54,12 @@
|
|
|
53
54
|
}
|
|
54
55
|
let path = this._paths[particle.svgPathIndex];
|
|
55
56
|
if (path) {
|
|
56
|
-
const pathLength = path.length;
|
|
57
|
+
const pathLength = path.length, indexOffset = 1;
|
|
57
58
|
if (particle.svgStep >= pathLength) {
|
|
58
|
-
particle.svgPathIndex = particle.svgPathIndex +
|
|
59
|
+
particle.svgPathIndex = particle.svgPathIndex + indexOffset;
|
|
59
60
|
if (particle.svgPathIndex >= this._paths.length) {
|
|
60
61
|
if (this._reverse) {
|
|
61
|
-
particle.svgPathIndex = this._paths.length -
|
|
62
|
+
particle.svgPathIndex = this._paths.length - indexOffset;
|
|
62
63
|
particle.svgDirection = 1;
|
|
63
64
|
}
|
|
64
65
|
else {
|
|
@@ -67,15 +68,15 @@
|
|
|
67
68
|
}
|
|
68
69
|
}
|
|
69
70
|
}
|
|
70
|
-
else if (particle.svgStep <=
|
|
71
|
-
particle.svgPathIndex = particle.svgPathIndex -
|
|
72
|
-
if (particle.svgPathIndex <
|
|
71
|
+
else if (particle.svgStep <= minStep) {
|
|
72
|
+
particle.svgPathIndex = particle.svgPathIndex - indexOffset;
|
|
73
|
+
if (particle.svgPathIndex < minIndex) {
|
|
73
74
|
if (this._reverse) {
|
|
74
75
|
particle.svgPathIndex = 0;
|
|
75
76
|
particle.svgDirection = 0;
|
|
76
77
|
}
|
|
77
78
|
else {
|
|
78
|
-
particle.svgPathIndex = this._paths.length -
|
|
79
|
+
particle.svgPathIndex = this._paths.length - indexOffset;
|
|
79
80
|
path = this._paths[particle.svgPathIndex];
|
|
80
81
|
particle.svgStep = path.length;
|
|
81
82
|
}
|
|
@@ -86,12 +87,12 @@
|
|
|
86
87
|
if (path) {
|
|
87
88
|
const pathElement = path.element, pos = pathElement.getPointAtLength(particle.svgStep), canvasSize = particle.container.canvas.size, offset = (0, engine_1.getPosition)(this._offset, canvasSize), scale = this._scale * pxRatio;
|
|
88
89
|
particle.position.x =
|
|
89
|
-
(pos.x - this._size.width
|
|
90
|
+
(pos.x - this._size.width * half) * scale +
|
|
90
91
|
particle.svgInitialPosition.x +
|
|
91
92
|
offset.x +
|
|
92
93
|
particle.svgOffset.width;
|
|
93
94
|
particle.position.y =
|
|
94
|
-
(pos.y - this._size.height
|
|
95
|
+
(pos.y - this._size.height * half) * scale +
|
|
95
96
|
particle.svgInitialPosition.y +
|
|
96
97
|
offset.y +
|
|
97
98
|
particle.svgOffset.height;
|
|
@@ -101,16 +102,16 @@
|
|
|
101
102
|
init(container) {
|
|
102
103
|
const options = container.actualOptions.particles.move.path.options, position = options.position ?? this._offset;
|
|
103
104
|
this._reverse = options.reverse ?? this._reverse;
|
|
104
|
-
this._scale = options.scale ??
|
|
105
|
+
this._scale = options.scale ?? minScale;
|
|
105
106
|
this._offset.x = position.x;
|
|
106
107
|
this._offset.y = position.y;
|
|
107
108
|
this._offset.mode = position.mode;
|
|
108
|
-
this._width = options.width ??
|
|
109
|
+
this._width = options.width ?? minWidth;
|
|
109
110
|
if (options.url && !options.path) {
|
|
110
111
|
const url = options.url;
|
|
111
|
-
(async () => {
|
|
112
|
+
void (async () => {
|
|
112
113
|
const response = await fetch(url), data = await response.text();
|
|
113
|
-
const parser = new DOMParser(), doc = parser.parseFromString(data, "image/svg+xml"), svg = doc.getElementsByTagName("svg")[
|
|
114
|
+
const parser = new DOMParser(), doc = parser.parseFromString(data, "image/svg+xml"), firstIndex = 0, svg = doc.getElementsByTagName("svg")[firstIndex];
|
|
114
115
|
let svgPaths = svg.getElementsByTagName("path");
|
|
115
116
|
if (!svgPaths.length) {
|
|
116
117
|
svgPaths = doc.getElementsByTagName("path");
|