@tsparticles/shape-path 3.0.3 → 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 CHANGED
@@ -1,38 +1,44 @@
1
1
  export function drawPath(ctx, radius, path) {
2
- ctx.moveTo(path.segments[0].values[0].x * radius, path.segments[0].values[0].y * radius);
3
- for (let i = 0; i < path.segments.length; i++) {
4
- const segment = path.segments[i];
2
+ const firstIndex = 0, firstSegment = path.segments[firstIndex], firstValue = firstSegment.values[firstIndex];
3
+ ctx.moveTo(firstValue.x * radius, firstValue.y * radius);
4
+ for (const segment of path.segments) {
5
+ const value = segment.values[firstIndex], index2 = 1, index3 = 2, index4 = 3;
5
6
  switch (segment.type) {
6
7
  case "line":
7
- ctx.lineTo(segment.values[0].x * radius, segment.values[0].y * radius);
8
+ ctx.lineTo(value.x * radius, value.y * radius);
8
9
  break;
9
10
  case "bezier":
10
- ctx.bezierCurveTo(segment.values[1].x * radius, segment.values[1].y * radius, segment.values[2].x * radius, segment.values[2].y * radius, segment.values[3].x * radius, segment.values[3].y * radius);
11
+ ctx.bezierCurveTo(segment.values[index2].x * radius, segment.values[index2].y * radius, segment.values[index3].x * radius, segment.values[index3].y * radius, segment.values[index4].x * radius, segment.values[index4].y * radius);
11
12
  break;
12
13
  case "quadratic":
13
- ctx.quadraticCurveTo(segment.values[1].x * radius, segment.values[1].y * radius, segment.values[2].x * radius, segment.values[2].y * radius);
14
+ ctx.quadraticCurveTo(segment.values[index2].x * radius, segment.values[index2].y * radius, segment.values[index3].x * radius, segment.values[index3].y * radius);
14
15
  break;
15
16
  case "arc":
16
- ctx.arc(segment.values[0].x * radius, segment.values[0].y * radius, segment.values[1].x * radius, segment.values[2].x, segment.values[2].y);
17
+ ctx.arc(value.x * radius, value.y * radius, segment.values[index2].x * radius, segment.values[index3].x, segment.values[index3].y);
17
18
  break;
18
19
  case "ellipse":
19
- ctx.ellipse(segment.values[0].x * radius, segment.values[0].y * radius, segment.values[1].x * radius, segment.values[1].y * radius, segment.values[2].x, segment.values[3].x, segment.values[3].y);
20
+ ctx.ellipse(value.x * radius, value.y * radius, segment.values[index2].x * radius, segment.values[index2].y * radius, segment.values[index3].x, segment.values[index4].x, segment.values[index4].y);
20
21
  }
21
22
  }
22
23
  if (!path.half) {
23
24
  return;
24
25
  }
25
- for (let i = path.segments.length - 1; i >= 0; i--) {
26
- const segment = path.segments[i];
26
+ const lengthOffset = 1, minLength = 0;
27
+ for (let i = path.segments.length - lengthOffset; i >= minLength; i--) {
28
+ const segment = path.segments[i], value = segment.values[firstIndex], index2 = 1, index3 = 2;
27
29
  switch (segment.type) {
28
30
  case "line":
29
- ctx.lineTo(segment.values[0].x * -radius, segment.values[0].y * radius);
31
+ ctx.lineTo(value.x * -radius, value.y * radius);
30
32
  break;
31
33
  case "bezier":
32
- ctx.bezierCurveTo(-segment.values[2].x * radius, segment.values[2].y * radius, -segment.values[1].x * radius, segment.values[1].y * radius, -segment.values[0].x * radius, segment.values[0].y * radius);
34
+ ctx.bezierCurveTo(-segment.values[index3].x * radius, segment.values[index3].y * radius, -segment.values[index2].x * radius, segment.values[index2].y * radius, value.x * radius, value.y * radius);
33
35
  break;
34
36
  case "quadratic":
35
- ctx.quadraticCurveTo(-segment.values[1].x * radius, segment.values[1].y * radius, -segment.values[2].x * radius, segment.values[2].y * radius);
37
+ ctx.quadraticCurveTo(-segment.values[index2].x * radius, segment.values[index2].y * radius, -segment.values[index3].x * radius, segment.values[index3].y * radius);
38
+ break;
39
+ case "arc":
40
+ case "ellipse":
41
+ default:
36
42
  break;
37
43
  }
38
44
  }
package/cjs/Utils.js CHANGED
@@ -2,40 +2,46 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.drawPath = void 0;
4
4
  function drawPath(ctx, radius, path) {
5
- ctx.moveTo(path.segments[0].values[0].x * radius, path.segments[0].values[0].y * radius);
6
- for (let i = 0; i < path.segments.length; i++) {
7
- const segment = path.segments[i];
5
+ const firstIndex = 0, firstSegment = path.segments[firstIndex], firstValue = firstSegment.values[firstIndex];
6
+ ctx.moveTo(firstValue.x * radius, firstValue.y * radius);
7
+ for (const segment of path.segments) {
8
+ const value = segment.values[firstIndex], index2 = 1, index3 = 2, index4 = 3;
8
9
  switch (segment.type) {
9
10
  case "line":
10
- ctx.lineTo(segment.values[0].x * radius, segment.values[0].y * radius);
11
+ ctx.lineTo(value.x * radius, value.y * radius);
11
12
  break;
12
13
  case "bezier":
13
- ctx.bezierCurveTo(segment.values[1].x * radius, segment.values[1].y * radius, segment.values[2].x * radius, segment.values[2].y * radius, segment.values[3].x * radius, segment.values[3].y * radius);
14
+ ctx.bezierCurveTo(segment.values[index2].x * radius, segment.values[index2].y * radius, segment.values[index3].x * radius, segment.values[index3].y * radius, segment.values[index4].x * radius, segment.values[index4].y * radius);
14
15
  break;
15
16
  case "quadratic":
16
- ctx.quadraticCurveTo(segment.values[1].x * radius, segment.values[1].y * radius, segment.values[2].x * radius, segment.values[2].y * radius);
17
+ ctx.quadraticCurveTo(segment.values[index2].x * radius, segment.values[index2].y * radius, segment.values[index3].x * radius, segment.values[index3].y * radius);
17
18
  break;
18
19
  case "arc":
19
- ctx.arc(segment.values[0].x * radius, segment.values[0].y * radius, segment.values[1].x * radius, segment.values[2].x, segment.values[2].y);
20
+ ctx.arc(value.x * radius, value.y * radius, segment.values[index2].x * radius, segment.values[index3].x, segment.values[index3].y);
20
21
  break;
21
22
  case "ellipse":
22
- ctx.ellipse(segment.values[0].x * radius, segment.values[0].y * radius, segment.values[1].x * radius, segment.values[1].y * radius, segment.values[2].x, segment.values[3].x, segment.values[3].y);
23
+ ctx.ellipse(value.x * radius, value.y * radius, segment.values[index2].x * radius, segment.values[index2].y * radius, segment.values[index3].x, segment.values[index4].x, segment.values[index4].y);
23
24
  }
24
25
  }
25
26
  if (!path.half) {
26
27
  return;
27
28
  }
28
- for (let i = path.segments.length - 1; i >= 0; i--) {
29
- const segment = path.segments[i];
29
+ const lengthOffset = 1, minLength = 0;
30
+ for (let i = path.segments.length - lengthOffset; i >= minLength; i--) {
31
+ const segment = path.segments[i], value = segment.values[firstIndex], index2 = 1, index3 = 2;
30
32
  switch (segment.type) {
31
33
  case "line":
32
- ctx.lineTo(segment.values[0].x * -radius, segment.values[0].y * radius);
34
+ ctx.lineTo(value.x * -radius, value.y * radius);
33
35
  break;
34
36
  case "bezier":
35
- ctx.bezierCurveTo(-segment.values[2].x * radius, segment.values[2].y * radius, -segment.values[1].x * radius, segment.values[1].y * radius, -segment.values[0].x * radius, segment.values[0].y * radius);
37
+ ctx.bezierCurveTo(-segment.values[index3].x * radius, segment.values[index3].y * radius, -segment.values[index2].x * radius, segment.values[index2].y * radius, value.x * radius, value.y * radius);
36
38
  break;
37
39
  case "quadratic":
38
- ctx.quadraticCurveTo(-segment.values[1].x * radius, segment.values[1].y * radius, -segment.values[2].x * radius, segment.values[2].y * radius);
40
+ ctx.quadraticCurveTo(-segment.values[index2].x * radius, segment.values[index2].y * radius, -segment.values[index3].x * radius, segment.values[index3].y * radius);
41
+ break;
42
+ case "arc":
43
+ case "ellipse":
44
+ default:
39
45
  break;
40
46
  }
41
47
  }
package/esm/Utils.js CHANGED
@@ -1,38 +1,44 @@
1
1
  export function drawPath(ctx, radius, path) {
2
- ctx.moveTo(path.segments[0].values[0].x * radius, path.segments[0].values[0].y * radius);
3
- for (let i = 0; i < path.segments.length; i++) {
4
- const segment = path.segments[i];
2
+ const firstIndex = 0, firstSegment = path.segments[firstIndex], firstValue = firstSegment.values[firstIndex];
3
+ ctx.moveTo(firstValue.x * radius, firstValue.y * radius);
4
+ for (const segment of path.segments) {
5
+ const value = segment.values[firstIndex], index2 = 1, index3 = 2, index4 = 3;
5
6
  switch (segment.type) {
6
7
  case "line":
7
- ctx.lineTo(segment.values[0].x * radius, segment.values[0].y * radius);
8
+ ctx.lineTo(value.x * radius, value.y * radius);
8
9
  break;
9
10
  case "bezier":
10
- ctx.bezierCurveTo(segment.values[1].x * radius, segment.values[1].y * radius, segment.values[2].x * radius, segment.values[2].y * radius, segment.values[3].x * radius, segment.values[3].y * radius);
11
+ ctx.bezierCurveTo(segment.values[index2].x * radius, segment.values[index2].y * radius, segment.values[index3].x * radius, segment.values[index3].y * radius, segment.values[index4].x * radius, segment.values[index4].y * radius);
11
12
  break;
12
13
  case "quadratic":
13
- ctx.quadraticCurveTo(segment.values[1].x * radius, segment.values[1].y * radius, segment.values[2].x * radius, segment.values[2].y * radius);
14
+ ctx.quadraticCurveTo(segment.values[index2].x * radius, segment.values[index2].y * radius, segment.values[index3].x * radius, segment.values[index3].y * radius);
14
15
  break;
15
16
  case "arc":
16
- ctx.arc(segment.values[0].x * radius, segment.values[0].y * radius, segment.values[1].x * radius, segment.values[2].x, segment.values[2].y);
17
+ ctx.arc(value.x * radius, value.y * radius, segment.values[index2].x * radius, segment.values[index3].x, segment.values[index3].y);
17
18
  break;
18
19
  case "ellipse":
19
- ctx.ellipse(segment.values[0].x * radius, segment.values[0].y * radius, segment.values[1].x * radius, segment.values[1].y * radius, segment.values[2].x, segment.values[3].x, segment.values[3].y);
20
+ ctx.ellipse(value.x * radius, value.y * radius, segment.values[index2].x * radius, segment.values[index2].y * radius, segment.values[index3].x, segment.values[index4].x, segment.values[index4].y);
20
21
  }
21
22
  }
22
23
  if (!path.half) {
23
24
  return;
24
25
  }
25
- for (let i = path.segments.length - 1; i >= 0; i--) {
26
- const segment = path.segments[i];
26
+ const lengthOffset = 1, minLength = 0;
27
+ for (let i = path.segments.length - lengthOffset; i >= minLength; i--) {
28
+ const segment = path.segments[i], value = segment.values[firstIndex], index2 = 1, index3 = 2;
27
29
  switch (segment.type) {
28
30
  case "line":
29
- ctx.lineTo(segment.values[0].x * -radius, segment.values[0].y * radius);
31
+ ctx.lineTo(value.x * -radius, value.y * radius);
30
32
  break;
31
33
  case "bezier":
32
- ctx.bezierCurveTo(-segment.values[2].x * radius, segment.values[2].y * radius, -segment.values[1].x * radius, segment.values[1].y * radius, -segment.values[0].x * radius, segment.values[0].y * radius);
34
+ ctx.bezierCurveTo(-segment.values[index3].x * radius, segment.values[index3].y * radius, -segment.values[index2].x * radius, segment.values[index2].y * radius, value.x * radius, value.y * radius);
33
35
  break;
34
36
  case "quadratic":
35
- ctx.quadraticCurveTo(-segment.values[1].x * radius, segment.values[1].y * radius, -segment.values[2].x * radius, segment.values[2].y * radius);
37
+ ctx.quadraticCurveTo(-segment.values[index2].x * radius, segment.values[index2].y * radius, -segment.values[index3].x * radius, segment.values[index3].y * radius);
38
+ break;
39
+ case "arc":
40
+ case "ellipse":
41
+ default:
36
42
  break;
37
43
  }
38
44
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tsparticles/shape-path",
3
- "version": "3.0.3",
3
+ "version": "3.1.0",
4
4
  "description": "tsParticles path shape",
5
5
  "homepage": "https://particles.js.org",
6
6
  "repository": {
@@ -100,7 +100,7 @@
100
100
  "./package.json": "./package.json"
101
101
  },
102
102
  "dependencies": {
103
- "@tsparticles/engine": "^3.0.3"
103
+ "@tsparticles/engine": "^3.1.0"
104
104
  },
105
105
  "publishConfig": {
106
106
  "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/shape-path [26 Dec 2023 at 19:30]</title>
6
+ <title>@tsparticles/shape-path [13 Jan 2024 at 23:06]</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.shape.path.js","isAsset":true,"statSize":2621,"parsedSize":6424,"gzipSize":1814,"groups":[{"label":"dist/browser","path":"./dist/browser","statSize":2579,"groups":[{"id":657,"label":"index.js + 2 modules (concatenated)","path":"./dist/browser/index.js + 2 modules (concatenated)","statSize":2579,"parsedSize":6424,"gzipSize":1814,"concatenated":true,"groups":[{"label":"dist/browser","path":"./dist/browser/index.js + 2 modules (concatenated)/dist/browser","statSize":2579,"groups":[{"id":null,"label":"index.js","path":"./dist/browser/index.js + 2 modules (concatenated)/dist/browser/index.js","statSize":169,"parsedSize":420,"gzipSize":118,"inaccurateSizes":true},{"id":null,"label":"PathDrawer.js","path":"./dist/browser/index.js + 2 modules (concatenated)/dist/browser/PathDrawer.js","statSize":470,"parsedSize":1170,"gzipSize":330,"inaccurateSizes":true},{"id":null,"label":"Utils.js","path":"./dist/browser/index.js + 2 modules (concatenated)/dist/browser/Utils.js","statSize":1940,"parsedSize":4832,"gzipSize":1364,"inaccurateSizes":true}],"parsedSize":6424,"gzipSize":1814,"inaccurateSizes":true}]}],"parsedSize":6424,"gzipSize":1814},{"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.shape.path":true}}];
34
+ window.chartData = [{"label":"tsparticles.shape.path.js","isAsset":true,"statSize":2982,"parsedSize":6785,"gzipSize":1911,"groups":[{"label":"dist/browser","path":"./dist/browser","statSize":2940,"groups":[{"id":334,"label":"index.js + 2 modules (concatenated)","path":"./dist/browser/index.js + 2 modules (concatenated)","statSize":2940,"parsedSize":6785,"gzipSize":1911,"concatenated":true,"groups":[{"label":"dist/browser","path":"./dist/browser/index.js + 2 modules (concatenated)/dist/browser","statSize":2940,"groups":[{"id":null,"label":"index.js","path":"./dist/browser/index.js + 2 modules (concatenated)/dist/browser/index.js","statSize":169,"parsedSize":390,"gzipSize":109,"inaccurateSizes":true},{"id":null,"label":"PathDrawer.js","path":"./dist/browser/index.js + 2 modules (concatenated)/dist/browser/PathDrawer.js","statSize":470,"parsedSize":1084,"gzipSize":305,"inaccurateSizes":true},{"id":null,"label":"Utils.js","path":"./dist/browser/index.js + 2 modules (concatenated)/dist/browser/Utils.js","statSize":2301,"parsedSize":5310,"gzipSize":1495,"inaccurateSizes":true}],"parsedSize":6785,"gzipSize":1911,"inaccurateSizes":true}]}],"parsedSize":6785,"gzipSize":1911},{"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.shape.path":true}}];
35
35
  window.entrypoints = ["tsparticles.shape.path","tsparticles.shape.path.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.3
7
+ * v3.1.0
8
8
  */
9
9
  (function webpackUniversalModuleDefinition(root, factory) {
10
10
  if(typeof exports === 'object' && typeof module === 'object')
@@ -98,40 +98,55 @@ __webpack_require__.d(__webpack_exports__, {
98
98
  var engine_root_window_ = __webpack_require__(533);
99
99
  ;// CONCATENATED MODULE: ./dist/browser/Utils.js
100
100
  function drawPath(ctx, radius, path) {
101
- ctx.moveTo(path.segments[0].values[0].x * radius, path.segments[0].values[0].y * radius);
102
- for (let i = 0; i < path.segments.length; i++) {
103
- const segment = path.segments[i];
101
+ const firstIndex = 0,
102
+ firstSegment = path.segments[firstIndex],
103
+ firstValue = firstSegment.values[firstIndex];
104
+ ctx.moveTo(firstValue.x * radius, firstValue.y * radius);
105
+ for (const segment of path.segments) {
106
+ const value = segment.values[firstIndex],
107
+ index2 = 1,
108
+ index3 = 2,
109
+ index4 = 3;
104
110
  switch (segment.type) {
105
111
  case "line":
106
- ctx.lineTo(segment.values[0].x * radius, segment.values[0].y * radius);
112
+ ctx.lineTo(value.x * radius, value.y * radius);
107
113
  break;
108
114
  case "bezier":
109
- ctx.bezierCurveTo(segment.values[1].x * radius, segment.values[1].y * radius, segment.values[2].x * radius, segment.values[2].y * radius, segment.values[3].x * radius, segment.values[3].y * radius);
115
+ ctx.bezierCurveTo(segment.values[index2].x * radius, segment.values[index2].y * radius, segment.values[index3].x * radius, segment.values[index3].y * radius, segment.values[index4].x * radius, segment.values[index4].y * radius);
110
116
  break;
111
117
  case "quadratic":
112
- ctx.quadraticCurveTo(segment.values[1].x * radius, segment.values[1].y * radius, segment.values[2].x * radius, segment.values[2].y * radius);
118
+ ctx.quadraticCurveTo(segment.values[index2].x * radius, segment.values[index2].y * radius, segment.values[index3].x * radius, segment.values[index3].y * radius);
113
119
  break;
114
120
  case "arc":
115
- ctx.arc(segment.values[0].x * radius, segment.values[0].y * radius, segment.values[1].x * radius, segment.values[2].x, segment.values[2].y);
121
+ ctx.arc(value.x * radius, value.y * radius, segment.values[index2].x * radius, segment.values[index3].x, segment.values[index3].y);
116
122
  break;
117
123
  case "ellipse":
118
- ctx.ellipse(segment.values[0].x * radius, segment.values[0].y * radius, segment.values[1].x * radius, segment.values[1].y * radius, segment.values[2].x, segment.values[3].x, segment.values[3].y);
124
+ ctx.ellipse(value.x * radius, value.y * radius, segment.values[index2].x * radius, segment.values[index2].y * radius, segment.values[index3].x, segment.values[index4].x, segment.values[index4].y);
119
125
  }
120
126
  }
121
127
  if (!path.half) {
122
128
  return;
123
129
  }
124
- for (let i = path.segments.length - 1; i >= 0; i--) {
125
- const segment = path.segments[i];
130
+ const lengthOffset = 1,
131
+ minLength = 0;
132
+ for (let i = path.segments.length - lengthOffset; i >= minLength; i--) {
133
+ const segment = path.segments[i],
134
+ value = segment.values[firstIndex],
135
+ index2 = 1,
136
+ index3 = 2;
126
137
  switch (segment.type) {
127
138
  case "line":
128
- ctx.lineTo(segment.values[0].x * -radius, segment.values[0].y * radius);
139
+ ctx.lineTo(value.x * -radius, value.y * radius);
129
140
  break;
130
141
  case "bezier":
131
- ctx.bezierCurveTo(-segment.values[2].x * radius, segment.values[2].y * radius, -segment.values[1].x * radius, segment.values[1].y * radius, -segment.values[0].x * radius, segment.values[0].y * radius);
142
+ ctx.bezierCurveTo(-segment.values[index3].x * radius, segment.values[index3].y * radius, -segment.values[index2].x * radius, segment.values[index2].y * radius, value.x * radius, value.y * radius);
132
143
  break;
133
144
  case "quadratic":
134
- ctx.quadraticCurveTo(-segment.values[1].x * radius, segment.values[1].y * radius, -segment.values[2].x * radius, segment.values[2].y * radius);
145
+ ctx.quadraticCurveTo(-segment.values[index2].x * radius, segment.values[index2].y * radius, -segment.values[index3].x * radius, segment.values[index3].y * radius);
146
+ break;
147
+ case "arc":
148
+ case "ellipse":
149
+ default:
135
150
  break;
136
151
  }
137
152
  }
@@ -1,2 +1,2 @@
1
1
  /*! For license information please see tsparticles.shape.path.min.js.LICENSE.txt */
2
- !function(e,a){if("object"==typeof exports&&"object"==typeof module)module.exports=a(require("@tsparticles/engine"));else if("function"==typeof define&&define.amd)define(["@tsparticles/engine"],a);else{var s="object"==typeof exports?a(require("@tsparticles/engine")):a(e.window);for(var t in s)("object"==typeof exports?exports:e)[t]=s[t]}}(this,(e=>(()=>{"use strict";var a={533:a=>{a.exports=e}},s={};function t(e){var r=s[e];if(void 0!==r)return r.exports;var l=s[e]={exports:{}};return a[e](l,l.exports,t),l.exports}t.d=(e,a)=>{for(var s in a)t.o(a,s)&&!t.o(e,s)&&Object.defineProperty(e,s,{enumerable:!0,get:a[s]})},t.o=(e,a)=>Object.prototype.hasOwnProperty.call(e,a),t.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var r={};return(()=>{t.r(r),t.d(r,{loadPathShape:()=>s});var e=t(533);class a{draw(e){const{context:a,particle:s,radius:t}=e;s.pathData&&function(e,a,s){e.moveTo(s.segments[0].values[0].x*a,s.segments[0].values[0].y*a);for(let t=0;t<s.segments.length;t++){const r=s.segments[t];switch(r.type){case"line":e.lineTo(r.values[0].x*a,r.values[0].y*a);break;case"bezier":e.bezierCurveTo(r.values[1].x*a,r.values[1].y*a,r.values[2].x*a,r.values[2].y*a,r.values[3].x*a,r.values[3].y*a);break;case"quadratic":e.quadraticCurveTo(r.values[1].x*a,r.values[1].y*a,r.values[2].x*a,r.values[2].y*a);break;case"arc":e.arc(r.values[0].x*a,r.values[0].y*a,r.values[1].x*a,r.values[2].x,r.values[2].y);break;case"ellipse":e.ellipse(r.values[0].x*a,r.values[0].y*a,r.values[1].x*a,r.values[1].y*a,r.values[2].x,r.values[3].x,r.values[3].y)}}if(s.half)for(let t=s.segments.length-1;t>=0;t--){const r=s.segments[t];switch(r.type){case"line":e.lineTo(r.values[0].x*-a,r.values[0].y*a);break;case"bezier":e.bezierCurveTo(-r.values[2].x*a,r.values[2].y*a,-r.values[1].x*a,r.values[1].y*a,-r.values[0].x*a,r.values[0].y*a);break;case"quadratic":e.quadraticCurveTo(-r.values[1].x*a,r.values[1].y*a,-r.values[2].x*a,r.values[2].y*a)}}}(a,t,s.pathData)}particleInit(a,s){const t=s.shapeData;t&&(s.pathData=(0,e.deepExtend)({},t))}}async function s(e,s=!0){await e.addShape("path",new a,s)}})(),r})()));
2
+ !function(e,a){if("object"==typeof exports&&"object"==typeof module)module.exports=a(require("@tsparticles/engine"));else if("function"==typeof define&&define.amd)define(["@tsparticles/engine"],a);else{var t="object"==typeof exports?a(require("@tsparticles/engine")):a(e.window);for(var s in t)("object"==typeof exports?exports:e)[s]=t[s]}}(this,(e=>(()=>{"use strict";var a={533:a=>{a.exports=e}},t={};function s(e){var r=t[e];if(void 0!==r)return r.exports;var o=t[e]={exports:{}};return a[e](o,o.exports,s),o.exports}s.d=(e,a)=>{for(var t in a)s.o(a,t)&&!s.o(e,t)&&Object.defineProperty(e,t,{enumerable:!0,get:a[t]})},s.o=(e,a)=>Object.prototype.hasOwnProperty.call(e,a),s.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var r={};return(()=>{s.r(r),s.d(r,{loadPathShape:()=>t});var e=s(533);class a{draw(e){const{context:a,particle:t,radius:s}=e;t.pathData&&function(e,a,t){const s=t.segments[0].values[0];e.moveTo(s.x*a,s.y*a);for(const s of t.segments){const t=s.values[0],r=1,o=2,l=3;switch(s.type){case"line":e.lineTo(t.x*a,t.y*a);break;case"bezier":e.bezierCurveTo(s.values[r].x*a,s.values[r].y*a,s.values[o].x*a,s.values[o].y*a,s.values[l].x*a,s.values[l].y*a);break;case"quadratic":e.quadraticCurveTo(s.values[r].x*a,s.values[r].y*a,s.values[o].x*a,s.values[o].y*a);break;case"arc":e.arc(t.x*a,t.y*a,s.values[r].x*a,s.values[o].x,s.values[o].y);break;case"ellipse":e.ellipse(t.x*a,t.y*a,s.values[r].x*a,s.values[r].y*a,s.values[o].x,s.values[l].x,s.values[l].y)}}if(!t.half)return;for(let s=t.segments.length-1;s>=0;s--){const r=t.segments[s],o=r.values[0],l=1,u=2;switch(r.type){case"line":e.lineTo(o.x*-a,o.y*a);break;case"bezier":e.bezierCurveTo(-r.values[u].x*a,r.values[u].y*a,-r.values[l].x*a,r.values[l].y*a,o.x*a,o.y*a);break;case"quadratic":e.quadraticCurveTo(-r.values[l].x*a,r.values[l].y*a,-r.values[u].x*a,r.values[u].y*a)}}}(a,s,t.pathData)}particleInit(a,t){const s=t.shapeData;s&&(t.pathData=(0,e.deepExtend)({},s))}}async function t(e,t=!0){await e.addShape("path",new a,t)}})(),r})()));
@@ -1 +1 @@
1
- /*! tsParticles Path Shape v3.0.3 by Matteo Bruni */
1
+ /*! tsParticles Path Shape v3.1.0 by Matteo Bruni */
package/umd/Utils.js CHANGED
@@ -11,40 +11,46 @@
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.drawPath = void 0;
13
13
  function drawPath(ctx, radius, path) {
14
- ctx.moveTo(path.segments[0].values[0].x * radius, path.segments[0].values[0].y * radius);
15
- for (let i = 0; i < path.segments.length; i++) {
16
- const segment = path.segments[i];
14
+ const firstIndex = 0, firstSegment = path.segments[firstIndex], firstValue = firstSegment.values[firstIndex];
15
+ ctx.moveTo(firstValue.x * radius, firstValue.y * radius);
16
+ for (const segment of path.segments) {
17
+ const value = segment.values[firstIndex], index2 = 1, index3 = 2, index4 = 3;
17
18
  switch (segment.type) {
18
19
  case "line":
19
- ctx.lineTo(segment.values[0].x * radius, segment.values[0].y * radius);
20
+ ctx.lineTo(value.x * radius, value.y * radius);
20
21
  break;
21
22
  case "bezier":
22
- ctx.bezierCurveTo(segment.values[1].x * radius, segment.values[1].y * radius, segment.values[2].x * radius, segment.values[2].y * radius, segment.values[3].x * radius, segment.values[3].y * radius);
23
+ ctx.bezierCurveTo(segment.values[index2].x * radius, segment.values[index2].y * radius, segment.values[index3].x * radius, segment.values[index3].y * radius, segment.values[index4].x * radius, segment.values[index4].y * radius);
23
24
  break;
24
25
  case "quadratic":
25
- ctx.quadraticCurveTo(segment.values[1].x * radius, segment.values[1].y * radius, segment.values[2].x * radius, segment.values[2].y * radius);
26
+ ctx.quadraticCurveTo(segment.values[index2].x * radius, segment.values[index2].y * radius, segment.values[index3].x * radius, segment.values[index3].y * radius);
26
27
  break;
27
28
  case "arc":
28
- ctx.arc(segment.values[0].x * radius, segment.values[0].y * radius, segment.values[1].x * radius, segment.values[2].x, segment.values[2].y);
29
+ ctx.arc(value.x * radius, value.y * radius, segment.values[index2].x * radius, segment.values[index3].x, segment.values[index3].y);
29
30
  break;
30
31
  case "ellipse":
31
- ctx.ellipse(segment.values[0].x * radius, segment.values[0].y * radius, segment.values[1].x * radius, segment.values[1].y * radius, segment.values[2].x, segment.values[3].x, segment.values[3].y);
32
+ ctx.ellipse(value.x * radius, value.y * radius, segment.values[index2].x * radius, segment.values[index2].y * radius, segment.values[index3].x, segment.values[index4].x, segment.values[index4].y);
32
33
  }
33
34
  }
34
35
  if (!path.half) {
35
36
  return;
36
37
  }
37
- for (let i = path.segments.length - 1; i >= 0; i--) {
38
- const segment = path.segments[i];
38
+ const lengthOffset = 1, minLength = 0;
39
+ for (let i = path.segments.length - lengthOffset; i >= minLength; i--) {
40
+ const segment = path.segments[i], value = segment.values[firstIndex], index2 = 1, index3 = 2;
39
41
  switch (segment.type) {
40
42
  case "line":
41
- ctx.lineTo(segment.values[0].x * -radius, segment.values[0].y * radius);
43
+ ctx.lineTo(value.x * -radius, value.y * radius);
42
44
  break;
43
45
  case "bezier":
44
- ctx.bezierCurveTo(-segment.values[2].x * radius, segment.values[2].y * radius, -segment.values[1].x * radius, segment.values[1].y * radius, -segment.values[0].x * radius, segment.values[0].y * radius);
46
+ ctx.bezierCurveTo(-segment.values[index3].x * radius, segment.values[index3].y * radius, -segment.values[index2].x * radius, segment.values[index2].y * radius, value.x * radius, value.y * radius);
45
47
  break;
46
48
  case "quadratic":
47
- ctx.quadraticCurveTo(-segment.values[1].x * radius, segment.values[1].y * radius, -segment.values[2].x * radius, segment.values[2].y * radius);
49
+ ctx.quadraticCurveTo(-segment.values[index2].x * radius, segment.values[index2].y * radius, -segment.values[index3].x * radius, segment.values[index3].y * radius);
50
+ break;
51
+ case "arc":
52
+ case "ellipse":
53
+ default:
48
54
  break;
49
55
  }
50
56
  }