@d3p1/img2pxl 2.0.0 → 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/dist/core.js DELETED
@@ -1,1363 +0,0 @@
1
- var je = Object.defineProperty;
2
- var ue = (a) => {
3
- throw TypeError(a);
4
- };
5
- var Je = (a, e, t) => e in a ? je(a, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : a[e] = t;
6
- var q = (a, e, t) => Je(a, typeof e != "symbol" ? e + "" : e, t), ee = (a, e, t) => e.has(a) || ue("Cannot " + t);
7
- var i = (a, e, t) => (ee(a, e, "read from private field"), t ? t.call(a) : e.get(a)), o = (a, e, t) => e.has(a) ? ue("Cannot add the same private member more than once") : e instanceof WeakSet ? e.add(a) : e.set(a, t), l = (a, e, t, s) => (ee(a, e, "write to private field"), s ? s.call(a, t) : e.set(a, t), t), r = (a, e, t) => (ee(a, e, "access private method"), t);
8
- import * as d from "three";
9
- import { Pane as Ce } from "tweakpane";
10
- class Ie {
11
- constructor() {
12
- this._previousTime = 0, this._currentTime = 0, this._startTime = ie(), this._delta = 0, this._elapsed = 0, this._timescale = 1, this._usePageVisibilityAPI = typeof document < "u" && document.hidden !== void 0, this._usePageVisibilityAPI === !0 && (this._pageVisibilityHandler = De.bind(this), document.addEventListener("visibilitychange", this._pageVisibilityHandler, !1));
13
- }
14
- getDelta() {
15
- return this._delta / 1e3;
16
- }
17
- getElapsed() {
18
- return this._elapsed / 1e3;
19
- }
20
- getTimescale() {
21
- return this._timescale;
22
- }
23
- setTimescale(e) {
24
- return this._timescale = e, this;
25
- }
26
- reset() {
27
- return this._currentTime = ie() - this._startTime, this;
28
- }
29
- dispose() {
30
- return this._usePageVisibilityAPI === !0 && document.removeEventListener("visibilitychange", this._pageVisibilityHandler), this;
31
- }
32
- update(e) {
33
- return this._usePageVisibilityAPI === !0 && document.hidden === !0 ? this._delta = 0 : (this._previousTime = this._currentTime, this._currentTime = (e !== void 0 ? e : ie()) - this._startTime, this._delta = (this._currentTime - this._previousTime) * this._timescale, this._elapsed += this._delta), this;
34
- }
35
- }
36
- function ie() {
37
- return performance.now();
38
- }
39
- function De() {
40
- document.hidden === !1 && this.reset();
41
- }
42
- var Ee = `attribute float aDisAngle;
43
- attribute float aDisAmplitude;
44
-
45
- uniform float uTime;
46
- uniform float uDisFrequency;
47
- uniform float uDisAmplitude;
48
- uniform sampler2D uDisTexture;
49
- uniform float uNoiseFrequency;
50
- uniform float uNoiseAmplitude;
51
- uniform sampler2D uNoiseTexture;
52
-
53
- varying vec4 vColor;`, Ye = `vec3 vertexPosition = position;
54
-
55
- vec2 noiseUv = vec2(uv.x - uNoiseFrequency * uTime, uv.y);
56
- float noiseFactor = texture(uNoiseTexture, noiseUv).r * uNoiseAmplitude;
57
- float noiseX = cos(aDisAngle) * noiseFactor;
58
- float noiseY = sin(aDisAngle) * noiseFactor;
59
- vec2 noise = vec2(noiseX, noiseY);
60
- vertexPosition.xy += noise;
61
-
62
- float disFactor = texture(uDisTexture, uv).r;
63
- disFactor = smoothstep(0.2, 0.8, disFactor);
64
- disFactor = (sin(uDisFrequency * uTime) + 1.5) / (2.5) *
65
- disFactor *
66
- uDisAmplitude;
67
- disFactor *= aDisAmplitude;
68
-
69
- float displacementX = cos(aDisAngle) * disFactor;
70
- float displacementY = sin(aDisAngle) * disFactor;
71
- vec2 displacement = vec2(displacementX, displacementY);
72
- vertexPosition.xy += displacement;`, h, R, K, X, F, ve, he, ce, fe;
73
- class Qe {
74
- /**
75
- * Constructor
76
- *
77
- * @param {Image} image
78
- * @param {Pointer} pointer
79
- * @param {RendererManager} rendererManager
80
- * @param {DebugManager} debugManager
81
- * @param {string} noiseImageSrc
82
- * @param {number} noiseFrequency
83
- * @param {number} noiseAmplitude
84
- * @param {number} displacementFrequency
85
- * @param {number} displacementAmplitude
86
- */
87
- constructor(e, t, s, n, V, m = 0.1, c = 5, p = 5, T = 50) {
88
- o(this, F);
89
- /**
90
- * @type {Image}
91
- */
92
- o(this, h);
93
- /**
94
- * @type {Pointer}
95
- */
96
- o(this, R);
97
- /**
98
- * @type {RendererManager}
99
- */
100
- o(this, K);
101
- /**
102
- * @type {DebugManager}
103
- */
104
- o(this, X);
105
- l(this, h, e), l(this, R, t), l(this, K, s), l(this, X, n), r(this, F, ve).call(this, V, m, c, p, T), r(this, F, he).call(this);
106
- }
107
- /**
108
- * Update
109
- *
110
- * @param {number} elapsed
111
- * @returns {void}
112
- */
113
- update(e) {
114
- i(this, h).points.material.uniforms.uTime.value = e, i(this, R).update(), i(this, K).update();
115
- }
116
- /**
117
- * Enable debug mode
118
- *
119
- * @returns {void}
120
- */
121
- debug() {
122
- i(this, R).debug(), i(this, h).debug();
123
- const e = i(this, X).addFolder({
124
- title: "Image Pixel Motion"
125
- });
126
- i(this, X).addBindingWithOnChange(
127
- i(this, h).points.material.uniforms.uDisFrequency,
128
- "value",
129
- "frequency",
130
- { min: 0, max: 10 * 2 * Math.PI, step: 0.01 },
131
- e
132
- ), i(this, X).addBindingWithOnChange(
133
- i(this, h).points.material.uniforms.uDisAmplitude,
134
- "value",
135
- "amplitude",
136
- { min: 0, max: i(this, K).width, step: 1 },
137
- e
138
- );
139
- const t = i(this, X).addFolder({
140
- title: "Image Motion"
141
- });
142
- i(this, X).addBindingWithOnChange(
143
- i(this, h).points.material.uniforms.uNoiseFrequency,
144
- "value",
145
- "frequency",
146
- { min: 0, max: 2 * Math.PI, step: 0.01 },
147
- t
148
- ), i(this, X).addBindingWithOnChange(
149
- i(this, h).points.material.uniforms.uNoiseAmplitude,
150
- "value",
151
- "amplitude",
152
- { min: 0, max: i(this, K).width, step: 1 },
153
- t
154
- );
155
- }
156
- /**
157
- * Dispose
158
- *
159
- * @returns {void}
160
- */
161
- dispose() {
162
- i(this, h).dispose(), i(this, R).dispose();
163
- }
164
- }
165
- h = new WeakMap(), R = new WeakMap(), K = new WeakMap(), X = new WeakMap(), F = new WeakSet(), /**
166
- * Init image
167
- *
168
- * @param {string} noiseImageSrc
169
- * @param {number} noiseFrequency
170
- * @param {number} noiseAmplitude
171
- * @param {number} displacementFrequency
172
- * @param {number} displacementAmplitude
173
- * @returns {void}
174
- */
175
- ve = function(e, t, s, n, V) {
176
- i(this, K).scene.add(i(this, h).points), r(this, F, fe).call(this), r(this, F, ce).call(this, e, t, s, n, V);
177
- }, /**
178
- * Init pointer
179
- *
180
- * @returns {void}
181
- */
182
- he = function() {
183
- i(this, R).raycasterPlane.position.copy(i(this, h).points.position), i(this, R).raycasterPlane.position.z += 0.01, i(this, K).scene.add(i(this, R).raycasterPlane);
184
- }, /**
185
- * Add logic that handles vertex/point/pixel displacement to image
186
- *
187
- * @param {string} noiseImageSrc
188
- * @param {number} noiseFrequency
189
- * @param {number} noiseAmplitude
190
- * @param {number} displacementFrequency
191
- * @param {number} displacementAmplitude
192
- * @returns {void}
193
- * @note Take into consideration that the pointer canvas/image/texture
194
- * is called `uDisTexture` inside the shader because
195
- * it is considered that the shader does not need to know
196
- * that this texture is related to a pointer
197
- * @note Force shader compilation with `compile()`.
198
- * If it is not forced the shader compilation, then
199
- * uniforms will be undefined until first render of the scene
200
- * {@link https://github.com/mrdoob/three.js/pull/10960}
201
- */
202
- ce = function(e, t, s, n, V) {
203
- const c = new d.TextureLoader().load(e);
204
- c.wrapS = d.RepeatWrapping, i(this, h).points.material.onBeforeCompile = (p) => {
205
- p.uniforms.uTime = new d.Uniform(0), p.uniforms.uDisFrequency = new d.Uniform(
206
- n
207
- ), p.uniforms.uDisAmplitude = new d.Uniform(
208
- V
209
- ), p.uniforms.uDisTexture = new d.Uniform(
210
- i(this, R).canvas.texture
211
- ), p.uniforms.uNoiseFrequency = new d.Uniform(t), p.uniforms.uNoiseAmplitude = new d.Uniform(s), p.uniforms.uNoiseTexture = new d.Uniform(c), p.vertexShader = p.vertexShader.replace(
212
- "varying vec4 vColor;",
213
- Ee
214
- ), p.vertexShader = p.vertexShader.replace(
215
- "vec3 vertexPosition = position;",
216
- Ye
217
- );
218
- }, i(this, K).compile();
219
- }, /**
220
- * Add attributes that handle displacement to image
221
- *
222
- * @returns {void}
223
- */
224
- fe = function() {
225
- const e = i(this, h).points.geometry.attributes.position.count, t = new Float32Array(e), s = new Float32Array(e);
226
- for (let n = 0; n < e; n++)
227
- t[n] = Math.random() * 2 * Math.PI, s[n] = Math.random();
228
- i(this, h).points.geometry.setAttribute(
229
- "aDisAngle",
230
- new d.BufferAttribute(t, 1)
231
- ), i(this, h).points.geometry.setAttribute(
232
- "aDisAmplitude",
233
- new d.BufferAttribute(s, 1)
234
- );
235
- };
236
- var W, Ue, We, Re, be, Ke;
237
- class Ge {
238
- /**
239
- * Constructor
240
- *
241
- * @param {number} width
242
- * @param {number} height
243
- */
244
- constructor(e, t) {
245
- o(this, W);
246
- /**
247
- * @type {THREE.Scene}
248
- */
249
- q(this, "scene");
250
- /**
251
- * @type {THREE.WebGLRenderer}
252
- */
253
- q(this, "renderer");
254
- /**
255
- * @type {THREE.OrthographicCamera}
256
- * @note It is used an orthographic camera because it is desired
257
- * to draw a 2d image without perspective
258
- */
259
- q(this, "camera");
260
- /**
261
- * @type {number}
262
- */
263
- q(this, "width");
264
- /**
265
- * @type {number}
266
- */
267
- q(this, "height");
268
- /**
269
- * @type {number}
270
- * @note Device pixel ratio
271
- */
272
- q(this, "dpr");
273
- this.width = e, this.height = t, r(this, W, Ue).call(this), r(this, W, Re).call(this), r(this, W, We).call(this);
274
- }
275
- /**
276
- * Update
277
- *
278
- * @returns {void}
279
- */
280
- update() {
281
- this.renderer.render(this.scene, this.camera);
282
- }
283
- /**
284
- * Compile shaders
285
- *
286
- * @returns {void}
287
- * {@link https://github.com/mrdoob/three.js/pull/10960}
288
- */
289
- compile() {
290
- this.renderer.compile(this.scene, this.camera);
291
- }
292
- /**
293
- * Dispose
294
- *
295
- * @returns {void}
296
- */
297
- dispose() {
298
- r(this, W, Ke).call(this), r(this, W, be).call(this), this.renderer.domElement.remove();
299
- }
300
- }
301
- W = new WeakSet(), /**
302
- * Init renderer
303
- *
304
- * @returns {void}
305
- * @note The antialias is only enabled for devices with less than `2`
306
- * as a pixel ratio. This is done to improve performance because
307
- * devices with `2` or more as pixel ratio
308
- * do not require this feature
309
- */
310
- Ue = function() {
311
- const e = document.createElement("canvas");
312
- document.body.append(e), this.dpr = Math.min(window.devicePixelRatio, 2);
313
- let t = !1;
314
- this.dpr <= 1 && (t = !0), this.renderer = new d.WebGLRenderer({
315
- canvas: e,
316
- antialias: t
317
- }), this.renderer.setPixelRatio(this.dpr), this.renderer.setSize(this.width, this.height), this.renderer.setClearAlpha(0);
318
- }, /**
319
- * Init camera
320
- *
321
- * @returns {void}
322
- * @note The renderer will have the same dimensions as the image.
323
- * The idea is that a plane with the image as texture will be
324
- * used inside the renderer, and this plane also will have the
325
- * image dimensions.
326
- * An orthographic camera will be positioned to show exactly
327
- * that plane.
328
- * Because it is used an orthographic camera,
329
- * `1` world unit is `1` pixel, making it easy to position things
330
- * @link https://discourse.threejs.org/t/mapping-orthographiccamera-world-units-to-pixels/10142
331
- */
332
- We = function() {
333
- const e = -this.renderer.domElement.width / 2, t = this.renderer.domElement.width / 2, s = this.renderer.domElement.height / 2, n = -this.renderer.domElement.height / 2, V = 0.1, m = 1;
334
- this.camera = new d.OrthographicCamera(
335
- e,
336
- t,
337
- s,
338
- n,
339
- V,
340
- m
341
- ), this.scene.add(this.camera), this.camera.position.z = m - 0.1;
342
- }, /**
343
- * Init scene
344
- *
345
- * @returns {void}
346
- */
347
- Re = function() {
348
- this.scene = new d.Scene();
349
- }, /**
350
- * Dispose renderer
351
- *
352
- * @returns {void}
353
- */
354
- be = function() {
355
- this.renderer.dispose();
356
- }, /**
357
- * Dispose scene
358
- *
359
- * @returns {void}
360
- */
361
- Ke = function() {
362
- for (; this.scene.children.length > 0; )
363
- this.scene.remove(this.scene.children[0]);
364
- };
365
- const Be = (a, e, t, s, n, V, m) => `{
366
- images: {
367
- 0: {
368
- src: <image-src>,
369
- width: <image-width>,
370
- height: <image-height>,
371
- resolution: {
372
- width: <image-resolution-width>,
373
- height: <image-resolution-height>
374
- },
375
- pixel: {
376
- size: ${a},
377
- motion: {
378
- displacement: {
379
- frequency: ${e},
380
- amplitude: ${t}
381
- }
382
- }
383
- },
384
- motion: {
385
- noise: {
386
- frequency: ${s},
387
- amplitude: ${n}
388
- }
389
- }
390
- }
391
- },
392
- pointer: {
393
- size: ${V},
394
- trailing: {
395
- factor: ${m}
396
- }
397
- }
398
- }`;
399
- var _, Xe;
400
- class He {
401
- /**
402
- * Constructor
403
- */
404
- constructor() {
405
- o(this, _);
406
- /**
407
- * @type {Pane}
408
- */
409
- q(this, "debugger");
410
- this.debugger = new Ce(), r(this, _, Xe).call(this);
411
- }
412
- /**
413
- * Enable. Show debugger
414
- *
415
- * @returns {void}
416
- */
417
- enable() {
418
- this.debugger.element.style.display = "block";
419
- }
420
- /**
421
- * Disable. Hide debugger
422
- *
423
- * @returns {void}
424
- */
425
- disable() {
426
- this.debugger.element.style.display = "none";
427
- }
428
- /**
429
- * Dispose
430
- *
431
- * @returns {void}
432
- */
433
- dispose() {
434
- this.debugger.dispose(), this.debugger.element.remove();
435
- }
436
- /**
437
- * Add folder
438
- *
439
- * @param {{title: string; expanded?: boolean;}} config
440
- * @returns {object}
441
- */
442
- addFolder(e) {
443
- return e = { expanded: !1, ...e }, this.debugger.addFolder(e);
444
- }
445
- /**
446
- * Add binding with on change handler
447
- *
448
- * @param {object} object
449
- * @param {string} property
450
- * @param {string} label
451
- * @param {object | undefined} config
452
- * @param {object | undefined} folder
453
- * @returns {object}
454
- */
455
- addBindingWithOnChange(e, t, s, n, V = void 0) {
456
- return this.addBinding(s, e[t], n, V).on(
457
- "change",
458
- (m) => {
459
- e[t] = m.value;
460
- }
461
- );
462
- }
463
- /**
464
- * Add binding
465
- *
466
- * @param {string} label
467
- * @param {string | number} value
468
- * @param {object | undefined} config
469
- * @param {object | undefined} folder
470
- * @returns {object}
471
- */
472
- addBinding(e, t, s, n = void 0) {
473
- let V = this.debugger;
474
- return n && (V = n), V.addBinding(
475
- {
476
- [e]: t
477
- },
478
- e,
479
- s
480
- );
481
- }
482
- }
483
- _ = new WeakSet(), /**
484
- * Add copy button
485
- *
486
- * @returns {void}
487
- */
488
- Xe = function() {
489
- const e = this.debugger.addButton({
490
- title: "Copy"
491
- });
492
- e.on("click", () => {
493
- const t = this.debugger.exportState();
494
- if (t.children && t.children instanceof Array) {
495
- const s = t.children[1], n = s.children[0].binding.value, V = s.children[1].binding.value, c = t.children[4].children[0].binding.value, p = t.children[5], T = p.children[0].binding.value, G = p.children[1].binding.value, E = t.children[6], B = E.children[0].binding.value, H = E.children[1].binding.value, A = Be(
496
- c,
497
- T,
498
- G,
499
- B,
500
- H,
501
- n,
502
- V
503
- );
504
- navigator.clipboard.writeText(A).then(() => {
505
- e.title = "Copied!", setTimeout(() => {
506
- e.title = "Copy";
507
- }, 1e3);
508
- });
509
- }
510
- });
511
- };
512
- var Ae = `uniform sampler2D uImageTexture;
513
- uniform float uPointSize;
514
-
515
- varying vec4 vColor;
516
-
517
- void main() {
518
- vec3 vertexPosition = position;
519
-
520
- vec4 modelPosition = modelMatrix * vec4(vertexPosition, 1.0);
521
- vec4 viewPosition = viewMatrix * modelPosition;
522
- vec4 projectionPosition = projectionMatrix * viewPosition;
523
-
524
- gl_Position = projectionPosition;
525
- gl_PointSize = uPointSize;
526
-
527
- vColor = texture(uImageTexture, uv);
528
- }`, _e = `uniform float uAlphaTest;
529
-
530
- varying vec4 vColor;
531
-
532
- void main() {
533
- if (vColor.a < uAlphaTest) {
534
- discard;
535
- }
536
-
537
- gl_FragColor = vColor;
538
-
539
- #include <tonemapping_fragment>
540
- #include <colorspace_fragment>
541
- }`, M, w, y, Z, Fe, te, se, qe;
542
- let $e = (qe = class {
543
- /**
544
- * Constructor
545
- *
546
- * @param {RendererManager} rendererManager
547
- * @param {DebugManager} debugManager
548
- * @param {string} imageSrc
549
- * @param {number} resolutionWidth
550
- * @param {number} resolutionHeight
551
- * @param {number} pointSize
552
- * @param {number} alphaTest
553
- */
554
- constructor(e, t, s, n, V, m = 1, c = 0.1) {
555
- o(this, Z);
556
- /**
557
- * @type {THREE.Points}
558
- */
559
- q(this, "points");
560
- /**
561
- * @type {THREE.Texture}
562
- */
563
- o(this, M);
564
- /**
565
- * @type {RendererManager}
566
- */
567
- o(this, w);
568
- /**
569
- * @type {DebugManager}
570
- */
571
- o(this, y);
572
- l(this, w, e), l(this, y, t), r(this, Z, Fe).call(this, s, n, V, m, c);
573
- }
574
- /**
575
- * Enable debug mode
576
- *
577
- * @returns {void}
578
- */
579
- debug() {
580
- const e = i(this, y).addFolder({
581
- title: "Image Resolution"
582
- });
583
- i(this, y).addBinding(
584
- "width",
585
- this.points.geometry.parameters.widthSegments,
586
- { min: 0, max: this.points.geometry.parameters.width, step: 1 },
587
- e
588
- ).on("change", (s) => {
589
- s.last && r(this, Z, te).call(this, s.value, this.points.geometry.parameters.heightSegments);
590
- }), i(this, y).addBinding(
591
- "height",
592
- this.points.geometry.parameters.heightSegments,
593
- { min: 0, max: this.points.geometry.parameters.height, step: 1 },
594
- e
595
- ).on("change", (s) => {
596
- s.last && r(this, Z, te).call(this, this.points.geometry.parameters.widthSegments, s.value);
597
- });
598
- const t = i(this, y).addFolder({ title: "Image Pixel" });
599
- i(this, y).addBinding(
600
- "size",
601
- this.points.material.uniforms.uPointSize.value,
602
- { min: 1, max: 100, step: 1 },
603
- t
604
- ).on("change", (s) => {
605
- s.last && (this.points.material.uniforms.uPointSize.value = s.value);
606
- });
607
- }
608
- /**
609
- * Dispose
610
- *
611
- * @returns {void}
612
- */
613
- dispose() {
614
- this.points.geometry.dispose(), this.points.material.dispose(), i(this, M).dispose();
615
- }
616
- }, M = new WeakMap(), w = new WeakMap(), y = new WeakMap(), Z = new WeakSet(), /**
617
- * Init points
618
- *
619
- * @param {string} imageSrc
620
- * @param {number} resolutionWidth
621
- * @param {number} resolutionHeight
622
- * @param {number} pointSize
623
- * @param {number} alphaTest
624
- * @returns {void}
625
- */
626
- Fe = function(e, t, s, n, V) {
627
- const m = new d.TextureLoader();
628
- l(this, M, m.load(e));
629
- const c = r(this, Z, se).call(this, t, s), p = new d.ShaderMaterial({
630
- vertexShader: Ae,
631
- fragmentShader: _e,
632
- uniforms: {
633
- uImageTexture: new d.Uniform(i(this, M)),
634
- uPointSize: new d.Uniform(n),
635
- uAlphaTest: new d.Uniform(V)
636
- },
637
- transparent: !0,
638
- depthWrite: !1,
639
- alphaTest: V
640
- });
641
- this.points = new d.Points(c, p);
642
- }, /**
643
- * Replace image geometry
644
- *
645
- * @param {number} resolutionWidth
646
- * @param {number} resolutionHeight
647
- * @returns {void}
648
- * @note It is sent old attributes to be persisted by the new geometry.
649
- * New generated geometry attributes will replace old ones if
650
- * they exist in the old geometry
651
- */
652
- te = function(e, t) {
653
- const s = this.points.geometry.attributes;
654
- this.points.geometry.dispose(), this.points.geometry = r(this, Z, se).call(this, e, t, s);
655
- }, /**
656
- * Create image geometry
657
- *
658
- * @param {number} resolutionWidth
659
- * @param {number} resolutionHeight
660
- * @param {THREE.NormalBufferAttributes | null} attributes
661
- * @returns {THREE.PlaneGeometry}
662
- * @note It is created a plane that occupies all the render
663
- * @note The dom element width and height of the renderer include
664
- * the device pixel ratio, so it is important to use them
665
- * to create a plane that take all the render space/pixels
666
- * @note It is removed the index and normals from the geometry
667
- * to improve performance.
668
- * Normals are not going to be needed.
669
- * The index could cause the draw of multiple points/pixels in the
670
- * same place. That is why it is required to remove it
671
- */
672
- se = function(e, t, s = null) {
673
- const n = new d.PlaneGeometry(
674
- i(this, w).renderer.domElement.width,
675
- i(this, w).renderer.domElement.height,
676
- e * i(this, w).dpr,
677
- t * i(this, w).dpr
678
- );
679
- return n.setIndex(null), n.deleteAttribute("normal"), s && (n.attributes = { ...s, ...n.attributes }), n;
680
- }, qe);
681
- var b, k, j, S, Ze, Se, ye, Pe;
682
- class ei {
683
- /**
684
- * Constructor
685
- *
686
- * @param {RendererManager} rendererManager
687
- * @param {Canvas} canvas
688
- */
689
- constructor(e, t) {
690
- o(this, S);
691
- /**
692
- * @type {THREE.Vector2 | {x: number | undefined, y: number | undefined}}
693
- */
694
- q(this, "coord");
695
- /**
696
- * @type {Canvas}
697
- */
698
- q(this, "canvas");
699
- /**
700
- * @type {THREE.Raycaster}
701
- */
702
- q(this, "raycaster");
703
- /**
704
- * @type {THREE.Mesh}
705
- */
706
- q(this, "raycasterPlane");
707
- /**
708
- * @type {RendererManager}
709
- */
710
- o(this, b);
711
- /**
712
- * @type {Function}
713
- */
714
- o(this, k);
715
- /**
716
- * @type {Function}
717
- */
718
- o(this, j);
719
- this.canvas = t, this.coord = new d.Vector2(void 0, void 0), l(this, b, e), r(this, S, ye).call(this);
720
- }
721
- /**
722
- * Update
723
- *
724
- * @returns {void}
725
- */
726
- update() {
727
- let e = null, t = null;
728
- if (this.coord.x && this.coord.y) {
729
- this.raycaster.setFromCamera(
730
- this.coord,
731
- i(this, b).camera
732
- );
733
- const s = this.raycaster.intersectObject(this.raycasterPlane);
734
- if (s.length) {
735
- const n = s[0].uv;
736
- e = n.x * this.canvas.element.width, t = (1 - n.y) * this.canvas.element.height;
737
- }
738
- }
739
- this.canvas.update(e, t);
740
- }
741
- /**
742
- * Enable debug mode
743
- *
744
- * @returns {void}
745
- */
746
- debug() {
747
- this.canvas.debug();
748
- }
749
- /**
750
- * Dispose
751
- *
752
- * @returns {void}
753
- */
754
- dispose() {
755
- this.canvas.dispose(), r(this, S, Pe).call(this);
756
- }
757
- }
758
- b = new WeakMap(), k = new WeakMap(), j = new WeakMap(), S = new WeakSet(), /**
759
- * Process pointer move
760
- *
761
- * @param {PointerEvent} e
762
- * @returns {void}
763
- * @note Pointer coordinates are normalized to
764
- * clip space (NDC - Normalized Device Coordinate) to
765
- * use it for raycasting
766
- */
767
- Ze = function(e) {
768
- const t = e.target;
769
- this.coord.x = (e.offsetX / t.width - 0.5) * 2, this.coord.y = -(e.offsetY / t.height - 0.5) * 2;
770
- }, /**
771
- * Process pointer leave
772
- *
773
- * @returns {void}
774
- */
775
- Se = function() {
776
- this.coord.x = void 0, this.coord.y = void 0;
777
- }, /**
778
- * Init raycaster
779
- *
780
- * @returns {void}
781
- * @note It is created low poly plane in front of the image
782
- * to avoid performance issues that could arise while
783
- * working between the raycaster and image points
784
- */
785
- ye = function() {
786
- this.raycaster = new d.Raycaster(), l(this, k, r(this, S, Ze).bind(this)), i(this, b).renderer.domElement.addEventListener(
787
- "pointermove",
788
- i(this, k)
789
- ), l(this, j, r(this, S, Se).bind(this)), i(this, b).renderer.domElement.addEventListener(
790
- "pointerleave",
791
- i(this, j)
792
- ), this.raycasterPlane = new d.Mesh(
793
- new d.PlaneGeometry(
794
- i(this, b).width,
795
- i(this, b).height
796
- ),
797
- new d.MeshBasicMaterial()
798
- ), this.raycasterPlane.visible = !1;
799
- }, /**
800
- * Dispose raycaster
801
- *
802
- * @returns {void}
803
- */
804
- Pe = function() {
805
- i(this, b).renderer.domElement.removeEventListener(
806
- "pointermove",
807
- i(this, k)
808
- ), i(this, b).renderer.domElement.removeEventListener(
809
- "pointerleave",
810
- i(this, j)
811
- ), this.raycasterPlane.geometry.dispose(), this.raycasterPlane.material.dispose();
812
- };
813
- var P, f, J, g, x, U, ge, ze, we, xe, ne;
814
- class ii {
815
- /**
816
- * Constructor
817
- *
818
- * @param {DebugManager} debugManager
819
- * @param {number} resolutionWidth
820
- * @param {number} resolutionHeight
821
- * @param {string} pointerImageSrc
822
- * @param {number} pointerImageSize
823
- * @param {number} pointerTrailingFactor
824
- */
825
- constructor(e, t, s, n, V = 0.1, m = 0.05) {
826
- o(this, U);
827
- /**
828
- * @type {DebugManager}
829
- */
830
- o(this, P);
831
- /**
832
- * @type {THREE.CanvasTexture}
833
- */
834
- q(this, "texture");
835
- /**
836
- * @type {HTMLCanvasElement}
837
- */
838
- q(this, "element");
839
- /**
840
- * @type {CanvasRenderingContext2D}
841
- */
842
- o(this, f);
843
- /**
844
- * @type {HTMLImageElement}
845
- * @note Image that will represent the pointer.
846
- * This image is used to
847
- * select which vertices/points/pixels
848
- * should be displaced
849
- */
850
- o(this, J);
851
- /**
852
- * @type {number}
853
- * @note This value defines how many pixels are affected by the
854
- * pointer effect.
855
- * It is defined as a proportion of the image resolution width
856
- */
857
- o(this, g);
858
- /**
859
- * @type {number}
860
- * @note This value defines the strength of the
861
- * pointer trailing effect on the
862
- * pixels' displacement
863
- */
864
- o(this, x);
865
- l(this, P, e), l(this, x, m), r(this, U, we).call(this, t, s), r(this, U, xe).call(this, n, V);
866
- }
867
- /**
868
- * Update
869
- *
870
- * @param {number | null} dx
871
- * @param {number | null} dy
872
- * @returns {void}
873
- */
874
- update(e, t) {
875
- r(this, U, ze).call(this), e && t && r(this, U, ge).call(this, e, t), this.texture.needsUpdate = !0;
876
- }
877
- /**
878
- * Enable debug mode
879
- *
880
- * @returns {void}
881
- */
882
- debug() {
883
- const e = i(this, P).addFolder({
884
- title: "Pointer"
885
- });
886
- i(this, P).addBinding(
887
- "size",
888
- i(this, g) / this.element.width,
889
- {
890
- min: 0,
891
- max: 1,
892
- step: 0.01
893
- },
894
- e
895
- ).on("change", (s) => r(this, U, ne).call(this, s.value)), i(this, P).addBinding(
896
- "trailing",
897
- i(this, x),
898
- {
899
- min: 0,
900
- max: 1,
901
- step: 0.01
902
- },
903
- e
904
- ).on("change", (s) => l(this, x, s.value));
905
- const t = i(this, P).addFolder({
906
- title: "Pointer Canvas"
907
- });
908
- i(this, P).addBinding("show", !1, void 0, t).on("change", (s) => {
909
- s.value ? (document.body.appendChild(this.element), this.element.style.position = "fixed", this.element.style.top = "0", this.element.style.left = "0", this.element.style.border = "1px solid #fff") : document.body.removeChild(this.element);
910
- });
911
- }
912
- /**
913
- * Dispose
914
- *
915
- * @returns {void}
916
- */
917
- dispose() {
918
- this.texture.dispose();
919
- }
920
- }
921
- P = new WeakMap(), f = new WeakMap(), J = new WeakMap(), g = new WeakMap(), x = new WeakMap(), U = new WeakSet(), /**
922
- * Draw
923
- *
924
- * @param {number} dx
925
- * @param {number} dy
926
- * @returns {void}
927
- * @note The destination of the image is moved half its size
928
- * so it is drawn at the center of the destination position
929
- */
930
- ge = function(e, t) {
931
- e -= i(this, g) / 2, t -= i(this, g) / 2, i(this, f).save(), i(this, f).globalCompositeOperation = "lighten", i(this, f).drawImage(
932
- i(this, J),
933
- e,
934
- t,
935
- i(this, g),
936
- i(this, g)
937
- ), i(this, f).restore();
938
- }, /**
939
- * Clear
940
- *
941
- * @returns {void}
942
- * @note The idea is to draw a white image that will
943
- * indicate how much points inside them will be displaced.
944
- * That is why it is required to clear the canvas with black color
945
- */
946
- ze = function() {
947
- i(this, f).save(), i(this, f).globalAlpha = i(this, x), i(this, f).fillStyle = "#000", i(this, f).fillRect(0, 0, this.element.width, this.element.height), i(this, f).restore();
948
- }, /**
949
- * Init canvas texture used to detect pointer location and
950
- * displace points
951
- *
952
- * @param {number} resolutionWidth
953
- * @param {number} resolutionHeight
954
- * @returns {void}
955
- * @note The canvas will have the same number of pixels as the
956
- * image.
957
- * That is why it is used the image resolution as its dimensions
958
- */
959
- we = function(e, t) {
960
- this.element = document.createElement("canvas"), this.element.width = e, this.element.height = t, this.texture = new d.CanvasTexture(this.element), l(this, f, this.element.getContext("2d"));
961
- }, /**
962
- * Init pointer image
963
- *
964
- * @param {string} pointerImageSrc
965
- * @param {number} pointerImageSize
966
- * @returns {void}
967
- * @note It is considered that the pointer image will be
968
- * a white image that will indicate which pixels should be displaced
969
- */
970
- xe = function(e, t) {
971
- l(this, J, new Image()), i(this, J).src = e, r(this, U, ne).call(this, t);
972
- }, /**
973
- * Process pointer image size
974
- *
975
- * @param {number} pointerImageSize
976
- * @returns {void}
977
- * @note The aspect ratio of the image is always square
978
- * (the same size is used for the width and the height of the image).
979
- * It is proportional to the canvas width.
980
- * This approach is considered correct because web elements
981
- * adjust only their width to fit in the page
982
- */
983
- ne = function(e) {
984
- l(this, g, e * this.element.width);
985
- };
986
- const ti = "", si = "", me = 0;
987
- var C, Y, $, Ne;
988
- class ni {
989
- /**
990
- * Constructor
991
- *
992
- * @param {{
993
- * src : string;
994
- * width : number;
995
- * height : number;
996
- * resolution: {
997
- * width : number;
998
- * height: number;
999
- * };
1000
- * pixel?: {
1001
- * size ?: number;
1002
- * alphaTest?: number;
1003
- * motion ?: {
1004
- * displacement?: {
1005
- * frequency?: number;
1006
- * amplitude?: number;
1007
- * };
1008
- * };
1009
- * };
1010
- * motion?: {
1011
- * noise?: {
1012
- * src ?: string;
1013
- * frequency?: number;
1014
- * amplitude?: number;
1015
- * };
1016
- * };
1017
- * }[]} images
1018
- * @throws {Error}
1019
- */
1020
- constructor(e) {
1021
- o(this, $);
1022
- /**
1023
- * @type {{
1024
- * src : string;
1025
- * width : number;
1026
- * height : number;
1027
- * resolution: {
1028
- * width : number;
1029
- * height: number;
1030
- * }
1031
- * pixel?: {
1032
- * size ?: number;
1033
- * alphaTest?: number;
1034
- * motion ?: {
1035
- * displacement?: {
1036
- * frequency?: number;
1037
- * amplitude?: number;
1038
- * };
1039
- * };
1040
- * };
1041
- * motion?: {
1042
- * noise?: {
1043
- * src ?: string;
1044
- * frequency?: number;
1045
- * amplitude?: number;
1046
- * };
1047
- * };
1048
- * }[]}
1049
- */
1050
- q(this, "images");
1051
- /**
1052
- * @type {{
1053
- * src : string;
1054
- * width : number;
1055
- * height : number;
1056
- * resolution: {
1057
- * width : number;
1058
- * height: number;
1059
- * };
1060
- * pixel?: {
1061
- * size ?: number;
1062
- * alphaTest?: number;
1063
- * motion ?: {
1064
- * displacement?: {
1065
- * frequency?: number;
1066
- * amplitude?: number;
1067
- * }
1068
- * };
1069
- * };
1070
- * motion?: {
1071
- * noise?: {
1072
- * src ?: string;
1073
- * frequency?: number;
1074
- * amplitude?: number;
1075
- * };
1076
- * };
1077
- * }}
1078
- */
1079
- q(this, "currentImage");
1080
- /**
1081
- * @type {number}
1082
- */
1083
- o(this, C);
1084
- /**
1085
- * @type {number[]}
1086
- */
1087
- o(this, Y);
1088
- this.images = e, r(this, $, Ne).call(this, Object.keys(this.images).map(Number)), this.update();
1089
- }
1090
- /**
1091
- * Taking into consideration window size,
1092
- * it is selected the breakpoint and image to be used
1093
- *
1094
- * @returns {boolean}
1095
- * @note Each breakpoint defines the `min-width` at which
1096
- * a specific image should be used.
1097
- * That is why it is returned
1098
- * the greater breakpoint that is less than or equal
1099
- * the window size
1100
- */
1101
- update() {
1102
- const e = window.innerWidth, t = i(this, Y).reduce(
1103
- (s, n) => n <= e && n > s ? n : s,
1104
- me
1105
- );
1106
- return t !== i(this, C) ? (l(this, C, t), this.currentImage = this.images[i(this, C)], !0) : !1;
1107
- }
1108
- }
1109
- C = new WeakMap(), Y = new WeakMap(), $ = new WeakSet(), /**
1110
- * Init breakpoints from image
1111
- *
1112
- * @param {number[]} breakpoints
1113
- * @returns {void}
1114
- * @throws {Error}
1115
- */
1116
- Ne = function(e) {
1117
- if (e.find(
1118
- (t) => t === me
1119
- ) === void 0)
1120
- throw new Error(
1121
- "The `0` breakpoint is required. It defines the default image that should be used."
1122
- );
1123
- l(this, Y, e);
1124
- };
1125
- var N, v, L, z, O, Q, I, D, u, re, ae, Le, oe, Oe, Te, Me, ke;
1126
- class li {
1127
- /**
1128
- * Constructor
1129
- *
1130
- * @param {{
1131
- * containerSelector?: string;
1132
- * image : {
1133
- * src : string;
1134
- * width : number;
1135
- * height : number;
1136
- * resolution: {
1137
- * width : number;
1138
- * height: number;
1139
- * };
1140
- * pixel?: {
1141
- * size ?: number;
1142
- * alphaTest?: number;
1143
- * motion ?: {
1144
- * displacement?: {
1145
- * frequency?: number;
1146
- * amplitude?: number;
1147
- * }
1148
- * }
1149
- * };
1150
- * motion?: {
1151
- * noise?: {
1152
- * src ?: string;
1153
- * frequency?: number;
1154
- * amplitude?: number;
1155
- * }
1156
- * }
1157
- * }[];
1158
- * pointer?: {
1159
- * src ?: string;
1160
- * size ?: number;
1161
- * trailing?: {
1162
- * factor?: number;
1163
- * }
1164
- * };
1165
- * isDebugging?: boolean;
1166
- * }} config
1167
- * @throws {Error}
1168
- */
1169
- constructor(e) {
1170
- o(this, u);
1171
- /**
1172
- * @type {RendererManager}
1173
- */
1174
- q(this, "rendererManager");
1175
- /**
1176
- * @type {DebugManager}
1177
- */
1178
- q(this, "debugManager");
1179
- /**
1180
- * @type {Runner}
1181
- */
1182
- o(this, N);
1183
- /**
1184
- * @type {ImageManager}
1185
- */
1186
- o(this, v);
1187
- /**
1188
- * @type {Timer}
1189
- */
1190
- o(this, L);
1191
- /**
1192
- * @type {{
1193
- * containerSelector?: string;
1194
- * image : {
1195
- * src : string;
1196
- * width : number;
1197
- * height : number;
1198
- * resolution: {
1199
- * width : number;
1200
- * height: number;
1201
- * };
1202
- * pixel?: {
1203
- * size ?: number;
1204
- * motion?: {
1205
- * displacement?: {
1206
- * frequency?: number;
1207
- * amplitude?: number;
1208
- * }
1209
- * }
1210
- * };
1211
- * motion?: {
1212
- * noise?: {
1213
- * src ?: string;
1214
- * frequency?: number;
1215
- * amplitude?: number;
1216
- * }
1217
- * }
1218
- * }[];
1219
- * pointer?: {
1220
- * src ?: string;
1221
- * size ?: number;
1222
- * trailing?: {
1223
- * factor?: number;
1224
- * }
1225
- * };
1226
- * isDebugging?: boolean;
1227
- * }}
1228
- */
1229
- o(this, z);
1230
- /**
1231
- * @type {boolean}
1232
- */
1233
- o(this, O);
1234
- /**
1235
- * @type {number}
1236
- */
1237
- o(this, Q);
1238
- /**
1239
- * @type {Function}
1240
- */
1241
- o(this, I);
1242
- /**
1243
- * @type {Function}
1244
- */
1245
- o(this, D);
1246
- l(this, z, e), l(this, O, e.isDebugging ?? !1), l(this, v, new ni(e.images)), r(this, u, re).call(this);
1247
- }
1248
- /**
1249
- * Debug
1250
- *
1251
- * @returns {void}
1252
- */
1253
- debug() {
1254
- i(this, O) || (r(this, u, oe).call(this), l(this, O, !0));
1255
- }
1256
- /**
1257
- * Dispose
1258
- *
1259
- * @returns {void}
1260
- */
1261
- dispose() {
1262
- cancelAnimationFrame(i(this, Q)), window.removeEventListener("keydown", i(this, I)), window.removeEventListener("resize", i(this, D)), i(this, L).dispose(), i(this, N).dispose(), this.rendererManager.dispose(), this.debugManager.dispose();
1263
- }
1264
- }
1265
- N = new WeakMap(), v = new WeakMap(), L = new WeakMap(), z = new WeakMap(), O = new WeakMap(), Q = new WeakMap(), I = new WeakMap(), D = new WeakMap(), u = new WeakSet(), /**
1266
- * Init
1267
- *
1268
- * @returns {void}
1269
- */
1270
- re = function() {
1271
- this.rendererManager = new Ge(
1272
- i(this, v).currentImage.width,
1273
- i(this, v).currentImage.height
1274
- ), l(this, L, new Ie()), r(this, u, Me).call(this), r(this, u, Te).call(this), i(this, z).containerSelector && r(this, u, ke).call(this, i(this, z).containerSelector), l(this, I, r(this, u, Le).bind(this)), window.addEventListener("keydown", i(this, I)), i(this, O) ? r(this, u, oe).call(this) : r(this, u, Oe).call(this), l(this, D, () => {
1275
- i(this, v).update() && (this.dispose(), r(this, u, re).call(this));
1276
- }), window.addEventListener("resize", i(this, D)), r(this, u, ae).call(this);
1277
- }, /**
1278
- * Render
1279
- *
1280
- * @params {number} t
1281
- * @returns {void}
1282
- */
1283
- ae = function(e = 0) {
1284
- i(this, L).update(e), i(this, N).update(i(this, L).getElapsed()), l(this, Q, requestAnimationFrame(r(this, u, ae).bind(this)));
1285
- }, /**
1286
- * Handle debug
1287
- *
1288
- * @param {KeyboardEvent} e
1289
- * @returns {void}
1290
- */
1291
- Le = function(e) {
1292
- e.key === "d" && this.debug();
1293
- }, /**
1294
- * Enable debug
1295
- *
1296
- * @returns {void}
1297
- */
1298
- oe = function() {
1299
- i(this, N).debug(), this.debugManager.enable();
1300
- }, /**
1301
- * Disable debug
1302
- *
1303
- * @returns {void}
1304
- */
1305
- Oe = function() {
1306
- this.debugManager.disable();
1307
- }, /**
1308
- * Init runner
1309
- *
1310
- * @returns {void}
1311
- */
1312
- Te = function() {
1313
- var e, t, s, n, V, m, c, p, T, G, E, B, H, A, le, de, Ve, pe;
1314
- l(this, N, new Qe(
1315
- new $e(
1316
- this.rendererManager,
1317
- this.debugManager,
1318
- i(this, v).currentImage.src,
1319
- i(this, v).currentImage.resolution.width,
1320
- i(this, v).currentImage.resolution.height,
1321
- ((e = i(this, v).currentImage.pixel) == null ? void 0 : e.size) ?? 1,
1322
- ((t = i(this, v).currentImage.pixel) == null ? void 0 : t.alphaTest) ?? 0.1
1323
- ),
1324
- new ei(
1325
- this.rendererManager,
1326
- new ii(
1327
- this.debugManager,
1328
- i(this, v).currentImage.resolution.width,
1329
- i(this, v).currentImage.resolution.height,
1330
- ((s = i(this, z).pointer) == null ? void 0 : s.src) ?? ti,
1331
- ((n = i(this, z).pointer) == null ? void 0 : n.size) ?? 0.15,
1332
- ((m = (V = i(this, z).pointer) == null ? void 0 : V.trailing) == null ? void 0 : m.factor) ?? 0.01
1333
- )
1334
- ),
1335
- this.rendererManager,
1336
- this.debugManager,
1337
- ((p = (c = i(this, v).currentImage.motion) == null ? void 0 : c.noise) == null ? void 0 : p.src) ?? si,
1338
- ((G = (T = i(this, v).currentImage.motion) == null ? void 0 : T.noise) == null ? void 0 : G.frequency) ?? 0.05,
1339
- ((B = (E = i(this, v).currentImage.motion) == null ? void 0 : E.noise) == null ? void 0 : B.amplitude) ?? 3,
1340
- ((le = (A = (H = i(this, v).currentImage.pixel) == null ? void 0 : H.motion) == null ? void 0 : A.displacement) == null ? void 0 : le.frequency) ?? 5,
1341
- ((pe = (Ve = (de = i(this, v).currentImage.pixel) == null ? void 0 : de.motion) == null ? void 0 : Ve.displacement) == null ? void 0 : pe.amplitude) ?? 4
1342
- ));
1343
- }, /**
1344
- * Init debug manager
1345
- *
1346
- * @returns {void}
1347
- */
1348
- Me = function() {
1349
- this.debugManager = new He();
1350
- }, /**
1351
- * Init DOM
1352
- *
1353
- * @param {string} containerSelector
1354
- * @returns {void}
1355
- */
1356
- ke = function(e) {
1357
- const t = document.querySelector(e);
1358
- t == null || t.appendChild(this.rendererManager.renderer.domElement), t == null || t.appendChild(this.debugManager.debugger.element);
1359
- };
1360
- export {
1361
- li as Img2Pxl
1362
- };
1363
- //# sourceMappingURL=core.js.map