angular-three-soba 2.0.0-beta.2 → 2.0.0-beta.21
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/abstractions/billboard/billboard.d.ts +11 -7
- package/abstractions/detailed/detailed.d.ts +26 -0
- package/abstractions/edges/edges.d.ts +24 -12
- package/abstractions/grid/grid.d.ts +50 -0
- package/abstractions/index.d.ts +2 -7
- package/abstractions/text/text.d.ts +10 -5
- package/abstractions/text-3d/text-3d.d.ts +51 -41
- package/cameras/camera/camera-content.d.ts +1 -1
- package/cameras/camera/camera.d.ts +16 -13
- package/cameras/cube-camera/cube-camera.d.ts +50 -23
- package/cameras/index.d.ts +0 -1
- package/cameras/orthographic-camera/orthographic-camera.d.ts +29 -18
- package/cameras/perspective-camera/perspective-camera.d.ts +10 -1
- package/controls/orbit-controls/orbit-controls.d.ts +31 -12
- package/esm2022/abstractions/billboard/billboard.mjs +36 -33
- package/esm2022/abstractions/detailed/detailed.mjs +64 -0
- package/esm2022/abstractions/edges/edges.mjs +58 -63
- package/esm2022/abstractions/grid/grid.mjs +180 -0
- package/esm2022/abstractions/index.mjs +3 -8
- package/esm2022/abstractions/text/text.mjs +123 -124
- package/esm2022/abstractions/text-3d/text-3d.mjs +120 -115
- package/esm2022/cameras/camera/camera-content.mjs +6 -6
- package/esm2022/cameras/camera/camera.mjs +48 -42
- package/esm2022/cameras/cube-camera/cube-camera.mjs +129 -99
- package/esm2022/cameras/index.mjs +1 -2
- package/esm2022/cameras/orthographic-camera/orthographic-camera.mjs +78 -75
- package/esm2022/cameras/perspective-camera/perspective-camera.mjs +25 -26
- package/esm2022/controls/orbit-controls/orbit-controls.mjs +105 -85
- package/esm2022/gizmos/angular-three-soba-gizmos.mjs +5 -0
- package/esm2022/gizmos/gizmo-helper/gizmo-helper.mjs +197 -0
- package/esm2022/gizmos/gizmo-helper/gizmo-viewcube/constants.mjs +31 -0
- package/esm2022/gizmos/gizmo-helper/gizmo-viewcube/gizmo-viewcube-edge.mjs +93 -0
- package/esm2022/gizmos/gizmo-helper/gizmo-viewcube/gizmo-viewcube-face.mjs +150 -0
- package/esm2022/gizmos/gizmo-helper/gizmo-viewcube/gizmo-viewcube-input.mjs +66 -0
- package/esm2022/gizmos/gizmo-helper/gizmo-viewcube/gizmo-viewcube.mjs +71 -0
- package/esm2022/gizmos/gizmo-helper/gizmo-viewport/gizmo-viewport-axis.mjs +195 -0
- package/esm2022/gizmos/gizmo-helper/gizmo-viewport/gizmo-viewport.mjs +272 -0
- package/esm2022/gizmos/index.mjs +4 -0
- package/esm2022/loaders/gltf-loader/gltf-loader.mjs +3 -6
- package/esm2022/loaders/loader/loader.mjs +92 -87
- package/esm2022/loaders/progress/progress.mjs +29 -29
- package/esm2022/loaders/texture-loader/texture-loader.mjs +4 -4
- package/esm2022/materials/index.mjs +2 -1
- package/esm2022/materials/mesh-distort-material/mesh-distort-material.mjs +60 -51
- package/esm2022/materials/mesh-reflector-material/mesh-reflector-material.mjs +239 -255
- package/esm2022/materials/mesh-refraction-material/mesh-refraction-material.mjs +102 -99
- package/esm2022/materials/mesh-transmission-material/mesh-transmission-material.mjs +167 -146
- package/esm2022/materials/mesh-wobble-material/mesh-wobble-material.mjs +44 -42
- package/esm2022/materials/point-material/point-material.mjs +50 -0
- package/esm2022/misc/animations/animations.mjs +36 -32
- package/esm2022/misc/bake-shadows/bake-shadows.mjs +13 -13
- package/esm2022/misc/caustics/caustics.mjs +387 -0
- package/esm2022/misc/decal/decal.mjs +187 -0
- package/esm2022/misc/depth-buffer/depth-buffer.mjs +33 -35
- package/esm2022/misc/example/example.mjs +160 -0
- package/esm2022/misc/fbo/fbo.mjs +35 -35
- package/esm2022/misc/html/html-wrapper.mjs +478 -0
- package/esm2022/misc/html/html.mjs +304 -0
- package/esm2022/misc/index.mjs +10 -1
- package/esm2022/misc/sampler/sampler.mjs +142 -0
- package/esm2022/misc/shadow/shadow.mjs +111 -0
- package/esm2022/misc/stats-gl/stats-gl.mjs +61 -0
- package/esm2022/misc/trail/trail.mjs +209 -0
- package/esm2022/misc/trail-texture/inject-trail-texture.mjs +17 -0
- package/esm2022/misc/trail-texture/trail-texture.mjs +106 -0
- package/esm2022/modifiers/angular-three-soba-modifiers.mjs +5 -0
- package/esm2022/modifiers/curve-modifier/curve-modifier.mjs +64 -0
- package/esm2022/modifiers/index.mjs +2 -0
- package/esm2022/performances/adaptive-dpr/adaptive-dpr.mjs +44 -0
- package/esm2022/performances/adaptive-events/adaptive-events.mjs +27 -0
- package/esm2022/performances/angular-three-soba-performances.mjs +5 -0
- package/esm2022/performances/index.mjs +8 -0
- package/esm2022/performances/instances/instances.mjs +220 -0
- package/esm2022/performances/instances/position-mesh.mjs +52 -0
- package/esm2022/performances/points/points-input.mjs +64 -0
- package/esm2022/performances/points/points.mjs +326 -0
- package/esm2022/performances/points/position-point.mjs +54 -0
- package/esm2022/performances/segments/segment-object.mjs +9 -0
- package/esm2022/performances/segments/segments.mjs +182 -0
- package/esm2022/shaders/blur-pass/blur-pass.mjs +2 -2
- package/esm2022/shaders/caustics/caustics-material.mjs +130 -0
- package/esm2022/shaders/caustics/caustics-projection-material.mjs +31 -0
- package/esm2022/shaders/convolution-material/convolution-material.mjs +1 -1
- package/esm2022/shaders/discard-material/discard-material.mjs +1 -1
- package/esm2022/shaders/grid-material/grid-material.mjs +77 -0
- package/esm2022/shaders/index.mjs +6 -3
- package/esm2022/shaders/mesh-distort-material/mesh-distort-material.mjs +42 -41
- package/esm2022/shaders/mesh-reflector-material/mesh-reflector-material.mjs +2 -2
- package/esm2022/shaders/mesh-refraction-material/mesh-refraction-material.mjs +2 -2
- package/esm2022/shaders/mesh-transmission-material/mesh-transmission-material.mjs +4 -4
- package/esm2022/shaders/mesh-wobble-material/mesh-wobble-material.mjs +1 -1
- package/esm2022/shaders/shader-material/shader-material.mjs +1 -1
- package/esm2022/shaders/soft-shadow-material/soft-shadow-material.mjs +17 -25
- package/esm2022/shaders/sparkles-material/sparkles-material.mjs +32 -46
- package/esm2022/shaders/spot-light-material/spot-light-material.mjs +7 -7
- package/esm2022/shaders/star-field-material/star-field-material.mjs +3 -2
- package/esm2022/shaders/wireframe-material/wireframe-material.mjs +247 -0
- package/esm2022/staging/accumulative-shadows/accumulative-shadows.mjs +160 -176
- package/esm2022/staging/accumulative-shadows/progressive-light-map.mjs +1 -1
- package/esm2022/staging/accumulative-shadows/randomized-lights.mjs +126 -128
- package/esm2022/staging/backdrop/backdrop.mjs +77 -0
- package/esm2022/staging/bb-anchor/bb-anchor.mjs +69 -0
- package/esm2022/staging/bounds/bounds.mjs +144 -143
- package/esm2022/staging/camera-shake/camera-shake.mjs +86 -80
- package/esm2022/staging/center/center.mjs +129 -112
- package/esm2022/staging/cloud/cloud.mjs +118 -124
- package/esm2022/staging/contact-shadows/contact-shadows.mjs +131 -134
- package/esm2022/staging/environment/assets.mjs +12 -12
- package/esm2022/staging/environment/environment-cube.mjs +28 -30
- package/esm2022/staging/environment/environment-ground.mjs +17 -19
- package/esm2022/staging/environment/environment-input.mjs +98 -85
- package/esm2022/staging/environment/environment-map.mjs +33 -33
- package/esm2022/staging/environment/environment-portal.mjs +75 -97
- package/esm2022/staging/environment/environment.mjs +34 -51
- package/esm2022/staging/environment/utils.mjs +37 -15
- package/esm2022/staging/float/float.mjs +70 -58
- package/esm2022/staging/index.mjs +7 -3
- package/esm2022/staging/matcap-texture/matcap-texture.mjs +64 -0
- package/esm2022/staging/normal-texture/normal-texture.mjs +53 -0
- package/esm2022/staging/sky/sky.mjs +85 -80
- package/esm2022/staging/sparkles/sparkles.mjs +108 -105
- package/esm2022/staging/spot-light/shadow-mesh-input.mjs +63 -0
- package/esm2022/staging/spot-light/shadow-mesh.mjs +266 -0
- package/esm2022/staging/spot-light/spot-light-input.mjs +67 -58
- package/esm2022/staging/spot-light/spot-light.mjs +51 -64
- package/esm2022/staging/spot-light/volumetric-mesh.mjs +67 -70
- package/esm2022/staging/stage/stage.mjs +305 -290
- package/esm2022/staging/stars/stars.mjs +101 -102
- package/esm2022/staging/wireframe/wireframe-input.mjs +191 -0
- package/esm2022/staging/wireframe/wireframe.mjs +228 -0
- package/esm2022/utils/angular-three-soba-utils.mjs +5 -0
- package/esm2022/utils/content/content.mjs +15 -0
- package/esm2022/utils/index.mjs +2 -0
- package/fesm2022/angular-three-soba-abstractions.mjs +514 -1947
- package/fesm2022/angular-three-soba-abstractions.mjs.map +1 -1
- package/fesm2022/angular-three-soba-cameras.mjs +302 -259
- package/fesm2022/angular-three-soba-cameras.mjs.map +1 -1
- package/fesm2022/angular-three-soba-controls.mjs +104 -83
- package/fesm2022/angular-three-soba-controls.mjs.map +1 -1
- package/fesm2022/angular-three-soba-gizmos.mjs +1043 -0
- package/fesm2022/angular-three-soba-gizmos.mjs.map +1 -0
- package/fesm2022/angular-three-soba-loaders.mjs +121 -117
- package/fesm2022/angular-three-soba-loaders.mjs.map +1 -1
- package/fesm2022/angular-three-soba-materials.mjs +662 -592
- package/fesm2022/angular-three-soba-materials.mjs.map +1 -1
- package/fesm2022/angular-three-soba-misc.mjs +2214 -105
- package/fesm2022/angular-three-soba-misc.mjs.map +1 -1
- package/fesm2022/angular-three-soba-modifiers.mjs +71 -0
- package/fesm2022/angular-three-soba-modifiers.mjs.map +1 -0
- package/fesm2022/angular-three-soba-performances.mjs +956 -0
- package/fesm2022/angular-three-soba-performances.mjs.map +1 -0
- package/fesm2022/angular-three-soba-shaders.mjs +549 -252
- package/fesm2022/angular-three-soba-shaders.mjs.map +1 -1
- package/fesm2022/angular-three-soba-staging.mjs +2899 -2563
- package/fesm2022/angular-three-soba-staging.mjs.map +1 -1
- package/fesm2022/angular-three-soba-utils.mjs +22 -0
- package/fesm2022/angular-three-soba-utils.mjs.map +1 -0
- package/gizmos/README.md +3 -0
- package/gizmos/gizmo-helper/gizmo-helper.d.ts +69 -0
- package/gizmos/gizmo-helper/gizmo-viewcube/gizmo-viewcube-edge.d.ts +22 -0
- package/gizmos/gizmo-helper/gizmo-viewcube/gizmo-viewcube-face.d.ts +29 -0
- package/gizmos/gizmo-helper/gizmo-viewcube/gizmo-viewcube-input.d.ts +33 -0
- package/gizmos/gizmo-helper/gizmo-viewcube/gizmo-viewcube.d.ts +10 -0
- package/gizmos/gizmo-helper/gizmo-viewport/gizmo-viewport-axis.d.ts +40 -0
- package/gizmos/gizmo-helper/gizmo-viewport/gizmo-viewport.d.ts +30 -0
- package/gizmos/index.d.ts +3 -0
- package/loaders/gltf-loader/gltf-loader.d.ts +4 -3
- package/loaders/loader/loader.d.ts +19 -17
- package/loaders/progress/progress.d.ts +1 -1
- package/loaders/texture-loader/texture-loader.d.ts +2 -2
- package/materials/index.d.ts +1 -0
- package/materials/mesh-distort-material/mesh-distort-material.d.ts +25 -15
- package/materials/mesh-reflector-material/mesh-reflector-material.d.ts +74 -56
- package/materials/mesh-refraction-material/mesh-refraction-material.d.ts +33 -21
- package/materials/mesh-transmission-material/mesh-transmission-material.d.ts +55 -39
- package/materials/mesh-wobble-material/mesh-wobble-material.d.ts +19 -10
- package/materials/point-material/point-material.d.ts +24 -0
- package/metadata.json +1 -0
- package/misc/animations/animations.d.ts +6 -4
- package/misc/caustics/caustics.d.ts +87 -0
- package/misc/decal/decal.d.ts +49 -0
- package/misc/depth-buffer/depth-buffer.d.ts +2 -2
- package/misc/example/example.d.ts +81 -0
- package/misc/fbo/fbo.d.ts +2 -2
- package/misc/html/html-wrapper.d.ts +559 -0
- package/misc/html/html.d.ts +214 -0
- package/misc/index.d.ts +9 -0
- package/misc/sampler/sampler.d.ts +67 -0
- package/misc/shadow/shadow.d.ts +37 -0
- package/misc/stats-gl/stats-gl.d.ts +24 -0
- package/misc/trail/trail.d.ts +57 -0
- package/misc/trail-texture/inject-trail-texture.d.ts +9 -0
- package/misc/trail-texture/trail-texture.d.ts +50 -0
- package/modifiers/README.md +3 -0
- package/modifiers/curve-modifier/curve-modifier.d.ts +23 -0
- package/modifiers/index.d.ts +1 -0
- package/package.json +31 -16
- package/performances/README.md +3 -0
- package/performances/adaptive-dpr/adaptive-dpr.d.ts +14 -0
- package/{performance/adaptive → performances/adaptive-events}/adaptive-events.d.ts +3 -0
- package/performances/index.d.ts +7 -0
- package/performances/instances/instances.d.ts +79 -0
- package/{performance → performances}/instances/position-mesh.d.ts +1 -1
- package/performances/points/points-input.d.ts +32 -0
- package/performances/points/points.d.ts +92 -0
- package/performances/points/position-point.d.ts +11 -0
- package/performances/segments/segment-object.d.ts +7 -0
- package/performances/segments/segments.d.ts +124 -0
- package/shaders/grid-material/grid-material.d.ts +37 -0
- package/shaders/index.d.ts +5 -2
- package/shaders/mesh-distort-material/mesh-distort-material.d.ts +147 -2
- package/shaders/mesh-transmission-material/mesh-transmission-material.d.ts +1 -1
- package/shaders/shader-material/shader-material.d.ts +2 -2
- package/shaders/soft-shadow-material/soft-shadow-material.d.ts +10 -1
- package/shaders/sparkles-material/sparkles-material.d.ts +15 -1
- package/shaders/spot-light-material/spot-light-material.d.ts +11 -2
- package/shaders/star-field-material/star-field-material.d.ts +11 -1
- package/shaders/wireframe-material/wireframe-material.d.ts +58 -0
- package/staging/accumulative-shadows/accumulative-shadows.d.ts +89 -39
- package/staging/accumulative-shadows/randomized-lights.d.ts +40 -27
- package/staging/backdrop/backdrop.d.ts +30 -0
- package/staging/bb-anchor/bb-anchor.d.ts +27 -0
- package/staging/bounds/bounds.d.ts +100 -24
- package/staging/camera-shake/camera-shake.d.ts +30 -19
- package/staging/center/center.d.ts +43 -35
- package/staging/cloud/cloud.d.ts +26 -23
- package/staging/contact-shadows/contact-shadows.d.ts +41 -28
- package/staging/environment/assets.d.ts +9 -9
- package/staging/environment/environment-cube.d.ts +9 -5
- package/staging/environment/environment-ground.d.ts +7 -7
- package/staging/environment/environment-input.d.ts +37 -37
- package/staging/environment/environment-map.d.ts +10 -5
- package/staging/environment/environment-portal.d.ts +10 -5
- package/staging/environment/environment.d.ts +0 -4
- package/staging/environment/utils.d.ts +2 -2
- package/staging/float/float.d.ts +14 -10
- package/staging/index.d.ts +6 -2
- package/staging/matcap-texture/matcap-texture.d.ts +13 -0
- package/staging/normal-texture/normal-texture.d.ts +16 -0
- package/staging/sky/sky.d.ts +28 -21
- package/staging/sparkles/sparkles.d.ts +36 -22
- package/staging/spot-light/shadow-mesh-input.d.ts +29 -0
- package/staging/spot-light/shadow-mesh.d.ts +37 -0
- package/staging/spot-light/spot-light-input.d.ts +25 -25
- package/staging/spot-light/spot-light.d.ts +31 -15
- package/staging/spot-light/volumetric-mesh.d.ts +15 -9
- package/staging/stage/stage.d.ts +89 -65
- package/staging/stars/stars.d.ts +28 -17
- package/staging/wireframe/wireframe-input.d.ts +65 -0
- package/staging/wireframe/wireframe.d.ts +28 -0
- package/utils/README.md +3 -0
- package/utils/content/content.d.ts +8 -0
- package/utils/index.d.ts +1 -0
- package/web-types.json +1 -0
- package/abstractions/catmull-rom-line/catmull-rom-line.d.ts +0 -25
- package/abstractions/cubic-bezier-line/cubic-bezier-line.d.ts +0 -25
- package/abstractions/gizmo-helper/gizmo-helper.d.ts +0 -34
- package/abstractions/gizmo-helper/gizmo-viewcube/gizmo-viewcube-edge.d.ts +0 -22
- package/abstractions/gizmo-helper/gizmo-viewcube/gizmo-viewcube-face.d.ts +0 -30
- package/abstractions/gizmo-helper/gizmo-viewcube/gizmo-viewcube-inputs.d.ts +0 -32
- package/abstractions/gizmo-helper/gizmo-viewcube/gizmo-viewcube.d.ts +0 -14
- package/abstractions/gizmo-helper/gizmo-viewport/gizmo-viewport-axis.d.ts +0 -47
- package/abstractions/gizmo-helper/gizmo-viewport/gizmo-viewport.d.ts +0 -40
- package/abstractions/line/line-input.d.ts +0 -42
- package/abstractions/line/line.d.ts +0 -35
- package/abstractions/quadratic-bezier-line/quadratic-bezier-line.d.ts +0 -23
- package/esm2022/abstractions/catmull-rom-line/catmull-rom-line.mjs +0 -131
- package/esm2022/abstractions/cubic-bezier-line/cubic-bezier-line.mjs +0 -113
- package/esm2022/abstractions/gizmo-helper/gizmo-helper.mjs +0 -210
- package/esm2022/abstractions/gizmo-helper/gizmo-viewcube/constants.mjs +0 -31
- package/esm2022/abstractions/gizmo-helper/gizmo-viewcube/gizmo-viewcube-edge.mjs +0 -95
- package/esm2022/abstractions/gizmo-helper/gizmo-viewcube/gizmo-viewcube-face.mjs +0 -155
- package/esm2022/abstractions/gizmo-helper/gizmo-viewcube/gizmo-viewcube-inputs.mjs +0 -62
- package/esm2022/abstractions/gizmo-helper/gizmo-viewcube/gizmo-viewcube.mjs +0 -80
- package/esm2022/abstractions/gizmo-helper/gizmo-viewport/gizmo-viewport-axis.mjs +0 -206
- package/esm2022/abstractions/gizmo-helper/gizmo-viewport/gizmo-viewport.mjs +0 -273
- package/esm2022/abstractions/line/line-input.mjs +0 -113
- package/esm2022/abstractions/line/line.mjs +0 -165
- package/esm2022/abstractions/quadratic-bezier-line/quadratic-bezier-line.mjs +0 -128
- package/esm2022/performance/adaptive/adaptive-dpr.mjs +0 -46
- package/esm2022/performance/adaptive/adaptive-events.mjs +0 -31
- package/esm2022/performance/angular-three-soba-performance.mjs +0 -5
- package/esm2022/performance/detailed/detailed.mjs +0 -61
- package/esm2022/performance/index.mjs +0 -7
- package/esm2022/performance/instances/instance.mjs +0 -48
- package/esm2022/performance/instances/instances.mjs +0 -189
- package/esm2022/performance/instances/position-mesh.mjs +0 -52
- package/esm2022/performance/stats/stats.mjs +0 -79
- package/esm2022/shaders/caustics-material/caustics-material.mjs +0 -128
- package/esm2022/shaders/caustics-material/caustics-projection-material.mjs +0 -33
- package/esm2022/staging/caustics/caustisc.mjs +0 -384
- package/esm2022/staging/spot-light/spot-light-shadow-mesh-input.mjs +0 -57
- package/esm2022/staging/spot-light/spot-light-shadow-mesh.mjs +0 -256
- package/fesm2022/angular-three-soba-performance.mjs +0 -487
- package/fesm2022/angular-three-soba-performance.mjs.map +0 -1
- package/performance/README.md +0 -3
- package/performance/adaptive/adaptive-dpr.d.ts +0 -8
- package/performance/detailed/detailed.d.ts +0 -20
- package/performance/index.d.ts +0 -6
- package/performance/instances/instance.d.ts +0 -9
- package/performance/instances/instances.d.ts +0 -35
- package/performance/stats/stats.d.ts +0 -18
- package/plugin/generators.json +0 -19
- package/plugin/libs/plugin/README.md +0 -11
- package/plugin/package.json +0 -9
- package/plugin/src/generators/init/compat.d.ts +0 -2
- package/plugin/src/generators/init/compat.js +0 -6
- package/plugin/src/generators/init/compat.js.map +0 -1
- package/plugin/src/generators/init/init.d.ts +0 -4
- package/plugin/src/generators/init/init.js +0 -22
- package/plugin/src/generators/init/init.js.map +0 -1
- package/plugin/src/generators/init/schema.json +0 -6
- package/plugin/src/index.d.ts +0 -1
- package/plugin/src/index.js +0 -6
- package/plugin/src/index.js.map +0 -1
- package/staging/caustics/caustisc.d.ts +0 -70
- package/staging/spot-light/spot-light-shadow-mesh-input.d.ts +0 -29
- package/staging/spot-light/spot-light-shadow-mesh.d.ts +0 -38
- /package/{abstractions → gizmos}/gizmo-helper/gizmo-viewcube/constants.d.ts +0 -0
- /package/shaders/{caustics-material → caustics}/caustics-material.d.ts +0 -0
- /package/shaders/{caustics-material → caustics}/caustics-projection-material.d.ts +0 -0
|
@@ -1,89 +1,88 @@
|
|
|
1
1
|
import { Component, computed, CUSTOM_ELEMENTS_SCHEMA, Input } from '@angular/core';
|
|
2
|
-
import { extend, getLocalState, injectBeforeRender, injectNgtRef, NgtArgs,
|
|
2
|
+
import { extend, getLocalState, injectBeforeRender, injectNgtRef, NgtArgs, signalStore, } from 'angular-three';
|
|
3
3
|
import { injectNgtsFBO } from 'angular-three-soba/misc';
|
|
4
4
|
import { DiscardMaterial, MeshTransmissionMaterial } from 'angular-three-soba/shaders';
|
|
5
5
|
import * as THREE from 'three';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
extend({ MeshTransmissionMaterial });
|
|
8
|
-
class NgtsMeshTranmissionMaterial
|
|
8
|
+
export class NgtsMeshTranmissionMaterial {
|
|
9
9
|
/** transmissionSampler, you can use the threejs transmission sampler texture that is
|
|
10
10
|
* generated once for all transmissive materials. The upside is that it can be faster if you
|
|
11
11
|
* use multiple MeshPhysical and Transmission materials, the downside is that transmissive materials
|
|
12
12
|
* using this can't see other transparent or transmissive objects, default: false */
|
|
13
|
-
set
|
|
14
|
-
this.set({ transmissionSampler });
|
|
13
|
+
set _transmissionSampler(transmissionSampler) {
|
|
14
|
+
this.inputs.set({ transmissionSampler });
|
|
15
15
|
}
|
|
16
16
|
/** Render the backside of the material (more cost, better results), default: false */
|
|
17
|
-
set
|
|
18
|
-
this.set({ backside });
|
|
17
|
+
set _backside(backside) {
|
|
18
|
+
this.inputs.set({ backside });
|
|
19
19
|
}
|
|
20
20
|
/** Backside thickness (when backside is true), default: 0 */
|
|
21
|
-
set
|
|
22
|
-
this.set({ backsideThickness });
|
|
21
|
+
set _backsideThickness(backsideThickness) {
|
|
22
|
+
this.inputs.set({ backsideThickness });
|
|
23
23
|
}
|
|
24
24
|
/** Resolution of the local buffer, default: undefined (fullscreen) */
|
|
25
|
-
set
|
|
26
|
-
this.set({ resolution });
|
|
25
|
+
set _resolution(resolution) {
|
|
26
|
+
this.inputs.set({ resolution });
|
|
27
27
|
}
|
|
28
28
|
/** Resolution of the local buffer for backfaces, default: undefined (fullscreen) */
|
|
29
|
-
set
|
|
30
|
-
this.set({ backsideResolution });
|
|
29
|
+
set _backsideResolution(backsideResolution) {
|
|
30
|
+
this.inputs.set({ backsideResolution });
|
|
31
31
|
}
|
|
32
32
|
/** Refraction samples, default: 10 */
|
|
33
|
-
set
|
|
34
|
-
this.set({ samples });
|
|
33
|
+
set _samples(samples) {
|
|
34
|
+
this.inputs.set({ samples });
|
|
35
35
|
}
|
|
36
36
|
/** Buffer scene background (can be a texture, a cubetexture or a color), default: null */
|
|
37
|
-
set
|
|
38
|
-
this.set({ background });
|
|
37
|
+
set _background(background) {
|
|
38
|
+
this.inputs.set({ background });
|
|
39
39
|
}
|
|
40
40
|
/* Transmission, default: 1 */
|
|
41
|
-
set
|
|
42
|
-
this.set({ transmission });
|
|
41
|
+
set _transmission(transmission) {
|
|
42
|
+
this.inputs.set({ transmission });
|
|
43
43
|
}
|
|
44
44
|
/* Thickness (refraction), default: 0 */
|
|
45
|
-
set
|
|
46
|
-
this.set({ thickness });
|
|
45
|
+
set _thickness(thickness) {
|
|
46
|
+
this.inputs.set({ thickness });
|
|
47
47
|
}
|
|
48
48
|
/* Roughness (blur), default: 0 */
|
|
49
|
-
set
|
|
50
|
-
this.set({ roughness });
|
|
49
|
+
set _roughness(roughness) {
|
|
50
|
+
this.inputs.set({ roughness });
|
|
51
51
|
}
|
|
52
52
|
/* Chromatic aberration, default: 0.03 */
|
|
53
|
-
set
|
|
54
|
-
this.set({ chromaticAberration });
|
|
53
|
+
set _chromaticAberration(chromaticAberration) {
|
|
54
|
+
this.inputs.set({ chromaticAberration });
|
|
55
55
|
}
|
|
56
56
|
/* Anisotropy, default: 0.1 */
|
|
57
|
-
set
|
|
58
|
-
this.set({ anisotropy });
|
|
57
|
+
set _anisotropy(anisotropy) {
|
|
58
|
+
this.inputs.set({ anisotropy });
|
|
59
|
+
}
|
|
60
|
+
/* AnisotropicBlur, default: 0.1 */
|
|
61
|
+
set _anisotropicBlur(anisotropicBlur) {
|
|
62
|
+
this.inputs.set({ anisotropicBlur });
|
|
59
63
|
}
|
|
60
64
|
/* Distortion, default: 0 */
|
|
61
|
-
set
|
|
62
|
-
this.set({ distortion });
|
|
65
|
+
set _distortion(distortion) {
|
|
66
|
+
this.inputs.set({ distortion });
|
|
63
67
|
}
|
|
64
68
|
/* Distortion scale, default: 0.5 */
|
|
65
|
-
set
|
|
66
|
-
this.set({ distortionScale });
|
|
69
|
+
set _distortionScale(distortionScale) {
|
|
70
|
+
this.inputs.set({ distortionScale });
|
|
67
71
|
}
|
|
68
72
|
/* Temporal distortion (speed of movement), default: 0.0 */
|
|
69
|
-
set
|
|
70
|
-
this.set({ temporalDistortion });
|
|
73
|
+
set _temporalDistortion(temporalDistortion) {
|
|
74
|
+
this.inputs.set({ temporalDistortion });
|
|
71
75
|
}
|
|
72
76
|
/** The scene rendered into a texture (use it to share a texture between materials), default: null */
|
|
73
|
-
set
|
|
74
|
-
this.set({ buffer });
|
|
77
|
+
set _buffer(buffer) {
|
|
78
|
+
this.inputs.set({ buffer });
|
|
75
79
|
}
|
|
76
80
|
/** Internals */
|
|
77
|
-
set
|
|
78
|
-
this.set({ time });
|
|
81
|
+
set _time(time) {
|
|
82
|
+
this.inputs.set({ time });
|
|
79
83
|
}
|
|
80
|
-
#discardMaterial;
|
|
81
|
-
#backsideResolution;
|
|
82
|
-
#resolution;
|
|
83
|
-
#fboBackSettings;
|
|
84
|
-
#fboMainSettings;
|
|
85
84
|
constructor() {
|
|
86
|
-
|
|
85
|
+
this.inputs = signalStore({
|
|
87
86
|
transmissionSampler: false,
|
|
88
87
|
backside: false,
|
|
89
88
|
transmission: 1,
|
|
@@ -92,6 +91,7 @@ class NgtsMeshTranmissionMaterial extends NgtSignalStore {
|
|
|
92
91
|
samples: 10,
|
|
93
92
|
roughness: 0,
|
|
94
93
|
anisotropy: 0.1,
|
|
94
|
+
anisotropicBlur: 0.1,
|
|
95
95
|
chromaticAberration: 0.03,
|
|
96
96
|
distortion: 0,
|
|
97
97
|
distortionScale: 0.5,
|
|
@@ -99,27 +99,28 @@ class NgtsMeshTranmissionMaterial extends NgtSignalStore {
|
|
|
99
99
|
buffer: null,
|
|
100
100
|
});
|
|
101
101
|
this.materialRef = injectNgtRef();
|
|
102
|
-
this.
|
|
103
|
-
this.
|
|
104
|
-
this.
|
|
105
|
-
this.
|
|
106
|
-
this.
|
|
107
|
-
this.
|
|
108
|
-
this.
|
|
109
|
-
this.
|
|
110
|
-
this.
|
|
111
|
-
this.
|
|
112
|
-
this.
|
|
113
|
-
this.
|
|
114
|
-
this.
|
|
115
|
-
this.
|
|
116
|
-
this
|
|
117
|
-
this
|
|
118
|
-
this
|
|
119
|
-
this
|
|
120
|
-
this
|
|
121
|
-
this.
|
|
122
|
-
this.
|
|
102
|
+
this.transmissionSampler = this.inputs.select('transmissionSampler');
|
|
103
|
+
this.backside = this.inputs.select('backside');
|
|
104
|
+
this.transmission = this.inputs.select('transmission');
|
|
105
|
+
this.thickness = this.inputs.select('thickness');
|
|
106
|
+
this.backsideThickness = this.inputs.select('backsideThickness');
|
|
107
|
+
this.samples = this.inputs.select('samples');
|
|
108
|
+
this.roughness = this.inputs.select('roughness');
|
|
109
|
+
this.anisotropy = this.inputs.select('anisotropy');
|
|
110
|
+
this.anisotropicBlur = this.inputs.select('anisotropicBlur');
|
|
111
|
+
this.chromaticAberration = this.inputs.select('chromaticAberration');
|
|
112
|
+
this.distortion = this.inputs.select('distortion');
|
|
113
|
+
this.distortionScale = this.inputs.select('distortionScale');
|
|
114
|
+
this.temporalDistortion = this.inputs.select('temporalDistortion');
|
|
115
|
+
this.buffer = this.inputs.select('buffer');
|
|
116
|
+
this.time = this.inputs.select('time');
|
|
117
|
+
this.discardMaterial = new DiscardMaterial();
|
|
118
|
+
this.backsideResolution = this.inputs.select('backsideResolution');
|
|
119
|
+
this.resolution = this.inputs.select('resolution');
|
|
120
|
+
this.fboBackSettings = computed(() => ({ width: this.backsideResolution() || this.resolution() }));
|
|
121
|
+
this.fboMainSettings = computed(() => ({ width: this.resolution() }));
|
|
122
|
+
this.fboBackRef = injectNgtsFBO(this.fboBackSettings);
|
|
123
|
+
this.fboMainRef = injectNgtsFBO(this.fboMainSettings);
|
|
123
124
|
this.side = THREE.FrontSide;
|
|
124
125
|
let oldBg;
|
|
125
126
|
let oldTone;
|
|
@@ -127,11 +128,12 @@ class NgtsMeshTranmissionMaterial extends NgtSignalStore {
|
|
|
127
128
|
injectBeforeRender((state) => {
|
|
128
129
|
if (!this.materialRef.nativeElement)
|
|
129
130
|
return;
|
|
130
|
-
const { transmissionSampler, background, backside, backsideThickness, thickness } = this.get();
|
|
131
|
+
const { transmissionSampler, background, backside, backsideThickness, thickness } = this.inputs.get();
|
|
131
132
|
this.materialRef.nativeElement.time = state.clock.getElapsedTime();
|
|
132
133
|
// Render only if the buffer matches the built-in and no transmission sampler is set
|
|
133
|
-
if (this.materialRef.nativeElement.buffer === this.fboMainRef
|
|
134
|
-
|
|
134
|
+
if (this.materialRef.nativeElement.buffer === this.fboMainRef.nativeElement?.texture &&
|
|
135
|
+
!transmissionSampler) {
|
|
136
|
+
parent = getLocalState(this.materialRef.nativeElement).parent?.();
|
|
135
137
|
if (parent) {
|
|
136
138
|
// Save defaults
|
|
137
139
|
oldTone = state.gl.toneMapping;
|
|
@@ -142,23 +144,23 @@ class NgtsMeshTranmissionMaterial extends NgtSignalStore {
|
|
|
142
144
|
state.gl.toneMapping = THREE.NoToneMapping;
|
|
143
145
|
if (background)
|
|
144
146
|
state.scene.background = background;
|
|
145
|
-
parent['material'] = this
|
|
147
|
+
parent['material'] = this.discardMaterial;
|
|
146
148
|
if (backside) {
|
|
147
149
|
// Render into the backside buffer
|
|
148
|
-
state.gl.setRenderTarget(this.fboBackRef
|
|
150
|
+
state.gl.setRenderTarget(this.fboBackRef.nativeElement);
|
|
149
151
|
state.gl.render(state.scene, state.camera);
|
|
150
152
|
// And now prepare the material for the main render using the backside buffer
|
|
151
153
|
parent['material'] = this.materialRef.nativeElement;
|
|
152
|
-
parent['material'].buffer = this.fboBackRef
|
|
154
|
+
parent['material'].buffer = this.fboBackRef.nativeElement?.texture;
|
|
153
155
|
parent['material'].thickness = backsideThickness;
|
|
154
156
|
parent['material'].side = THREE.BackSide;
|
|
155
157
|
}
|
|
156
158
|
// Render into the main buffer
|
|
157
|
-
state.gl.setRenderTarget(this.fboMainRef
|
|
159
|
+
state.gl.setRenderTarget(this.fboMainRef.nativeElement);
|
|
158
160
|
state.gl.render(state.scene, state.camera);
|
|
159
161
|
parent['material'].thickness = thickness;
|
|
160
162
|
parent['material'].side = this.side;
|
|
161
|
-
parent['material'].buffer = this.fboMainRef
|
|
163
|
+
parent['material'].buffer = this.fboMainRef.nativeElement?.texture;
|
|
162
164
|
// Set old state back
|
|
163
165
|
state.scene.background = oldBg;
|
|
164
166
|
state.gl.setRenderTarget(null);
|
|
@@ -168,90 +170,109 @@ class NgtsMeshTranmissionMaterial extends NgtSignalStore {
|
|
|
168
170
|
}
|
|
169
171
|
});
|
|
170
172
|
}
|
|
171
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.
|
|
172
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
173
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: NgtsMeshTranmissionMaterial, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
174
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.2", type: NgtsMeshTranmissionMaterial, isStandalone: true, selector: "ngts-mesh-transmission-material", inputs: { materialRef: "materialRef", _transmissionSampler: ["transmissionSampler", "_transmissionSampler"], _backside: ["backside", "_backside"], _backsideThickness: ["backsideThickness", "_backsideThickness"], _resolution: ["resolution", "_resolution"], _backsideResolution: ["backsideResolution", "_backsideResolution"], _samples: ["samples", "_samples"], _background: ["background", "_background"], _transmission: ["transmission", "_transmission"], _thickness: ["thickness", "_thickness"], _roughness: ["roughness", "_roughness"], _chromaticAberration: ["chromaticAberration", "_chromaticAberration"], _anisotropy: ["anisotropy", "_anisotropy"], _anisotropicBlur: ["anisotropicBlur", "_anisotropicBlur"], _distortion: ["distortion", "_distortion"], _distortionScale: ["distortionScale", "_distortionScale"], _temporalDistortion: ["temporalDistortion", "_temporalDistortion"], _buffer: ["buffer", "_buffer"], _time: ["time", "_time"] }, ngImport: i0, template: `
|
|
175
|
+
<ngt-mesh-transmission-material
|
|
176
|
+
ngtCompound
|
|
177
|
+
*args="[samples(), transmissionSampler()]"
|
|
178
|
+
[ref]="materialRef"
|
|
179
|
+
[buffer]="buffer() || fboMainRef.nativeElement?.texture"
|
|
180
|
+
[_transmission]="transmission()"
|
|
181
|
+
[transmission]="transmissionSampler() ? transmission() : 0"
|
|
182
|
+
[thickness]="thickness()"
|
|
183
|
+
[side]="side"
|
|
184
|
+
[anisotropicBlur]="anisotropicBlur() ?? anisotropy()"
|
|
185
|
+
[roughness]="roughness()"
|
|
186
|
+
[chromaticAberration]="chromaticAberration()"
|
|
187
|
+
[distortion]="distortion()"
|
|
188
|
+
[distortionScale]="distortionScale()"
|
|
189
|
+
[temporalDistortion]="temporalDistortion()"
|
|
190
|
+
[time]="time()"
|
|
191
|
+
/>
|
|
192
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgtArgs, selector: "ng-template[args]", inputs: ["args"] }] }); }
|
|
191
193
|
}
|
|
192
|
-
|
|
193
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsMeshTranmissionMaterial, decorators: [{
|
|
194
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: NgtsMeshTranmissionMaterial, decorators: [{
|
|
194
195
|
type: Component,
|
|
195
196
|
args: [{
|
|
196
197
|
selector: 'ngts-mesh-transmission-material',
|
|
197
198
|
standalone: true,
|
|
198
199
|
template: `
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
200
|
+
<ngt-mesh-transmission-material
|
|
201
|
+
ngtCompound
|
|
202
|
+
*args="[samples(), transmissionSampler()]"
|
|
203
|
+
[ref]="materialRef"
|
|
204
|
+
[buffer]="buffer() || fboMainRef.nativeElement?.texture"
|
|
205
|
+
[_transmission]="transmission()"
|
|
206
|
+
[transmission]="transmissionSampler() ? transmission() : 0"
|
|
207
|
+
[thickness]="thickness()"
|
|
208
|
+
[side]="side"
|
|
209
|
+
[anisotropicBlur]="anisotropicBlur() ?? anisotropy()"
|
|
210
|
+
[roughness]="roughness()"
|
|
211
|
+
[chromaticAberration]="chromaticAberration()"
|
|
212
|
+
[distortion]="distortion()"
|
|
213
|
+
[distortionScale]="distortionScale()"
|
|
214
|
+
[temporalDistortion]="temporalDistortion()"
|
|
215
|
+
[time]="time()"
|
|
216
|
+
/>
|
|
217
|
+
`,
|
|
217
218
|
imports: [NgtArgs],
|
|
218
219
|
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
219
220
|
}]
|
|
220
221
|
}], ctorParameters: function () { return []; }, propDecorators: { materialRef: [{
|
|
221
222
|
type: Input
|
|
222
|
-
}],
|
|
223
|
-
type: Input
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
}],
|
|
229
|
-
type: Input
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
}],
|
|
235
|
-
type: Input
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
}],
|
|
241
|
-
type: Input
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
}],
|
|
247
|
-
type: Input
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
}],
|
|
253
|
-
type: Input
|
|
254
|
-
|
|
255
|
-
|
|
223
|
+
}], _transmissionSampler: [{
|
|
224
|
+
type: Input,
|
|
225
|
+
args: [{ alias: 'transmissionSampler' }]
|
|
226
|
+
}], _backside: [{
|
|
227
|
+
type: Input,
|
|
228
|
+
args: [{ alias: 'backside' }]
|
|
229
|
+
}], _backsideThickness: [{
|
|
230
|
+
type: Input,
|
|
231
|
+
args: [{ alias: 'backsideThickness' }]
|
|
232
|
+
}], _resolution: [{
|
|
233
|
+
type: Input,
|
|
234
|
+
args: [{ alias: 'resolution' }]
|
|
235
|
+
}], _backsideResolution: [{
|
|
236
|
+
type: Input,
|
|
237
|
+
args: [{ alias: 'backsideResolution' }]
|
|
238
|
+
}], _samples: [{
|
|
239
|
+
type: Input,
|
|
240
|
+
args: [{ alias: 'samples' }]
|
|
241
|
+
}], _background: [{
|
|
242
|
+
type: Input,
|
|
243
|
+
args: [{ alias: 'background' }]
|
|
244
|
+
}], _transmission: [{
|
|
245
|
+
type: Input,
|
|
246
|
+
args: [{ alias: 'transmission' }]
|
|
247
|
+
}], _thickness: [{
|
|
248
|
+
type: Input,
|
|
249
|
+
args: [{ alias: 'thickness' }]
|
|
250
|
+
}], _roughness: [{
|
|
251
|
+
type: Input,
|
|
252
|
+
args: [{ alias: 'roughness' }]
|
|
253
|
+
}], _chromaticAberration: [{
|
|
254
|
+
type: Input,
|
|
255
|
+
args: [{ alias: 'chromaticAberration' }]
|
|
256
|
+
}], _anisotropy: [{
|
|
257
|
+
type: Input,
|
|
258
|
+
args: [{ alias: 'anisotropy' }]
|
|
259
|
+
}], _anisotropicBlur: [{
|
|
260
|
+
type: Input,
|
|
261
|
+
args: [{ alias: 'anisotropicBlur' }]
|
|
262
|
+
}], _distortion: [{
|
|
263
|
+
type: Input,
|
|
264
|
+
args: [{ alias: 'distortion' }]
|
|
265
|
+
}], _distortionScale: [{
|
|
266
|
+
type: Input,
|
|
267
|
+
args: [{ alias: 'distortionScale' }]
|
|
268
|
+
}], _temporalDistortion: [{
|
|
269
|
+
type: Input,
|
|
270
|
+
args: [{ alias: 'temporalDistortion' }]
|
|
271
|
+
}], _buffer: [{
|
|
272
|
+
type: Input,
|
|
273
|
+
args: [{ alias: 'buffer' }]
|
|
274
|
+
}], _time: [{
|
|
275
|
+
type: Input,
|
|
276
|
+
args: [{ alias: 'time' }]
|
|
256
277
|
}] } });
|
|
257
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mesh-transmission-material.js","sourceRoot":"","sources":["../../../../../../libs/soba/materials/src/mesh-transmission-material/mesh-transmission-material.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, CUSTOM_ELEMENTS_SCHEMA, Input } from '@angular/core';\nimport {\n    extend,\n    getLocalState,\n    injectBeforeRender,\n    injectNgtRef,\n    NgtAnyRecord,\n    NgtArgs,\n    NgtSignalStore,\n} from 'angular-three';\nimport { injectNgtsFBO } from 'angular-three-soba/misc';\nimport { DiscardMaterial, MeshTransmissionMaterial } from 'angular-three-soba/shaders';\nimport * as THREE from 'three';\n\nextend({ MeshTransmissionMaterial });\n\nexport interface NgtsMeshTranmissionMaterialState {\n    /** transmissionSampler, you can use the threejs transmission sampler texture that is\n     *  generated once for all transmissive materials. The upside is that it can be faster if you\n     *  use multiple MeshPhysical and Transmission materials, the downside is that transmissive materials\n     *  using this can't see other transparent or transmissive objects, default: false */\n    transmissionSampler: boolean;\n    /** Render the backside of the material (more cost, better results), default: false */\n    backside: boolean;\n    /** Backside thickness (when backside is true), default: 0 */\n    backsideThickness: number;\n    /** Resolution of the local buffer, default: undefined (fullscreen) */\n    resolution: number;\n    /** Resolution of the local buffer for backfaces, default: undefined (fullscreen) */\n    backsideResolution: number;\n    /** Refraction samples, default: 10 */\n    samples: number;\n    /** Buffer scene background (can be a texture, a cubetexture or a color), default: null */\n    background: THREE.Texture | THREE.Color;\n    /* Transmission, default: 1 */\n    transmission: number;\n    /* Thickness (refraction), default: 0 */\n    thickness: number;\n    /* Roughness (blur), default: 0 */\n    roughness: number;\n    /* Chromatic aberration, default: 0.03 */\n    chromaticAberration: number;\n    /* Anisotropy, default: 0.1 */\n    anisotropy: number;\n    /* Distortion, default: 0 */\n    distortion: number;\n    /* Distortion scale, default: 0.5 */\n    distortionScale: number;\n    /* Temporal distortion (speed of movement), default: 0.0 */\n    temporalDistortion: number;\n    /** The scene rendered into a texture (use it to share a texture between materials), default: null  */\n    buffer: THREE.Texture | null;\n    /** Internals */\n    time: number;\n}\n\n@Component({\n    selector: 'ngts-mesh-transmission-material',\n    standalone: true,\n    template: `\n        <ngt-mesh-transmission-material\n            ngtCompound\n            *args=\"[transmissionSamples(), transmissionTransmissionSampler()]\"\n            [ref]=\"materialRef\"\n            [buffer]=\"transmissionBuffer() || fboMainRef()?.texture\"\n            [_transmission]=\"transmissionTransmission()\"\n            [transmission]=\"transmissionTransmissionSampler() ? transmissionTransmission() : 0\"\n            [thickness]=\"transmissionThickness()\"\n            [side]=\"side\"\n            [anisotropy]=\"transmissionAnisotropy()\"\n            [roughness]=\"transmissionRoughness()\"\n            [chromaticAberration]=\"transmissionChromaticAberration()\"\n            [distortion]=\"transmissionDistortion()\"\n            [distortionScale]=\"transmissionDistortionScale()\"\n            [temporalDistortion]=\"transmissionTemporalDistortion()\"\n            [time]=\"transmissionTime()\"\n        />\n    `,\n    imports: [NgtArgs],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsMeshTranmissionMaterial extends NgtSignalStore<NgtsMeshTranmissionMaterialState> {\n    @Input() materialRef = injectNgtRef<MeshTransmissionMaterial & { time: number; buffer?: THREE.Texture }>();\n    /** transmissionSampler, you can use the threejs transmission sampler texture that is\n     *  generated once for all transmissive materials. The upside is that it can be faster if you\n     *  use multiple MeshPhysical and Transmission materials, the downside is that transmissive materials\n     *  using this can't see other transparent or transmissive objects, default: false */\n    @Input() set transmissionSampler(transmissionSampler: boolean) {\n        this.set({ transmissionSampler });\n    }\n    /** Render the backside of the material (more cost, better results), default: false */\n    @Input() set backside(backside: boolean) {\n        this.set({ backside });\n    }\n    /** Backside thickness (when backside is true), default: 0 */\n    @Input() set backsideThickness(backsideThickness: number) {\n        this.set({ backsideThickness });\n    }\n    /** Resolution of the local buffer, default: undefined (fullscreen) */\n    @Input() set resolution(resolution: number) {\n        this.set({ resolution });\n    }\n    /** Resolution of the local buffer for backfaces, default: undefined (fullscreen) */\n    @Input() set backsideResolution(backsideResolution: number) {\n        this.set({ backsideResolution });\n    }\n    /** Refraction samples, default: 10 */\n    @Input() set samples(samples: number) {\n        this.set({ samples });\n    }\n    /** Buffer scene background (can be a texture, a cubetexture or a color), default: null */\n    @Input() set background(background: THREE.Texture | THREE.Color) {\n        this.set({ background });\n    }\n    /* Transmission, default: 1 */\n    @Input() set transmission(transmission: number) {\n        this.set({ transmission });\n    }\n    /* Thickness (refraction), default: 0 */\n    @Input() set thickness(thickness: number) {\n        this.set({ thickness });\n    }\n    /* Roughness (blur), default: 0 */\n    @Input() set roughness(roughness: number) {\n        this.set({ roughness });\n    }\n    /* Chromatic aberration, default: 0.03 */\n    @Input() set chromaticAberration(chromaticAberration: number) {\n        this.set({ chromaticAberration });\n    }\n    /* Anisotropy, default: 0.1 */\n    @Input() set anisotropy(anisotropy: number) {\n        this.set({ anisotropy });\n    }\n    /* Distortion, default: 0 */\n    @Input() set distortion(distortion: number) {\n        this.set({ distortion });\n    }\n    /* Distortion scale, default: 0.5 */\n    @Input() set distortionScale(distortionScale: number) {\n        this.set({ distortionScale });\n    }\n    /* Temporal distortion (speed of movement), default: 0.0 */\n    @Input() set temporalDistortion(temporalDistortion: number) {\n        this.set({ temporalDistortion });\n    }\n    /** The scene rendered into a texture (use it to share a texture between materials), default: null  */\n    @Input() set buffer(buffer: THREE.Texture) {\n        this.set({ buffer });\n    }\n    /** Internals */\n    @Input() set time(time: number) {\n        this.set({ time });\n    }\n\n    readonly transmissionTransmissionSampler = this.select('transmissionSampler');\n    readonly transmissionBackside = this.select('backside');\n    readonly transmissionTransmission = this.select('transmission');\n    readonly transmissionThickness = this.select('thickness');\n    readonly transmissionBacksideThickness = this.select('backsideThickness');\n    readonly transmissionSamples = this.select('samples');\n    readonly transmissionRoughness = this.select('roughness');\n    readonly transmissionAnisotropy = this.select('anisotropy');\n    readonly transmissionChromaticAberration = this.select('chromaticAberration');\n    readonly transmissionDistortion = this.select('distortion');\n    readonly transmissionDistortionScale = this.select('distortionScale');\n    readonly transmissionTemporalDistortion = this.select('temporalDistortion');\n    readonly transmissionBuffer = this.select('buffer');\n    readonly transmissionTime = this.select('time');\n\n    readonly #discardMaterial = new DiscardMaterial();\n\n    readonly #backsideResolution = this.select('backsideResolution');\n    readonly #resolution = this.select('resolution');\n\n    readonly #fboBackSettings = computed(() => ({ width: this.#backsideResolution() || this.#resolution() }));\n    readonly #fboMainSettings = computed(() => ({ width: this.#resolution() }));\n\n    readonly fboBackRef = injectNgtsFBO(this.#fboBackSettings);\n    readonly fboMainRef = injectNgtsFBO(this.#fboMainSettings);\n\n    readonly side = THREE.FrontSide;\n\n    constructor() {\n        super({\n            transmissionSampler: false,\n            backside: false,\n            transmission: 1,\n            thickness: 0,\n            backsideThickness: 0,\n            samples: 10,\n            roughness: 0,\n            anisotropy: 0.1,\n            chromaticAberration: 0.03,\n            distortion: 0,\n            distortionScale: 0.5,\n            temporalDistortion: 0.0,\n            buffer: null,\n        });\n        let oldBg: THREE.Scene['background'];\n        let oldTone: THREE.WebGLRenderer['toneMapping'];\n        let parent: THREE.Object3D;\n\n        injectBeforeRender((state) => {\n            if (!this.materialRef.nativeElement) return;\n\n            const { transmissionSampler, background, backside, backsideThickness, thickness } = this.get();\n\n            this.materialRef.nativeElement.time = state.clock.getElapsedTime();\n            // Render only if the buffer matches the built-in and no transmission sampler is set\n            if (this.materialRef.nativeElement.buffer === this.fboMainRef().texture && !transmissionSampler) {\n                parent = getLocalState(this.materialRef.nativeElement).parent() as THREE.Object3D;\n                if (parent) {\n                    // Save defaults\n                    oldTone = state.gl.toneMapping;\n                    oldBg = state.scene.background;\n\n                    // Switch off tonemapping lest it double tone maps\n                    // Save the current background and set the HDR as the new BG\n                    // Use discardmaterial, the parent will be invisible, but it's shadows will still be cast\n                    state.gl.toneMapping = THREE.NoToneMapping;\n                    if (background) state.scene.background = background;\n                    (parent as NgtAnyRecord)['material'] = this.#discardMaterial;\n\n                    if (backside) {\n                        // Render into the backside buffer\n                        state.gl.setRenderTarget(this.fboBackRef());\n                        state.gl.render(state.scene, state.camera);\n                        // And now prepare the material for the main render using the backside buffer\n                        (parent as NgtAnyRecord)['material'] = this.materialRef.nativeElement;\n                        (parent as NgtAnyRecord)['material'].buffer = this.fboBackRef().texture;\n                        (parent as NgtAnyRecord)['material'].thickness = backsideThickness;\n                        (parent as NgtAnyRecord)['material'].side = THREE.BackSide;\n                    }\n\n                    // Render into the main buffer\n                    state.gl.setRenderTarget(this.fboMainRef());\n                    state.gl.render(state.scene, state.camera);\n\n                    (parent as NgtAnyRecord)['material'].thickness = thickness;\n                    (parent as NgtAnyRecord)['material'].side = this.side;\n                    (parent as NgtAnyRecord)['material'].buffer = this.fboMainRef().texture;\n\n                    // Set old state back\n                    state.scene.background = oldBg;\n                    state.gl.setRenderTarget(null);\n                    (parent as NgtAnyRecord)['material'] = this.materialRef.nativeElement;\n                    state.gl.toneMapping = oldTone;\n                }\n            }\n        });\n    }\n}\n"]}
|
|
278
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mesh-transmission-material.js","sourceRoot":"","sources":["../../../../../../libs/soba/materials/src/mesh-transmission-material/mesh-transmission-material.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, CUSTOM_ELEMENTS_SCHEMA, Input } from '@angular/core';\nimport {\n\textend,\n\tgetLocalState,\n\tinjectBeforeRender,\n\tinjectNgtRef,\n\tNgtArgs,\n\tsignalStore,\n\ttype NgtAnyRecord,\n\ttype NgtMeshPhysicalMaterial,\n} from 'angular-three';\nimport { injectNgtsFBO } from 'angular-three-soba/misc';\nimport { DiscardMaterial, MeshTransmissionMaterial } from 'angular-three-soba/shaders';\nimport * as THREE from 'three';\n\nextend({ MeshTransmissionMaterial });\n\nexport type NgtsMeshTranmissionMaterialState = {\n\t/** transmissionSampler, you can use the threejs transmission sampler texture that is\n\t *  generated once for all transmissive materials. The upside is that it can be faster if you\n\t *  use multiple MeshPhysical and Transmission materials, the downside is that transmissive materials\n\t *  using this can't see other transparent or transmissive objects, default: false */\n\ttransmissionSampler: boolean;\n\t/** Render the backside of the material (more cost, better results), default: false */\n\tbackside: boolean;\n\t/** Backside thickness (when backside is true), default: 0 */\n\tbacksideThickness: number;\n\t/** Resolution of the local buffer, default: undefined (fullscreen) */\n\tresolution: number;\n\t/** Resolution of the local buffer for backfaces, default: undefined (fullscreen) */\n\tbacksideResolution: number;\n\t/** Refraction samples, default: 10 */\n\tsamples: number;\n\t/** Buffer scene background (can be a texture, a cubetexture or a color), default: null */\n\tbackground: THREE.Texture | THREE.Color;\n\t/* Transmission, default: 1 */\n\ttransmission: number;\n\t/* Thickness (refraction), default: 0 */\n\tthickness: number;\n\t/* Roughness (blur), default: 0 */\n\troughness: number;\n\t/* Chromatic aberration, default: 0.03 */\n\tchromaticAberration: number;\n\t/* Anisotropy, default: 0.1 */\n\tanisotropy: number;\n\t/* AnisotropicBlur, default: 0.1 */\n\tanisotropicBlur: number;\n\t/* Distortion, default: 0 */\n\tdistortion: number;\n\t/* Distortion scale, default: 0.5 */\n\tdistortionScale: number;\n\t/* Temporal distortion (speed of movement), default: 0.0 */\n\ttemporalDistortion: number;\n\t/** The scene rendered into a texture (use it to share a texture between materials), default: null  */\n\tbuffer: THREE.Texture | null;\n\t/** Internals */\n\ttime: number;\n};\n\ndeclare global {\n\tinterface HTMLElementTagNameMap {\n\t\t/**\n\t\t * @extends ngt-mesh-physical-material\n\t\t */\n\t\t'ngts-mesh-transmission-material': NgtsMeshTranmissionMaterialState & NgtMeshPhysicalMaterial;\n\t}\n}\n\n@Component({\n\tselector: 'ngts-mesh-transmission-material',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ngt-mesh-transmission-material\n\t\t\tngtCompound\n\t\t\t*args=\"[samples(), transmissionSampler()]\"\n\t\t\t[ref]=\"materialRef\"\n\t\t\t[buffer]=\"buffer() || fboMainRef.nativeElement?.texture\"\n\t\t\t[_transmission]=\"transmission()\"\n\t\t\t[transmission]=\"transmissionSampler() ? transmission() : 0\"\n\t\t\t[thickness]=\"thickness()\"\n\t\t\t[side]=\"side\"\n\t\t\t[anisotropicBlur]=\"anisotropicBlur() ?? anisotropy()\"\n\t\t\t[roughness]=\"roughness()\"\n\t\t\t[chromaticAberration]=\"chromaticAberration()\"\n\t\t\t[distortion]=\"distortion()\"\n\t\t\t[distortionScale]=\"distortionScale()\"\n\t\t\t[temporalDistortion]=\"temporalDistortion()\"\n\t\t\t[time]=\"time()\"\n\t\t/>\n\t`,\n\timports: [NgtArgs],\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsMeshTranmissionMaterial {\n\tprivate inputs = signalStore<NgtsMeshTranmissionMaterialState>({\n\t\ttransmissionSampler: false,\n\t\tbackside: false,\n\t\ttransmission: 1,\n\t\tthickness: 0,\n\t\tbacksideThickness: 0,\n\t\tsamples: 10,\n\t\troughness: 0,\n\t\tanisotropy: 0.1,\n\t\tanisotropicBlur: 0.1,\n\t\tchromaticAberration: 0.03,\n\t\tdistortion: 0,\n\t\tdistortionScale: 0.5,\n\t\ttemporalDistortion: 0.0,\n\t\tbuffer: null,\n\t});\n\n\t@Input() materialRef = injectNgtRef<MeshTransmissionMaterial & { time: number; buffer?: THREE.Texture }>();\n\t/** transmissionSampler, you can use the threejs transmission sampler texture that is\n\t *  generated once for all transmissive materials. The upside is that it can be faster if you\n\t *  use multiple MeshPhysical and Transmission materials, the downside is that transmissive materials\n\t *  using this can't see other transparent or transmissive objects, default: false */\n\t@Input({ alias: 'transmissionSampler' }) set _transmissionSampler(transmissionSampler: boolean) {\n\t\tthis.inputs.set({ transmissionSampler });\n\t}\n\t/** Render the backside of the material (more cost, better results), default: false */\n\t@Input({ alias: 'backside' }) set _backside(backside: boolean) {\n\t\tthis.inputs.set({ backside });\n\t}\n\t/** Backside thickness (when backside is true), default: 0 */\n\t@Input({ alias: 'backsideThickness' }) set _backsideThickness(backsideThickness: number) {\n\t\tthis.inputs.set({ backsideThickness });\n\t}\n\t/** Resolution of the local buffer, default: undefined (fullscreen) */\n\t@Input({ alias: 'resolution' }) set _resolution(resolution: number) {\n\t\tthis.inputs.set({ resolution });\n\t}\n\t/** Resolution of the local buffer for backfaces, default: undefined (fullscreen) */\n\t@Input({ alias: 'backsideResolution' }) set _backsideResolution(backsideResolution: number) {\n\t\tthis.inputs.set({ backsideResolution });\n\t}\n\t/** Refraction samples, default: 10 */\n\t@Input({ alias: 'samples' }) set _samples(samples: number) {\n\t\tthis.inputs.set({ samples });\n\t}\n\t/** Buffer scene background (can be a texture, a cubetexture or a color), default: null */\n\t@Input({ alias: 'background' }) set _background(background: THREE.Texture | THREE.Color) {\n\t\tthis.inputs.set({ background });\n\t}\n\t/* Transmission, default: 1 */\n\t@Input({ alias: 'transmission' }) set _transmission(transmission: number) {\n\t\tthis.inputs.set({ transmission });\n\t}\n\t/* Thickness (refraction), default: 0 */\n\t@Input({ alias: 'thickness' }) set _thickness(thickness: number) {\n\t\tthis.inputs.set({ thickness });\n\t}\n\t/* Roughness (blur), default: 0 */\n\t@Input({ alias: 'roughness' }) set _roughness(roughness: number) {\n\t\tthis.inputs.set({ roughness });\n\t}\n\t/* Chromatic aberration, default: 0.03 */\n\t@Input({ alias: 'chromaticAberration' }) set _chromaticAberration(chromaticAberration: number) {\n\t\tthis.inputs.set({ chromaticAberration });\n\t}\n\t/* Anisotropy, default: 0.1 */\n\t@Input({ alias: 'anisotropy' }) set _anisotropy(anisotropy: number) {\n\t\tthis.inputs.set({ anisotropy });\n\t}\n\t/* AnisotropicBlur, default: 0.1 */\n\t@Input({ alias: 'anisotropicBlur' }) set _anisotropicBlur(anisotropicBlur: number) {\n\t\tthis.inputs.set({ anisotropicBlur });\n\t}\n\t/* Distortion, default: 0 */\n\t@Input({ alias: 'distortion' }) set _distortion(distortion: number) {\n\t\tthis.inputs.set({ distortion });\n\t}\n\t/* Distortion scale, default: 0.5 */\n\t@Input({ alias: 'distortionScale' }) set _distortionScale(distortionScale: number) {\n\t\tthis.inputs.set({ distortionScale });\n\t}\n\t/* Temporal distortion (speed of movement), default: 0.0 */\n\t@Input({ alias: 'temporalDistortion' }) set _temporalDistortion(temporalDistortion: number) {\n\t\tthis.inputs.set({ temporalDistortion });\n\t}\n\t/** The scene rendered into a texture (use it to share a texture between materials), default: null  */\n\t@Input({ alias: 'buffer' }) set _buffer(buffer: THREE.Texture) {\n\t\tthis.inputs.set({ buffer });\n\t}\n\t/** Internals */\n\t@Input({ alias: 'time' }) set _time(time: number) {\n\t\tthis.inputs.set({ time });\n\t}\n\n\ttransmissionSampler = this.inputs.select('transmissionSampler');\n\tbackside = this.inputs.select('backside');\n\ttransmission = this.inputs.select('transmission');\n\tthickness = this.inputs.select('thickness');\n\tbacksideThickness = this.inputs.select('backsideThickness');\n\tsamples = this.inputs.select('samples');\n\troughness = this.inputs.select('roughness');\n\tanisotropy = this.inputs.select('anisotropy');\n\tanisotropicBlur = this.inputs.select('anisotropicBlur');\n\tchromaticAberration = this.inputs.select('chromaticAberration');\n\tdistortion = this.inputs.select('distortion');\n\tdistortionScale = this.inputs.select('distortionScale');\n\ttemporalDistortion = this.inputs.select('temporalDistortion');\n\tbuffer = this.inputs.select('buffer');\n\ttime = this.inputs.select('time');\n\n\tprivate discardMaterial = new DiscardMaterial();\n\n\tprivate backsideResolution = this.inputs.select('backsideResolution');\n\tprivate resolution = this.inputs.select('resolution');\n\n\tprivate fboBackSettings = computed(() => ({ width: this.backsideResolution() || this.resolution() }));\n\tprivate fboMainSettings = computed(() => ({ width: this.resolution() }));\n\n\tfboBackRef = injectNgtsFBO(this.fboBackSettings);\n\tfboMainRef = injectNgtsFBO(this.fboMainSettings);\n\n\tside = THREE.FrontSide;\n\n\tconstructor() {\n\t\tlet oldBg: THREE.Scene['background'];\n\t\tlet oldTone: THREE.WebGLRenderer['toneMapping'];\n\t\tlet parent: THREE.Object3D;\n\n\t\tinjectBeforeRender((state) => {\n\t\t\tif (!this.materialRef.nativeElement) return;\n\n\t\t\tconst { transmissionSampler, background, backside, backsideThickness, thickness } = this.inputs.get();\n\n\t\t\tthis.materialRef.nativeElement.time = state.clock.getElapsedTime();\n\t\t\t// Render only if the buffer matches the built-in and no transmission sampler is set\n\t\t\tif (\n\t\t\t\tthis.materialRef.nativeElement.buffer === this.fboMainRef.nativeElement?.texture &&\n\t\t\t\t!transmissionSampler\n\t\t\t) {\n\t\t\t\tparent = getLocalState(this.materialRef.nativeElement).parent?.() as THREE.Object3D;\n\t\t\t\tif (parent) {\n\t\t\t\t\t// Save defaults\n\t\t\t\t\toldTone = state.gl.toneMapping;\n\t\t\t\t\toldBg = state.scene.background;\n\n\t\t\t\t\t// Switch off tonemapping lest it double tone maps\n\t\t\t\t\t// Save the current background and set the HDR as the new BG\n\t\t\t\t\t// Use discardmaterial, the parent will be invisible, but it's shadows will still be cast\n\t\t\t\t\tstate.gl.toneMapping = THREE.NoToneMapping;\n\t\t\t\t\tif (background) state.scene.background = background;\n\t\t\t\t\t(parent as NgtAnyRecord)['material'] = this.discardMaterial;\n\n\t\t\t\t\tif (backside) {\n\t\t\t\t\t\t// Render into the backside buffer\n\t\t\t\t\t\tstate.gl.setRenderTarget(this.fboBackRef.nativeElement);\n\t\t\t\t\t\tstate.gl.render(state.scene, state.camera);\n\t\t\t\t\t\t// And now prepare the material for the main render using the backside buffer\n\t\t\t\t\t\t(parent as NgtAnyRecord)['material'] = this.materialRef.nativeElement;\n\t\t\t\t\t\t(parent as NgtAnyRecord)['material'].buffer = this.fboBackRef.nativeElement?.texture;\n\t\t\t\t\t\t(parent as NgtAnyRecord)['material'].thickness = backsideThickness;\n\t\t\t\t\t\t(parent as NgtAnyRecord)['material'].side = THREE.BackSide;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Render into the main buffer\n\t\t\t\t\tstate.gl.setRenderTarget(this.fboMainRef.nativeElement);\n\t\t\t\t\tstate.gl.render(state.scene, state.camera);\n\n\t\t\t\t\t(parent as NgtAnyRecord)['material'].thickness = thickness;\n\t\t\t\t\t(parent as NgtAnyRecord)['material'].side = this.side;\n\t\t\t\t\t(parent as NgtAnyRecord)['material'].buffer = this.fboMainRef.nativeElement?.texture;\n\n\t\t\t\t\t// Set old state back\n\t\t\t\t\tstate.scene.background = oldBg;\n\t\t\t\t\tstate.gl.setRenderTarget(null);\n\t\t\t\t\t(parent as NgtAnyRecord)['material'] = this.materialRef.nativeElement;\n\t\t\t\t\tstate.gl.toneMapping = oldTone;\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n}\n"]}
|