angular-three-soba 1.12.4 → 1.14.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.
Files changed (262) hide show
  1. package/abstractions/lib/billboard/billboard.d.ts +1 -1
  2. package/abstractions/lib/catmull-rom-line/catmull-rom-line.d.ts +1 -1
  3. package/abstractions/lib/cubic-bezier-line/cubic-bezier-line.d.ts +1 -1
  4. package/abstractions/lib/edges/edges.d.ts +2 -2
  5. package/abstractions/lib/gizmo-helper/gizmo-helper.d.ts +1 -1
  6. package/abstractions/lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube-edge.d.ts +1 -1
  7. package/abstractions/lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube-face.d.ts +2 -2
  8. package/abstractions/lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube-inputs.d.ts +1 -1
  9. package/abstractions/lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube.d.ts +1 -1
  10. package/abstractions/lib/gizmo-helper/gizmo-viewport/gizmo-viewport-axis.d.ts +2 -2
  11. package/abstractions/lib/gizmo-helper/gizmo-viewport/gizmo-viewport.d.ts +1 -1
  12. package/abstractions/lib/line/line-input.d.ts +1 -1
  13. package/abstractions/lib/line/line.d.ts +1 -1
  14. package/abstractions/lib/quadratic-bezier-line/quadratic-bezier-line.d.ts +1 -1
  15. package/abstractions/lib/text/text.d.ts +1 -1
  16. package/abstractions/lib/text-3d/text-3d.d.ts +1 -1
  17. package/cameras/lib/camera/camera-content.d.ts +1 -1
  18. package/cameras/lib/camera/camera.d.ts +1 -1
  19. package/cameras/lib/cube-camera/cube-camera.d.ts +1 -1
  20. package/cameras/lib/orthographic-camera/orthographic-camera.d.ts +1 -1
  21. package/controls/lib/orbit-controls/orbit-controls.d.ts +1 -1
  22. package/esm2022/abstractions/lib/billboard/billboard.mjs +74 -0
  23. package/esm2022/abstractions/lib/catmull-rom-line/catmull-rom-line.mjs +120 -0
  24. package/esm2022/abstractions/lib/cubic-bezier-line/cubic-bezier-line.mjs +99 -0
  25. package/esm2022/abstractions/lib/edges/edges.mjs +96 -0
  26. package/esm2022/abstractions/lib/gizmo-helper/gizmo-helper.mjs +213 -0
  27. package/esm2022/abstractions/lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube-edge.mjs +92 -0
  28. package/esm2022/abstractions/lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube-face.mjs +184 -0
  29. package/esm2022/abstractions/lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube-inputs.mjs +46 -0
  30. package/{esm2020 → esm2022}/abstractions/lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube.mjs +8 -7
  31. package/esm2022/abstractions/lib/gizmo-helper/gizmo-viewport/gizmo-viewport-axis.mjs +195 -0
  32. package/{esm2020 → esm2022}/abstractions/lib/gizmo-helper/gizmo-viewport/gizmo-viewport.mjs +8 -7
  33. package/esm2022/abstractions/lib/line/line-input.mjs +76 -0
  34. package/esm2022/abstractions/lib/line/line.mjs +133 -0
  35. package/esm2022/abstractions/lib/quadratic-bezier-line/quadratic-bezier-line.mjs +128 -0
  36. package/esm2022/abstractions/lib/text/text.mjs +115 -0
  37. package/esm2022/abstractions/lib/text-3d/text-3d.mjs +145 -0
  38. package/esm2022/cameras/lib/camera/camera-content.mjs +21 -0
  39. package/esm2022/cameras/lib/camera/camera.mjs +75 -0
  40. package/esm2022/cameras/lib/cube-camera/cube-camera.mjs +131 -0
  41. package/esm2022/cameras/lib/orthographic-camera/orthographic-camera.mjs +93 -0
  42. package/{esm2020 → esm2022}/cameras/lib/perspective-camera/perspective-camera.mjs +8 -7
  43. package/esm2022/controls/lib/orbit-controls/orbit-controls.mjs +147 -0
  44. package/esm2022/loaders/index.mjs +6 -0
  45. package/esm2022/loaders/lib/cube-texture-loader/cube-texture-loader.mjs +10 -0
  46. package/esm2022/loaders/lib/loader/loader.mjs +134 -0
  47. package/esm2022/materials/lib/mesh-distort-material/mesh-distort-material.mjs +75 -0
  48. package/esm2022/materials/lib/mesh-reflector-material/mesh-reflector-material.mjs +328 -0
  49. package/esm2022/materials/lib/mesh-refraction-material/mesh-refraction-material.mjs +158 -0
  50. package/esm2022/materials/lib/mesh-transmission-material/mesh-transmission-material.mjs +238 -0
  51. package/esm2022/materials/lib/mesh-wobble-material/mesh-wobble-material.mjs +68 -0
  52. package/esm2022/misc/lib/bake-shadows/bake-shadows.mjs +26 -0
  53. package/esm2022/performance/lib/adaptive/adaptive-dpr.mjs +47 -0
  54. package/esm2022/performance/lib/adaptive/adaptive-events.mjs +37 -0
  55. package/esm2022/performance/lib/detailed/detailed.mjs +54 -0
  56. package/esm2022/performance/lib/stats/stats.mjs +80 -0
  57. package/esm2022/shaders/lib/blur-pass/blur-pass.mjs +61 -0
  58. package/esm2022/staging/lib/accumulative-shadows/accumulative-shadows.mjs +249 -0
  59. package/esm2022/staging/lib/accumulative-shadows/randomized-lights.mjs +201 -0
  60. package/{esm2020 → esm2022}/staging/lib/bounds/bounds.mjs +8 -7
  61. package/esm2022/staging/lib/camera-shake/camera-shake.mjs +122 -0
  62. package/esm2022/staging/lib/caustics/caustics.mjs +364 -0
  63. package/esm2022/staging/lib/center/center.mjs +143 -0
  64. package/esm2022/staging/lib/cloud/cloud.mjs +160 -0
  65. package/esm2022/staging/lib/contact-shadows/contact-shadows.mjs +228 -0
  66. package/esm2022/staging/lib/environment/environment-cube.mjs +41 -0
  67. package/esm2022/staging/lib/environment/environment-ground.mjs +67 -0
  68. package/esm2022/staging/lib/environment/environment-inputs.mjs +87 -0
  69. package/esm2022/staging/lib/environment/environment-map.mjs +39 -0
  70. package/esm2022/staging/lib/environment/environment-portal.mjs +111 -0
  71. package/{esm2020 → esm2022}/staging/lib/environment/environment.mjs +13 -11
  72. package/esm2022/staging/lib/float/float.mjs +77 -0
  73. package/esm2022/staging/lib/sky/sky.mjs +109 -0
  74. package/esm2022/staging/lib/sparkles/sparkles.mjs +210 -0
  75. package/esm2022/staging/lib/spot-light/shadow-mesh-input.mjs +51 -0
  76. package/esm2022/staging/lib/spot-light/spot-light-input.mjs +62 -0
  77. package/esm2022/staging/lib/spot-light/spot-light-shadow-no-shader.mjs +74 -0
  78. package/esm2022/staging/lib/spot-light/spot-light-shadow-shader.mjs +126 -0
  79. package/{esm2020 → esm2022}/staging/lib/spot-light/spot-light-shadow.mjs +8 -7
  80. package/esm2022/staging/lib/spot-light/spot-light.mjs +117 -0
  81. package/esm2022/staging/lib/spot-light/volumetric-mesh.mjs +86 -0
  82. package/{esm2020 → esm2022}/staging/lib/stage/stage.mjs +13 -11
  83. package/esm2022/staging/lib/stars/stars.mjs +140 -0
  84. package/{fesm2020 → fesm2022}/angular-three-soba-abstractions.mjs +89 -89
  85. package/{fesm2015 → fesm2022}/angular-three-soba-abstractions.mjs.map +1 -1
  86. package/{fesm2015 → fesm2022}/angular-three-soba-cameras.mjs +21 -21
  87. package/{fesm2015 → fesm2022}/angular-three-soba-cameras.mjs.map +1 -1
  88. package/{fesm2020 → fesm2022}/angular-three-soba-controls.mjs +5 -5
  89. package/fesm2022/angular-three-soba-controls.mjs.map +1 -0
  90. package/{fesm2020 → fesm2022}/angular-three-soba-loaders.mjs +15 -8
  91. package/fesm2022/angular-three-soba-loaders.mjs.map +1 -0
  92. package/{fesm2020 → fesm2022}/angular-three-soba-materials.mjs +25 -25
  93. package/fesm2022/angular-three-soba-materials.mjs.map +1 -0
  94. package/{fesm2020 → fesm2022}/angular-three-soba-misc.mjs +3 -3
  95. package/{fesm2020 → fesm2022}/angular-three-soba-misc.mjs.map +1 -1
  96. package/{fesm2020 → fesm2022}/angular-three-soba-performance.mjs +14 -14
  97. package/{fesm2020 → fesm2022}/angular-three-soba-performance.mjs.map +1 -1
  98. package/{fesm2020 → fesm2022}/angular-three-soba-shaders.mjs +2 -2
  99. package/fesm2022/angular-three-soba-shaders.mjs.map +1 -0
  100. package/{fesm2020 → fesm2022}/angular-three-soba-staging.mjs +139 -139
  101. package/{fesm2020 → fesm2022}/angular-three-soba-staging.mjs.map +1 -1
  102. package/loaders/index.d.ts +1 -0
  103. package/loaders/lib/cube-texture-loader/cube-texture-loader.d.ts +3 -0
  104. package/loaders/lib/loader/loader.d.ts +1 -1
  105. package/materials/lib/mesh-distort-material/mesh-distort-material.d.ts +8 -3
  106. package/materials/lib/mesh-reflector-material/mesh-reflector-material.d.ts +1 -1
  107. package/materials/lib/mesh-refraction-material/mesh-refraction-material.d.ts +1 -1
  108. package/materials/lib/mesh-transmission-material/mesh-transmission-material.d.ts +1 -1
  109. package/materials/lib/mesh-wobble-material/mesh-wobble-material.d.ts +1 -1
  110. package/package.json +43 -68
  111. package/performance/lib/adaptive/adaptive-dpr.d.ts +1 -1
  112. package/performance/lib/detailed/detailed.d.ts +1 -1
  113. package/performance/lib/stats/stats.d.ts +1 -1
  114. package/plugin/package.json +1 -1
  115. package/plugin/src/generators/init/compat.js +1 -1
  116. package/plugin/src/generators/init/compat.js.map +1 -1
  117. package/plugin/src/generators/init/init.d.ts +1 -1
  118. package/plugin/src/generators/init/init.js +1 -1
  119. package/plugin/src/generators/init/init.js.map +1 -1
  120. package/staging/lib/accumulative-shadows/accumulative-shadows.d.ts +2 -2
  121. package/staging/lib/accumulative-shadows/randomized-lights.d.ts +1 -1
  122. package/staging/lib/bounds/bounds.d.ts +1 -1
  123. package/staging/lib/camera-shake/camera-shake.d.ts +1 -1
  124. package/staging/lib/caustics/caustics.d.ts +2 -2
  125. package/staging/lib/center/center.d.ts +1 -1
  126. package/staging/lib/cloud/cloud.d.ts +1 -1
  127. package/staging/lib/contact-shadows/contact-shadows.d.ts +1 -1
  128. package/staging/lib/environment/environment-inputs.d.ts +1 -1
  129. package/staging/lib/float/float.d.ts +1 -1
  130. package/staging/lib/sky/sky.d.ts +1 -1
  131. package/staging/lib/sparkles/sparkles.d.ts +2 -2
  132. package/staging/lib/spot-light/shadow-mesh-input.d.ts +1 -1
  133. package/staging/lib/spot-light/spot-light-input.d.ts +1 -1
  134. package/staging/lib/spot-light/spot-light-shadow-no-shader.d.ts +1 -1
  135. package/staging/lib/spot-light/spot-light-shadow-shader.d.ts +1 -1
  136. package/staging/lib/spot-light/spot-light.d.ts +1 -1
  137. package/staging/lib/spot-light/volumetric-mesh.d.ts +1 -1
  138. package/staging/lib/stage/stage.d.ts +2 -2
  139. package/staging/lib/stars/stars.d.ts +2 -2
  140. package/esm2020/abstractions/lib/billboard/billboard.mjs +0 -73
  141. package/esm2020/abstractions/lib/catmull-rom-line/catmull-rom-line.mjs +0 -119
  142. package/esm2020/abstractions/lib/cubic-bezier-line/cubic-bezier-line.mjs +0 -98
  143. package/esm2020/abstractions/lib/edges/edges.mjs +0 -95
  144. package/esm2020/abstractions/lib/gizmo-helper/gizmo-helper.mjs +0 -211
  145. package/esm2020/abstractions/lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube-edge.mjs +0 -91
  146. package/esm2020/abstractions/lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube-face.mjs +0 -182
  147. package/esm2020/abstractions/lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube-inputs.mjs +0 -45
  148. package/esm2020/abstractions/lib/gizmo-helper/gizmo-viewport/gizmo-viewport-axis.mjs +0 -193
  149. package/esm2020/abstractions/lib/line/line-input.mjs +0 -75
  150. package/esm2020/abstractions/lib/line/line.mjs +0 -132
  151. package/esm2020/abstractions/lib/quadratic-bezier-line/quadratic-bezier-line.mjs +0 -127
  152. package/esm2020/abstractions/lib/text/text.mjs +0 -114
  153. package/esm2020/abstractions/lib/text-3d/text-3d.mjs +0 -144
  154. package/esm2020/cameras/lib/camera/camera-content.mjs +0 -20
  155. package/esm2020/cameras/lib/camera/camera.mjs +0 -74
  156. package/esm2020/cameras/lib/cube-camera/cube-camera.mjs +0 -130
  157. package/esm2020/cameras/lib/orthographic-camera/orthographic-camera.mjs +0 -92
  158. package/esm2020/controls/lib/orbit-controls/orbit-controls.mjs +0 -146
  159. package/esm2020/loaders/index.mjs +0 -5
  160. package/esm2020/loaders/lib/loader/loader.mjs +0 -133
  161. package/esm2020/materials/lib/mesh-distort-material/mesh-distort-material.mjs +0 -74
  162. package/esm2020/materials/lib/mesh-reflector-material/mesh-reflector-material.mjs +0 -327
  163. package/esm2020/materials/lib/mesh-refraction-material/mesh-refraction-material.mjs +0 -157
  164. package/esm2020/materials/lib/mesh-transmission-material/mesh-transmission-material.mjs +0 -237
  165. package/esm2020/materials/lib/mesh-wobble-material/mesh-wobble-material.mjs +0 -67
  166. package/esm2020/misc/lib/bake-shadows/bake-shadows.mjs +0 -25
  167. package/esm2020/performance/lib/adaptive/adaptive-dpr.mjs +0 -46
  168. package/esm2020/performance/lib/adaptive/adaptive-events.mjs +0 -36
  169. package/esm2020/performance/lib/detailed/detailed.mjs +0 -53
  170. package/esm2020/performance/lib/stats/stats.mjs +0 -79
  171. package/esm2020/shaders/lib/blur-pass/blur-pass.mjs +0 -61
  172. package/esm2020/staging/lib/accumulative-shadows/accumulative-shadows.mjs +0 -247
  173. package/esm2020/staging/lib/accumulative-shadows/randomized-lights.mjs +0 -199
  174. package/esm2020/staging/lib/camera-shake/camera-shake.mjs +0 -121
  175. package/esm2020/staging/lib/caustics/caustics.mjs +0 -363
  176. package/esm2020/staging/lib/center/center.mjs +0 -142
  177. package/esm2020/staging/lib/cloud/cloud.mjs +0 -159
  178. package/esm2020/staging/lib/contact-shadows/contact-shadows.mjs +0 -227
  179. package/esm2020/staging/lib/environment/environment-cube.mjs +0 -40
  180. package/esm2020/staging/lib/environment/environment-ground.mjs +0 -66
  181. package/esm2020/staging/lib/environment/environment-inputs.mjs +0 -86
  182. package/esm2020/staging/lib/environment/environment-map.mjs +0 -38
  183. package/esm2020/staging/lib/environment/environment-portal.mjs +0 -110
  184. package/esm2020/staging/lib/float/float.mjs +0 -76
  185. package/esm2020/staging/lib/sky/sky.mjs +0 -108
  186. package/esm2020/staging/lib/sparkles/sparkles.mjs +0 -209
  187. package/esm2020/staging/lib/spot-light/shadow-mesh-input.mjs +0 -50
  188. package/esm2020/staging/lib/spot-light/spot-light-input.mjs +0 -61
  189. package/esm2020/staging/lib/spot-light/spot-light-shadow-no-shader.mjs +0 -73
  190. package/esm2020/staging/lib/spot-light/spot-light-shadow-shader.mjs +0 -125
  191. package/esm2020/staging/lib/spot-light/spot-light.mjs +0 -116
  192. package/esm2020/staging/lib/spot-light/volumetric-mesh.mjs +0 -85
  193. package/esm2020/staging/lib/stars/stars.mjs +0 -139
  194. package/fesm2015/angular-three-soba-abstractions.mjs +0 -2048
  195. package/fesm2015/angular-three-soba-controls.mjs +0 -153
  196. package/fesm2015/angular-three-soba-controls.mjs.map +0 -1
  197. package/fesm2015/angular-three-soba-loaders.mjs +0 -222
  198. package/fesm2015/angular-three-soba-loaders.mjs.map +0 -1
  199. package/fesm2015/angular-three-soba-materials.mjs +0 -851
  200. package/fesm2015/angular-three-soba-materials.mjs.map +0 -1
  201. package/fesm2015/angular-three-soba-misc.mjs +0 -148
  202. package/fesm2015/angular-three-soba-misc.mjs.map +0 -1
  203. package/fesm2015/angular-three-soba-performance.mjs +0 -210
  204. package/fesm2015/angular-three-soba-performance.mjs.map +0 -1
  205. package/fesm2015/angular-three-soba-shaders.mjs +0 -1239
  206. package/fesm2015/angular-three-soba-shaders.mjs.map +0 -1
  207. package/fesm2015/angular-three-soba-staging.mjs +0 -3772
  208. package/fesm2015/angular-three-soba-staging.mjs.map +0 -1
  209. package/fesm2020/angular-three-soba-abstractions.mjs.map +0 -1
  210. package/fesm2020/angular-three-soba-cameras.mjs +0 -347
  211. package/fesm2020/angular-three-soba-cameras.mjs.map +0 -1
  212. package/fesm2020/angular-three-soba-controls.mjs.map +0 -1
  213. package/fesm2020/angular-three-soba-loaders.mjs.map +0 -1
  214. package/fesm2020/angular-three-soba-materials.mjs.map +0 -1
  215. package/fesm2020/angular-three-soba-shaders.mjs.map +0 -1
  216. package/fesm2020/angular-three-soba.mjs +0 -6
  217. package/fesm2020/angular-three-soba.mjs.map +0 -1
  218. /package/{esm2020 → esm2022}/abstractions/angular-three-soba-abstractions.mjs +0 -0
  219. /package/{esm2020 → esm2022}/abstractions/index.mjs +0 -0
  220. /package/{esm2020 → esm2022}/abstractions/lib/gizmo-helper/gizmo-viewcube/constants.mjs +0 -0
  221. /package/{esm2020 → esm2022}/angular-three-soba.mjs +0 -0
  222. /package/{esm2020 → esm2022}/cameras/angular-three-soba-cameras.mjs +0 -0
  223. /package/{esm2020 → esm2022}/cameras/index.mjs +0 -0
  224. /package/{esm2020 → esm2022}/controls/angular-three-soba-controls.mjs +0 -0
  225. /package/{esm2020 → esm2022}/controls/index.mjs +0 -0
  226. /package/{esm2020 → esm2022}/index.mjs +0 -0
  227. /package/{esm2020 → esm2022}/loaders/angular-three-soba-loaders.mjs +0 -0
  228. /package/{esm2020 → esm2022}/loaders/lib/gltf-loader/gltf-loader.mjs +0 -0
  229. /package/{esm2020 → esm2022}/loaders/lib/progress/progress.mjs +0 -0
  230. /package/{esm2020 → esm2022}/loaders/lib/texture-loader/texture-loader.mjs +0 -0
  231. /package/{esm2020 → esm2022}/materials/angular-three-soba-materials.mjs +0 -0
  232. /package/{esm2020 → esm2022}/materials/index.mjs +0 -0
  233. /package/{esm2020 → esm2022}/misc/angular-three-soba-misc.mjs +0 -0
  234. /package/{esm2020 → esm2022}/misc/index.mjs +0 -0
  235. /package/{esm2020 → esm2022}/misc/lib/animations/animations.mjs +0 -0
  236. /package/{esm2020 → esm2022}/misc/lib/depth-buffer/depth-buffer.mjs +0 -0
  237. /package/{esm2020 → esm2022}/misc/lib/fbo/fbo.mjs +0 -0
  238. /package/{esm2020 → esm2022}/performance/angular-three-soba-performance.mjs +0 -0
  239. /package/{esm2020 → esm2022}/performance/index.mjs +0 -0
  240. /package/{esm2020 → esm2022}/shaders/angular-three-soba-shaders.mjs +0 -0
  241. /package/{esm2020 → esm2022}/shaders/index.mjs +0 -0
  242. /package/{esm2020 → esm2022}/shaders/lib/caustics-material/caustics-material.mjs +0 -0
  243. /package/{esm2020 → esm2022}/shaders/lib/caustics-projection-material/caustics-projection-material.mjs +0 -0
  244. /package/{esm2020 → esm2022}/shaders/lib/convolution-material/convolution-material.mjs +0 -0
  245. /package/{esm2020 → esm2022}/shaders/lib/discard-material/discard-material.mjs +0 -0
  246. /package/{esm2020 → esm2022}/shaders/lib/mesh-distort-material/mesh-distort-material.mjs +0 -0
  247. /package/{esm2020 → esm2022}/shaders/lib/mesh-reflector-material/mesh-reflector-material.mjs +0 -0
  248. /package/{esm2020 → esm2022}/shaders/lib/mesh-refraction-material/mesh-refraction-material.mjs +0 -0
  249. /package/{esm2020 → esm2022}/shaders/lib/mesh-transmission-material/mesh-transmission-material.mjs +0 -0
  250. /package/{esm2020 → esm2022}/shaders/lib/mesh-wobble-material/mesh-wobble-material.mjs +0 -0
  251. /package/{esm2020 → esm2022}/shaders/lib/shader-material/shader-material.mjs +0 -0
  252. /package/{esm2020 → esm2022}/shaders/lib/soft-shadow-material/soft-shadow-material.mjs +0 -0
  253. /package/{esm2020 → esm2022}/shaders/lib/spot-light-material/spot-light-material.mjs +0 -0
  254. /package/{esm2020 → esm2022}/shaders/lib/star-field-material/star-field-material.mjs +0 -0
  255. /package/{esm2020 → esm2022}/staging/angular-three-soba-staging.mjs +0 -0
  256. /package/{esm2020 → esm2022}/staging/index.mjs +0 -0
  257. /package/{esm2020 → esm2022}/staging/lib/accumulative-shadows/progressive-light-map.mjs +0 -0
  258. /package/{esm2020 → esm2022}/staging/lib/environment/assets.mjs +0 -0
  259. /package/{esm2020 → esm2022}/staging/lib/environment/utils.mjs +0 -0
  260. /package/{esm2020 → esm2022}/staging/lib/spot-light/common.mjs +0 -0
  261. /package/{fesm2015 → fesm2022}/angular-three-soba.mjs +0 -0
  262. /package/{fesm2015 → fesm2022}/angular-three-soba.mjs.map +0 -0
@@ -0,0 +1,61 @@
1
+ import { BufferAttribute, BufferGeometry, LinearFilter, Mesh, PerspectiveCamera, Scene, Vector2, WebGLRenderTarget, } from 'three';
2
+ import { ConvolutionMaterial } from '../convolution-material/convolution-material';
3
+ export class BlurPass {
4
+ constructor({ gl, resolution, width = 500, height = 500, minDepthThreshold = 0, maxDepthThreshold = 1, depthScale = 0, depthToBlurRatioBias = 0.25, }) {
5
+ this.renderToScreen = false;
6
+ this.renderTargetA = new WebGLRenderTarget(resolution, resolution, {
7
+ minFilter: LinearFilter,
8
+ magFilter: LinearFilter,
9
+ stencilBuffer: false,
10
+ depthBuffer: false,
11
+ encoding: gl.outputEncoding,
12
+ });
13
+ this.renderTargetB = this.renderTargetA.clone();
14
+ this.convolutionMaterial = new ConvolutionMaterial();
15
+ this.convolutionMaterial.setTexelSize(1.0 / width, 1.0 / height);
16
+ this.convolutionMaterial.setResolution(new Vector2(width, height));
17
+ this.scene = new Scene();
18
+ this.camera = new PerspectiveCamera();
19
+ this.convolutionMaterial.uniforms['minDepthThreshold'].value = minDepthThreshold;
20
+ this.convolutionMaterial.uniforms['maxDepthThreshold'].value = maxDepthThreshold;
21
+ this.convolutionMaterial.uniforms['depthScale'].value = depthScale;
22
+ this.convolutionMaterial.uniforms['depthToBlurRatioBias'].value = depthToBlurRatioBias;
23
+ this.convolutionMaterial.defines['USE_DEPTH'] = depthScale > 0;
24
+ const vertices = new Float32Array([-1, -1, 0, 3, -1, 0, -1, 3, 0]);
25
+ const uvs = new Float32Array([0, 0, 2, 0, 0, 2]);
26
+ const geometry = new BufferGeometry();
27
+ geometry.setAttribute('position', new BufferAttribute(vertices, 3));
28
+ geometry.setAttribute('uv', new BufferAttribute(uvs, 2));
29
+ this.screen = new Mesh(geometry, this.convolutionMaterial);
30
+ this.screen.frustumCulled = false;
31
+ this.scene.add(this.screen);
32
+ }
33
+ render(renderer, inputBuffer, outputBuffer) {
34
+ const scene = this.scene;
35
+ const camera = this.camera;
36
+ const renderTargetA = this.renderTargetA;
37
+ const renderTargetB = this.renderTargetB;
38
+ const material = this.convolutionMaterial;
39
+ const uniforms = material.uniforms;
40
+ uniforms['depthBuffer'].value = inputBuffer.depthTexture;
41
+ const kernel = material.kernel;
42
+ let lastRT = inputBuffer;
43
+ let destRT;
44
+ let i, l;
45
+ // Apply the multi-pass blur.
46
+ for (i = 0, l = kernel.length - 1; i < l; ++i) {
47
+ // Alternate between targets.
48
+ destRT = (i & 1) === 0 ? renderTargetA : renderTargetB;
49
+ uniforms['kernel'].value = kernel[i];
50
+ uniforms['inputBuffer'].value = lastRT.texture;
51
+ renderer.setRenderTarget(destRT);
52
+ renderer.render(scene, camera);
53
+ lastRT = destRT;
54
+ }
55
+ uniforms['kernel'].value = kernel[i];
56
+ uniforms['inputBuffer'].value = lastRT.texture;
57
+ renderer.setRenderTarget(this.renderToScreen ? null : outputBuffer);
58
+ renderer.render(scene, camera);
59
+ }
60
+ }
61
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"blur-pass.js","sourceRoot":"","sources":["../../../../../../../libs/angular-three-soba/shaders/src/lib/blur-pass/blur-pass.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,eAAe,EACf,cAAc,EAEd,YAAY,EACZ,IAAI,EACJ,iBAAiB,EACjB,KAAK,EACL,OAAO,EAEP,iBAAiB,GACpB,MAAM,OAAO,CAAC;AAEf,OAAO,EAAE,mBAAmB,EAAE,MAAM,8CAA8C,CAAC;AAanF,MAAM,OAAO,QAAQ;IASjB,YAAY,EACR,EAAE,EACF,UAAU,EACV,KAAK,GAAG,GAAG,EACX,MAAM,GAAG,GAAG,EACZ,iBAAiB,GAAG,CAAC,EACrB,iBAAiB,GAAG,CAAC,EACrB,UAAU,GAAG,CAAC,EACd,oBAAoB,GAAG,IAAI,GACf;QAXhB,mBAAc,GAAG,KAAK,CAAC;QAYnB,IAAI,CAAC,aAAa,GAAG,IAAI,iBAAiB,CAAC,UAAU,EAAE,UAAU,EAAE;YAC/D,SAAS,EAAE,YAAY;YACvB,SAAS,EAAE,YAAY;YACvB,aAAa,EAAE,KAAK;YACpB,WAAW,EAAE,KAAK;YAClB,QAAQ,EAAE,EAAE,CAAC,cAAc;SAC9B,CAAC,CAAC;QACH,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QAChD,IAAI,CAAC,mBAAmB,GAAG,IAAI,mBAAmB,EAAE,CAAC;QACrD,IAAI,CAAC,mBAAmB,CAAC,YAAY,CAAC,GAAG,GAAG,KAAK,EAAE,GAAG,GAAG,MAAM,CAAC,CAAC;QACjE,IAAI,CAAC,mBAAmB,CAAC,aAAa,CAAC,IAAI,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC;QACnE,IAAI,CAAC,KAAK,GAAG,IAAI,KAAK,EAAE,CAAC;QACzB,IAAI,CAAC,MAAM,GAAG,IAAI,iBAAiB,EAAE,CAAC;QACtC,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,mBAAmB,CAAC,CAAC,KAAK,GAAG,iBAAiB,CAAC;QACjF,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,mBAAmB,CAAC,CAAC,KAAK,GAAG,iBAAiB,CAAC;QACjF,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,KAAK,GAAG,UAAU,CAAC;QACnE,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,sBAAsB,CAAC,CAAC,KAAK,GAAG,oBAAoB,CAAC;QACvF,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,WAAW,CAAC,GAAG,UAAU,GAAG,CAAC,CAAC;QAC/D,MAAM,QAAQ,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACnE,MAAM,GAAG,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACjD,MAAM,QAAQ,GAAG,IAAI,cAAc,EAAE,CAAC;QACtC,QAAQ,CAAC,YAAY,CAAC,UAAU,EAAE,IAAI,eAAe,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC;QACpE,QAAQ,CAAC,YAAY,CAAC,IAAI,EAAE,IAAI,eAAe,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;QACzD,IAAI,CAAC,MAAM,GAAG,IAAI,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;QAC3D,IAAI,CAAC,MAAM,CAAC,aAAa,GAAG,KAAK,CAAC;QAClC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAChC,CAAC;IAED,MAAM,CAAC,QAAuB,EAAE,WAAgB,EAAE,YAAiB;QAC/D,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QACzB,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC3B,MAAM,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;QACzC,MAAM,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;QACzC,MAAM,QAAQ,GAAG,IAAI,CAAC,mBAAmB,CAAC;QAC1C,MAAM,QAAQ,GAAG,QAAQ,CAAC,QAAQ,CAAC;QACnC,QAAQ,CAAC,aAAa,CAAC,CAAC,KAAK,GAAG,WAAW,CAAC,YAAY,CAAC;QACzD,MAAM,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC;QAC/B,IAAI,MAAM,GAAG,WAAW,CAAC;QACzB,IAAI,MAAM,CAAC;QACX,IAAI,CAAC,EAAE,CAAC,CAAC;QACT,6BAA6B;QAC7B,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,EAAE;YAC3C,6BAA6B;YAC7B,MAAM,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,aAAa,CAAC;YACvD,QAAQ,CAAC,QAAQ,CAAC,CAAC,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;YACrC,QAAQ,CAAC,aAAa,CAAC,CAAC,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC;YAC/C,QAAQ,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;YACjC,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;YAC/B,MAAM,GAAG,MAAM,CAAC;SACnB;QACD,QAAQ,CAAC,QAAQ,CAAC,CAAC,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACrC,QAAQ,CAAC,aAAa,CAAC,CAAC,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC;QAC/C,QAAQ,CAAC,eAAe,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC;QACpE,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;IACnC,CAAC;CACJ","sourcesContent":["import {\n    BufferAttribute,\n    BufferGeometry,\n    Camera,\n    LinearFilter,\n    Mesh,\n    PerspectiveCamera,\n    Scene,\n    Vector2,\n    WebGLRenderer,\n    WebGLRenderTarget,\n} from 'three';\n\nimport { ConvolutionMaterial } from '../convolution-material/convolution-material';\n\nexport interface BlurPassProps {\n    gl: WebGLRenderer;\n    resolution: number;\n    width?: number;\n    height?: number;\n    minDepthThreshold?: number;\n    maxDepthThreshold?: number;\n    depthScale?: number;\n    depthToBlurRatioBias?: number;\n}\n\nexport class BlurPass {\n    readonly renderTargetA: WebGLRenderTarget;\n    readonly renderTargetB: WebGLRenderTarget;\n    readonly convolutionMaterial: ConvolutionMaterial;\n    readonly scene: Scene;\n    readonly camera: Camera;\n    readonly screen: Mesh;\n    renderToScreen = false;\n\n    constructor({\n        gl,\n        resolution,\n        width = 500,\n        height = 500,\n        minDepthThreshold = 0,\n        maxDepthThreshold = 1,\n        depthScale = 0,\n        depthToBlurRatioBias = 0.25,\n    }: BlurPassProps) {\n        this.renderTargetA = new WebGLRenderTarget(resolution, resolution, {\n            minFilter: LinearFilter,\n            magFilter: LinearFilter,\n            stencilBuffer: false,\n            depthBuffer: false,\n            encoding: gl.outputEncoding,\n        });\n        this.renderTargetB = this.renderTargetA.clone();\n        this.convolutionMaterial = new ConvolutionMaterial();\n        this.convolutionMaterial.setTexelSize(1.0 / width, 1.0 / height);\n        this.convolutionMaterial.setResolution(new Vector2(width, height));\n        this.scene = new Scene();\n        this.camera = new PerspectiveCamera();\n        this.convolutionMaterial.uniforms['minDepthThreshold'].value = minDepthThreshold;\n        this.convolutionMaterial.uniforms['maxDepthThreshold'].value = maxDepthThreshold;\n        this.convolutionMaterial.uniforms['depthScale'].value = depthScale;\n        this.convolutionMaterial.uniforms['depthToBlurRatioBias'].value = depthToBlurRatioBias;\n        this.convolutionMaterial.defines['USE_DEPTH'] = depthScale > 0;\n        const vertices = new Float32Array([-1, -1, 0, 3, -1, 0, -1, 3, 0]);\n        const uvs = new Float32Array([0, 0, 2, 0, 0, 2]);\n        const geometry = new BufferGeometry();\n        geometry.setAttribute('position', new BufferAttribute(vertices, 3));\n        geometry.setAttribute('uv', new BufferAttribute(uvs, 2));\n        this.screen = new Mesh(geometry, this.convolutionMaterial);\n        this.screen.frustumCulled = false;\n        this.scene.add(this.screen);\n    }\n\n    render(renderer: WebGLRenderer, inputBuffer: any, outputBuffer: any) {\n        const scene = this.scene;\n        const camera = this.camera;\n        const renderTargetA = this.renderTargetA;\n        const renderTargetB = this.renderTargetB;\n        const material = this.convolutionMaterial;\n        const uniforms = material.uniforms;\n        uniforms['depthBuffer'].value = inputBuffer.depthTexture;\n        const kernel = material.kernel;\n        let lastRT = inputBuffer;\n        let destRT;\n        let i, l;\n        // Apply the multi-pass blur.\n        for (i = 0, l = kernel.length - 1; i < l; ++i) {\n            // Alternate between targets.\n            destRT = (i & 1) === 0 ? renderTargetA : renderTargetB;\n            uniforms['kernel'].value = kernel[i];\n            uniforms['inputBuffer'].value = lastRT.texture;\n            renderer.setRenderTarget(destRT);\n            renderer.render(scene, camera);\n            lastRT = destRT;\n        }\n        uniforms['kernel'].value = kernel[i];\n        uniforms['inputBuffer'].value = lastRT.texture;\n        renderer.setRenderTarget(this.renderToScreen ? null : outputBuffer);\n        renderer.render(scene, camera);\n    }\n}\n"]}
@@ -0,0 +1,249 @@
1
+ import { Component, CUSTOM_ELEMENTS_SCHEMA, Directive, inject, InjectionToken, Input } from '@angular/core';
2
+ import { extend, getLocalState, injectNgtRef, NgtRxStore, NgtStore } from 'angular-three';
3
+ import { SoftShadowMaterial } from 'angular-three-soba/shaders';
4
+ import { combineLatest, Subject } from 'rxjs';
5
+ import { Group, Mesh, PlaneGeometry } from 'three';
6
+ import { ProgressiveLightMap } from './progressive-light-map';
7
+ import * as i0 from "@angular/core";
8
+ extend({ SoftShadowMaterial, Group, Mesh, PlaneGeometry });
9
+ export const NGTS_ACCUMULATIVE_SHADOWS_API = new InjectionToken('NgtsAccumulativeShadows API');
10
+ function accumulativeShadowsApiFactory(accumulativeShadows) {
11
+ const store = inject(NgtStore);
12
+ const api = {
13
+ lights: new Map(),
14
+ count: 0,
15
+ getMesh: () => accumulativeShadows.meshRef.nativeElement,
16
+ reset: () => {
17
+ accumulativeShadows.pLM.clear();
18
+ const material = api.getMesh().material;
19
+ material.opacity = 0;
20
+ material.alphaTest = 0;
21
+ api.count = 0;
22
+ },
23
+ update: (frames = 1) => {
24
+ // adapt the opacity blend ratio to the number of frames
25
+ const material = api.getMesh().material;
26
+ if (!api.temporal) {
27
+ material.opacity = accumulativeShadows.get('opacity');
28
+ material.alphaTest = accumulativeShadows.get('alphaTest');
29
+ }
30
+ else {
31
+ material.opacity = Math.min(accumulativeShadows.get('opacity'), material.opacity + accumulativeShadows.get('opacity') / api.blend);
32
+ material.alphaTest = Math.min(accumulativeShadows.get('alphaTest'), material.alphaTest + accumulativeShadows.get('alphaTest') / api.blend);
33
+ }
34
+ // switch accumulative lights on
35
+ accumulativeShadows.accumulativeShadowsRef.nativeElement.visible = true;
36
+ // collect scene lights and meshes
37
+ accumulativeShadows.pLM.prepare();
38
+ // update the lightmap and the accumulative lights
39
+ for (let i = 0; i < frames; i++) {
40
+ api.lights.forEach((light) => light.update());
41
+ accumulativeShadows.pLM.update(store.get('camera'), api.blend);
42
+ }
43
+ // switch lights off
44
+ accumulativeShadows.accumulativeShadowsRef.nativeElement.visible = false;
45
+ // restore lights and meshes
46
+ accumulativeShadows.pLM.finish();
47
+ },
48
+ };
49
+ Object.defineProperties(api, {
50
+ temporal: {
51
+ get: () => !!accumulativeShadows.get('temporal'),
52
+ },
53
+ frames: {
54
+ get: () => Math.max(2, accumulativeShadows.get('frames')),
55
+ },
56
+ blend: {
57
+ get: () => Math.max(2, accumulativeShadows.get('frames') === Infinity
58
+ ? accumulativeShadows.get('blend')
59
+ : accumulativeShadows.get('frames')),
60
+ },
61
+ });
62
+ const subject = new Subject();
63
+ accumulativeShadows.hold(accumulativeShadows.meshRef.$, (mesh) => {
64
+ accumulativeShadows.pLM.configure(mesh);
65
+ accumulativeShadows.hold(combineLatest([accumulativeShadows.select(), getLocalState(store.get('scene')).objects]), () => {
66
+ // reset internals, buffers, ...
67
+ api.reset();
68
+ // update lightmap
69
+ if (!api.temporal && api.frames !== Infinity)
70
+ api.update(api.blend);
71
+ });
72
+ accumulativeShadows.effect(subject, () => store.get('internal').subscribe(() => {
73
+ const limit = accumulativeShadows.get('limit');
74
+ if ((api.temporal || api.frames === Infinity) && api.count < api.frames && api.count < limit) {
75
+ api.update();
76
+ api.count++;
77
+ }
78
+ }));
79
+ subject.next();
80
+ });
81
+ return api;
82
+ }
83
+ class AccumulativeShadowsConsumer {
84
+ constructor() {
85
+ inject(NGTS_ACCUMULATIVE_SHADOWS_API);
86
+ }
87
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: AccumulativeShadowsConsumer, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
88
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: AccumulativeShadowsConsumer, isStandalone: true, selector: "[ngtsAccumulativeShadowsConsumer]", ngImport: i0 }); }
89
+ }
90
+ export { AccumulativeShadowsConsumer };
91
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: AccumulativeShadowsConsumer, decorators: [{
92
+ type: Directive,
93
+ args: [{ selector: '[ngtsAccumulativeShadowsConsumer]', standalone: true }]
94
+ }], ctorParameters: function () { return []; } });
95
+ class NgtsAccumulativeShadows extends NgtRxStore {
96
+ constructor() {
97
+ super(...arguments);
98
+ this.nullTraverse = () => null;
99
+ this.Math = Math;
100
+ this.store = inject(NgtStore);
101
+ this.pLM = new ProgressiveLightMap(this.store.get('gl'), this.store.get('scene'), this.get('resolution'));
102
+ this.accumulativeShadowsRef = injectNgtRef();
103
+ this.meshRef = injectNgtRef();
104
+ }
105
+ /** How many frames it can render, more yields cleaner results but takes more time, 40 */
106
+ set frames(frames) {
107
+ this.set({ frames });
108
+ }
109
+ /** If frames === Infinity blend controls the refresh ratio, 100 */
110
+ set blend(blend) {
111
+ this.set({ blend });
112
+ }
113
+ /** Can limit the amount of frames rendered if frames === Infinity, usually to get some performance back once a movable scene has settled, Infinity */
114
+ set limit(limit) {
115
+ this.set({ limit });
116
+ }
117
+ /** Scale of the plane, */
118
+ set scale(scale) {
119
+ this.set({ scale });
120
+ }
121
+ /** Temporal accumulates shadows over time which is more performant but has a visual regression over instant results, false */
122
+ set temporal(temporal) {
123
+ this.set({ temporal });
124
+ }
125
+ /** Opacity of the plane, 1 */
126
+ set opacity(opacity) {
127
+ this.set({ opacity });
128
+ }
129
+ /** Discards alpha pixels, 0.65 */
130
+ set alphaTest(alphaTest) {
131
+ this.set({ alphaTest });
132
+ }
133
+ /** Shadow color, black */
134
+ set color(color) {
135
+ this.set({ color });
136
+ }
137
+ /** Colorblend, how much colors turn to black, 0 is black, 2 */
138
+ set colorBlend(colorBlend) {
139
+ this.set({ colorBlend });
140
+ }
141
+ /** Buffer resolution, 1024 */
142
+ set resolution(resolution) {
143
+ this.set({ resolution });
144
+ }
145
+ /** Texture tonemapping */
146
+ set toneMapped(toneMapped) {
147
+ this.set({ toneMapped });
148
+ }
149
+ initialize() {
150
+ super.initialize();
151
+ this.set({
152
+ frames: 40,
153
+ limit: Infinity,
154
+ blend: 20,
155
+ scale: 10,
156
+ opacity: 1,
157
+ alphaTest: 0.75,
158
+ color: 'black',
159
+ colorBlend: 2,
160
+ resolution: 1024,
161
+ toneMapped: true,
162
+ });
163
+ }
164
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsAccumulativeShadows, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
165
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: NgtsAccumulativeShadows, isStandalone: true, selector: "ngts-accumulative-shadows", inputs: { frames: "frames", blend: "blend", limit: "limit", scale: "scale", temporal: "temporal", opacity: "opacity", alphaTest: "alphaTest", color: "color", colorBlend: "colorBlend", resolution: "resolution", toneMapped: "toneMapped" }, providers: [
166
+ {
167
+ provide: NGTS_ACCUMULATIVE_SHADOWS_API,
168
+ useFactory: accumulativeShadowsApiFactory,
169
+ deps: [NgtsAccumulativeShadows],
170
+ },
171
+ ], usesInheritance: true, ngImport: i0, template: `
172
+ <ngt-group ngtCompound>
173
+ <ngt-group [ref]="accumulativeShadowsRef" [traverse]="nullTraverse">
174
+ <ng-content />
175
+ <ng-container ngtsAccumulativeShadowsConsumer />
176
+ </ngt-group>
177
+ <ngt-mesh [ref]="meshRef" [receiveShadow]="true" [scale]="get('scale')" [rotation]="[-Math.PI / 2, 0, 0]">
178
+ <ngt-plane-geometry />
179
+ <ngt-soft-shadow-material
180
+ [transparent]="true"
181
+ [depthWrite]="false"
182
+ [color]="get('color')"
183
+ [toneMapped]="get('toneMapped')"
184
+ [blend]="get('colorBlend')"
185
+ [map]="pLM.progressiveLightMap2.texture"
186
+ />
187
+ </ngt-mesh>
188
+ </ngt-group>
189
+ `, isInline: true, dependencies: [{ kind: "directive", type: AccumulativeShadowsConsumer, selector: "[ngtsAccumulativeShadowsConsumer]" }] }); }
190
+ }
191
+ export { NgtsAccumulativeShadows };
192
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsAccumulativeShadows, decorators: [{
193
+ type: Component,
194
+ args: [{
195
+ selector: 'ngts-accumulative-shadows',
196
+ standalone: true,
197
+ template: `
198
+ <ngt-group ngtCompound>
199
+ <ngt-group [ref]="accumulativeShadowsRef" [traverse]="nullTraverse">
200
+ <ng-content />
201
+ <ng-container ngtsAccumulativeShadowsConsumer />
202
+ </ngt-group>
203
+ <ngt-mesh [ref]="meshRef" [receiveShadow]="true" [scale]="get('scale')" [rotation]="[-Math.PI / 2, 0, 0]">
204
+ <ngt-plane-geometry />
205
+ <ngt-soft-shadow-material
206
+ [transparent]="true"
207
+ [depthWrite]="false"
208
+ [color]="get('color')"
209
+ [toneMapped]="get('toneMapped')"
210
+ [blend]="get('colorBlend')"
211
+ [map]="pLM.progressiveLightMap2.texture"
212
+ />
213
+ </ngt-mesh>
214
+ </ngt-group>
215
+ `,
216
+ imports: [AccumulativeShadowsConsumer],
217
+ providers: [
218
+ {
219
+ provide: NGTS_ACCUMULATIVE_SHADOWS_API,
220
+ useFactory: accumulativeShadowsApiFactory,
221
+ deps: [NgtsAccumulativeShadows],
222
+ },
223
+ ],
224
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
225
+ }]
226
+ }], propDecorators: { frames: [{
227
+ type: Input
228
+ }], blend: [{
229
+ type: Input
230
+ }], limit: [{
231
+ type: Input
232
+ }], scale: [{
233
+ type: Input
234
+ }], temporal: [{
235
+ type: Input
236
+ }], opacity: [{
237
+ type: Input
238
+ }], alphaTest: [{
239
+ type: Input
240
+ }], color: [{
241
+ type: Input
242
+ }], colorBlend: [{
243
+ type: Input
244
+ }], resolution: [{
245
+ type: Input
246
+ }], toneMapped: [{
247
+ type: Input
248
+ }] } });
249
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accumulative-shadows.js","sourceRoot":"","sources":["../../../../../../../libs/angular-three-soba/staging/src/lib/accumulative-shadows/accumulative-shadows.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, CUSTOM_ELEMENTS_SCHEMA, Directive, inject, InjectionToken, Input } from '@angular/core';\nimport { extend, getLocalState, injectNgtRef, NgtRxStore, NgtStore } from 'angular-three';\nimport { SoftShadowMaterial, SoftShadowMaterialInputs } from 'angular-three-soba/shaders';\nimport { combineLatest, Subject } from 'rxjs';\nimport * as THREE from 'three';\nimport { Group, Mesh, PlaneGeometry } from 'three';\nimport { ProgressiveLightMap } from './progressive-light-map';\n\nextend({ SoftShadowMaterial, Group, Mesh, PlaneGeometry });\n\nexport type NgtsAccumulativeShadowsLightApi = { update: () => void };\n\nexport type NgtsAccumulativeShadowsApi = {\n    lights: Map<string, NgtsAccumulativeShadowsLightApi>;\n    temporal: boolean;\n    frames: number;\n    blend: number;\n    count: number;\n    getMesh: () => THREE.Mesh<THREE.PlaneGeometry, SoftShadowMaterialInputs & THREE.ShaderMaterial>;\n    reset: () => void;\n    update: (frames?: number) => void;\n};\n\nexport const NGTS_ACCUMULATIVE_SHADOWS_API = new InjectionToken<NgtsAccumulativeShadowsApi>(\n    'NgtsAccumulativeShadows API'\n);\n\nfunction accumulativeShadowsApiFactory(accumulativeShadows: NgtsAccumulativeShadows) {\n    const store = inject(NgtStore);\n\n    const api = {\n        lights: new Map(),\n        count: 0,\n        getMesh: () =>\n            accumulativeShadows.meshRef.nativeElement as THREE.Mesh<\n                THREE.PlaneGeometry,\n                SoftShadowMaterialInputs & THREE.ShaderMaterial\n            >,\n        reset: () => {\n            accumulativeShadows.pLM.clear();\n            const material = api.getMesh().material;\n            material.opacity = 0;\n            material.alphaTest = 0;\n            api.count = 0;\n        },\n        update: (frames = 1) => {\n            // adapt the opacity blend ratio to the number of frames\n            const material = api.getMesh().material;\n            if (!api.temporal) {\n                material.opacity = accumulativeShadows.get('opacity');\n                material.alphaTest = accumulativeShadows.get('alphaTest');\n            } else {\n                material.opacity = Math.min(\n                    accumulativeShadows.get('opacity'),\n                    material.opacity + accumulativeShadows.get('opacity') / api.blend\n                );\n                material.alphaTest = Math.min(\n                    accumulativeShadows.get('alphaTest'),\n                    material.alphaTest + accumulativeShadows.get('alphaTest') / api.blend\n                );\n            }\n\n            // switch accumulative lights on\n            accumulativeShadows.accumulativeShadowsRef.nativeElement.visible = true;\n            // collect scene lights and meshes\n            accumulativeShadows.pLM.prepare();\n\n            // update the lightmap and the accumulative lights\n            for (let i = 0; i < frames; i++) {\n                api.lights.forEach((light) => light.update());\n                accumulativeShadows.pLM.update(store.get('camera'), api.blend);\n            }\n\n            // switch lights off\n            accumulativeShadows.accumulativeShadowsRef.nativeElement.visible = false;\n            // restore lights and meshes\n            accumulativeShadows.pLM.finish();\n        },\n    } as NgtsAccumulativeShadowsApi;\n\n    Object.defineProperties(api, {\n        temporal: {\n            get: () => !!accumulativeShadows.get('temporal'),\n        },\n        frames: {\n            get: () => Math.max(2, accumulativeShadows.get('frames')),\n        },\n        blend: {\n            get: () =>\n                Math.max(\n                    2,\n                    accumulativeShadows.get('frames') === Infinity\n                        ? accumulativeShadows.get('blend')\n                        : accumulativeShadows.get('frames')\n                ),\n        },\n    });\n\n    const subject = new Subject<void>();\n\n    accumulativeShadows.hold(accumulativeShadows.meshRef.$, (mesh) => {\n        accumulativeShadows.pLM.configure(mesh);\n\n        accumulativeShadows.hold(\n            combineLatest([accumulativeShadows.select(), getLocalState(store.get('scene')).objects]),\n            () => {\n                // reset internals, buffers, ...\n                api.reset();\n                // update lightmap\n                if (!api.temporal && api.frames !== Infinity) api.update(api.blend);\n            }\n        );\n\n        accumulativeShadows.effect(subject, () =>\n            store.get('internal').subscribe(() => {\n                const limit = accumulativeShadows.get('limit');\n                if ((api.temporal || api.frames === Infinity) && api.count < api.frames && api.count < limit) {\n                    api.update();\n                    api.count++;\n                }\n            })\n        );\n        subject.next();\n    });\n\n    return api;\n}\n\n@Directive({ selector: '[ngtsAccumulativeShadowsConsumer]', standalone: true })\nexport class AccumulativeShadowsConsumer {\n    constructor() {\n        inject(NGTS_ACCUMULATIVE_SHADOWS_API);\n    }\n}\n\n@Component({\n    selector: 'ngts-accumulative-shadows',\n    standalone: true,\n    template: `\n        <ngt-group ngtCompound>\n            <ngt-group [ref]=\"accumulativeShadowsRef\" [traverse]=\"nullTraverse\">\n                <ng-content />\n                <ng-container ngtsAccumulativeShadowsConsumer />\n            </ngt-group>\n            <ngt-mesh [ref]=\"meshRef\" [receiveShadow]=\"true\" [scale]=\"get('scale')\" [rotation]=\"[-Math.PI / 2, 0, 0]\">\n                <ngt-plane-geometry />\n                <ngt-soft-shadow-material\n                    [transparent]=\"true\"\n                    [depthWrite]=\"false\"\n                    [color]=\"get('color')\"\n                    [toneMapped]=\"get('toneMapped')\"\n                    [blend]=\"get('colorBlend')\"\n                    [map]=\"pLM.progressiveLightMap2.texture\"\n                />\n            </ngt-mesh>\n        </ngt-group>\n    `,\n    imports: [AccumulativeShadowsConsumer],\n    providers: [\n        {\n            provide: NGTS_ACCUMULATIVE_SHADOWS_API,\n            useFactory: accumulativeShadowsApiFactory,\n            deps: [NgtsAccumulativeShadows],\n        },\n    ],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsAccumulativeShadows extends NgtRxStore {\n    readonly nullTraverse = () => null;\n    readonly Math = Math;\n\n    private readonly store = inject(NgtStore);\n\n    readonly pLM = new ProgressiveLightMap(this.store.get('gl'), this.store.get('scene'), this.get('resolution'));\n\n    readonly accumulativeShadowsRef = injectNgtRef<THREE.Group>();\n    readonly meshRef = injectNgtRef<THREE.Mesh>();\n\n    /** How many frames it can render, more yields cleaner results but takes more time, 40 */\n    @Input() set frames(frames: number) {\n        this.set({ frames });\n    }\n\n    /** If frames === Infinity blend controls the refresh ratio, 100 */\n    @Input() set blend(blend: number) {\n        this.set({ blend });\n    }\n\n    /** Can limit the amount of frames rendered if frames === Infinity, usually to get some performance back once a movable scene has settled, Infinity */\n    @Input() set limit(limit: number) {\n        this.set({ limit });\n    }\n\n    /** Scale of the plane,  */\n    @Input() set scale(scale: number) {\n        this.set({ scale });\n    }\n\n    /** Temporal accumulates shadows over time which is more performant but has a visual regression over instant results, false  */\n    @Input() set temporal(temporal: boolean) {\n        this.set({ temporal });\n    }\n\n    /** Opacity of the plane, 1 */\n    @Input() set opacity(opacity: number) {\n        this.set({ opacity });\n    }\n\n    /** Discards alpha pixels, 0.65 */\n    @Input() set alphaTest(alphaTest: number) {\n        this.set({ alphaTest });\n    }\n\n    /** Shadow color, black */\n    @Input() set color(color: string) {\n        this.set({ color });\n    }\n\n    /** Colorblend, how much colors turn to black, 0 is black, 2 */\n    @Input() set colorBlend(colorBlend: number) {\n        this.set({ colorBlend });\n    }\n\n    /** Buffer resolution, 1024 */\n    @Input() set resolution(resolution: number) {\n        this.set({ resolution });\n    }\n\n    /** Texture tonemapping */\n    @Input() set toneMapped(toneMapped: boolean) {\n        this.set({ toneMapped });\n    }\n\n    override initialize(): void {\n        super.initialize();\n        this.set({\n            frames: 40,\n            limit: Infinity,\n            blend: 20,\n            scale: 10,\n            opacity: 1,\n            alphaTest: 0.75,\n            color: 'black',\n            colorBlend: 2,\n            resolution: 1024,\n            toneMapped: true,\n        });\n    }\n}\n"]}
@@ -0,0 +1,201 @@
1
+ import { Component, CUSTOM_ELEMENTS_SCHEMA, Directive, inject, InjectionToken, Input } from '@angular/core';
2
+ import { extend, injectNgtRef, NgtArgs, NgtRepeat, NgtRxStore } from 'angular-three';
3
+ import { combineLatest } from 'rxjs';
4
+ import * as THREE from 'three';
5
+ import { DirectionalLight, Group, OrthographicCamera, Vector2 } from 'three';
6
+ import { NGTS_ACCUMULATIVE_SHADOWS_API } from './accumulative-shadows';
7
+ import * as i0 from "@angular/core";
8
+ extend({ Group, DirectionalLight, OrthographicCamera, Vector2 });
9
+ export const NGTS_RANDOMIZED_LIGHTS_API = new InjectionToken('NgtsRandomizedLights API');
10
+ function randomizedLightsApiFactory(randomizedLights) {
11
+ const accumulativeApi = inject(NGTS_ACCUMULATIVE_SHADOWS_API);
12
+ const update = () => {
13
+ let light;
14
+ if (randomizedLights.lightsRef.nativeElement) {
15
+ for (let l = 0; l < randomizedLights.lightsRef.nativeElement.children.length; l++) {
16
+ light = randomizedLights.lightsRef.nativeElement.children[l];
17
+ if (Math.random() > randomizedLights.get('ambient')) {
18
+ const position = randomizedLights.get('position');
19
+ const radius = randomizedLights.get('radius');
20
+ light.position.set(position[0] + THREE.MathUtils.randFloatSpread(radius), position[1] + THREE.MathUtils.randFloatSpread(radius), position[2] + THREE.MathUtils.randFloatSpread(radius));
21
+ }
22
+ else {
23
+ const lambda = Math.acos(2 * Math.random() - 1) - Math.PI / 2.0;
24
+ const phi = 2 * Math.PI * Math.random();
25
+ const length = randomizedLights.get('length');
26
+ light.position.set(Math.cos(lambda) * Math.cos(phi) * length, Math.abs(Math.cos(lambda) * Math.sin(phi) * length), Math.sin(lambda) * length);
27
+ }
28
+ }
29
+ }
30
+ };
31
+ const api = { update };
32
+ randomizedLights.effect(combineLatest([
33
+ randomizedLights.lightsRef.$,
34
+ randomizedLights.select('position'),
35
+ randomizedLights.select('radius'),
36
+ randomizedLights.select('length'),
37
+ randomizedLights.select('ambient'),
38
+ ]), ([group]) => {
39
+ if (accumulativeApi)
40
+ accumulativeApi.lights.set(group.uuid, api);
41
+ return () => accumulativeApi.lights.delete(group.uuid);
42
+ });
43
+ return api;
44
+ }
45
+ class RandomizedLightsConsumer {
46
+ constructor() {
47
+ inject(NGTS_RANDOMIZED_LIGHTS_API);
48
+ }
49
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: RandomizedLightsConsumer, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
50
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: RandomizedLightsConsumer, isStandalone: true, selector: "[ngtsRandomizedLightsConsumer]", ngImport: i0 }); }
51
+ }
52
+ export { RandomizedLightsConsumer };
53
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: RandomizedLightsConsumer, decorators: [{
54
+ type: Directive,
55
+ args: [{ selector: '[ngtsRandomizedLightsConsumer]', standalone: true }]
56
+ }], ctorParameters: function () { return []; } });
57
+ class NgtsRandomizedLights extends NgtRxStore {
58
+ constructor() {
59
+ super(...arguments);
60
+ this.lightsRef = injectNgtRef();
61
+ }
62
+ /** How many frames it will jiggle the lights, 1.
63
+ * Frames is context aware, if a provider like AccumulativeShadows exists, frames will be taken from there! */
64
+ set frames(frames) {
65
+ this.set({ frames });
66
+ }
67
+ /** Light position, [0, 0, 0] */
68
+ set position(position) {
69
+ this.set({ position });
70
+ }
71
+ /** Radius of the jiggle, higher values make softer light, 5 */
72
+ set radius(radius) {
73
+ this.set({ radius });
74
+ }
75
+ /** Amount of lights, 8 */
76
+ set amount(amount) {
77
+ this.set({ amount });
78
+ }
79
+ /** Light intensity, 1 */
80
+ set intensity(intensity) {
81
+ this.set({ intensity });
82
+ }
83
+ /** Ambient occlusion, lower values mean less AO, hight more, you can mix AO and directional light, 0.5 */
84
+ set ambient(ambient) {
85
+ this.set({ ambient });
86
+ }
87
+ /** If the lights cast shadows, this is true by default */
88
+ set castShadow(castShadow) {
89
+ this.set({ castShadow });
90
+ }
91
+ /** Default shadow bias, 0 */
92
+ set bias(bias) {
93
+ this.set({ bias });
94
+ }
95
+ /** Default map size, 512 */
96
+ set mapSize(mapSize) {
97
+ this.set({ mapSize });
98
+ }
99
+ /** Default size of the shadow camera, 10 */
100
+ set size(size) {
101
+ this.set({ size });
102
+ }
103
+ /** Default shadow camera near, 0.5 */
104
+ set near(near) {
105
+ this.set({ near });
106
+ }
107
+ /** Default shadow camera far, 500 */
108
+ set far(far) {
109
+ this.set({ far });
110
+ }
111
+ initialize() {
112
+ super.initialize();
113
+ this.set({
114
+ castShadow: true,
115
+ bias: 0.001,
116
+ mapSize: 512,
117
+ size: 5,
118
+ near: 0.5,
119
+ far: 500,
120
+ frames: 1,
121
+ position: [0, 0, 0],
122
+ radius: 1,
123
+ amount: 8,
124
+ intensity: 1,
125
+ ambient: 0.5,
126
+ });
127
+ this.connect('cameraArgs', this.select(['size', 'near', 'far'], ({ size, near, far }) => [-size, size, size, -size, near, far]));
128
+ this.connect('length', this.select(['position'], ({ position }) => new THREE.Vector3(...position).length()));
129
+ }
130
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsRandomizedLights, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
131
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: NgtsRandomizedLights, isStandalone: true, selector: "ngts-randomized-lights", inputs: { lightsRef: "lightsRef", frames: "frames", position: "position", radius: "radius", amount: "amount", intensity: "intensity", ambient: "ambient", castShadow: "castShadow", bias: "bias", mapSize: "mapSize", size: "size", near: "near", far: "far" }, providers: [
132
+ { provide: NGTS_RANDOMIZED_LIGHTS_API, useFactory: randomizedLightsApiFactory, deps: [NgtsRandomizedLights] },
133
+ ], usesInheritance: true, ngImport: i0, template: `
134
+ <ngt-group ngtCompound [ref]="lightsRef">
135
+ <ngt-directional-light
136
+ *ngFor="let i; repeat: get('amount')"
137
+ [castShadow]="get('castShadow')"
138
+ [intensity]="get('intensity') / get('amount')"
139
+ >
140
+ <ngt-value [rawValue]="get('bias')" attach="shadow.bias" />
141
+ <ngt-vector2 *args="[get('mapSize'), get('mapSize')]" attach="shadow.mapSize" />
142
+ <ngt-orthographic-camera *args="get('cameraArgs')" attach="shadow.camera" />
143
+ </ngt-directional-light>
144
+ <ng-container ngtsRandomizedLightsConsumer />
145
+ </ngt-group>
146
+ `, isInline: true, dependencies: [{ kind: "directive", type: RandomizedLightsConsumer, selector: "[ngtsRandomizedLightsConsumer]" }, { kind: "directive", type: NgtArgs, selector: "[args]", inputs: ["args"] }, { kind: "directive", type: NgtRepeat, selector: "[ngFor][ngForRepeat]", inputs: ["ngForRepeat"] }] }); }
147
+ }
148
+ export { NgtsRandomizedLights };
149
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: NgtsRandomizedLights, decorators: [{
150
+ type: Component,
151
+ args: [{
152
+ selector: 'ngts-randomized-lights',
153
+ standalone: true,
154
+ template: `
155
+ <ngt-group ngtCompound [ref]="lightsRef">
156
+ <ngt-directional-light
157
+ *ngFor="let i; repeat: get('amount')"
158
+ [castShadow]="get('castShadow')"
159
+ [intensity]="get('intensity') / get('amount')"
160
+ >
161
+ <ngt-value [rawValue]="get('bias')" attach="shadow.bias" />
162
+ <ngt-vector2 *args="[get('mapSize'), get('mapSize')]" attach="shadow.mapSize" />
163
+ <ngt-orthographic-camera *args="get('cameraArgs')" attach="shadow.camera" />
164
+ </ngt-directional-light>
165
+ <ng-container ngtsRandomizedLightsConsumer />
166
+ </ngt-group>
167
+ `,
168
+ imports: [RandomizedLightsConsumer, NgtArgs, NgtRepeat],
169
+ providers: [
170
+ { provide: NGTS_RANDOMIZED_LIGHTS_API, useFactory: randomizedLightsApiFactory, deps: [NgtsRandomizedLights] },
171
+ ],
172
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
173
+ }]
174
+ }], propDecorators: { lightsRef: [{
175
+ type: Input
176
+ }], frames: [{
177
+ type: Input
178
+ }], position: [{
179
+ type: Input
180
+ }], radius: [{
181
+ type: Input
182
+ }], amount: [{
183
+ type: Input
184
+ }], intensity: [{
185
+ type: Input
186
+ }], ambient: [{
187
+ type: Input
188
+ }], castShadow: [{
189
+ type: Input
190
+ }], bias: [{
191
+ type: Input
192
+ }], mapSize: [{
193
+ type: Input
194
+ }], size: [{
195
+ type: Input
196
+ }], near: [{
197
+ type: Input
198
+ }], far: [{
199
+ type: Input
200
+ }] } });
201
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"randomized-lights.js","sourceRoot":"","sources":["../../../../../../../libs/angular-three-soba/staging/src/lib/accumulative-shadows/randomized-lights.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, CUSTOM_ELEMENTS_SCHEMA, Directive, inject, InjectionToken, Input } from '@angular/core';\nimport { extend, injectNgtRef, NgtArgs, NgtRepeat, NgtRxStore } from 'angular-three';\nimport { combineLatest } from 'rxjs';\nimport * as THREE from 'three';\nimport { DirectionalLight, Group, OrthographicCamera, Vector2 } from 'three';\nimport { NgtsAccumulativeShadowsLightApi, NGTS_ACCUMULATIVE_SHADOWS_API } from './accumulative-shadows';\n\nextend({ Group, DirectionalLight, OrthographicCamera, Vector2 });\n\nexport const NGTS_RANDOMIZED_LIGHTS_API = new InjectionToken<NgtsAccumulativeShadowsLightApi>(\n    'NgtsRandomizedLights API'\n);\n\nfunction randomizedLightsApiFactory(randomizedLights: NgtsRandomizedLights) {\n    const accumulativeApi = inject(NGTS_ACCUMULATIVE_SHADOWS_API);\n\n    const update = () => {\n        let light: THREE.DirectionalLight | undefined;\n        if (randomizedLights.lightsRef.nativeElement) {\n            for (let l = 0; l < randomizedLights.lightsRef.nativeElement.children.length; l++) {\n                light = randomizedLights.lightsRef.nativeElement.children[l] as THREE.DirectionalLight;\n                if (Math.random() > randomizedLights.get('ambient')) {\n                    const position = randomizedLights.get('position');\n                    const radius = randomizedLights.get('radius');\n                    light.position.set(\n                        position[0] + THREE.MathUtils.randFloatSpread(radius),\n                        position[1] + THREE.MathUtils.randFloatSpread(radius),\n                        position[2] + THREE.MathUtils.randFloatSpread(radius)\n                    );\n                } else {\n                    const lambda = Math.acos(2 * Math.random() - 1) - Math.PI / 2.0;\n                    const phi = 2 * Math.PI * Math.random();\n                    const length = randomizedLights.get('length');\n                    light.position.set(\n                        Math.cos(lambda) * Math.cos(phi) * length,\n                        Math.abs(Math.cos(lambda) * Math.sin(phi) * length),\n                        Math.sin(lambda) * length\n                    );\n                }\n            }\n        }\n    };\n\n    const api = { update } as NgtsAccumulativeShadowsLightApi;\n\n    randomizedLights.effect(\n        combineLatest([\n            randomizedLights.lightsRef.$,\n            randomizedLights.select('position'),\n            randomizedLights.select('radius'),\n            randomizedLights.select('length'),\n            randomizedLights.select('ambient'),\n        ]),\n        ([group]) => {\n            if (accumulativeApi) accumulativeApi.lights.set(group.uuid, api);\n            return () => accumulativeApi.lights.delete(group.uuid);\n        }\n    );\n\n    return api;\n}\n\n@Directive({ selector: '[ngtsRandomizedLightsConsumer]', standalone: true })\nexport class RandomizedLightsConsumer {\n    constructor() {\n        inject(NGTS_RANDOMIZED_LIGHTS_API);\n    }\n}\n\n@Component({\n    selector: 'ngts-randomized-lights',\n    standalone: true,\n    template: `\n        <ngt-group ngtCompound [ref]=\"lightsRef\">\n            <ngt-directional-light\n                *ngFor=\"let i; repeat: get('amount')\"\n                [castShadow]=\"get('castShadow')\"\n                [intensity]=\"get('intensity') / get('amount')\"\n            >\n                <ngt-value [rawValue]=\"get('bias')\" attach=\"shadow.bias\" />\n                <ngt-vector2 *args=\"[get('mapSize'), get('mapSize')]\" attach=\"shadow.mapSize\" />\n                <ngt-orthographic-camera *args=\"get('cameraArgs')\" attach=\"shadow.camera\" />\n            </ngt-directional-light>\n            <ng-container ngtsRandomizedLightsConsumer />\n        </ngt-group>\n    `,\n    imports: [RandomizedLightsConsumer, NgtArgs, NgtRepeat],\n    providers: [\n        { provide: NGTS_RANDOMIZED_LIGHTS_API, useFactory: randomizedLightsApiFactory, deps: [NgtsRandomizedLights] },\n    ],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsRandomizedLights extends NgtRxStore {\n    @Input() lightsRef = injectNgtRef<THREE.Group>();\n    /** How many frames it will jiggle the lights, 1.\n     *  Frames is context aware, if a provider like AccumulativeShadows exists, frames will be taken from there!  */\n    @Input() set frames(frames: number) {\n        this.set({ frames });\n    }\n\n    /** Light position, [0, 0, 0] */\n    @Input() set position(position: [x: number, y: number, z: number]) {\n        this.set({ position });\n    }\n\n    /** Radius of the jiggle, higher values make softer light, 5 */\n    @Input() set radius(radius: number) {\n        this.set({ radius });\n    }\n\n    /** Amount of lights, 8 */\n    @Input() set amount(amount: number) {\n        this.set({ amount });\n    }\n\n    /** Light intensity, 1 */\n    @Input() set intensity(intensity: number) {\n        this.set({ intensity });\n    }\n\n    /** Ambient occlusion, lower values mean less AO, hight more, you can mix AO and directional light, 0.5 */\n    @Input() set ambient(ambient: number) {\n        this.set({ ambient });\n    }\n\n    /** If the lights cast shadows, this is true by default */\n    @Input() set castShadow(castShadow: boolean) {\n        this.set({ castShadow });\n    }\n\n    /** Default shadow bias, 0 */\n    @Input() set bias(bias: number) {\n        this.set({ bias });\n    }\n\n    /** Default map size, 512 */\n    @Input() set mapSize(mapSize: number) {\n        this.set({ mapSize });\n    }\n\n    /** Default size of the shadow camera, 10 */\n    @Input() set size(size: number) {\n        this.set({ size });\n    }\n\n    /** Default shadow camera near, 0.5 */\n    @Input() set near(near: number) {\n        this.set({ near });\n    }\n\n    /** Default shadow camera far, 500 */\n    @Input() set far(far: number) {\n        this.set({ far });\n    }\n\n    override initialize(): void {\n        super.initialize();\n        this.set({\n            castShadow: true,\n            bias: 0.001,\n            mapSize: 512,\n            size: 5,\n            near: 0.5,\n            far: 500,\n            frames: 1,\n            position: [0, 0, 0],\n            radius: 1,\n            amount: 8,\n            intensity: 1,\n            ambient: 0.5,\n        });\n        this.connect(\n            'cameraArgs',\n            this.select(['size', 'near', 'far'], ({ size, near, far }) => [-size, size, size, -size, near, far])\n        );\n        this.connect(\n            'length',\n            this.select(['position'], ({ position }) => new THREE.Vector3(...position).length())\n        );\n    }\n}\n"]}