@d3p1/img2pxl 1.22.1 → 1.23.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/README.md +93 -5
- package/dist/{core/app → app/main/runner}/image.d.ts +2 -2
- package/dist/{core/app → app/main/runner}/pointer/canvas.d.ts +1 -1
- package/dist/{core/app → app/main/runner}/pointer.d.ts +1 -1
- package/dist/{core/app.d.ts → app/main/runner.d.ts} +5 -5
- package/dist/{img2pxl.d.ts → app/main.d.ts} +4 -4
- package/dist/{img2pxl.js → core.js} +115 -117
- package/dist/core.js.map +1 -0
- package/dist/index.d.ts +6 -0
- package/dist/{core/lib → services}/debug-manager/copy/settings.d.ts +1 -1
- package/dist/{core/lib → services}/image-manager.d.ts +1 -1
- package/package.json +13 -11
- package/dist/img2pxl.js.map +0 -1
- package/dist/img2pxl.umd.cjs +0 -94
- package/dist/img2pxl.umd.cjs.map +0 -1
- /package/dist/{core/lib → services}/debug-manager.d.ts +0 -0
- /package/dist/{core/lib → services}/renderer-manager.d.ts +0 -0
|
@@ -3,13 +3,13 @@ var ue = (a) => {
|
|
|
3
3
|
throw TypeError(a);
|
|
4
4
|
};
|
|
5
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),
|
|
7
|
-
var i = (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
8
|
import * as d from "three";
|
|
9
9
|
import { Pane as Ce } from "tweakpane";
|
|
10
10
|
class Ie {
|
|
11
11
|
constructor() {
|
|
12
|
-
this._previousTime = 0, this._currentTime = 0, this._startTime =
|
|
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
13
|
}
|
|
14
14
|
getDelta() {
|
|
15
15
|
return this._delta / 1e3;
|
|
@@ -24,16 +24,16 @@ class Ie {
|
|
|
24
24
|
return this._timescale = e, this;
|
|
25
25
|
}
|
|
26
26
|
reset() {
|
|
27
|
-
return this._currentTime =
|
|
27
|
+
return this._currentTime = ie() - this._startTime, this;
|
|
28
28
|
}
|
|
29
29
|
dispose() {
|
|
30
30
|
return this._usePageVisibilityAPI === !0 && document.removeEventListener("visibilitychange", this._pageVisibilityHandler), this;
|
|
31
31
|
}
|
|
32
32
|
update(e) {
|
|
33
|
-
return this._usePageVisibilityAPI === !0 && document.hidden === !0 ? this._delta = 0 : (this._previousTime = this._currentTime, this._currentTime = (e !== void 0 ? 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
34
|
}
|
|
35
35
|
}
|
|
36
|
-
function
|
|
36
|
+
function ie() {
|
|
37
37
|
return performance.now();
|
|
38
38
|
}
|
|
39
39
|
function De() {
|
|
@@ -84,7 +84,7 @@ class Qe {
|
|
|
84
84
|
* @param {number} displacementFrequency
|
|
85
85
|
* @param {number} displacementAmplitude
|
|
86
86
|
*/
|
|
87
|
-
constructor(e, t, s, n, V,
|
|
87
|
+
constructor(e, t, s, n, V, m = 0.1, c = 5, p = 5, T = 50) {
|
|
88
88
|
o(this, F);
|
|
89
89
|
/**
|
|
90
90
|
* @type {Image}
|
|
@@ -102,7 +102,7 @@ class Qe {
|
|
|
102
102
|
* @type {DebugManager}
|
|
103
103
|
*/
|
|
104
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,
|
|
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
106
|
}
|
|
107
107
|
/**
|
|
108
108
|
* Update
|
|
@@ -330,15 +330,15 @@ Ue = function() {
|
|
|
330
330
|
* @link https://discourse.threejs.org/t/mapping-orthographiccamera-world-units-to-pixels/10142
|
|
331
331
|
*/
|
|
332
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,
|
|
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
334
|
this.camera = new d.OrthographicCamera(
|
|
335
335
|
e,
|
|
336
336
|
t,
|
|
337
337
|
s,
|
|
338
338
|
n,
|
|
339
339
|
V,
|
|
340
|
-
|
|
341
|
-
), this.scene.add(this.camera), this.camera.position.z =
|
|
340
|
+
m
|
|
341
|
+
), this.scene.add(this.camera), this.camera.position.z = m - 0.1;
|
|
342
342
|
}, /**
|
|
343
343
|
* Init scene
|
|
344
344
|
*
|
|
@@ -362,52 +362,52 @@ Ke = function() {
|
|
|
362
362
|
for (; this.scene.children.length > 0; )
|
|
363
363
|
this.scene.remove(this.scene.children[0]);
|
|
364
364
|
};
|
|
365
|
-
const Be = (a, e, t, s, n, V,
|
|
365
|
+
const Be = (a, e, t, s, n, V, m) => `{
|
|
366
366
|
images: {
|
|
367
367
|
0: {
|
|
368
368
|
src: <image-src>,
|
|
369
369
|
width: <image-width>,
|
|
370
370
|
height: <image-height>,
|
|
371
371
|
resolution: {
|
|
372
|
-
width:
|
|
373
|
-
height:
|
|
372
|
+
width: <image-resolution-width>,
|
|
373
|
+
height: <image-resolution-height>
|
|
374
374
|
},
|
|
375
375
|
pixel: {
|
|
376
|
-
size: ${
|
|
376
|
+
size: ${a},
|
|
377
377
|
motion: {
|
|
378
378
|
displacement: {
|
|
379
|
-
frequency: ${
|
|
380
|
-
amplitude: ${
|
|
379
|
+
frequency: ${e},
|
|
380
|
+
amplitude: ${t}
|
|
381
381
|
}
|
|
382
382
|
}
|
|
383
383
|
},
|
|
384
384
|
motion: {
|
|
385
385
|
noise: {
|
|
386
|
-
frequency: ${
|
|
387
|
-
amplitude: ${
|
|
386
|
+
frequency: ${s},
|
|
387
|
+
amplitude: ${n}
|
|
388
388
|
}
|
|
389
389
|
}
|
|
390
390
|
}
|
|
391
391
|
},
|
|
392
392
|
pointer: {
|
|
393
|
-
size: ${
|
|
393
|
+
size: ${V},
|
|
394
394
|
trailing: {
|
|
395
|
-
factor: ${
|
|
395
|
+
factor: ${m}
|
|
396
396
|
}
|
|
397
397
|
}
|
|
398
398
|
}`;
|
|
399
|
-
var
|
|
399
|
+
var _, Xe;
|
|
400
400
|
class He {
|
|
401
401
|
/**
|
|
402
402
|
* Constructor
|
|
403
403
|
*/
|
|
404
404
|
constructor() {
|
|
405
|
-
o(this,
|
|
405
|
+
o(this, _);
|
|
406
406
|
/**
|
|
407
407
|
* @type {Pane}
|
|
408
408
|
*/
|
|
409
409
|
q(this, "debugger");
|
|
410
|
-
this.debugger = new Ce(), r(this,
|
|
410
|
+
this.debugger = new Ce(), r(this, _, Xe).call(this);
|
|
411
411
|
}
|
|
412
412
|
/**
|
|
413
413
|
* Enable. Show debugger
|
|
@@ -455,8 +455,8 @@ class He {
|
|
|
455
455
|
addBindingWithOnChange(e, t, s, n, V = void 0) {
|
|
456
456
|
return this.addBinding(s, e[t], n, V).on(
|
|
457
457
|
"change",
|
|
458
|
-
(
|
|
459
|
-
e[t] =
|
|
458
|
+
(m) => {
|
|
459
|
+
e[t] = m.value;
|
|
460
460
|
}
|
|
461
461
|
);
|
|
462
462
|
}
|
|
@@ -480,7 +480,7 @@ class He {
|
|
|
480
480
|
);
|
|
481
481
|
}
|
|
482
482
|
}
|
|
483
|
-
|
|
483
|
+
_ = new WeakSet(), /**
|
|
484
484
|
* Add copy button
|
|
485
485
|
*
|
|
486
486
|
* @returns {void}
|
|
@@ -492,18 +492,16 @@ Xe = function() {
|
|
|
492
492
|
e.on("click", () => {
|
|
493
493
|
const t = this.debugger.exportState();
|
|
494
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,
|
|
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
496
|
c,
|
|
497
|
-
|
|
497
|
+
T,
|
|
498
|
+
G,
|
|
498
499
|
B,
|
|
499
500
|
H,
|
|
500
|
-
A,
|
|
501
|
-
_,
|
|
502
|
-
$,
|
|
503
501
|
n,
|
|
504
502
|
V
|
|
505
503
|
);
|
|
506
|
-
navigator.clipboard.writeText(
|
|
504
|
+
navigator.clipboard.writeText(A).then(() => {
|
|
507
505
|
e.title = "Copied!", setTimeout(() => {
|
|
508
506
|
e.title = "Copy";
|
|
509
507
|
}, 1e3);
|
|
@@ -540,7 +538,7 @@ void main() {
|
|
|
540
538
|
|
|
541
539
|
#include <tonemapping_fragment>
|
|
542
540
|
#include <colorspace_fragment>
|
|
543
|
-
}`,
|
|
541
|
+
}`, M, w, y, Z, Fe, te, se, qe;
|
|
544
542
|
let $e = (qe = class {
|
|
545
543
|
/**
|
|
546
544
|
* Constructor
|
|
@@ -553,7 +551,7 @@ let $e = (qe = class {
|
|
|
553
551
|
* @param {number} pointSize
|
|
554
552
|
* @param {number} alphaTest
|
|
555
553
|
*/
|
|
556
|
-
constructor(e, t, s, n, V,
|
|
554
|
+
constructor(e, t, s, n, V, m = 1, c = 0.1) {
|
|
557
555
|
o(this, Z);
|
|
558
556
|
/**
|
|
559
557
|
* @type {THREE.Points}
|
|
@@ -562,7 +560,7 @@ let $e = (qe = class {
|
|
|
562
560
|
/**
|
|
563
561
|
* @type {THREE.Texture}
|
|
564
562
|
*/
|
|
565
|
-
o(this,
|
|
563
|
+
o(this, M);
|
|
566
564
|
/**
|
|
567
565
|
* @type {RendererManager}
|
|
568
566
|
*/
|
|
@@ -571,7 +569,7 @@ let $e = (qe = class {
|
|
|
571
569
|
* @type {DebugManager}
|
|
572
570
|
*/
|
|
573
571
|
o(this, y);
|
|
574
|
-
l(this, w, e), l(this, y, t), r(this, Z, Fe).call(this, s, n, V,
|
|
572
|
+
l(this, w, e), l(this, y, t), r(this, Z, Fe).call(this, s, n, V, m, c);
|
|
575
573
|
}
|
|
576
574
|
/**
|
|
577
575
|
* Enable debug mode
|
|
@@ -588,14 +586,14 @@ let $e = (qe = class {
|
|
|
588
586
|
{ min: 0, max: this.points.geometry.parameters.width, step: 1 },
|
|
589
587
|
e
|
|
590
588
|
).on("change", (s) => {
|
|
591
|
-
s.last && r(this, Z,
|
|
589
|
+
s.last && r(this, Z, te).call(this, s.value, this.points.geometry.parameters.heightSegments);
|
|
592
590
|
}), i(this, y).addBinding(
|
|
593
591
|
"height",
|
|
594
592
|
this.points.geometry.parameters.heightSegments,
|
|
595
593
|
{ min: 0, max: this.points.geometry.parameters.height, step: 1 },
|
|
596
594
|
e
|
|
597
595
|
).on("change", (s) => {
|
|
598
|
-
s.last && r(this, Z,
|
|
596
|
+
s.last && r(this, Z, te).call(this, this.points.geometry.parameters.widthSegments, s.value);
|
|
599
597
|
});
|
|
600
598
|
const t = i(this, y).addFolder({ title: "Image Pixel" });
|
|
601
599
|
i(this, y).addBinding(
|
|
@@ -613,9 +611,9 @@ let $e = (qe = class {
|
|
|
613
611
|
* @returns {void}
|
|
614
612
|
*/
|
|
615
613
|
dispose() {
|
|
616
|
-
this.points.geometry.dispose(), this.points.material.dispose(), i(this,
|
|
614
|
+
this.points.geometry.dispose(), this.points.material.dispose(), i(this, M).dispose();
|
|
617
615
|
}
|
|
618
|
-
},
|
|
616
|
+
}, M = new WeakMap(), w = new WeakMap(), y = new WeakMap(), Z = new WeakSet(), /**
|
|
619
617
|
* Init points
|
|
620
618
|
*
|
|
621
619
|
* @param {string} imageSrc
|
|
@@ -626,13 +624,13 @@ let $e = (qe = class {
|
|
|
626
624
|
* @returns {void}
|
|
627
625
|
*/
|
|
628
626
|
Fe = function(e, t, s, n, V) {
|
|
629
|
-
const
|
|
630
|
-
l(this,
|
|
631
|
-
const c = r(this, Z,
|
|
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({
|
|
632
630
|
vertexShader: Ae,
|
|
633
631
|
fragmentShader: _e,
|
|
634
632
|
uniforms: {
|
|
635
|
-
uImageTexture: new d.Uniform(i(this,
|
|
633
|
+
uImageTexture: new d.Uniform(i(this, M)),
|
|
636
634
|
uPointSize: new d.Uniform(n),
|
|
637
635
|
uAlphaTest: new d.Uniform(V)
|
|
638
636
|
},
|
|
@@ -651,9 +649,9 @@ Fe = function(e, t, s, n, V) {
|
|
|
651
649
|
* New generated geometry attributes will replace old ones if
|
|
652
650
|
* they exist in the old geometry
|
|
653
651
|
*/
|
|
654
|
-
|
|
652
|
+
te = function(e, t) {
|
|
655
653
|
const s = this.points.geometry.attributes;
|
|
656
|
-
this.points.geometry.dispose(), this.points.geometry = r(this, Z,
|
|
654
|
+
this.points.geometry.dispose(), this.points.geometry = r(this, Z, se).call(this, e, t, s);
|
|
657
655
|
}, /**
|
|
658
656
|
* Create image geometry
|
|
659
657
|
*
|
|
@@ -671,7 +669,7 @@ re = function(e, t) {
|
|
|
671
669
|
* The index could cause the draw of multiple points/pixels in the
|
|
672
670
|
* same place. That is why it is required to remove it
|
|
673
671
|
*/
|
|
674
|
-
|
|
672
|
+
se = function(e, t, s = null) {
|
|
675
673
|
const n = new d.PlaneGeometry(
|
|
676
674
|
i(this, w).renderer.domElement.width,
|
|
677
675
|
i(this, w).renderer.domElement.height,
|
|
@@ -680,7 +678,7 @@ ae = function(e, t, s = null) {
|
|
|
680
678
|
);
|
|
681
679
|
return n.setIndex(null), n.deleteAttribute("normal"), s && (n.attributes = { ...s, ...n.attributes }), n;
|
|
682
680
|
}, qe);
|
|
683
|
-
var b,
|
|
681
|
+
var b, k, j, S, Ze, Se, ye, Pe;
|
|
684
682
|
class ei {
|
|
685
683
|
/**
|
|
686
684
|
* Constructor
|
|
@@ -713,11 +711,11 @@ class ei {
|
|
|
713
711
|
/**
|
|
714
712
|
* @type {Function}
|
|
715
713
|
*/
|
|
716
|
-
o(this,
|
|
714
|
+
o(this, k);
|
|
717
715
|
/**
|
|
718
716
|
* @type {Function}
|
|
719
717
|
*/
|
|
720
|
-
o(this,
|
|
718
|
+
o(this, j);
|
|
721
719
|
this.canvas = t, this.coord = new d.Vector2(void 0, void 0), l(this, b, e), r(this, S, ye).call(this);
|
|
722
720
|
}
|
|
723
721
|
/**
|
|
@@ -754,10 +752,10 @@ class ei {
|
|
|
754
752
|
* @returns {void}
|
|
755
753
|
*/
|
|
756
754
|
dispose() {
|
|
757
|
-
this.canvas.dispose(), r(this, S,
|
|
755
|
+
this.canvas.dispose(), r(this, S, Pe).call(this);
|
|
758
756
|
}
|
|
759
757
|
}
|
|
760
|
-
b = new WeakMap(),
|
|
758
|
+
b = new WeakMap(), k = new WeakMap(), j = new WeakMap(), S = new WeakSet(), /**
|
|
761
759
|
* Process pointer move
|
|
762
760
|
*
|
|
763
761
|
* @param {PointerEvent} e
|
|
@@ -785,12 +783,12 @@ Se = function() {
|
|
|
785
783
|
* working between the raycaster and image points
|
|
786
784
|
*/
|
|
787
785
|
ye = function() {
|
|
788
|
-
this.raycaster = new d.Raycaster(), l(this,
|
|
786
|
+
this.raycaster = new d.Raycaster(), l(this, k, r(this, S, Ze).bind(this)), i(this, b).renderer.domElement.addEventListener(
|
|
789
787
|
"pointermove",
|
|
790
|
-
i(this, M)
|
|
791
|
-
), l(this, k, r(this, S, Se).bind(this)), i(this, b).renderer.domElement.addEventListener(
|
|
792
|
-
"pointerleave",
|
|
793
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)
|
|
794
792
|
), this.raycasterPlane = new d.Mesh(
|
|
795
793
|
new d.PlaneGeometry(
|
|
796
794
|
i(this, b).width,
|
|
@@ -803,16 +801,16 @@ ye = function() {
|
|
|
803
801
|
*
|
|
804
802
|
* @returns {void}
|
|
805
803
|
*/
|
|
806
|
-
|
|
804
|
+
Pe = function() {
|
|
807
805
|
i(this, b).renderer.domElement.removeEventListener(
|
|
808
806
|
"pointermove",
|
|
809
|
-
i(this,
|
|
807
|
+
i(this, k)
|
|
810
808
|
), i(this, b).renderer.domElement.removeEventListener(
|
|
811
809
|
"pointerleave",
|
|
812
|
-
i(this,
|
|
810
|
+
i(this, j)
|
|
813
811
|
), this.raycasterPlane.geometry.dispose(), this.raycasterPlane.material.dispose();
|
|
814
812
|
};
|
|
815
|
-
var
|
|
813
|
+
var P, f, J, g, x, U, ge, ze, we, xe, ne;
|
|
816
814
|
class ii {
|
|
817
815
|
/**
|
|
818
816
|
* Constructor
|
|
@@ -824,12 +822,12 @@ class ii {
|
|
|
824
822
|
* @param {number} pointerImageSize
|
|
825
823
|
* @param {number} pointerTrailingFactor
|
|
826
824
|
*/
|
|
827
|
-
constructor(e, t, s, n, V = 0.1,
|
|
825
|
+
constructor(e, t, s, n, V = 0.1, m = 0.05) {
|
|
828
826
|
o(this, U);
|
|
829
827
|
/**
|
|
830
828
|
* @type {DebugManager}
|
|
831
829
|
*/
|
|
832
|
-
o(this,
|
|
830
|
+
o(this, P);
|
|
833
831
|
/**
|
|
834
832
|
* @type {THREE.CanvasTexture}
|
|
835
833
|
*/
|
|
@@ -849,14 +847,14 @@ class ii {
|
|
|
849
847
|
* select which vertices/points/pixels
|
|
850
848
|
* should be displaced
|
|
851
849
|
*/
|
|
852
|
-
o(this,
|
|
850
|
+
o(this, J);
|
|
853
851
|
/**
|
|
854
852
|
* @type {number}
|
|
855
853
|
* @note This value defines how many pixels are affected by the
|
|
856
854
|
* pointer effect.
|
|
857
855
|
* It is defined as a proportion of the image resolution width
|
|
858
856
|
*/
|
|
859
|
-
o(this,
|
|
857
|
+
o(this, g);
|
|
860
858
|
/**
|
|
861
859
|
* @type {number}
|
|
862
860
|
* @note This value defines the strength of the
|
|
@@ -864,7 +862,7 @@ class ii {
|
|
|
864
862
|
* pixels' displacement
|
|
865
863
|
*/
|
|
866
864
|
o(this, x);
|
|
867
|
-
l(this,
|
|
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);
|
|
868
866
|
}
|
|
869
867
|
/**
|
|
870
868
|
* Update
|
|
@@ -874,7 +872,7 @@ class ii {
|
|
|
874
872
|
* @returns {void}
|
|
875
873
|
*/
|
|
876
874
|
update(e, t) {
|
|
877
|
-
r(this, U, ze).call(this), e && t && r(this, U,
|
|
875
|
+
r(this, U, ze).call(this), e && t && r(this, U, ge).call(this, e, t), this.texture.needsUpdate = !0;
|
|
878
876
|
}
|
|
879
877
|
/**
|
|
880
878
|
* Enable debug mode
|
|
@@ -882,19 +880,19 @@ class ii {
|
|
|
882
880
|
* @returns {void}
|
|
883
881
|
*/
|
|
884
882
|
debug() {
|
|
885
|
-
const e = i(this,
|
|
883
|
+
const e = i(this, P).addFolder({
|
|
886
884
|
title: "Pointer"
|
|
887
885
|
});
|
|
888
|
-
i(this,
|
|
886
|
+
i(this, P).addBinding(
|
|
889
887
|
"size",
|
|
890
|
-
i(this,
|
|
888
|
+
i(this, g) / this.element.width,
|
|
891
889
|
{
|
|
892
890
|
min: 0,
|
|
893
891
|
max: 1,
|
|
894
892
|
step: 0.01
|
|
895
893
|
},
|
|
896
894
|
e
|
|
897
|
-
).on("change", (s) => r(this, U,
|
|
895
|
+
).on("change", (s) => r(this, U, ne).call(this, s.value)), i(this, P).addBinding(
|
|
898
896
|
"trailing",
|
|
899
897
|
i(this, x),
|
|
900
898
|
{
|
|
@@ -904,10 +902,10 @@ class ii {
|
|
|
904
902
|
},
|
|
905
903
|
e
|
|
906
904
|
).on("change", (s) => l(this, x, s.value));
|
|
907
|
-
const t = i(this,
|
|
905
|
+
const t = i(this, P).addFolder({
|
|
908
906
|
title: "Pointer Canvas"
|
|
909
907
|
});
|
|
910
|
-
i(this,
|
|
908
|
+
i(this, P).addBinding("show", !1, void 0, t).on("change", (s) => {
|
|
911
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);
|
|
912
910
|
});
|
|
913
911
|
}
|
|
@@ -920,7 +918,7 @@ class ii {
|
|
|
920
918
|
this.texture.dispose();
|
|
921
919
|
}
|
|
922
920
|
}
|
|
923
|
-
|
|
921
|
+
P = new WeakMap(), f = new WeakMap(), J = new WeakMap(), g = new WeakMap(), x = new WeakMap(), U = new WeakSet(), /**
|
|
924
922
|
* Draw
|
|
925
923
|
*
|
|
926
924
|
* @param {number} dx
|
|
@@ -929,13 +927,13 @@ g = new WeakMap(), f = new WeakMap(), j = new WeakMap(), P = new WeakMap(), x =
|
|
|
929
927
|
* @note The destination of the image is moved half its size
|
|
930
928
|
* so it is drawn at the center of the destination position
|
|
931
929
|
*/
|
|
932
|
-
|
|
933
|
-
e -= i(this,
|
|
934
|
-
i(this,
|
|
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),
|
|
935
933
|
e,
|
|
936
934
|
t,
|
|
937
|
-
i(this,
|
|
938
|
-
i(this,
|
|
935
|
+
i(this, g),
|
|
936
|
+
i(this, g)
|
|
939
937
|
), i(this, f).restore();
|
|
940
938
|
}, /**
|
|
941
939
|
* Clear
|
|
@@ -970,7 +968,7 @@ we = function(e, t) {
|
|
|
970
968
|
* a white image that will indicate which pixels should be displaced
|
|
971
969
|
*/
|
|
972
970
|
xe = function(e, t) {
|
|
973
|
-
l(this,
|
|
971
|
+
l(this, J, new Image()), i(this, J).src = e, r(this, U, ne).call(this, t);
|
|
974
972
|
}, /**
|
|
975
973
|
* Process pointer image size
|
|
976
974
|
*
|
|
@@ -982,11 +980,11 @@ xe = function(e, t) {
|
|
|
982
980
|
* This approach is considered correct because web elements
|
|
983
981
|
* adjust only their width to fit in the page
|
|
984
982
|
*/
|
|
985
|
-
|
|
986
|
-
l(this,
|
|
983
|
+
ne = function(e) {
|
|
984
|
+
l(this, g, e * this.element.width);
|
|
987
985
|
};
|
|
988
986
|
const ti = "", si = "", me = 0;
|
|
989
|
-
var
|
|
987
|
+
var C, Y, $, Ne;
|
|
990
988
|
class ni {
|
|
991
989
|
/**
|
|
992
990
|
* Constructor
|
|
@@ -1020,7 +1018,7 @@ class ni {
|
|
|
1020
1018
|
* @throws {Error}
|
|
1021
1019
|
*/
|
|
1022
1020
|
constructor(e) {
|
|
1023
|
-
o(this,
|
|
1021
|
+
o(this, $);
|
|
1024
1022
|
/**
|
|
1025
1023
|
* @type {{
|
|
1026
1024
|
* src : string;
|
|
@@ -1082,12 +1080,12 @@ class ni {
|
|
|
1082
1080
|
/**
|
|
1083
1081
|
* @type {number}
|
|
1084
1082
|
*/
|
|
1085
|
-
o(this,
|
|
1083
|
+
o(this, C);
|
|
1086
1084
|
/**
|
|
1087
1085
|
* @type {number[]}
|
|
1088
1086
|
*/
|
|
1089
|
-
o(this,
|
|
1090
|
-
this.images = e, r(this,
|
|
1087
|
+
o(this, Y);
|
|
1088
|
+
this.images = e, r(this, $, Ne).call(this, Object.keys(this.images).map(Number)), this.update();
|
|
1091
1089
|
}
|
|
1092
1090
|
/**
|
|
1093
1091
|
* Taking into consideration window size,
|
|
@@ -1101,14 +1099,14 @@ class ni {
|
|
|
1101
1099
|
* the window size
|
|
1102
1100
|
*/
|
|
1103
1101
|
update() {
|
|
1104
|
-
const e = window.innerWidth, t = i(this,
|
|
1102
|
+
const e = window.innerWidth, t = i(this, Y).reduce(
|
|
1105
1103
|
(s, n) => n <= e && n > s ? n : s,
|
|
1106
1104
|
me
|
|
1107
1105
|
);
|
|
1108
|
-
return t !== i(this,
|
|
1106
|
+
return t !== i(this, C) ? (l(this, C, t), this.currentImage = this.images[i(this, C)], !0) : !1;
|
|
1109
1107
|
}
|
|
1110
1108
|
}
|
|
1111
|
-
|
|
1109
|
+
C = new WeakMap(), Y = new WeakMap(), $ = new WeakSet(), /**
|
|
1112
1110
|
* Init breakpoints from image
|
|
1113
1111
|
*
|
|
1114
1112
|
* @param {number[]} breakpoints
|
|
@@ -1122,9 +1120,9 @@ Ne = function(e) {
|
|
|
1122
1120
|
throw new Error(
|
|
1123
1121
|
"The `0` breakpoint is required. It defines the default image that should be used."
|
|
1124
1122
|
);
|
|
1125
|
-
l(this,
|
|
1123
|
+
l(this, Y, e);
|
|
1126
1124
|
};
|
|
1127
|
-
var N, v, L, z, O,
|
|
1125
|
+
var N, v, L, z, O, Q, I, D, u, re, ae, Le, oe, Oe, Te, Me, ke;
|
|
1128
1126
|
class li {
|
|
1129
1127
|
/**
|
|
1130
1128
|
* Constructor
|
|
@@ -1169,7 +1167,7 @@ class li {
|
|
|
1169
1167
|
* @throws {Error}
|
|
1170
1168
|
*/
|
|
1171
1169
|
constructor(e) {
|
|
1172
|
-
o(this,
|
|
1170
|
+
o(this, u);
|
|
1173
1171
|
/**
|
|
1174
1172
|
* @type {RendererManager}
|
|
1175
1173
|
*/
|
|
@@ -1179,7 +1177,7 @@ class li {
|
|
|
1179
1177
|
*/
|
|
1180
1178
|
q(this, "debugManager");
|
|
1181
1179
|
/**
|
|
1182
|
-
* @type {
|
|
1180
|
+
* @type {Runner}
|
|
1183
1181
|
*/
|
|
1184
1182
|
o(this, N);
|
|
1185
1183
|
/**
|
|
@@ -1236,16 +1234,16 @@ class li {
|
|
|
1236
1234
|
/**
|
|
1237
1235
|
* @type {number}
|
|
1238
1236
|
*/
|
|
1239
|
-
o(this,
|
|
1237
|
+
o(this, Q);
|
|
1240
1238
|
/**
|
|
1241
1239
|
* @type {Function}
|
|
1242
1240
|
*/
|
|
1243
|
-
o(this,
|
|
1241
|
+
o(this, I);
|
|
1244
1242
|
/**
|
|
1245
1243
|
* @type {Function}
|
|
1246
1244
|
*/
|
|
1247
|
-
o(this,
|
|
1248
|
-
l(this, z, e), l(this, O, e.isDebugging ?? !1), l(this, v, new ni(e.images)), r(this,
|
|
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);
|
|
1249
1247
|
}
|
|
1250
1248
|
/**
|
|
1251
1249
|
* Debug
|
|
@@ -1253,7 +1251,7 @@ class li {
|
|
|
1253
1251
|
* @returns {void}
|
|
1254
1252
|
*/
|
|
1255
1253
|
debug() {
|
|
1256
|
-
i(this, O) || (r(this,
|
|
1254
|
+
i(this, O) || (r(this, u, oe).call(this), l(this, O, !0));
|
|
1257
1255
|
}
|
|
1258
1256
|
/**
|
|
1259
1257
|
* Dispose
|
|
@@ -1261,29 +1259,29 @@ class li {
|
|
|
1261
1259
|
* @returns {void}
|
|
1262
1260
|
*/
|
|
1263
1261
|
dispose() {
|
|
1264
|
-
cancelAnimationFrame(i(this,
|
|
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();
|
|
1265
1263
|
}
|
|
1266
1264
|
}
|
|
1267
|
-
N = new WeakMap(), v = new WeakMap(), L = new WeakMap(), z = new WeakMap(), O = new WeakMap(),
|
|
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(), /**
|
|
1268
1266
|
* Init
|
|
1269
1267
|
*
|
|
1270
1268
|
* @returns {void}
|
|
1271
1269
|
*/
|
|
1272
|
-
|
|
1270
|
+
re = function() {
|
|
1273
1271
|
this.rendererManager = new Ge(
|
|
1274
1272
|
i(this, v).currentImage.width,
|
|
1275
1273
|
i(this, v).currentImage.height
|
|
1276
|
-
), l(this, L, new Ie()), r(this,
|
|
1277
|
-
i(this, v).update() && (this.dispose(), r(this,
|
|
1278
|
-
}), window.addEventListener("resize", i(this,
|
|
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);
|
|
1279
1277
|
}, /**
|
|
1280
1278
|
* Render
|
|
1281
1279
|
*
|
|
1282
1280
|
* @params {number} t
|
|
1283
1281
|
* @returns {void}
|
|
1284
1282
|
*/
|
|
1285
|
-
|
|
1286
|
-
i(this, L).update(e), i(this, N).update(i(this, L).getElapsed()), l(this,
|
|
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)));
|
|
1287
1285
|
}, /**
|
|
1288
1286
|
* Handle debug
|
|
1289
1287
|
*
|
|
@@ -1297,7 +1295,7 @@ Le = function(e) {
|
|
|
1297
1295
|
*
|
|
1298
1296
|
* @returns {void}
|
|
1299
1297
|
*/
|
|
1300
|
-
|
|
1298
|
+
oe = function() {
|
|
1301
1299
|
i(this, N).debug(), this.debugManager.enable();
|
|
1302
1300
|
}, /**
|
|
1303
1301
|
* Disable debug
|
|
@@ -1307,12 +1305,12 @@ Ve = function() {
|
|
|
1307
1305
|
Oe = function() {
|
|
1308
1306
|
this.debugManager.disable();
|
|
1309
1307
|
}, /**
|
|
1310
|
-
* Init
|
|
1308
|
+
* Init runner
|
|
1311
1309
|
*
|
|
1312
1310
|
* @returns {void}
|
|
1313
1311
|
*/
|
|
1314
1312
|
Te = function() {
|
|
1315
|
-
var e, t, s, n, V,
|
|
1313
|
+
var e, t, s, n, V, m, c, p, T, G, E, B, H, A, le, de, Ve, pe;
|
|
1316
1314
|
l(this, N, new Qe(
|
|
1317
1315
|
new $e(
|
|
1318
1316
|
this.rendererManager,
|
|
@@ -1331,16 +1329,16 @@ Te = function() {
|
|
|
1331
1329
|
i(this, v).currentImage.resolution.height,
|
|
1332
1330
|
((s = i(this, z).pointer) == null ? void 0 : s.src) ?? ti,
|
|
1333
1331
|
((n = i(this, z).pointer) == null ? void 0 : n.size) ?? 0.15,
|
|
1334
|
-
((
|
|
1332
|
+
((m = (V = i(this, z).pointer) == null ? void 0 : V.trailing) == null ? void 0 : m.factor) ?? 0.01
|
|
1335
1333
|
)
|
|
1336
1334
|
),
|
|
1337
1335
|
this.rendererManager,
|
|
1338
1336
|
this.debugManager,
|
|
1339
1337
|
((p = (c = i(this, v).currentImage.motion) == null ? void 0 : c.noise) == null ? void 0 : p.src) ?? si,
|
|
1340
|
-
((
|
|
1341
|
-
((
|
|
1342
|
-
((
|
|
1343
|
-
((pe = (
|
|
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
|
|
1344
1342
|
));
|
|
1345
1343
|
}, /**
|
|
1346
1344
|
* Init debug manager
|
|
@@ -1360,6 +1358,6 @@ ke = function(e) {
|
|
|
1360
1358
|
t == null || t.appendChild(this.rendererManager.renderer.domElement), t == null || t.appendChild(this.debugManager.debugger.element);
|
|
1361
1359
|
};
|
|
1362
1360
|
export {
|
|
1363
|
-
li as
|
|
1361
|
+
li as Img2Pxl
|
|
1364
1362
|
};
|
|
1365
|
-
//# sourceMappingURL=
|
|
1363
|
+
//# sourceMappingURL=core.js.map
|