masoneffect 0.1.18 → 0.1.20

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.
Files changed (41) hide show
  1. package/README.md +1 -1
  2. package/dist/core/index.d.ts.map +1 -1
  3. package/dist/index.cjs +1 -0
  4. package/dist/index.mjs +1 -0
  5. package/dist/react/MasonEffect.cjs +1 -526
  6. package/dist/react/MasonEffect.d.ts.map +1 -1
  7. package/dist/react/MasonEffect.mjs +1 -0
  8. package/dist/react/core/index.d.ts +0 -1
  9. package/dist/react/core/index.d.ts.map +1 -1
  10. package/dist/react/index.d.ts +2 -8
  11. package/dist/react/index.mjs +1 -0
  12. package/dist/react/index.umd.d.ts +0 -1
  13. package/dist/react/react/MasonEffect.d.ts +0 -1
  14. package/dist/react/react/MasonEffect.d.ts.map +1 -1
  15. package/dist/react/react/index.d.ts +2 -0
  16. package/dist/react/react/index.d.ts.map +1 -0
  17. package/dist/react/vue/index.d.ts +5 -0
  18. package/dist/react/vue/index.d.ts.map +1 -0
  19. package/dist/vue/index.cjs +1 -0
  20. package/dist/vue/index.d.ts +90 -0
  21. package/{src/core/index.ts → dist/vue/index.mjs} +227 -237
  22. package/package.json +14 -15
  23. package/dist/index.esm.js +0 -387
  24. package/dist/index.esm.js.map +0 -1
  25. package/dist/index.esm.min.js +0 -1
  26. package/dist/index.js +0 -392
  27. package/dist/index.js.map +0 -1
  28. package/dist/index.min.js +0 -1
  29. package/dist/index.umd.js +0 -396
  30. package/dist/index.umd.js.map +0 -1
  31. package/dist/index.umd.min.js +0 -1
  32. package/dist/react/MasonEffect.cjs.map +0 -1
  33. package/dist/react/MasonEffect.js +0 -524
  34. package/dist/react/MasonEffect.js.map +0 -1
  35. package/dist/react/MasonEffect.min.cjs +0 -1
  36. package/dist/react/MasonEffect.min.js +0 -1
  37. package/src/index.ts +0 -14
  38. package/src/index.umd.ts +0 -10
  39. package/src/react/MasonEffect.tsx +0 -228
  40. package/src/react/index.js +0 -2
  41. package/src/vue/MasonEffect.vue +0 -140
package/dist/index.js DELETED
@@ -1,392 +0,0 @@
1
- 'use strict';
2
-
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
- /**
6
- * MasonEffect - 파티클 모핑 효과 라이브러리
7
- * 바닐라 JS 코어 클래스
8
- */
9
- // 디바운스 유틸리티 함수
10
- function debounce(func, wait) {
11
- let timeout = null;
12
- return function executedFunction(...args) {
13
- const later = () => {
14
- timeout = null;
15
- func.apply(this, args);
16
- };
17
- if (timeout !== null) {
18
- clearTimeout(timeout);
19
- }
20
- timeout = setTimeout(later, wait);
21
- };
22
- }
23
- class MasonEffect {
24
- constructor(container, options = {}) {
25
- // 컨테이너 요소
26
- this.container = typeof container === 'string'
27
- ? document.querySelector(container)
28
- : container;
29
- if (!this.container) {
30
- throw new Error('Container element not found');
31
- }
32
- // 설정값들
33
- this.config = {
34
- text: options.text || 'mason effect',
35
- densityStep: options.densityStep ?? 2,
36
- maxParticles: options.maxParticles ?? 3200,
37
- pointSize: options.pointSize ?? 0.5,
38
- ease: options.ease ?? 0.05,
39
- repelRadius: options.repelRadius ?? 150,
40
- repelStrength: options.repelStrength ?? 1,
41
- particleColor: options.particleColor || '#fff',
42
- fontFamily: options.fontFamily || 'Inter, system-ui, Arial',
43
- fontSize: options.fontSize || null,
44
- width: options.width || null,
45
- height: options.height || null,
46
- devicePixelRatio: options.devicePixelRatio ?? null,
47
- onReady: options.onReady || null,
48
- onUpdate: options.onUpdate || null,
49
- };
50
- // 캔버스 생성
51
- this.canvas = document.createElement('canvas');
52
- const ctx = this.canvas.getContext('2d');
53
- if (!ctx) {
54
- throw new Error('Canvas context not available');
55
- }
56
- this.ctx = ctx;
57
- this.container.appendChild(this.canvas);
58
- this.canvas.style.display = 'block';
59
- // 오프스크린 캔버스 (텍스트 렌더링용)
60
- this.offCanvas = document.createElement('canvas');
61
- const offCtx = this.offCanvas.getContext('2d');
62
- if (!offCtx) {
63
- throw new Error('Offscreen canvas context not available');
64
- }
65
- this.offCtx = offCtx;
66
- // 상태
67
- this.W = 0;
68
- this.H = 0;
69
- this.DPR = this.config.devicePixelRatio || Math.min(window.devicePixelRatio || 1, 1.8);
70
- this.particles = [];
71
- this.mouse = { x: 0, y: 0, down: false };
72
- this.animationId = null;
73
- this.isRunning = false;
74
- this.isVisible = false;
75
- this.intersectionObserver = null;
76
- // 디바운스 설정 (ms)
77
- this.debounceDelay = options.debounceDelay ?? 150;
78
- // 이벤트 핸들러 바인딩 (디바운스 적용 전에 바인딩)
79
- const boundHandleResize = this.handleResize.bind(this);
80
- this.handleResize = debounce(boundHandleResize, this.debounceDelay);
81
- this.handleMouseMove = this.handleMouseMove.bind(this);
82
- this.handleMouseLeave = this.handleMouseLeave.bind(this);
83
- this.handleMouseDown = this.handleMouseDown.bind(this);
84
- this.handleMouseUp = this.handleMouseUp.bind(this);
85
- // morph와 updateConfig를 위한 디바운스된 내부 메서드
86
- this._debouncedMorph = debounce(this._morphInternal.bind(this), this.debounceDelay);
87
- this._debouncedUpdateConfig = debounce(this._updateConfigInternal.bind(this), this.debounceDelay);
88
- // 초기화
89
- this.init();
90
- }
91
- init() {
92
- this.resize();
93
- this.setupEventListeners();
94
- this.setupIntersectionObserver();
95
- if (this.config.onReady) {
96
- this.config.onReady(this);
97
- }
98
- }
99
- setupIntersectionObserver() {
100
- // IntersectionObserver가 지원되지 않는 환경에서는 항상 재생
101
- if (typeof window === 'undefined' || typeof window.IntersectionObserver === 'undefined') {
102
- this.isVisible = true;
103
- this.start();
104
- return;
105
- }
106
- // 이미 설정되어 있다면 다시 만들지 않음
107
- if (this.intersectionObserver) {
108
- return;
109
- }
110
- this.intersectionObserver = new IntersectionObserver((entries) => {
111
- for (const entry of entries) {
112
- if (entry.target !== this.container)
113
- continue;
114
- if (entry.isIntersecting) {
115
- this.isVisible = true;
116
- this.start();
117
- }
118
- else {
119
- this.isVisible = false;
120
- this.stop();
121
- }
122
- }
123
- }, {
124
- threshold: 0.1, // 10% 이상 보일 때 동작
125
- });
126
- this.intersectionObserver.observe(this.container);
127
- }
128
- resize() {
129
- const width = this.config.width || this.container.clientWidth || window.innerWidth;
130
- const height = this.config.height || this.container.clientHeight || window.innerHeight * 0.7;
131
- this.W = Math.floor(width * this.DPR);
132
- this.H = Math.floor(height * this.DPR);
133
- this.canvas.width = this.W;
134
- this.canvas.height = this.H;
135
- this.canvas.style.width = width + 'px';
136
- this.canvas.style.height = height + 'px';
137
- this.buildTargets();
138
- if (!this.particles.length) {
139
- this.initParticles();
140
- }
141
- }
142
- buildTargets() {
143
- const text = this.config.text;
144
- this.offCanvas.width = this.W;
145
- this.offCanvas.height = this.H;
146
- this.offCtx.clearRect(0, 0, this.offCanvas.width, this.offCanvas.height);
147
- const base = Math.min(this.W, this.H);
148
- const fontSize = this.config.fontSize || Math.max(80, Math.floor(base * 0.18));
149
- this.offCtx.fillStyle = '#ffffff';
150
- this.offCtx.textAlign = 'center';
151
- this.offCtx.textBaseline = 'middle';
152
- this.offCtx.font = `400 ${fontSize}px ${this.config.fontFamily}`;
153
- // 글자 간격 계산 및 그리기
154
- const chars = text.split('');
155
- const spacing = fontSize * 0.05;
156
- const totalWidth = this.offCtx.measureText(text).width + spacing * (chars.length - 1);
157
- let x = this.W / 2 - totalWidth / 2;
158
- for (const ch of chars) {
159
- this.offCtx.fillText(ch, x + this.offCtx.measureText(ch).width / 2, this.H / 2);
160
- x += this.offCtx.measureText(ch).width + spacing;
161
- }
162
- // 픽셀 샘플링
163
- const step = Math.max(2, this.config.densityStep);
164
- const img = this.offCtx.getImageData(0, 0, this.W, this.H).data;
165
- const targets = [];
166
- for (let y = 0; y < this.H; y += step) {
167
- for (let x = 0; x < this.W; x += step) {
168
- const i = (y * this.W + x) * 4;
169
- if (img[i] + img[i + 1] + img[i + 2] > 600) {
170
- targets.push({ x, y });
171
- }
172
- }
173
- }
174
- // 파티클 수 제한
175
- while (targets.length > this.config.maxParticles) {
176
- targets.splice(Math.floor(Math.random() * targets.length), 1);
177
- }
178
- // 파티클 수 조정
179
- if (this.particles.length < targets.length) {
180
- const need = targets.length - this.particles.length;
181
- for (let i = 0; i < need; i++) {
182
- this.particles.push(this.makeParticle());
183
- }
184
- }
185
- else if (this.particles.length > targets.length) {
186
- this.particles.length = targets.length;
187
- }
188
- // 목표 좌표 할당
189
- for (let i = 0; i < this.particles.length; i++) {
190
- const p = this.particles[i];
191
- const t = targets[i];
192
- p.tx = t.x;
193
- p.ty = t.y;
194
- }
195
- }
196
- makeParticle() {
197
- // 캔버스 전체에 골고루 분포 (여백 없이)
198
- const sx = Math.random() * this.W;
199
- const sy = Math.random() * this.H;
200
- return {
201
- x: sx,
202
- y: sy,
203
- vx: 0,
204
- vy: 0,
205
- tx: sx,
206
- ty: sy,
207
- initialX: sx, // 초기 위치 저장 (scatter 시 돌아갈 위치)
208
- initialY: sy,
209
- j: Math.random() * Math.PI * 2,
210
- };
211
- }
212
- initParticles() {
213
- // 캔버스 전체에 골고루 분포 (여백 없이)
214
- for (const p of this.particles) {
215
- const sx = Math.random() * this.W;
216
- const sy = Math.random() * this.H;
217
- p.x = sx;
218
- p.y = sy;
219
- p.vx = p.vy = 0;
220
- // 초기 위치 저장 (scatter 시 돌아갈 위치)
221
- p.initialX = sx;
222
- p.initialY = sy;
223
- }
224
- }
225
- scatter() {
226
- // 각 파티클을 초기 위치로 돌아가도록 설정
227
- for (const p of this.particles) {
228
- // 초기 위치가 저장되어 있으면 그 위치로, 없으면 현재 위치 유지
229
- if (p.initialX !== undefined && p.initialY !== undefined) {
230
- p.tx = p.initialX;
231
- p.ty = p.initialY;
232
- }
233
- else {
234
- // 초기 위치가 없으면 현재 위치를 초기 위치로 저장
235
- p.initialX = p.x;
236
- p.initialY = p.y;
237
- p.tx = p.initialX;
238
- p.ty = p.initialY;
239
- }
240
- }
241
- }
242
- morph(textOrOptions) {
243
- // 즉시 실행이 필요한 경우 (예: 초기화 시)를 위해 내부 메서드 직접 호출
244
- // 일반적인 경우에는 디바운스 적용
245
- this._debouncedMorph(textOrOptions);
246
- }
247
- _morphInternal(textOrOptions) {
248
- // W와 H가 0이면 resize 먼저 실행
249
- if (this.W === 0 || this.H === 0) {
250
- this.resize();
251
- }
252
- if (typeof textOrOptions === 'string') {
253
- // 문자열인 경우: 기존 동작 유지
254
- this.config.text = textOrOptions;
255
- this.buildTargets();
256
- }
257
- else if (textOrOptions && typeof textOrOptions === 'object') {
258
- // 객체인 경우: 텍스트와 함께 다른 설정도 변경
259
- const needsRebuild = textOrOptions.text !== undefined;
260
- this.config = { ...this.config, ...textOrOptions };
261
- if (needsRebuild) {
262
- this.buildTargets();
263
- }
264
- }
265
- else {
266
- // null이거나 undefined인 경우: 현재 텍스트로 재빌드
267
- this.buildTargets();
268
- }
269
- }
270
- update() {
271
- this.ctx.clearRect(0, 0, this.W, this.H);
272
- for (const p of this.particles) {
273
- // 목표 좌표로 당기는 힘
274
- let ax = (p.tx - p.x) * this.config.ease;
275
- let ay = (p.ty - p.y) * this.config.ease;
276
- // 마우스 반발/흡입
277
- if (this.mouse.x || this.mouse.y) {
278
- const dx = p.x - this.mouse.x;
279
- const dy = p.y - this.mouse.y;
280
- const d2 = dx * dx + dy * dy;
281
- const r = this.config.repelRadius * this.DPR;
282
- if (d2 < r * r) {
283
- const d = Math.sqrt(d2) + 0.0001;
284
- const f = (this.mouse.down ? -1 : 1) * this.config.repelStrength * (1 - d / r);
285
- ax += (dx / d) * f * 6.0;
286
- ay += (dy / d) * f * 6.0;
287
- }
288
- }
289
- // 진동 효과
290
- p.j += 2;
291
- ax += Math.cos(p.j) * 0.05;
292
- ay += Math.sin(p.j * 1.3) * 0.05;
293
- // 속도와 위치 업데이트
294
- p.vx = (p.vx + ax) * Math.random();
295
- p.vy = (p.vy + ay) * Math.random();
296
- p.x += p.vx;
297
- p.y += p.vy;
298
- }
299
- // 파티클 그리기
300
- this.ctx.fillStyle = this.config.particleColor;
301
- const r = this.config.pointSize * this.DPR;
302
- for (const p of this.particles) {
303
- this.ctx.beginPath();
304
- this.ctx.arc(p.x, p.y, r, 0, Math.PI * 2);
305
- this.ctx.fill();
306
- }
307
- if (this.config.onUpdate) {
308
- this.config.onUpdate(this);
309
- }
310
- }
311
- animate() {
312
- if (!this.isRunning)
313
- return;
314
- this.update();
315
- this.animationId = requestAnimationFrame(() => this.animate());
316
- }
317
- start() {
318
- if (this.isRunning)
319
- return;
320
- this.isRunning = true;
321
- this.animate();
322
- }
323
- stop() {
324
- this.isRunning = false;
325
- if (this.animationId) {
326
- cancelAnimationFrame(this.animationId);
327
- this.animationId = null;
328
- }
329
- }
330
- setupEventListeners() {
331
- window.addEventListener('resize', this.handleResize);
332
- this.canvas.addEventListener('mousemove', this.handleMouseMove);
333
- this.canvas.addEventListener('mouseleave', this.handleMouseLeave);
334
- this.canvas.addEventListener('mousedown', this.handleMouseDown);
335
- window.addEventListener('mouseup', this.handleMouseUp);
336
- }
337
- removeEventListeners() {
338
- window.removeEventListener('resize', this.handleResize);
339
- this.canvas.removeEventListener('mousemove', this.handleMouseMove);
340
- this.canvas.removeEventListener('mouseleave', this.handleMouseLeave);
341
- this.canvas.removeEventListener('mousedown', this.handleMouseDown);
342
- window.removeEventListener('mouseup', this.handleMouseUp);
343
- }
344
- handleResize() {
345
- this.resize();
346
- }
347
- handleMouseMove(e) {
348
- const rect = this.canvas.getBoundingClientRect();
349
- this.mouse.x = (e.clientX - rect.left) * this.DPR;
350
- this.mouse.y = (e.clientY - rect.top) * this.DPR;
351
- }
352
- handleMouseLeave() {
353
- this.mouse.x = this.mouse.y = 0;
354
- }
355
- handleMouseDown() {
356
- this.mouse.down = true;
357
- }
358
- handleMouseUp() {
359
- this.mouse.down = false;
360
- }
361
- // 설정 업데이트
362
- updateConfig(newConfig) {
363
- // 디바운스 적용
364
- this._debouncedUpdateConfig(newConfig);
365
- }
366
- _updateConfigInternal(newConfig) {
367
- this.config = { ...this.config, ...newConfig };
368
- if (newConfig.text) {
369
- this.buildTargets();
370
- }
371
- }
372
- // 파괴 및 정리
373
- destroy() {
374
- this.stop();
375
- this.removeEventListeners();
376
- if (this.intersectionObserver) {
377
- this.intersectionObserver.disconnect();
378
- this.intersectionObserver = null;
379
- }
380
- if (this.canvas && this.canvas.parentNode) {
381
- this.canvas.parentNode.removeChild(this.canvas);
382
- }
383
- }
384
- }
385
-
386
- /**
387
- * MasonEffect - 메인 엔트리 포인트
388
- */
389
-
390
- exports.MasonEffect = MasonEffect;
391
- exports.default = MasonEffect;
392
- //# sourceMappingURL=index.js.map
package/dist/index.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sources":["../src/core/index.ts","../src/index.ts"],"sourcesContent":[null,null],"names":[],"mappings":"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"}
package/dist/index.min.js DELETED
@@ -1 +0,0 @@
1
- function t(t,s){let i=null;return function(...h){null!==i&&clearTimeout(i),i=setTimeout(()=>{i=null,t.apply(this,h)},s)}}Object.defineProperty(exports,"t",{value:!0});class s{constructor(s,i={}){if(this.container="string"==typeof s?document.querySelector(s):s,!this.container)throw Error("Container element not found");this.config={text:i.text||"mason effect",densityStep:i.densityStep??2,maxParticles:i.maxParticles??3200,pointSize:i.pointSize??.5,ease:i.ease??.05,repelRadius:i.repelRadius??150,repelStrength:i.repelStrength??1,particleColor:i.particleColor||"#fff",fontFamily:i.fontFamily||"Inter, system-ui, Arial",fontSize:i.fontSize||null,width:i.width||null,height:i.height||null,devicePixelRatio:i.devicePixelRatio??null,onReady:i.onReady||null,onUpdate:i.onUpdate||null},this.canvas=document.createElement("canvas");const h=this.canvas.getContext("2d");if(!h)throw Error("Canvas context not available");this.ctx=h,this.container.appendChild(this.canvas),this.canvas.style.display="block",this.offCanvas=document.createElement("canvas");const e=this.offCanvas.getContext("2d");if(!e)throw Error("Offscreen canvas context not available");this.offCtx=e,this.W=0,this.H=0,this.DPR=this.config.devicePixelRatio||Math.min(window.devicePixelRatio||1,1.8),this.particles=[],this.mouse={x:0,y:0,down:!1},this.animationId=null,this.isRunning=!1,this.isVisible=!1,this.intersectionObserver=null,this.debounceDelay=i.debounceDelay??150;const o=this.handleResize.bind(this);this.handleResize=t(o,this.debounceDelay),this.handleMouseMove=this.handleMouseMove.bind(this),this.handleMouseLeave=this.handleMouseLeave.bind(this),this.handleMouseDown=this.handleMouseDown.bind(this),this.handleMouseUp=this.handleMouseUp.bind(this),this.i=t(this.h.bind(this),this.debounceDelay),this.o=t(this.l.bind(this),this.debounceDelay),this.init()}init(){this.resize(),this.setupEventListeners(),this.setupIntersectionObserver(),this.config.onReady&&this.config.onReady(this)}setupIntersectionObserver(){if("undefined"==typeof window||void 0===window.IntersectionObserver)return this.isVisible=!0,void this.start();this.intersectionObserver||(this.intersectionObserver=new IntersectionObserver(t=>{for(const s of t)s.target===this.container&&(s.isIntersecting?(this.isVisible=!0,this.start()):(this.isVisible=!1,this.stop()))},{threshold:.1}),this.intersectionObserver.observe(this.container))}resize(){const t=this.config.width||this.container.clientWidth||window.innerWidth,s=this.config.height||this.container.clientHeight||.7*window.innerHeight;this.W=Math.floor(t*this.DPR),this.H=Math.floor(s*this.DPR),this.canvas.width=this.W,this.canvas.height=this.H,this.canvas.style.width=t+"px",this.canvas.style.height=s+"px",this.buildTargets(),this.particles.length||this.initParticles()}buildTargets(){const t=this.config.text;this.offCanvas.width=this.W,this.offCanvas.height=this.H,this.offCtx.clearRect(0,0,this.offCanvas.width,this.offCanvas.height);const s=Math.min(this.W,this.H),i=this.config.fontSize||Math.max(80,Math.floor(.18*s));this.offCtx.fillStyle="#ffffff",this.offCtx.textAlign="center",this.offCtx.textBaseline="middle",this.offCtx.font=`400 ${i}px ${this.config.fontFamily}`;const h=t.split(""),e=.05*i,o=this.offCtx.measureText(t).width+e*(h.length-1);let n=this.W/2-o/2;for(const t of h)this.offCtx.fillText(t,n+this.offCtx.measureText(t).width/2,this.H/2),n+=this.offCtx.measureText(t).width+e;const a=Math.max(2,this.config.densityStep),r=this.offCtx.getImageData(0,0,this.W,this.H).data,l=[];for(let t=0;t<this.H;t+=a)for(let s=0;s<this.W;s+=a){const i=4*(t*this.W+s);r[i]+r[i+1]+r[i+2]>600&&l.push({x:s,y:t})}for(;l.length>this.config.maxParticles;)l.splice(Math.floor(Math.random()*l.length),1);if(this.particles.length<l.length){const t=l.length-this.particles.length;for(let s=0;t>s;s++)this.particles.push(this.makeParticle())}else this.particles.length>l.length&&(this.particles.length=l.length);for(let t=0;t<this.particles.length;t++){const s=this.particles[t],i=l[t];s.tx=i.x,s.ty=i.y}}makeParticle(){const t=Math.random()*this.W,s=Math.random()*this.H;return{x:t,y:s,vx:0,vy:0,tx:t,ty:s,initialX:t,initialY:s,j:Math.random()*Math.PI*2}}initParticles(){for(const t of this.particles){const s=Math.random()*this.W,i=Math.random()*this.H;t.x=s,t.y=i,t.vx=t.vy=0,t.initialX=s,t.initialY=i}}scatter(){for(const t of this.particles)void 0!==t.initialX&&void 0!==t.initialY?(t.tx=t.initialX,t.ty=t.initialY):(t.initialX=t.x,t.initialY=t.y,t.tx=t.initialX,t.ty=t.initialY)}morph(t){this.i(t)}h(t){if(0!==this.W&&0!==this.H||this.resize(),"string"==typeof t)this.config.text=t,this.buildTargets();else if(t&&"object"==typeof t){const s=void 0!==t.text;this.config={...this.config,...t},s&&this.buildTargets()}else this.buildTargets()}update(){this.ctx.clearRect(0,0,this.W,this.H);for(const t of this.particles){let s=(t.tx-t.x)*this.config.ease,i=(t.ty-t.y)*this.config.ease;if(this.mouse.x||this.mouse.y){const h=t.x-this.mouse.x,e=t.y-this.mouse.y,o=h*h+e*e,n=this.config.repelRadius*this.DPR;if(n*n>o){const t=Math.sqrt(o)+1e-4,a=(this.mouse.down?-1:1)*this.config.repelStrength*(1-t/n);s+=h/t*a*6,i+=e/t*a*6}}t.j+=2,s+=.05*Math.cos(t.j),i+=.05*Math.sin(1.3*t.j),t.vx=(t.vx+s)*Math.random(),t.vy=(t.vy+i)*Math.random(),t.x+=t.vx,t.y+=t.vy}this.ctx.fillStyle=this.config.particleColor;const t=this.config.pointSize*this.DPR;for(const s of this.particles)this.ctx.beginPath(),this.ctx.arc(s.x,s.y,t,0,2*Math.PI),this.ctx.fill();this.config.onUpdate&&this.config.onUpdate(this)}animate(){this.isRunning&&(this.update(),this.animationId=requestAnimationFrame(()=>this.animate()))}start(){this.isRunning||(this.isRunning=!0,this.animate())}stop(){this.isRunning=!1,this.animationId&&(cancelAnimationFrame(this.animationId),this.animationId=null)}setupEventListeners(){window.addEventListener("resize",this.handleResize),this.canvas.addEventListener("mousemove",this.handleMouseMove),this.canvas.addEventListener("mouseleave",this.handleMouseLeave),this.canvas.addEventListener("mousedown",this.handleMouseDown),window.addEventListener("mouseup",this.handleMouseUp)}removeEventListeners(){window.removeEventListener("resize",this.handleResize),this.canvas.removeEventListener("mousemove",this.handleMouseMove),this.canvas.removeEventListener("mouseleave",this.handleMouseLeave),this.canvas.removeEventListener("mousedown",this.handleMouseDown),window.removeEventListener("mouseup",this.handleMouseUp)}handleResize(){this.resize()}handleMouseMove(t){const s=this.canvas.getBoundingClientRect();this.mouse.x=(t.clientX-s.left)*this.DPR,this.mouse.y=(t.clientY-s.top)*this.DPR}handleMouseLeave(){this.mouse.x=this.mouse.y=0}handleMouseDown(){this.mouse.down=!0}handleMouseUp(){this.mouse.down=!1}updateConfig(t){this.o(t)}l(t){this.config={...this.config,...t},t.text&&this.buildTargets()}destroy(){this.stop(),this.removeEventListeners(),this.intersectionObserver&&(this.intersectionObserver.disconnect(),this.intersectionObserver=null),this.canvas&&this.canvas.parentNode&&this.canvas.parentNode.removeChild(this.canvas)}}exports.MasonEffect=s,exports.default=s;