@d3p1/img2pxl 1.22.2 → 2.0.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 +4 -8
- 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} +4 -4
- package/dist/core.js.map +1 -0
- package/dist/index.d.ts +6 -0
- 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/copy/settings.d.ts +0 -0
- /package/dist/{core/lib → services}/debug-manager.d.ts +0 -0
- /package/dist/{core/lib → services}/renderer-manager.d.ts +0 -0
package/dist/img2pxl.umd.cjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"img2pxl.umd.cjs","sources":["../node_modules/three/examples/jsm/misc/Timer.js","../src/core/app/shader/pars_vertex.glsl","../src/core/app/shader/position_vertex.glsl","../src/core/app.ts","../src/core/lib/renderer-manager.ts","../src/core/lib/debug-manager/copy/settings.ts","../src/core/lib/debug-manager.ts","../src/core/app/image/shader/vertex.glsl","../src/core/app/image/shader/fragment.glsl","../src/core/app/image.ts","../src/core/app/pointer.ts","../src/core/app/pointer/canvas.ts","../src/media/processor/displacement/pointer.png","../src/media/processor/displacement/noise.png","../src/core/lib/image-manager.ts","../src/img2pxl.ts"],"sourcesContent":["class Timer {\n\n\tconstructor() {\n\n\t\tthis._previousTime = 0;\n\t\tthis._currentTime = 0;\n\t\tthis._startTime = now();\n\n\t\tthis._delta = 0;\n\t\tthis._elapsed = 0;\n\n\t\tthis._timescale = 1;\n\n\t\t// use Page Visibility API to avoid large time delta values\n\n\t\tthis._usePageVisibilityAPI = ( typeof document !== 'undefined' && document.hidden !== undefined );\n\n\t\tif ( this._usePageVisibilityAPI === true ) {\n\n\t\t\tthis._pageVisibilityHandler = handleVisibilityChange.bind( this );\n\n\t\t\tdocument.addEventListener( 'visibilitychange', this._pageVisibilityHandler, false );\n\n\t\t}\n\n\t}\n\n\tgetDelta() {\n\n\t\treturn this._delta / 1000;\n\n\t}\n\n\tgetElapsed() {\n\n\t\treturn this._elapsed / 1000;\n\n\t}\n\n\tgetTimescale() {\n\n\t\treturn this._timescale;\n\n\t}\n\n\tsetTimescale( timescale ) {\n\n\t\tthis._timescale = timescale;\n\n\t\treturn this;\n\n\t}\n\n\treset() {\n\n\t\tthis._currentTime = now() - this._startTime;\n\n\t\treturn this;\n\n\t}\n\n\tdispose() {\n\n\t\tif ( this._usePageVisibilityAPI === true ) {\n\n\t\t\tdocument.removeEventListener( 'visibilitychange', this._pageVisibilityHandler );\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n\tupdate( timestamp ) {\n\n\n\t\tif ( this._usePageVisibilityAPI === true && document.hidden === true ) {\n\n\t\t\tthis._delta = 0;\n\n\t\t} else {\n\n\t\t\tthis._previousTime = this._currentTime;\n\t\t\tthis._currentTime = ( timestamp !== undefined ? timestamp : now() ) - this._startTime;\n\n\t\t\tthis._delta = ( this._currentTime - this._previousTime ) * this._timescale;\n\t\t\tthis._elapsed += this._delta; // _elapsed is the accumulation of all previous deltas\n\n\t\t}\n\n\t\treturn this;\n\n\t}\n\n}\n\nclass FixedTimer extends Timer {\n\n\tconstructor( fps = 60 ) {\n\n\t\tsuper();\n\t\tthis._delta = ( 1 / fps ) * 1000;\n\n\t}\n\n\tupdate() {\n\n\t\tthis._elapsed += ( this._delta * this._timescale ); // _elapsed is the accumulation of all previous deltas\n\n\t\treturn this;\n\n\t}\n\n}\n\nfunction now() {\n\n\treturn performance.now();\n\n}\n\nfunction handleVisibilityChange() {\n\n\tif ( document.hidden === false ) this.reset();\n\n}\n\nexport { Timer, FixedTimer };\n","/**\n * @description Shader chunk used to define params used in the\n * image vertex shader\n * to handle vertex/point/pixel displacement\n * @author C. M. de Picciotto <d3p1@d3p1.dev> (https://d3p1.dev/)\n * @note This file is called `pars_vertex.glsl` to mantain the\n * same naming style used by Three.js for its `.glsl` chunk\n * files that define shader params\n */\nattribute float aDisAngle;\nattribute float aDisAmplitude;\n\nuniform float uTime;\nuniform float uDisFrequency;\nuniform float uDisAmplitude;\nuniform sampler2D uDisTexture;\nuniform float uNoiseFrequency;\nuniform float uNoiseAmplitude;\nuniform sampler2D uNoiseTexture;\n\nvarying vec4 vColor;","/**\n * @description Shader chunk used to handle vertex/point/pixel displacement\n * to handle vertex/point/pixel displacement\n * @author C. M. de Picciotto <d3p1@d3p1.dev> (https://d3p1.dev/)\n */\nvec3 vertexPosition = position;\n\nvec2 noiseUv = vec2(uv.x - uNoiseFrequency * uTime, uv.y);\nfloat noiseFactor = texture(uNoiseTexture, noiseUv).r * uNoiseAmplitude;\nfloat noiseX = cos(aDisAngle) * noiseFactor;\nfloat noiseY = sin(aDisAngle) * noiseFactor;\nvec2 noise = vec2(noiseX, noiseY);\n vertexPosition.xy += noise;\n\nfloat disFactor = texture(uDisTexture, uv).r;\n disFactor = smoothstep(0.2, 0.8, disFactor);\n disFactor = (sin(uDisFrequency * uTime) + 1.5) / (2.5) *\n disFactor *\n uDisAmplitude;\n disFactor *= aDisAmplitude;\n\nfloat displacementX = cos(aDisAngle) * disFactor;\nfloat displacementY = sin(aDisAngle) * disFactor;\nvec2 displacement = vec2(displacementX, displacementY);\n vertexPosition.xy += displacement;","/**\n * @description App\n * @author C. M. de Picciotto <d3p1@d3p1.dev> (https://d3p1.dev/)\n * @note This class will manage how the renderer manager,\n * debug manager, the image, the pointer\n * and the motion (pixels' default motion, noise, etc.)\n * interact between each other\n */\nimport * as THREE from 'three'\nimport RendererManager from './lib/renderer-manager.js'\nimport DebugManager from './lib/debug-manager.js'\nimport Image from './app/image.js'\nimport Pointer from './app/pointer.js'\nimport parsVertexShader from './app/shader/pars_vertex.glsl'\nimport positionVertexShader from './app/shader/position_vertex.glsl'\n\nexport default class App {\n /**\n * @type {Image}\n */\n #image: Image\n\n /**\n * @type {Pointer}\n */\n #pointer: Pointer\n\n /**\n * @type {RendererManager}\n */\n #rendererManager: RendererManager\n\n /**\n * @type {DebugManager}\n */\n #debugManager: DebugManager\n\n /**\n * Constructor\n *\n * @param {Image} image\n * @param {Pointer} pointer\n * @param {RendererManager} rendererManager\n * @param {DebugManager} debugManager\n * @param {string} noiseImageSrc\n * @param {number} noiseFrequency\n * @param {number} noiseAmplitude\n * @param {number} displacementFrequency\n * @param {number} displacementAmplitude\n */\n constructor(\n image: Image,\n pointer: Pointer,\n rendererManager: RendererManager,\n debugManager: DebugManager,\n noiseImageSrc: string,\n noiseFrequency: number = 0.1,\n noiseAmplitude: number = 5,\n displacementFrequency: number = 5,\n displacementAmplitude: number = 50,\n ) {\n this.#image = image\n this.#pointer = pointer\n this.#rendererManager = rendererManager\n this.#debugManager = debugManager\n this.#initImage(\n noiseImageSrc,\n noiseFrequency,\n noiseAmplitude,\n displacementFrequency,\n displacementAmplitude,\n )\n this.#initPointer()\n }\n\n /**\n * Update\n *\n * @param {number} elapsed\n * @returns {void}\n */\n update(elapsed: number): void {\n this.#image.points.material.uniforms.uTime.value = elapsed\n this.#pointer.update()\n this.#rendererManager.update()\n }\n\n /**\n * Enable debug mode\n *\n * @returns {void}\n */\n debug(): void {\n this.#pointer.debug()\n\n this.#image.debug()\n\n const pixelMotionFolder = this.#debugManager.addFolder({\n title: 'Image Pixel Motion',\n })\n\n this.#debugManager.addBindingWithOnChange(\n this.#image.points.material.uniforms.uDisFrequency,\n 'value',\n 'frequency',\n {min: 0, max: 10 * 2 * Math.PI, step: 0.01},\n pixelMotionFolder,\n )\n\n this.#debugManager.addBindingWithOnChange(\n this.#image.points.material.uniforms.uDisAmplitude,\n 'value',\n 'amplitude',\n {min: 0, max: this.#rendererManager.width, step: 1},\n pixelMotionFolder,\n )\n\n const imageMotionFolder = this.#debugManager.addFolder({\n title: 'Image Motion',\n })\n\n this.#debugManager.addBindingWithOnChange(\n this.#image.points.material.uniforms.uNoiseFrequency,\n 'value',\n 'frequency',\n {min: 0, max: 2 * Math.PI, step: 0.01},\n imageMotionFolder,\n )\n\n this.#debugManager.addBindingWithOnChange(\n this.#image.points.material.uniforms.uNoiseAmplitude,\n 'value',\n 'amplitude',\n {min: 0, max: this.#rendererManager.width, step: 1},\n imageMotionFolder,\n )\n }\n\n /**\n * Dispose\n *\n * @returns {void}\n */\n dispose(): void {\n this.#image.dispose()\n this.#pointer.dispose()\n }\n\n /**\n * Init image\n *\n * @param {string} noiseImageSrc\n * @param {number} noiseFrequency\n * @param {number} noiseAmplitude\n * @param {number} displacementFrequency\n * @param {number} displacementAmplitude\n * @returns {void}\n */\n #initImage(\n noiseImageSrc: string,\n noiseFrequency: number,\n noiseAmplitude: number,\n displacementFrequency: number,\n displacementAmplitude: number,\n ): void {\n this.#rendererManager.scene.add(this.#image.points)\n this.#addDisplacementAttributesToImage()\n this.#addDisplacementHandlerToImage(\n noiseImageSrc,\n noiseFrequency,\n noiseAmplitude,\n displacementFrequency,\n displacementAmplitude,\n )\n }\n\n /**\n * Init pointer\n *\n * @returns {void}\n */\n #initPointer(): void {\n this.#pointer.raycasterPlane.position.copy(this.#image.points.position)\n this.#pointer.raycasterPlane.position.z += 0.01\n\n this.#rendererManager.scene.add(this.#pointer.raycasterPlane)\n }\n\n /**\n * Add logic that handles vertex/point/pixel displacement to image\n *\n * @param {string} noiseImageSrc\n * @param {number} noiseFrequency\n * @param {number} noiseAmplitude\n * @param {number} displacementFrequency\n * @param {number} displacementAmplitude\n * @returns {void}\n * @note Take into consideration that the pointer canvas/image/texture\n * is called `uDisTexture` inside the shader because\n * it is considered that the shader does not need to know\n * that this texture is related to a pointer\n * @note Force shader compilation with `compile()`.\n * If it is not forced the shader compilation, then\n * uniforms will be undefined until first render of the scene\n * {@link https://github.com/mrdoob/three.js/pull/10960}\n */\n #addDisplacementHandlerToImage(\n noiseImageSrc: string,\n noiseFrequency: number,\n noiseAmplitude: number,\n displacementFrequency: number,\n displacementAmplitude: number,\n ): void {\n const textureLoader = new THREE.TextureLoader()\n const noiseTexture = textureLoader.load(noiseImageSrc)\n noiseTexture.wrapS = THREE.RepeatWrapping\n\n this.#image.points.material.onBeforeCompile = (\n shader: THREE.WebGLProgramParametersWithUniforms,\n ) => {\n shader.uniforms['uTime'] = new THREE.Uniform(0)\n shader.uniforms['uDisFrequency'] = new THREE.Uniform(\n displacementFrequency,\n )\n shader.uniforms['uDisAmplitude'] = new THREE.Uniform(\n displacementAmplitude,\n )\n shader.uniforms['uDisTexture'] = new THREE.Uniform(\n this.#pointer.canvas.texture,\n )\n shader.uniforms['uNoiseFrequency'] = new THREE.Uniform(noiseFrequency)\n shader.uniforms['uNoiseAmplitude'] = new THREE.Uniform(noiseAmplitude)\n shader.uniforms['uNoiseTexture'] = new THREE.Uniform(noiseTexture)\n\n shader.vertexShader = shader.vertexShader.replace(\n 'varying vec4 vColor;',\n parsVertexShader,\n )\n shader.vertexShader = shader.vertexShader.replace(\n 'vec3 vertexPosition = position;',\n positionVertexShader,\n )\n }\n\n this.#rendererManager.compile()\n }\n\n /**\n * Add attributes that handle displacement to image\n *\n * @returns {void}\n */\n #addDisplacementAttributesToImage(): void {\n const vertices = this.#image.points.geometry.attributes.position.count\n const disAngle = new Float32Array(vertices)\n const disAmplitude = new Float32Array(vertices)\n for (let i = 0; i < vertices; i++) {\n disAngle[i] = Math.random() * 2 * Math.PI\n disAmplitude[i] = Math.random()\n }\n this.#image.points.geometry.setAttribute(\n 'aDisAngle',\n new THREE.BufferAttribute(disAngle, 1),\n )\n this.#image.points.geometry.setAttribute(\n 'aDisAmplitude',\n new THREE.BufferAttribute(disAmplitude, 1),\n )\n }\n}\n","/**\n * @description Renderer manager\n * @author C. M. de Picciotto <d3p1@d3p1.dev> (https://d3p1.dev/)\n * @note The idea behind this class is to encapsulate and wrap the\n * render logic\n */\nimport * as THREE from 'three'\n\nexport default class RendererManager {\n /**\n * @type {THREE.Scene}\n */\n scene: THREE.Scene\n\n /**\n * @type {THREE.WebGLRenderer}\n */\n renderer: THREE.WebGLRenderer\n\n /**\n * @type {THREE.OrthographicCamera}\n * @note It is used an orthographic camera because it is desired\n * to draw a 2d image without perspective\n */\n camera: THREE.OrthographicCamera\n\n /**\n * @type {number}\n */\n width: number\n\n /**\n * @type {number}\n */\n height: number\n\n /**\n * @type {number}\n * @note Device pixel ratio\n */\n dpr: number\n\n /**\n * Constructor\n *\n * @param {number} width\n * @param {number} height\n */\n constructor(width: number, height: number) {\n this.width = width\n this.height = height\n this.#initRenderer()\n this.#initScene()\n this.#initCamera()\n }\n\n /**\n * Update\n *\n * @returns {void}\n */\n update(): void {\n this.renderer.render(this.scene, this.camera)\n }\n\n /**\n * Compile shaders\n *\n * @returns {void}\n * {@link https://github.com/mrdoob/three.js/pull/10960}\n */\n compile(): void {\n this.renderer.compile(this.scene, this.camera)\n }\n\n /**\n * Dispose\n *\n * @returns {void}\n */\n dispose(): void {\n this.#disposeScene()\n this.#disposeRenderer()\n this.renderer.domElement.remove()\n }\n\n /**\n * Init renderer\n *\n * @returns {void}\n * @note The antialias is only enabled for devices with less than `2`\n * as a pixel ratio. This is done to improve performance because\n * devices with `2` or more as pixel ratio\n * do not require this feature\n */\n #initRenderer(): void {\n const canvas = document.createElement('canvas')\n document.body.append(canvas)\n\n this.dpr = Math.min(window.devicePixelRatio, 2)\n\n let antialias = false\n if (this.dpr <= 1) {\n antialias = true\n }\n this.renderer = new THREE.WebGLRenderer({\n canvas: canvas,\n antialias: antialias,\n })\n this.renderer.setPixelRatio(this.dpr)\n this.renderer.setSize(this.width, this.height)\n this.renderer.setClearAlpha(0)\n }\n\n /**\n * Init camera\n *\n * @returns {void}\n * @note The renderer will have the same dimensions as the image.\n * The idea is that a plane with the image as texture will be\n * used inside the renderer, and this plane also will have the\n * image dimensions.\n * An orthographic camera will be positioned to show exactly\n * that plane.\n * Because it is used an orthographic camera,\n * `1` world unit is `1` pixel, making it easy to position things\n * @link https://discourse.threejs.org/t/mapping-orthographiccamera-world-units-to-pixels/10142\n */\n #initCamera(): void {\n const left = -this.renderer.domElement.width / 2\n const right = this.renderer.domElement.width / 2\n const top = this.renderer.domElement.height / 2\n const bottom = -this.renderer.domElement.height / 2\n const near = 0.1\n const far = 1\n this.camera = new THREE.OrthographicCamera(\n left,\n right,\n top,\n bottom,\n near,\n far,\n )\n this.scene.add(this.camera)\n\n this.camera.position.z = far - 0.1\n }\n\n /**\n * Init scene\n *\n * @returns {void}\n */\n #initScene(): void {\n this.scene = new THREE.Scene()\n }\n\n /**\n * Dispose renderer\n *\n * @returns {void}\n */\n #disposeRenderer(): void {\n this.renderer.dispose()\n }\n\n /**\n * Dispose scene\n *\n * @returns {void}\n */\n #disposeScene(): void {\n while (this.scene.children.length > 0) {\n this.scene.remove(this.scene.children[0])\n }\n }\n}\n","/**\n * @description Debug manager raw settings\n * @author C. M. de Picciotto <d3p1@d3p1.dev> (https://d3p1.dev/)\n * @note It is returned a plain text of the settings that\n * should be used to instance current effect.\n * This plain text is used by the copy button of the\n * debug manager\n */\nexport const getSettings = (\n imagePixelSize: string,\n imagePixelMotionFrequency: string,\n imagePixelMotionAmplitude: string,\n imageMotionFrequency: string,\n imageMotionAmplitude: string,\n pointerSize: string,\n pointerTrailing: string,\n) => {\n return `{\n images: {\n 0: {\n src: <image-src>,\n width: <image-width>,\n height: <image-height>,\n resolution: {\n width: <image-resolution-width>,\n height: <image-resolution-height>\n },\n pixel: {\n size: ${imagePixelSize},\n motion: {\n displacement: {\n frequency: ${imagePixelMotionFrequency},\n amplitude: ${imagePixelMotionAmplitude}\n }\n }\n },\n motion: {\n noise: {\n frequency: ${imageMotionFrequency},\n amplitude: ${imageMotionAmplitude}\n }\n }\n }\n },\n pointer: {\n size: ${pointerSize},\n trailing: {\n factor: ${pointerTrailing}\n }\n }\n }`\n}\n","/**\n * @description Debug manager\n * @author C. M. de Picciotto <d3p1@d3p1.dev> (https://d3p1.dev/)\n * @note The idea behind this class is to encapsulate and wrap the\n * debug management logic\n */\nimport {BindingParams, FolderApi, FolderParams, Pane} from 'tweakpane'\nimport {BindingApi} from '@tweakpane/core'\nimport {getSettings} from './debug-manager/copy/settings.js'\n\nexport default class DebugManager {\n /**\n * @type {Pane}\n */\n debugger: Pane\n\n /**\n * Constructor\n */\n constructor() {\n this.debugger = new Pane()\n this.#addCopyButton()\n }\n\n /**\n * Enable. Show debugger\n *\n * @returns {void}\n */\n enable(): void {\n this.debugger.element.style.display = 'block'\n }\n\n /**\n * Disable. Hide debugger\n *\n * @returns {void}\n */\n disable(): void {\n this.debugger.element.style.display = 'none'\n }\n\n /**\n * Dispose\n *\n * @returns {void}\n */\n dispose(): void {\n this.debugger.dispose()\n this.debugger.element.remove()\n }\n\n /**\n * Add folder\n *\n * @param {{title: string; expanded?: boolean;}} config\n * @returns {object}\n */\n addFolder(config: FolderParams): FolderApi {\n config = {expanded: false, ...config}\n return this.debugger.addFolder(config)\n }\n\n /**\n * Add binding with on change handler\n *\n * @param {object} object\n * @param {string} property\n * @param {string} label\n * @param {object | undefined} config\n * @param {object | undefined} folder\n * @returns {object}\n */\n addBindingWithOnChange<K extends string, V>(\n object: {[key in K]: V},\n property: K,\n label: string,\n config: BindingParams | undefined,\n folder: FolderApi | undefined = undefined,\n ): BindingApi<unknown, V> {\n return this.addBinding(label, object[property], config, folder).on(\n 'change',\n (e) => {\n object[property] = e.value\n },\n )\n }\n\n /**\n * Add binding\n *\n * @param {string} label\n * @param {string | number} value\n * @param {object | undefined} config\n * @param {object | undefined} folder\n * @returns {object}\n */\n addBinding<V>(\n label: string,\n value: V,\n config: BindingParams | undefined,\n folder: FolderApi | undefined = undefined,\n ): BindingApi<unknown, V> {\n let debuggerObj: Pane | FolderApi = this.debugger\n if (folder) {\n debuggerObj = folder\n }\n\n return debuggerObj.addBinding(\n {\n [label]: value,\n },\n label,\n config,\n )\n }\n\n /**\n * Add copy button\n *\n * @returns {void}\n */\n #addCopyButton(): void {\n const btn = this.debugger.addButton({\n title: 'Copy',\n })\n btn.on('click', () => {\n const state = this.debugger.exportState()\n\n if (state.children && state.children instanceof Array) {\n const pointer = state.children[1]\n const pointerSize = pointer.children[0]['binding']['value']\n const pointerTrailing = pointer.children[1]['binding']['value']\n\n const imagePixel = state.children[4]\n const imagePixelSize = imagePixel.children[0]['binding']['value']\n\n const imagePixelMotion = state.children[5]\n const imagePixelMotionFrequency =\n imagePixelMotion.children[0]['binding']['value']\n const imagePixelMotionAmplitude =\n imagePixelMotion.children[1]['binding']['value']\n\n const imageMotion = state.children[6]\n const imageMotionFrequency = imageMotion.children[0]['binding']['value']\n const imageMotionAmplitude = imageMotion.children[1]['binding']['value']\n\n const settings = getSettings(\n imagePixelSize,\n imagePixelMotionFrequency,\n imagePixelMotionAmplitude,\n imageMotionFrequency,\n imageMotionAmplitude,\n pointerSize,\n pointerTrailing,\n )\n\n navigator.clipboard.writeText(settings).then(() => {\n btn.title = 'Copied!'\n setTimeout(() => {\n btn.title = 'Copy'\n }, 1000)\n })\n }\n })\n }\n}\n","/**\n * @description Image vertex shader\n * @author C. M. de Picciotto <d3p1@d3p1.dev> (https://d3p1.dev/)\n */\nuniform sampler2D uImageTexture;\nuniform float uPointSize;\n\nvarying vec4 vColor;\n\nvoid main() {\n vec3 vertexPosition = position;\n\n vec4 modelPosition = modelMatrix * vec4(vertexPosition, 1.0);\n vec4 viewPosition = viewMatrix * modelPosition;\n vec4 projectionPosition = projectionMatrix * viewPosition;\n\n gl_Position = projectionPosition;\n gl_PointSize = uPointSize;\n\n vColor = texture(uImageTexture, uv);\n}","/**\n * @description Image fragment shader\n * @author C. M. de Picciotto <d3p1@d3p1.dev> (https://d3p1.dev/)\n * @note It is introduced a `discard` logic to avoid issues\n * on mobile devices where transparent pixels of the border\n * of the image, are not tested correctly against\n * the alpha test param and are incorrectly shown\n */\nuniform float uAlphaTest;\n\nvarying vec4 vColor;\n\nvoid main() {\n if (vColor.a < uAlphaTest) {\n discard;\n }\n\n gl_FragColor = vColor;\n\n #include <tonemapping_fragment>\n #include <colorspace_fragment>\n}","/**\n * @description Image\n * @author C. M. de Picciotto <d3p1@d3p1.dev> (https://d3p1.dev/)\n * @note This class handles the logic related to the\n * transformation of the image into vertices/points/pixels\n */\nimport * as THREE from 'three'\nimport RendererManager from '../lib/renderer-manager.js'\nimport DebugManager from '../lib/debug-manager.js'\nimport imageVertexShader from './image/shader/vertex.glsl'\nimport imageFragmentShader from './image/shader/fragment.glsl'\n\nexport default class Image {\n /**\n * @type {THREE.Points}\n */\n points: THREE.Points<THREE.PlaneGeometry, THREE.ShaderMaterial>\n\n /**\n * @type {THREE.Texture}\n */\n #imageTexture: THREE.Texture\n\n /**\n * @type {RendererManager}\n */\n #rendererManager: RendererManager\n\n /**\n * @type {DebugManager}\n */\n #debugManager: DebugManager\n\n /**\n * Constructor\n *\n * @param {RendererManager} rendererManager\n * @param {DebugManager} debugManager\n * @param {string} imageSrc\n * @param {number} resolutionWidth\n * @param {number} resolutionHeight\n * @param {number} pointSize\n * @param {number} alphaTest\n */\n constructor(\n rendererManager: RendererManager,\n debugManager: DebugManager,\n imageSrc: string,\n resolutionWidth: number,\n resolutionHeight: number,\n pointSize: number = 1,\n alphaTest: number = 0.1,\n ) {\n this.#rendererManager = rendererManager\n this.#debugManager = debugManager\n this.#initPoints(\n imageSrc,\n resolutionWidth,\n resolutionHeight,\n pointSize,\n alphaTest,\n )\n }\n\n /**\n * Enable debug mode\n *\n * @returns {void}\n */\n debug(): void {\n const resolutionFolder = this.#debugManager.addFolder({\n title: 'Image Resolution',\n })\n\n this.#debugManager\n .addBinding(\n 'width',\n this.points.geometry.parameters.widthSegments,\n {min: 0, max: this.points.geometry.parameters.width, step: 1},\n resolutionFolder,\n )\n .on('change', (e) => {\n if (e.last) {\n this.#replaceImageGeometry(\n e.value,\n this.points.geometry.parameters.heightSegments,\n )\n }\n })\n\n this.#debugManager\n .addBinding(\n 'height',\n this.points.geometry.parameters.heightSegments,\n {min: 0, max: this.points.geometry.parameters.height, step: 1},\n resolutionFolder,\n )\n .on('change', (e) => {\n if (e.last) {\n this.#replaceImageGeometry(\n this.points.geometry.parameters.widthSegments,\n e.value,\n )\n }\n })\n\n const pixelFolder = this.#debugManager.addFolder({title: 'Image Pixel'})\n\n this.#debugManager\n .addBinding(\n 'size',\n this.points.material.uniforms.uPointSize.value,\n {min: 1, max: 100, step: 1},\n pixelFolder,\n )\n .on('change', (e) => {\n if (e.last) {\n this.points.material.uniforms.uPointSize.value = e.value\n }\n })\n }\n\n /**\n * Dispose\n *\n * @returns {void}\n */\n dispose(): void {\n this.points.geometry.dispose()\n this.points.material.dispose()\n this.#imageTexture.dispose()\n }\n\n /**\n * Init points\n *\n * @param {string} imageSrc\n * @param {number} resolutionWidth\n * @param {number} resolutionHeight\n * @param {number} pointSize\n * @param {number} alphaTest\n * @returns {void}\n */\n #initPoints(\n imageSrc: string,\n resolutionWidth: number,\n resolutionHeight: number,\n pointSize: number,\n alphaTest: number,\n ): void {\n const textureLoader = new THREE.TextureLoader()\n this.#imageTexture = textureLoader.load(imageSrc)\n\n const imageGeometry = this.#createImageGeometry(\n resolutionWidth,\n resolutionHeight,\n )\n\n const imageMaterial = new THREE.ShaderMaterial({\n vertexShader: imageVertexShader,\n fragmentShader: imageFragmentShader,\n uniforms: {\n uImageTexture: new THREE.Uniform(this.#imageTexture),\n uPointSize: new THREE.Uniform(pointSize),\n uAlphaTest: new THREE.Uniform(alphaTest),\n },\n transparent: true,\n depthWrite: false,\n alphaTest: alphaTest,\n })\n\n this.points = new THREE.Points(imageGeometry, imageMaterial)\n }\n\n /**\n * Replace image geometry\n *\n * @param {number} resolutionWidth\n * @param {number} resolutionHeight\n * @returns {void}\n * @note It is sent old attributes to be persisted by the new geometry.\n * New generated geometry attributes will replace old ones if\n * they exist in the old geometry\n */\n #replaceImageGeometry(\n resolutionWidth: number,\n resolutionHeight: number,\n ): void {\n const attributes = this.points.geometry.attributes\n this.points.geometry.dispose()\n this.points.geometry = this.#createImageGeometry(\n resolutionWidth,\n resolutionHeight,\n attributes,\n )\n }\n\n /**\n * Create image geometry\n *\n * @param {number} resolutionWidth\n * @param {number} resolutionHeight\n * @param {THREE.NormalBufferAttributes | null} attributes\n * @returns {THREE.PlaneGeometry}\n * @note It is created a plane that occupies all the render\n * @note The dom element width and height of the renderer include\n * the device pixel ratio, so it is important to use them\n * to create a plane that take all the render space/pixels\n * @note It is removed the index and normals from the geometry\n * to improve performance.\n * Normals are not going to be needed.\n * The index could cause the draw of multiple points/pixels in the\n * same place. That is why it is required to remove it\n */\n #createImageGeometry(\n resolutionWidth: number,\n resolutionHeight: number,\n attributes: THREE.NormalBufferAttributes | null = null,\n ): THREE.PlaneGeometry {\n const geometry = new THREE.PlaneGeometry(\n this.#rendererManager.renderer.domElement.width,\n this.#rendererManager.renderer.domElement.height,\n resolutionWidth * this.#rendererManager.dpr,\n resolutionHeight * this.#rendererManager.dpr,\n )\n geometry.setIndex(null)\n geometry.deleteAttribute('normal')\n\n if (attributes) {\n geometry.attributes = {...attributes, ...geometry.attributes}\n }\n\n return geometry\n }\n}\n","/**\n * @description Pointer\n * @author C. M. de Picciotto <d3p1@d3p1.dev> (https://d3p1.dev/)\n */\nimport * as THREE from 'three'\nimport RendererManager from '../lib/renderer-manager.js'\nimport Canvas from './pointer/canvas.js'\n\nexport default class Pointer {\n /**\n * @type {THREE.Vector2 | {x: number | undefined, y: number | undefined}}\n */\n coord: THREE.Vector2 | {x: number | undefined; y: number | undefined}\n\n /**\n * @type {Canvas}\n */\n canvas: Canvas\n\n /**\n * @type {THREE.Raycaster}\n */\n raycaster: THREE.Raycaster\n\n /**\n * @type {THREE.Mesh}\n */\n raycasterPlane: THREE.Mesh<THREE.PlaneGeometry, THREE.MeshBasicMaterial>\n\n /**\n * @type {RendererManager}\n */\n #rendererManager: RendererManager\n\n /**\n * @type {Function}\n */\n #boundPointerMove: (e: PointerEvent) => void\n\n /**\n * @type {Function}\n */\n #boundPointerLeave: (e: PointerEvent) => void\n\n /**\n * Constructor\n *\n * @param {RendererManager} rendererManager\n * @param {Canvas} canvas\n */\n constructor(rendererManager: RendererManager, canvas: Canvas) {\n this.canvas = canvas\n this.coord = new THREE.Vector2(undefined, undefined)\n this.#rendererManager = rendererManager\n this.#initRaycaster()\n }\n\n /**\n * Update\n *\n * @returns {void}\n */\n update(): void {\n let dx: number | null = null\n let dy: number | null = null\n\n if (this.coord.x && this.coord.y) {\n this.raycaster.setFromCamera(\n this.coord as THREE.Vector2,\n this.#rendererManager.camera,\n )\n const intersections = this.raycaster.intersectObject(this.raycasterPlane)\n if (intersections.length) {\n const uv = intersections[0].uv as THREE.Vector2\n dx = uv.x * this.canvas.element.width\n dy = (1 - uv.y) * this.canvas.element.height\n }\n }\n\n this.canvas.update(dx, dy)\n }\n\n /**\n * Enable debug mode\n *\n * @returns {void}\n */\n debug(): void {\n this.canvas.debug()\n }\n\n /**\n * Dispose\n *\n * @returns {void}\n */\n dispose(): void {\n this.canvas.dispose()\n this.#disposeRaycaster()\n }\n\n /**\n * Process pointer move\n *\n * @param {PointerEvent} e\n * @returns {void}\n * @note Pointer coordinates are normalized to\n * clip space (NDC - Normalized Device Coordinate) to\n * use it for raycasting\n */\n #processPointerMove(e: PointerEvent): void {\n const target = e.target as EventTarget & {width: number; height: number}\n this.coord.x = (e.offsetX / target.width - 0.5) * 2\n this.coord.y = -(e.offsetY / target.height - 0.5) * 2\n }\n\n /**\n * Process pointer leave\n *\n * @returns {void}\n */\n #processPointerLeave(): void {\n this.coord.x = undefined\n this.coord.y = undefined\n }\n\n /**\n * Init raycaster\n *\n * @returns {void}\n * @note It is created low poly plane in front of the image\n * to avoid performance issues that could arise while\n * working between the raycaster and image points\n */\n #initRaycaster(): void {\n this.raycaster = new THREE.Raycaster()\n\n this.#boundPointerMove = this.#processPointerMove.bind(this)\n this.#rendererManager.renderer.domElement.addEventListener(\n 'pointermove',\n this.#boundPointerMove,\n )\n\n this.#boundPointerLeave = this.#processPointerLeave.bind(this)\n this.#rendererManager.renderer.domElement.addEventListener(\n 'pointerleave',\n this.#boundPointerLeave,\n )\n\n this.raycasterPlane = new THREE.Mesh(\n new THREE.PlaneGeometry(\n this.#rendererManager.width,\n this.#rendererManager.height,\n ),\n new THREE.MeshBasicMaterial(),\n )\n this.raycasterPlane.visible = false\n }\n\n /**\n * Dispose raycaster\n *\n * @returns {void}\n */\n #disposeRaycaster(): void {\n this.#rendererManager.renderer.domElement.removeEventListener(\n 'pointermove',\n this.#boundPointerMove,\n )\n this.#rendererManager.renderer.domElement.removeEventListener(\n 'pointerleave',\n this.#boundPointerLeave,\n )\n\n this.raycasterPlane.geometry.dispose()\n this.raycasterPlane.material.dispose()\n }\n}\n","/**\n * @description Pointer canvas\n * @author C. M. de Picciotto <d3p1@d3p1.dev> (https://d3p1.dev/)\n * @note This canvas will be used as a texture that will be sent\n * to the vertex shader. This texture will be updated\n * to mark where the pointer is in relation with the image.\n * In that way, it allows selecting which vertices/points/pixels\n * should be displaced\n */\nimport * as THREE from 'three'\nimport DebugManager from '../../lib/debug-manager.js'\n\nexport default class Canvas {\n /**\n * @type {DebugManager}\n */\n #debugManager: DebugManager\n\n /**\n * @type {THREE.CanvasTexture}\n */\n texture: THREE.Texture\n\n /**\n * @type {HTMLCanvasElement}\n */\n element: HTMLCanvasElement\n\n /**\n * @type {CanvasRenderingContext2D}\n */\n #context: CanvasRenderingContext2D\n\n /**\n * @type {HTMLImageElement}\n * @note Image that will represent the pointer.\n * This image is used to\n * select which vertices/points/pixels\n * should be displaced\n */\n #pointerImage: HTMLImageElement\n\n /**\n * @type {number}\n * @note This value defines how many pixels are affected by the\n * pointer effect.\n * It is defined as a proportion of the image resolution width\n */\n #pointerImageSize: number\n\n /**\n * @type {number}\n * @note This value defines the strength of the\n * pointer trailing effect on the\n * pixels' displacement\n */\n #pointerTrailingFactor: number\n\n /**\n * Constructor\n *\n * @param {DebugManager} debugManager\n * @param {number} resolutionWidth\n * @param {number} resolutionHeight\n * @param {string} pointerImageSrc\n * @param {number} pointerImageSize\n * @param {number} pointerTrailingFactor\n */\n constructor(\n debugManager: DebugManager,\n resolutionWidth: number,\n resolutionHeight: number,\n pointerImageSrc: string,\n pointerImageSize: number = 0.1,\n pointerTrailingFactor: number = 0.05,\n ) {\n this.#debugManager = debugManager\n this.#pointerTrailingFactor = pointerTrailingFactor\n this.#initCanvasTexture(resolutionWidth, resolutionHeight)\n this.#initPointerImage(pointerImageSrc, pointerImageSize)\n }\n\n /**\n * Update\n *\n * @param {number | null} dx\n * @param {number | null} dy\n * @returns {void}\n */\n update(dx: number | null, dy: number | null): void {\n this.#clear()\n\n if (dx && dy) {\n this.#draw(dx, dy)\n }\n\n this.texture.needsUpdate = true\n }\n\n /**\n * Enable debug mode\n *\n * @returns {void}\n */\n debug(): void {\n const pointerFolder = this.#debugManager.addFolder({\n title: 'Pointer',\n })\n\n this.#debugManager\n .addBinding(\n 'size',\n this.#pointerImageSize / this.element.width,\n {\n min: 0,\n max: 1,\n step: 0.01,\n },\n pointerFolder,\n )\n .on('change', (e) => this.#processPointerImageSize(e.value))\n\n this.#debugManager\n .addBinding(\n 'trailing',\n this.#pointerTrailingFactor,\n {\n min: 0,\n max: 1,\n step: 0.01,\n },\n pointerFolder,\n )\n .on('change', (e) => (this.#pointerTrailingFactor = e.value))\n\n const pointerCanvasFolder = this.#debugManager.addFolder({\n title: 'Pointer Canvas',\n })\n\n this.#debugManager\n .addBinding('show', false, undefined, pointerCanvasFolder)\n .on('change', (e) => {\n if (e.value) {\n document.body.appendChild(this.element)\n this.element.style.position = 'fixed'\n this.element.style.top = '0'\n this.element.style.left = '0'\n this.element.style.border = '1px solid #fff'\n } else {\n document.body.removeChild(this.element)\n }\n })\n }\n\n /**\n * Dispose\n *\n * @returns {void}\n */\n dispose(): void {\n this.texture.dispose()\n }\n\n /**\n * Draw\n *\n * @param {number} dx\n * @param {number} dy\n * @returns {void}\n * @note The destination of the image is moved half its size\n * so it is drawn at the center of the destination position\n */\n #draw(dx: number, dy: number): void {\n dx -= this.#pointerImageSize / 2\n dy -= this.#pointerImageSize / 2\n\n this.#context.save()\n this.#context.globalCompositeOperation = 'lighten'\n this.#context.drawImage(\n this.#pointerImage,\n dx,\n dy,\n this.#pointerImageSize,\n this.#pointerImageSize,\n )\n this.#context.restore()\n }\n\n /**\n * Clear\n *\n * @returns {void}\n * @note The idea is to draw a white image that will\n * indicate how much points inside them will be displaced.\n * That is why it is required to clear the canvas with black color\n */\n #clear(): void {\n this.#context.save()\n this.#context.globalAlpha = this.#pointerTrailingFactor\n this.#context.fillStyle = '#000'\n this.#context.fillRect(0, 0, this.element.width, this.element.height)\n this.#context.restore()\n }\n\n /**\n * Init canvas texture used to detect pointer location and\n * displace points\n *\n * @param {number} resolutionWidth\n * @param {number} resolutionHeight\n * @returns {void}\n * @note The canvas will have the same number of pixels as the\n * image.\n * That is why it is used the image resolution as its dimensions\n */\n #initCanvasTexture(resolutionWidth: number, resolutionHeight: number): void {\n this.element = document.createElement('canvas')\n this.element.width = resolutionWidth\n this.element.height = resolutionHeight\n this.texture = new THREE.CanvasTexture(this.element)\n\n this.#context = this.element.getContext('2d') as CanvasRenderingContext2D\n }\n\n /**\n * Init pointer image\n *\n * @param {string} pointerImageSrc\n * @param {number} pointerImageSize\n * @returns {void}\n * @note It is considered that the pointer image will be\n * a white image that will indicate which pixels should be displaced\n */\n #initPointerImage(pointerImageSrc: string, pointerImageSize: number): void {\n this.#pointerImage = new Image()\n this.#pointerImage.src = pointerImageSrc\n this.#processPointerImageSize(pointerImageSize)\n }\n\n /**\n * Process pointer image size\n *\n * @param {number} pointerImageSize\n * @returns {void}\n * @note The aspect ratio of the image is always square\n * (the same size is used for the width and the height of the image).\n * It is proportional to the canvas width.\n * This approach is considered correct because web elements\n * adjust only their width to fit in the page\n */\n #processPointerImageSize(pointerImageSize: number): void {\n this.#pointerImageSize = pointerImageSize * this.element.width\n }\n}\n","export default \"\"","export default \"\"","/**\n * @description Image manager\n * @author C. M. de Picciotto <d3p1@d3p1.dev> (https://d3p1.dev/)\n * @note The idea behind this class is to encapsulate and wrap the\n * image management logic.\n * It is defined an image by breakpoint, so it is necessary\n * to handle which image should be used\n */\nimport {ImgSource, ImgSourceCollection} from '../../types'\n\n/**\n * @note The `0` breakpoint for image must always be set.\n * It defines the image that should be used by default\n */\nconst DEFAULT_IMAGE_BREAKPOINT = 0\n\nexport default class ImageManager {\n /**\n * @type {{\n * src : string;\n * width : number;\n * height : number;\n * resolution: {\n * width : number;\n * height: number;\n * }\n * pixel?: {\n * size ?: number;\n * alphaTest?: number;\n * motion ?: {\n * displacement?: {\n * frequency?: number;\n * amplitude?: number;\n * };\n * };\n * };\n * motion?: {\n * noise?: {\n * src ?: string;\n * frequency?: number;\n * amplitude?: number;\n * };\n * };\n * }[]}\n */\n images: ImgSourceCollection\n\n /**\n * @type {{\n * src : string;\n * width : number;\n * height : number;\n * resolution: {\n * width : number;\n * height: number;\n * };\n * pixel?: {\n * size ?: number;\n * alphaTest?: number;\n * motion ?: {\n * displacement?: {\n * frequency?: number;\n * amplitude?: number;\n * }\n * };\n * };\n * motion?: {\n * noise?: {\n * src ?: string;\n * frequency?: number;\n * amplitude?: number;\n * };\n * };\n * }}\n */\n currentImage: ImgSource\n\n /**\n * @type {number}\n */\n #currentBreakpoint: number\n\n /**\n * @type {number[]}\n */\n #breakpoints: number[]\n\n /**\n * Constructor\n *\n * @param {{\n * src : string;\n * width : number;\n * height : number;\n * resolution: {\n * width : number;\n * height: number;\n * };\n * pixel?: {\n * size ?: number;\n * alphaTest?: number;\n * motion ?: {\n * displacement?: {\n * frequency?: number;\n * amplitude?: number;\n * };\n * };\n * };\n * motion?: {\n * noise?: {\n * src ?: string;\n * frequency?: number;\n * amplitude?: number;\n * };\n * };\n * }[]} images\n * @throws {Error}\n */\n constructor(images: ImgSourceCollection) {\n this.images = images\n this.#initBreakpointsFromImages(Object.keys(this.images).map(Number))\n this.update()\n }\n\n /**\n * Taking into consideration window size,\n * it is selected the breakpoint and image to be used\n *\n * @returns {boolean}\n * @note Each breakpoint defines the `min-width` at which\n * a specific image should be used.\n * That is why it is returned\n * the greater breakpoint that is less than or equal\n * the window size\n */\n update(): boolean {\n const width = window.innerWidth\n\n const currentBreakpoint = this.#breakpoints.reduce(\n (max, breakpoint) =>\n breakpoint <= width && breakpoint > max ? breakpoint : max,\n DEFAULT_IMAGE_BREAKPOINT,\n )\n\n if (currentBreakpoint !== this.#currentBreakpoint) {\n this.#currentBreakpoint = currentBreakpoint\n this.currentImage = this.images[this.#currentBreakpoint]\n return true\n }\n\n return false\n }\n\n /**\n * Init breakpoints from image\n *\n * @param {number[]} breakpoints\n * @returns {void}\n * @throws {Error}\n */\n #initBreakpointsFromImages(breakpoints: number[]): void {\n if (\n breakpoints.find(\n (breakpoint) => breakpoint === DEFAULT_IMAGE_BREAKPOINT,\n ) === undefined\n ) {\n throw new Error(\n 'The `0` breakpoint is required. It defines the default image that should be used.',\n )\n }\n\n this.#breakpoints = breakpoints\n }\n}\n","/**\n * @description img2pxl\n * @author C. M. de Picciotto <d3p1@d3p1.dev> (https://d3p1.dev/)\n * @note This class works as the entry point of the library.\n * It is like a dependency injection manager (DI container).\n * Also, it adds features not related to the app/effect itself,\n * like enable debug to tweak app/effect parameters or\n * effect parent container configuration\n */\nimport {Timer} from 'three/addons'\nimport App from './core/app.js'\nimport RendererManager from './core/lib/renderer-manager.js'\nimport DebugManager from './core/lib/debug-manager.js'\nimport Image from './core/app/image.js'\nimport Pointer from './core/app/pointer.js'\nimport PointerCanvas from './core/app/pointer/canvas.js'\nimport pointerImage from './media/processor/displacement/pointer.png'\nimport noiseImage from './media/processor/displacement/noise.png'\nimport {Config} from './types'\nimport ImageManager from './core/lib/image-manager.js'\n\nexport default class Img2Pxl {\n /**\n * @type {RendererManager}\n */\n rendererManager: RendererManager\n\n /**\n * @type {DebugManager}\n */\n debugManager: DebugManager\n\n /**\n * @type {App}\n */\n #app: App\n\n /**\n * @type {ImageManager}\n */\n #imageManager: ImageManager\n\n /**\n * @type {Timer}\n */\n #timer: Timer\n\n /**\n * @type {{\n * containerSelector?: string;\n * image : {\n * src : string;\n * width : number;\n * height : number;\n * resolution: {\n * width : number;\n * height: number;\n * };\n * pixel?: {\n * size ?: number;\n * motion?: {\n * displacement?: {\n * frequency?: number;\n * amplitude?: number;\n * }\n * }\n * };\n * motion?: {\n * noise?: {\n * src ?: string;\n * frequency?: number;\n * amplitude?: number;\n * }\n * }\n * }[];\n * pointer?: {\n * src ?: string;\n * size ?: number;\n * trailing?: {\n * factor?: number;\n * }\n * };\n * isDebugging?: boolean;\n * }}\n */\n #config: Config\n\n /**\n * @type {boolean}\n */\n #isDebugging: boolean\n\n /**\n * @type {number}\n */\n #requestAnimationId: number\n\n /**\n * @type {Function}\n */\n #boundHandleDebug: (e: KeyboardEvent) => void\n\n /**\n * @type {Function}\n */\n #boundHandleResize: (e: Event) => void\n\n /**\n * Constructor\n *\n * @param {{\n * containerSelector?: string;\n * image : {\n * src : string;\n * width : number;\n * height : number;\n * resolution: {\n * width : number;\n * height: number;\n * };\n * pixel?: {\n * size ?: number;\n * alphaTest?: number;\n * motion ?: {\n * displacement?: {\n * frequency?: number;\n * amplitude?: number;\n * }\n * }\n * };\n * motion?: {\n * noise?: {\n * src ?: string;\n * frequency?: number;\n * amplitude?: number;\n * }\n * }\n * }[];\n * pointer?: {\n * src ?: string;\n * size ?: number;\n * trailing?: {\n * factor?: number;\n * }\n * };\n * isDebugging?: boolean;\n * }} config\n * @throws {Error}\n */\n constructor(config: Config) {\n this.#config = config\n this.#isDebugging = config.isDebugging ?? false\n this.#imageManager = new ImageManager(config.images)\n\n this.#init()\n }\n\n /**\n * Debug\n *\n * @returns {void}\n */\n debug(): void {\n if (!this.#isDebugging) {\n this.#enableDebug()\n this.#isDebugging = true\n }\n }\n\n /**\n * Dispose\n *\n * @returns {void}\n */\n dispose(): void {\n cancelAnimationFrame(this.#requestAnimationId)\n\n window.removeEventListener('keydown', this.#boundHandleDebug)\n window.removeEventListener('resize', this.#boundHandleResize)\n\n this.#timer.dispose()\n\n this.#app.dispose()\n\n this.rendererManager.dispose()\n\n this.debugManager.dispose()\n }\n\n /**\n * Init\n *\n * @returns {void}\n */\n #init(): void {\n this.rendererManager = new RendererManager(\n this.#imageManager.currentImage.width,\n this.#imageManager.currentImage.height,\n )\n\n this.#timer = new Timer()\n\n this.#initDebugManager()\n\n this.#initApp()\n\n if (this.#config.containerSelector) {\n this.#initDom(this.#config.containerSelector)\n }\n\n this.#boundHandleDebug = this.#handleDebug.bind(this)\n window.addEventListener('keydown', this.#boundHandleDebug)\n if (this.#isDebugging) {\n this.#enableDebug()\n } else {\n this.#disableDebug()\n }\n\n this.#boundHandleResize = () => {\n if (this.#imageManager.update()) {\n this.dispose()\n this.#init()\n }\n }\n window.addEventListener('resize', this.#boundHandleResize)\n\n this.#render()\n }\n\n /**\n * Render\n *\n * @params {number} t\n * @returns {void}\n */\n #render(t = 0): void {\n this.#timer.update(t)\n\n this.#app.update(this.#timer.getElapsed())\n\n this.#requestAnimationId = requestAnimationFrame(this.#render.bind(this))\n }\n\n /**\n * Handle debug\n *\n * @param {KeyboardEvent} e\n * @returns {void}\n */\n #handleDebug(e: KeyboardEvent): void {\n if (e.key === 'd') {\n this.debug()\n }\n }\n\n /**\n * Enable debug\n *\n * @returns {void}\n */\n #enableDebug(): void {\n this.#app.debug()\n this.debugManager.enable()\n }\n\n /**\n * Disable debug\n *\n * @returns {void}\n */\n #disableDebug(): void {\n this.debugManager.disable()\n }\n\n /**\n * Init app\n *\n * @returns {void}\n */\n #initApp(): void {\n this.#app = new App(\n new Image(\n this.rendererManager,\n this.debugManager,\n this.#imageManager.currentImage.src,\n this.#imageManager.currentImage.resolution.width,\n this.#imageManager.currentImage.resolution.height,\n this.#imageManager.currentImage.pixel?.size ?? 1,\n this.#imageManager.currentImage.pixel?.alphaTest ?? 0.1,\n ),\n new Pointer(\n this.rendererManager,\n new PointerCanvas(\n this.debugManager,\n this.#imageManager.currentImage.resolution.width,\n this.#imageManager.currentImage.resolution.height,\n this.#config.pointer?.src ?? pointerImage,\n this.#config.pointer?.size ?? 0.15,\n this.#config.pointer?.trailing?.factor ?? 0.01,\n ),\n ),\n this.rendererManager,\n this.debugManager,\n this.#imageManager.currentImage.motion?.noise?.src ?? noiseImage,\n this.#imageManager.currentImage.motion?.noise?.frequency ?? 0.05,\n this.#imageManager.currentImage.motion?.noise?.amplitude ?? 3,\n this.#imageManager.currentImage.pixel?.motion?.displacement?.frequency ??\n 5,\n this.#imageManager.currentImage.pixel?.motion?.displacement?.amplitude ??\n 4,\n )\n }\n\n /**\n * Init debug manager\n *\n * @returns {void}\n */\n #initDebugManager(): void {\n this.debugManager = new DebugManager()\n }\n\n /**\n * Init DOM\n *\n * @param {string} containerSelector\n * @returns {void}\n */\n #initDom(containerSelector: string): void {\n const node = document.querySelector(containerSelector)\n node?.appendChild(this.rendererManager.renderer.domElement)\n node?.appendChild(this.debugManager.debugger.element)\n }\n}\n"],"names":["Timer","now","handleVisibilityChange","timescale","timestamp","pars_vertex_default","position_vertex_default","App","image","pointer","rendererManager","debugManager","noiseImageSrc","noiseFrequency","noiseAmplitude","displacementFrequency","displacementAmplitude","__privateAdd","_App_instances","_image","_pointer","_rendererManager","_debugManager","__privateSet","__privateMethod","initImage_fn","initPointer_fn","elapsed","__privateGet","pixelMotionFolder","imageMotionFolder","addDisplacementAttributesToImage_fn","addDisplacementHandlerToImage_fn","noiseTexture","THREE","shader","parsVertexShader","positionVertexShader","vertices","disAngle","disAmplitude","i","RendererManager","width","height","_RendererManager_instances","__publicField","initRenderer_fn","initScene_fn","initCamera_fn","disposeScene_fn","disposeRenderer_fn","canvas","antialias","left","right","top","bottom","near","far","getSettings","imagePixelSize","imagePixelMotionFrequency","imagePixelMotionAmplitude","imageMotionFrequency","imageMotionAmplitude","pointerSize","pointerTrailing","DebugManager","_DebugManager_instances","Pane","addCopyButton_fn","config","object","property","label","folder","e","value","debuggerObj","btn","state","imagePixelMotion","imageMotion","settings","vertex_default","fragment_default","Image$1","_a","imageSrc","resolutionWidth","resolutionHeight","pointSize","alphaTest","_Image_instances","_imageTexture","initPoints_fn","resolutionFolder","replaceImageGeometry_fn","pixelFolder","textureLoader","imageGeometry","createImageGeometry_fn","imageMaterial","imageVertexShader","imageFragmentShader","attributes","geometry","Pointer","_Pointer_instances","_boundPointerMove","_boundPointerLeave","initRaycaster_fn","dx","dy","intersections","uv","disposeRaycaster_fn","processPointerMove_fn","target","processPointerLeave_fn","Canvas","pointerImageSrc","pointerImageSize","pointerTrailingFactor","_Canvas_instances","_context","_pointerImage","_pointerImageSize","_pointerTrailingFactor","initCanvasTexture_fn","initPointerImage_fn","clear_fn","draw_fn","pointerFolder","processPointerImageSize_fn","pointerCanvasFolder","pointerImage","noiseImage","DEFAULT_IMAGE_BREAKPOINT","ImageManager","images","_ImageManager_instances","_currentBreakpoint","_breakpoints","initBreakpointsFromImages_fn","currentBreakpoint","max","breakpoint","breakpoints","Img2Pxl","_Img2Pxl_instances","_app","_imageManager","_timer","_config","_isDebugging","_requestAnimationId","_boundHandleDebug","_boundHandleResize","init_fn","enableDebug_fn","initDebugManager_fn","initApp_fn","initDom_fn","handleDebug_fn","disableDebug_fn","render_fn","t","Image","_b","PointerCanvas","_c","_d","_f","_e","_h","_g","_j","_i","_l","_k","_o","_n","_m","_r","_q","_p","containerSelector","node"],"mappings":"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","x_google_ignoreList":[0]}
|
|
File without changes
|
|
File without changes
|
|
File without changes
|