@tsparticles/shape-circle 3.0.2 → 3.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,26 +1,27 @@
1
- import { isObject } from "@tsparticles/engine";
1
+ import { degToRad, isObject, } from "@tsparticles/engine";
2
+ const double = 2, doublePI = Math.PI * double, sides = 12, maxAngle = 360, minAngle = 0, origin = { x: 0, y: 0 };
2
3
  export class CircleDrawer {
3
4
  draw(data) {
4
5
  const { context, particle, radius } = data;
5
6
  if (!particle.circleRange) {
6
- particle.circleRange = { min: 0, max: Math.PI * 2 };
7
+ particle.circleRange = { min: minAngle, max: doublePI };
7
8
  }
8
9
  const circleRange = particle.circleRange;
9
- context.arc(0, 0, radius, circleRange.min, circleRange.max, false);
10
+ context.arc(origin.x, origin.y, radius, circleRange.min, circleRange.max, false);
10
11
  }
11
12
  getSidesCount() {
12
- return 12;
13
+ return sides;
13
14
  }
14
15
  particleInit(container, particle) {
15
16
  const shapeData = particle.shapeData, angle = shapeData?.angle ?? {
16
- max: 360,
17
- min: 0,
17
+ max: maxAngle,
18
+ min: minAngle,
18
19
  };
19
20
  particle.circleRange = !isObject(angle)
20
21
  ? {
21
- min: 0,
22
- max: (angle * Math.PI) / 180,
22
+ min: minAngle,
23
+ max: degToRad(angle),
23
24
  }
24
- : { min: (angle.min * Math.PI) / 180, max: (angle.max * Math.PI) / 180 };
25
+ : { min: degToRad(angle.min), max: degToRad(angle.max) };
25
26
  }
26
27
  }
@@ -2,29 +2,30 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.CircleDrawer = void 0;
4
4
  const engine_1 = require("@tsparticles/engine");
5
+ const double = 2, doublePI = Math.PI * double, sides = 12, maxAngle = 360, minAngle = 0, origin = { x: 0, y: 0 };
5
6
  class CircleDrawer {
6
7
  draw(data) {
7
8
  const { context, particle, radius } = data;
8
9
  if (!particle.circleRange) {
9
- particle.circleRange = { min: 0, max: Math.PI * 2 };
10
+ particle.circleRange = { min: minAngle, max: doublePI };
10
11
  }
11
12
  const circleRange = particle.circleRange;
12
- context.arc(0, 0, radius, circleRange.min, circleRange.max, false);
13
+ context.arc(origin.x, origin.y, radius, circleRange.min, circleRange.max, false);
13
14
  }
14
15
  getSidesCount() {
15
- return 12;
16
+ return sides;
16
17
  }
17
18
  particleInit(container, particle) {
18
19
  const shapeData = particle.shapeData, angle = shapeData?.angle ?? {
19
- max: 360,
20
- min: 0,
20
+ max: maxAngle,
21
+ min: minAngle,
21
22
  };
22
23
  particle.circleRange = !(0, engine_1.isObject)(angle)
23
24
  ? {
24
- min: 0,
25
- max: (angle * Math.PI) / 180,
25
+ min: minAngle,
26
+ max: (0, engine_1.degToRad)(angle),
26
27
  }
27
- : { min: (angle.min * Math.PI) / 180, max: (angle.max * Math.PI) / 180 };
28
+ : { min: (0, engine_1.degToRad)(angle.min), max: (0, engine_1.degToRad)(angle.max) };
28
29
  }
29
30
  }
30
31
  exports.CircleDrawer = CircleDrawer;
@@ -1,26 +1,27 @@
1
- import { isObject } from "@tsparticles/engine";
1
+ import { degToRad, isObject, } from "@tsparticles/engine";
2
+ const double = 2, doublePI = Math.PI * double, sides = 12, maxAngle = 360, minAngle = 0, origin = { x: 0, y: 0 };
2
3
  export class CircleDrawer {
3
4
  draw(data) {
4
5
  const { context, particle, radius } = data;
5
6
  if (!particle.circleRange) {
6
- particle.circleRange = { min: 0, max: Math.PI * 2 };
7
+ particle.circleRange = { min: minAngle, max: doublePI };
7
8
  }
8
9
  const circleRange = particle.circleRange;
9
- context.arc(0, 0, radius, circleRange.min, circleRange.max, false);
10
+ context.arc(origin.x, origin.y, radius, circleRange.min, circleRange.max, false);
10
11
  }
11
12
  getSidesCount() {
12
- return 12;
13
+ return sides;
13
14
  }
14
15
  particleInit(container, particle) {
15
16
  const shapeData = particle.shapeData, angle = shapeData?.angle ?? {
16
- max: 360,
17
- min: 0,
17
+ max: maxAngle,
18
+ min: minAngle,
18
19
  };
19
20
  particle.circleRange = !isObject(angle)
20
21
  ? {
21
- min: 0,
22
- max: (angle * Math.PI) / 180,
22
+ min: minAngle,
23
+ max: degToRad(angle),
23
24
  }
24
- : { min: (angle.min * Math.PI) / 180, max: (angle.max * Math.PI) / 180 };
25
+ : { min: degToRad(angle.min), max: degToRad(angle.max) };
25
26
  }
26
27
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tsparticles/shape-circle",
3
- "version": "3.0.2",
3
+ "version": "3.1.0",
4
4
  "description": "tsParticles circle shape",
5
5
  "homepage": "https://particles.js.org",
6
6
  "repository": {
@@ -59,7 +59,7 @@
59
59
  "./package.json": "./package.json"
60
60
  },
61
61
  "dependencies": {
62
- "@tsparticles/engine": "^3.0.2"
62
+ "@tsparticles/engine": "^3.1.0"
63
63
  },
64
64
  "publishConfig": {
65
65
  "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-circle [6 Dec 2023 at 17:44]</title>
6
+ <title>@tsparticles/shape-circle [13 Jan 2024 at 23:06]</title>
7
7
  <link rel="shortcut icon" href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAMAAACdt4HsAAABrVBMVEUAAAD///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////+O1foceMD///+J0/qK1Pr7/v8Xdr/9///W8P4UdL7L7P0Scr2r4Pyj3vwad8D5/f/2/f+55f3E6f34+/2H0/ojfMKpzOd0rNgQcb3F3O/j9f7c8v6g3Pz0/P/w+v/q+P7n9v6T1/uQ1vuE0vqLut/y+v+Z2fvt+f+15Pzv9fuc2/vR7v2V2Pvd6/bg9P7I6/285/2y4/yp3/zp8vk8i8kqgMT7/P31+fyv4vxGkcz6/P6/6P3j7vfS5PNnpNUxhcbO7f7F6v3O4vHK3/DA2u631Ouy0eqXweKJud5wqthfoNMMbLvY8f73+v2dxeR8sNtTmdDx9/zX6PSjyeaCtd1YnNGX2PuQveCGt95Nls42h8dLlM3F4vBtAAAAM3RSTlMAAyOx0/sKBvik8opWGBMOAe3l1snDm2E9LSb06eHcu5JpHbarfHZCN9CBb08zzkdNS0kYaptYAAAFV0lEQVRYw92X51/aYBDHHS2O2qqttVbrqNq9m+TJIAYIShBkWwqIiCgoWvfeq7Z2/s29hyQNyUcR7LveGwVyXy6XH8/9rqxglLfUPLxVduUor3h0rfp2TYvpivk37929TkG037hffoX0+peVtZQc1589rigVUdXS/ABSAyEmGIO/1XfvldSK8vs3OqB6u3m0nxmIrvgB0dj7rr7Y9IbuF68hnfFaiHA/sxqm0wciIG43P60qKv9WXWc1RXGh/mFESFABTSBi0sNAKzqet17eCtOb3kZIDwxEEU0oAIJGYxNBDhBND29e0rtXXbcpuPmED9IhEAAQ/AXEaF8EPmnrrKsv0LvWR3fg5sWDNAFZOgAgaKvZDogHNU9MFwnnYROkc56RD5CjAbQX9Ow4g7upCsvYu55aSI/Nj0H1akgKQEUM94dwK65hYRmFU9MIcH/fqJYOZYcnuJSU/waKDgTOEVaVKhwrTRP5XzgSpAITYzom7UvkhFX5VutmxeNnWDjjswTKTyfgluNDGbUpWissXhF3s7mlSml+czWkg3D0l1nNjGNjz3myOQOa1KM/jOS6ebdbAVTCi4gljHSFrviza7tOgRWcS0MOUX9zdNgag5w7rRqA44Lzw0hr1WqES36dFliSJFlh2rXIae3FFcDDgKdxrUIDePr8jGcSClV1u7A9xeN0ModY/pHMxmR1EzRh8TJiwqsHmKW0l4FCEZI+jHio+JdPPE9qwQtTRxku2D8sIeRL2LnxWSllANCQGOIiqVHAz2ye2JR0DcH+HoxDkaADLjgxjKQ+AwCX/g0+DNgdG0ukYCONAe+dbc2IAc6fwt1ARoDSezNHxV2Cmzwv3O6lDMV55edBGwGK9n1+x2F8EDfAGCxug8MhpsMEcTEAWf3rx2vZhe/LAmtIn/6apE6PN0ULKgywD9mmdxbmFl3OvD5AS5fW5zLbv/YHmcsBTjf/afDz3MaZTVCfAP9z6/Bw6ycv8EUBWJIn9zYcoAWWlW9+OzO3vkTy8H+RANLmdrpOuYWdZYEXpo+TlCJrW5EARb7fF+bWdqf3hhyZI1nWJQHgznErZhbjoEsWqi8dQNoE294aldzFurwSABL2XXMf9+H1VQGke9exw5P/AnA5Pv5ngMul7LOvO922iwACu8WkCwLCafvM4CeWPxfA8lNHcWZSoi8EwMAIciKX2Z4SWCMAa3snCZ/G4EA8D6CMLNFsGQhkkz/gQNEBbPCbWsxGUpYVu3z8IyNAknwJkfPMEhLyrdi5RTyUVACkw4GSFRNWJNEW+fgPGwHD8/JxnRuLabN4CGNRkAE23na2+VmEAUmrYymSGjMAYqH84YUIyzgzs3XC7gNgH36Vcc4zKY9o9fgPBXUAiHHwVboBHGLiX6Zcjp1f2wu4tvzZKo0ecPnDtQYDQvJXaBeNzce45Fp28ZQLrEZVuFqgBwOalArKXnW1UzlnSusQKJqKYNuz4tOnI6sZG4zanpemv+7ySU2jbA9h6uhcgpfy6G2PahirDZ6zvq6zDduMVFTKvzw8wgyEdelwY9in3XkEPs3osJuwRQ4qTkfzifndg9Gfc4pdsu82+tTnHZTBa2EAMrqr2t43pguc8tNm7JQVQ2S0ukj2d22dhXYP0/veWtwKrCkNoNimAN5+Xr/oLrxswKbVJjteWrX7eR63o4j9q0GxnaBdWgGA5VStpanIjQmEhV0/nVt5VOFUvix6awJhPcAaTEShgrG+iGyvb5a0Ndb1YGHFPEwoqAinoaykaID1o1pdPNu7XsnCKQ3R+hwWIIhGvORcJUBYXe3Xa3vq/mF/N9V13ugufMkfXn+KHsRD0B8AAAAASUVORK5CYII=" 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.circle.js","isAsset":true,"statSize":1013,"parsedSize":4815,"gzipSize":1631,"groups":[{"label":"dist/browser","path":"./dist/browser","statSize":971,"groups":[{"id":130,"label":"index.js + 1 modules (concatenated)","path":"./dist/browser/index.js + 1 modules (concatenated)","statSize":971,"parsedSize":4815,"gzipSize":1631,"concatenated":true,"groups":[{"label":"dist/browser","path":"./dist/browser/index.js + 1 modules (concatenated)/dist/browser","statSize":971,"groups":[{"id":null,"label":"index.js","path":"./dist/browser/index.js + 1 modules (concatenated)/dist/browser/index.js","statSize":179,"parsedSize":887,"gzipSize":300,"inaccurateSizes":true},{"id":null,"label":"CircleDrawer.js","path":"./dist/browser/index.js + 1 modules (concatenated)/dist/browser/CircleDrawer.js","statSize":792,"parsedSize":3927,"gzipSize":1330,"inaccurateSizes":true}],"parsedSize":4815,"gzipSize":1631,"inaccurateSizes":true}]}],"parsedSize":4815,"gzipSize":1631},{"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.circle":true}}];
34
+ window.chartData = [{"label":"tsparticles.shape.circle.js","isAsset":true,"statSize":1179,"parsedSize":5069,"gzipSize":1697,"groups":[{"label":"dist/browser","path":"./dist/browser","statSize":1137,"groups":[{"id":549,"label":"index.js + 1 modules (concatenated)","path":"./dist/browser/index.js + 1 modules (concatenated)","statSize":1137,"parsedSize":5069,"gzipSize":1697,"concatenated":true,"groups":[{"label":"dist/browser","path":"./dist/browser/index.js + 1 modules (concatenated)/dist/browser","statSize":1137,"groups":[{"id":null,"label":"index.js","path":"./dist/browser/index.js + 1 modules (concatenated)/dist/browser/index.js","statSize":179,"parsedSize":798,"gzipSize":267,"inaccurateSizes":true},{"id":null,"label":"CircleDrawer.js","path":"./dist/browser/index.js + 1 modules (concatenated)/dist/browser/CircleDrawer.js","statSize":958,"parsedSize":4270,"gzipSize":1429,"inaccurateSizes":true}],"parsedSize":5069,"gzipSize":1697,"inaccurateSizes":true}]}],"parsedSize":5069,"gzipSize":1697},{"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.circle":true}}];
35
35
  window.entrypoints = ["tsparticles.shape.circle","tsparticles.shape.circle.min"];
36
36
  window.defaultSizes = "parsed";
37
37
  </script>
@@ -4,7 +4,7 @@
4
4
  * Demo / Generator : https://particles.js.org/
5
5
  * GitHub : https://www.github.com/matteobruni/tsparticles
6
6
  * How to use? : Check the GitHub README
7
- * v3.0.2
7
+ * v3.1.0
8
8
  */
9
9
  (function webpackUniversalModuleDefinition(root, factory) {
10
10
  if(typeof exports === 'object' && typeof module === 'object')
@@ -98,6 +98,15 @@ __webpack_require__.d(__webpack_exports__, {
98
98
  var engine_root_window_ = __webpack_require__(533);
99
99
  ;// CONCATENATED MODULE: ./dist/browser/CircleDrawer.js
100
100
 
101
+ const CircleDrawer_double = 2,
102
+ doublePI = Math.PI * CircleDrawer_double,
103
+ sides = 12,
104
+ maxAngle = 360,
105
+ minAngle = 0,
106
+ origin = {
107
+ x: 0,
108
+ y: 0
109
+ };
101
110
  class CircleDrawer {
102
111
  draw(data) {
103
112
  const {
@@ -107,28 +116,28 @@ class CircleDrawer {
107
116
  } = data;
108
117
  if (!particle.circleRange) {
109
118
  particle.circleRange = {
110
- min: 0,
111
- max: Math.PI * 2
119
+ min: minAngle,
120
+ max: doublePI
112
121
  };
113
122
  }
114
123
  const circleRange = particle.circleRange;
115
- context.arc(0, 0, radius, circleRange.min, circleRange.max, false);
124
+ context.arc(origin.x, origin.y, radius, circleRange.min, circleRange.max, false);
116
125
  }
117
126
  getSidesCount() {
118
- return 12;
127
+ return sides;
119
128
  }
120
129
  particleInit(container, particle) {
121
130
  const shapeData = particle.shapeData,
122
131
  angle = shapeData?.angle ?? {
123
- max: 360,
124
- min: 0
132
+ max: maxAngle,
133
+ min: minAngle
125
134
  };
126
135
  particle.circleRange = !(0,engine_root_window_.isObject)(angle) ? {
127
- min: 0,
128
- max: angle * Math.PI / 180
136
+ min: minAngle,
137
+ max: (0,engine_root_window_.degToRad)(angle)
129
138
  } : {
130
- min: angle.min * Math.PI / 180,
131
- max: angle.max * Math.PI / 180
139
+ min: (0,engine_root_window_.degToRad)(angle.min),
140
+ max: (0,engine_root_window_.degToRad)(angle.max)
132
141
  };
133
142
  }
134
143
  }
@@ -1,2 +1,2 @@
1
1
  /*! For license information please see tsparticles.shape.circle.min.js.LICENSE.txt */
2
- !function(e,t){if("object"==typeof exports&&"object"==typeof module)module.exports=t(require("@tsparticles/engine"));else if("function"==typeof define&&define.amd)define(["@tsparticles/engine"],t);else{var r="object"==typeof exports?t(require("@tsparticles/engine")):t(e.window);for(var n in r)("object"==typeof exports?exports:e)[n]=r[n]}}(this,(e=>(()=>{"use strict";var t={533:t=>{t.exports=e}},r={};function n(e){var o=r[e];if(void 0!==o)return o.exports;var a=r[e]={exports:{}};return t[e](a,a.exports,n),a.exports}n.d=(e,t)=>{for(var r in t)n.o(t,r)&&!n.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},n.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),n.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var o={};return(()=>{n.r(o),n.d(o,{loadCircleShape:()=>r});var e=n(533);class t{draw(e){const{context:t,particle:r,radius:n}=e;r.circleRange||(r.circleRange={min:0,max:2*Math.PI});const o=r.circleRange;t.arc(0,0,n,o.min,o.max,!1)}getSidesCount(){return 12}particleInit(t,r){const n=r.shapeData,o=n?.angle??{max:360,min:0};r.circleRange=(0,e.isObject)(o)?{min:o.min*Math.PI/180,max:o.max*Math.PI/180}:{min:0,max:o*Math.PI/180}}}async function r(e,r=!0){await e.addShape("circle",new t,r)}})(),o})()));
2
+ !function(e,t){if("object"==typeof exports&&"object"==typeof module)module.exports=t(require("@tsparticles/engine"));else if("function"==typeof define&&define.amd)define(["@tsparticles/engine"],t);else{var r="object"==typeof exports?t(require("@tsparticles/engine")):t(e.window);for(var o in r)("object"==typeof exports?exports:e)[o]=r[o]}}(this,(e=>(()=>{"use strict";var t={533:t=>{t.exports=e}},r={};function o(e){var n=r[e];if(void 0!==n)return n.exports;var a=r[e]={exports:{}};return t[e](a,a.exports,o),a.exports}o.d=(e,t)=>{for(var r in t)o.o(t,r)&&!o.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},o.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),o.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var n={};return(()=>{o.r(n),o.d(n,{loadCircleShape:()=>c});var e=o(533);const t=2*Math.PI,r=0,a=0;class i{draw(e){const{context:o,particle:n,radius:i}=e;n.circleRange||(n.circleRange={min:0,max:t});const c=n.circleRange;o.arc(r,a,i,c.min,c.max,!1)}getSidesCount(){return 12}particleInit(t,r){const o=r.shapeData,n=o?.angle??{max:360,min:0};r.circleRange=(0,e.isObject)(n)?{min:(0,e.degToRad)(n.min),max:(0,e.degToRad)(n.max)}:{min:0,max:(0,e.degToRad)(n)}}}async function c(e,t=!0){await e.addShape("circle",new i,t)}})(),n})()));
@@ -1 +1 @@
1
- /*! tsParticles Circle Shape v3.0.2 by Matteo Bruni */
1
+ /*! tsParticles Circle Shape v3.1.0 by Matteo Bruni */
@@ -11,29 +11,30 @@
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.CircleDrawer = void 0;
13
13
  const engine_1 = require("@tsparticles/engine");
14
+ const double = 2, doublePI = Math.PI * double, sides = 12, maxAngle = 360, minAngle = 0, origin = { x: 0, y: 0 };
14
15
  class CircleDrawer {
15
16
  draw(data) {
16
17
  const { context, particle, radius } = data;
17
18
  if (!particle.circleRange) {
18
- particle.circleRange = { min: 0, max: Math.PI * 2 };
19
+ particle.circleRange = { min: minAngle, max: doublePI };
19
20
  }
20
21
  const circleRange = particle.circleRange;
21
- context.arc(0, 0, radius, circleRange.min, circleRange.max, false);
22
+ context.arc(origin.x, origin.y, radius, circleRange.min, circleRange.max, false);
22
23
  }
23
24
  getSidesCount() {
24
- return 12;
25
+ return sides;
25
26
  }
26
27
  particleInit(container, particle) {
27
28
  const shapeData = particle.shapeData, angle = shapeData?.angle ?? {
28
- max: 360,
29
- min: 0,
29
+ max: maxAngle,
30
+ min: minAngle,
30
31
  };
31
32
  particle.circleRange = !(0, engine_1.isObject)(angle)
32
33
  ? {
33
- min: 0,
34
- max: (angle * Math.PI) / 180,
34
+ min: minAngle,
35
+ max: (0, engine_1.degToRad)(angle),
35
36
  }
36
- : { min: (angle.min * Math.PI) / 180, max: (angle.max * Math.PI) / 180 };
37
+ : { min: (0, engine_1.degToRad)(angle.min), max: (0, engine_1.degToRad)(angle.max) };
37
38
  }
38
39
  }
39
40
  exports.CircleDrawer = CircleDrawer;