angular-three-soba 1.0.2 → 1.2.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 (101) hide show
  1. package/esm2020/controls/lib/orbit-controls/orbit-controls.mjs +3 -3
  2. package/esm2020/loaders/index.mjs +4 -1
  3. package/esm2020/loaders/lib/loader/loader.mjs +133 -0
  4. package/esm2020/loaders/lib/progress/progress.mjs +39 -0
  5. package/esm2020/loaders/lib/texture-loader/texture-loader.mjs +19 -0
  6. package/esm2020/misc/angular-three-soba-misc.mjs +5 -0
  7. package/esm2020/misc/index.mjs +2 -0
  8. package/esm2020/misc/lib/bake-shadows/bake-shadows.mjs +25 -0
  9. package/esm2020/performance/angular-three-soba-performance.mjs +5 -0
  10. package/esm2020/performance/index.mjs +5 -0
  11. package/esm2020/performance/lib/adaptive/adaptive-dpr.mjs +46 -0
  12. package/esm2020/performance/lib/adaptive/adaptive-events.mjs +36 -0
  13. package/esm2020/performance/lib/detailed/detailed.mjs +50 -0
  14. package/esm2020/performance/lib/stats/stats.mjs +63 -0
  15. package/esm2020/shaders/angular-three-soba-shaders.mjs +5 -0
  16. package/esm2020/shaders/index.mjs +2 -0
  17. package/esm2020/shaders/lib/shader-material/shader-material.mjs +34 -0
  18. package/esm2020/staging/angular-three-soba-staging.mjs +5 -0
  19. package/esm2020/staging/index.mjs +13 -0
  20. package/esm2020/staging/lib/accumulative-shadows/accumulative-shadows.mjs +276 -0
  21. package/esm2020/staging/lib/accumulative-shadows/progressive-light-map.mjs +109 -0
  22. package/esm2020/staging/lib/accumulative-shadows/randomized-lights.mjs +196 -0
  23. package/esm2020/staging/lib/bounds/bounds.mjs +283 -0
  24. package/esm2020/staging/lib/center/center.mjs +142 -0
  25. package/esm2020/staging/lib/contact-shadows/contact-shadows.mjs +227 -0
  26. package/esm2020/staging/lib/environment/assets.mjs +13 -0
  27. package/esm2020/staging/lib/environment/environment-cube.mjs +40 -0
  28. package/esm2020/staging/lib/environment/environment-ground.mjs +66 -0
  29. package/esm2020/staging/lib/environment/environment-inputs.mjs +86 -0
  30. package/esm2020/staging/lib/environment/environment-map.mjs +38 -0
  31. package/esm2020/staging/lib/environment/environment-portal.mjs +110 -0
  32. package/esm2020/staging/lib/environment/environment.mjs +163 -0
  33. package/esm2020/staging/lib/environment/utils.mjs +70 -0
  34. package/esm2020/staging/lib/float/float.mjs +76 -0
  35. package/esm2020/staging/lib/sky/sky.mjs +111 -0
  36. package/esm2020/staging/lib/sparkles/sparkles.mjs +209 -0
  37. package/esm2020/staging/lib/stage/stage.mjs +369 -0
  38. package/esm2020/staging/lib/stars/stars.mjs +171 -0
  39. package/fesm2015/angular-three-soba-controls.mjs +3 -3
  40. package/fesm2015/angular-three-soba-loaders.mjs +187 -3
  41. package/fesm2015/angular-three-soba-loaders.mjs.map +1 -1
  42. package/fesm2015/angular-three-soba-misc.mjs +32 -0
  43. package/fesm2015/angular-three-soba-misc.mjs.map +1 -0
  44. package/fesm2015/angular-three-soba-performance.mjs +191 -0
  45. package/fesm2015/angular-three-soba-performance.mjs.map +1 -0
  46. package/fesm2015/angular-three-soba-shaders.mjs +38 -0
  47. package/fesm2015/angular-three-soba-shaders.mjs.map +1 -0
  48. package/fesm2015/angular-three-soba-staging.mjs +2647 -0
  49. package/fesm2015/angular-three-soba-staging.mjs.map +1 -0
  50. package/fesm2020/angular-three-soba-controls.mjs +3 -3
  51. package/fesm2020/angular-three-soba-loaders.mjs +186 -3
  52. package/fesm2020/angular-three-soba-loaders.mjs.map +1 -1
  53. package/fesm2020/angular-three-soba-misc.mjs +32 -0
  54. package/fesm2020/angular-three-soba-misc.mjs.map +1 -0
  55. package/fesm2020/angular-three-soba-performance.mjs +191 -0
  56. package/fesm2020/angular-three-soba-performance.mjs.map +1 -0
  57. package/fesm2020/angular-three-soba-shaders.mjs +41 -0
  58. package/fesm2020/angular-three-soba-shaders.mjs.map +1 -0
  59. package/fesm2020/angular-three-soba-staging.mjs +2654 -0
  60. package/fesm2020/angular-three-soba-staging.mjs.map +1 -0
  61. package/loaders/index.d.ts +3 -0
  62. package/loaders/lib/loader/loader.d.ts +26 -0
  63. package/loaders/lib/progress/progress.d.ts +16 -0
  64. package/loaders/lib/texture-loader/texture-loader.d.ts +5 -0
  65. package/misc/README.md +3 -0
  66. package/misc/index.d.ts +1 -0
  67. package/misc/lib/bake-shadows/bake-shadows.d.ts +9 -0
  68. package/package.json +37 -2
  69. package/performance/README.md +3 -0
  70. package/performance/index.d.ts +4 -0
  71. package/performance/lib/adaptive/adaptive-dpr.d.ts +11 -0
  72. package/performance/lib/adaptive/adaptive-events.d.ts +10 -0
  73. package/performance/lib/detailed/detailed.d.ts +12 -0
  74. package/performance/lib/stats/stats.d.ts +14 -0
  75. package/plugin/package.json +1 -1
  76. package/plugin/src/generators/init/init.js +13 -17
  77. package/plugin/src/generators/init/init.js.map +1 -1
  78. package/shaders/README.md +3 -0
  79. package/shaders/index.d.ts +1 -0
  80. package/shaders/lib/shader-material/shader-material.d.ts +6 -0
  81. package/staging/README.md +3 -0
  82. package/staging/index.d.ts +12 -0
  83. package/staging/lib/accumulative-shadows/accumulative-shadows.d.ts +64 -0
  84. package/staging/lib/accumulative-shadows/progressive-light-map.d.ts +34 -0
  85. package/staging/lib/accumulative-shadows/randomized-lights.d.ts +42 -0
  86. package/staging/lib/bounds/bounds.d.ts +48 -0
  87. package/staging/lib/center/center.d.ts +40 -0
  88. package/staging/lib/contact-shadows/contact-shadows.d.ts +29 -0
  89. package/staging/lib/environment/assets.d.ts +13 -0
  90. package/staging/lib/environment/environment-cube.d.ts +11 -0
  91. package/staging/lib/environment/environment-ground.d.ts +9 -0
  92. package/staging/lib/environment/environment-inputs.d.ts +28 -0
  93. package/staging/lib/environment/environment-map.d.ts +10 -0
  94. package/staging/lib/environment/environment-portal.d.ts +15 -0
  95. package/staging/lib/environment/environment.d.ts +12 -0
  96. package/staging/lib/environment/utils.d.ts +8 -0
  97. package/staging/lib/float/float.d.ts +16 -0
  98. package/staging/lib/sky/sky.d.ts +21 -0
  99. package/staging/lib/sparkles/sparkles.d.ts +29 -0
  100. package/staging/lib/stage/stage.d.ts +87 -0
  101. package/staging/lib/stars/stars.d.ts +20 -0
@@ -0,0 +1,13 @@
1
+ export { NgtsAccumulativeShadows } from './lib/accumulative-shadows/accumulative-shadows';
2
+ export { NgtsRandomizedLights } from './lib/accumulative-shadows/randomized-lights';
3
+ export * from './lib/bounds/bounds';
4
+ export * from './lib/center/center';
5
+ export * from './lib/contact-shadows/contact-shadows';
6
+ export * from './lib/environment/assets';
7
+ export * from './lib/environment/environment';
8
+ export * from './lib/float/float';
9
+ export * from './lib/sky/sky';
10
+ export * from './lib/sparkles/sparkles';
11
+ export * from './lib/stage/stage';
12
+ export * from './lib/stars/stars';
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUtc29iYS9zdGFnaW5nL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxpREFBaUQsQ0FBQztBQUMxRixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSw4Q0FBOEMsQ0FBQztBQUNwRixjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxtQkFBbUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IE5ndHNBY2N1bXVsYXRpdmVTaGFkb3dzIH0gZnJvbSAnLi9saWIvYWNjdW11bGF0aXZlLXNoYWRvd3MvYWNjdW11bGF0aXZlLXNoYWRvd3MnO1xuZXhwb3J0IHsgTmd0c1JhbmRvbWl6ZWRMaWdodHMgfSBmcm9tICcuL2xpYi9hY2N1bXVsYXRpdmUtc2hhZG93cy9yYW5kb21pemVkLWxpZ2h0cyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9ib3VuZHMvYm91bmRzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NlbnRlci9jZW50ZXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29udGFjdC1zaGFkb3dzL2NvbnRhY3Qtc2hhZG93cyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbnZpcm9ubWVudC9hc3NldHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZW52aXJvbm1lbnQvZW52aXJvbm1lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmxvYXQvZmxvYXQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2t5L3NreSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zcGFya2xlcy9zcGFya2xlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zdGFnZS9zdGFnZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zdGFycy9zdGFycyc7XG4iXX0=
@@ -0,0 +1,276 @@
1
+ import { Component, CUSTOM_ELEMENTS_SCHEMA, Directive, inject, InjectionToken, Input } from '@angular/core';
2
+ import { extend, getLocalState, injectBeforeRender, injectNgtRef, NgtRxStore, NgtStore } from 'angular-three';
3
+ import { shaderMaterial } from 'angular-three-soba/shaders';
4
+ import { combineLatest } from 'rxjs';
5
+ import * as THREE from 'three';
6
+ import { Group, Mesh, PlaneGeometry } from 'three';
7
+ import { ProgressiveLightMap } from './progressive-light-map';
8
+ import * as i0 from "@angular/core";
9
+ const SoftShadowMaterial = shaderMaterial({
10
+ color: new THREE.Color(),
11
+ blend: 2.0,
12
+ alphaTest: 0.75,
13
+ opacity: 0,
14
+ map: null,
15
+ },
16
+ // language=GLSL
17
+ `
18
+ varying vec2 vUv;
19
+ void main() {
20
+ gl_Position = projectionMatrix * viewMatrix * modeLMatrix * vec4(position, 1.);
21
+ vUv = uv;
22
+ }
23
+ `,
24
+ // language=GLSL
25
+ `
26
+ varying vec2 vUv;
27
+ uniform sampler2D map;
28
+ uniform vec3 color;
29
+ uniform float blend;
30
+ uniform float opacity;
31
+ uniform float alphaTest;
32
+ void main() {
33
+ vec4 sampleDiffuseColor = texture2D(map, vUv):
34
+ gl_FragColor = vec4(color * sampledDiffuseColor.r * blend, max(0.0, (1.0 - (sampledDiffuseColor.r + sampledDiffuseColor.g + sampledDiffuseColor.b) / alphaTest)) * opacity);
35
+ #include <tonemapping_fragment>
36
+ #include <encodings_fragment>
37
+ }
38
+ `);
39
+ extend({ SoftShadowMaterial, Group, Mesh, PlaneGeometry });
40
+ export const NGTS_ACCUMULATIVE_SHADOWS_API = new InjectionToken('NgtsAccumulativeShadows API');
41
+ function accumulativeShadowsApiFactory(accumulativeShadows) {
42
+ const store = inject(NgtStore);
43
+ const api = {
44
+ lights: new Map(),
45
+ count: 0,
46
+ getMesh: () => accumulativeShadows.meshRef.nativeElement,
47
+ reset: () => {
48
+ accumulativeShadows.pLM.clear();
49
+ const material = api.getMesh().material;
50
+ material.opacity = 0;
51
+ material.alphaTest = 0;
52
+ api.count = 0;
53
+ },
54
+ update: (frames = 1) => {
55
+ // adapt the opacity blend ratio to the number of frames
56
+ const material = api.getMesh().material;
57
+ if (!api.temporal) {
58
+ material.opacity = accumulativeShadows.get('opacity');
59
+ material.alphaTest = accumulativeShadows.get('alphaTest');
60
+ }
61
+ else {
62
+ material.opacity = Math.min(accumulativeShadows.get('opacity'), material.opacity + accumulativeShadows.get('opacity') / api.blend);
63
+ material.alphaTest = Math.min(accumulativeShadows.get('alphaTest'), material.alphaTest + accumulativeShadows.get('alphaTest') / api.blend);
64
+ }
65
+ // switch accumulative lights on
66
+ accumulativeShadows.accumulativeShadowsRef.nativeElement.visible = true;
67
+ // collect scene lights and meshes
68
+ accumulativeShadows.pLM.prepare();
69
+ // update the lightmap and the accumulative lights
70
+ for (let i = 0; i < frames; i++) {
71
+ api.lights.forEach((light) => light.update());
72
+ accumulativeShadows.pLM.update(store.get('camera'), api.blend);
73
+ }
74
+ // switch lights off
75
+ accumulativeShadows.accumulativeShadowsRef.nativeElement.visible = false;
76
+ // restore lights and meshes
77
+ accumulativeShadows.pLM.finish();
78
+ },
79
+ };
80
+ Object.defineProperties(api, {
81
+ temporal: {
82
+ get: () => !!accumulativeShadows.get('temporal'),
83
+ },
84
+ frames: {
85
+ get: () => Math.max(2, accumulativeShadows.get('frames')),
86
+ },
87
+ blend: {
88
+ get: () => Math.max(2, accumulativeShadows.get('frames') === Infinity
89
+ ? accumulativeShadows.get('blend')
90
+ : accumulativeShadows.get('frames')),
91
+ },
92
+ });
93
+ accumulativeShadows.hold(accumulativeShadows.meshRef.$, (mesh) => {
94
+ accumulativeShadows.pLM.configure(mesh);
95
+ accumulativeShadows.hold(combineLatest([accumulativeShadows.select(), getLocalState(store.get('scene')).objects]), () => {
96
+ // reset internals, buffers, ...
97
+ api.reset();
98
+ // update lightmap
99
+ if (!api.temporal && api.frames !== Infinity)
100
+ api.update(api.blend);
101
+ });
102
+ });
103
+ injectBeforeRender(() => {
104
+ const limit = accumulativeShadows.get('limit');
105
+ if (api.getMesh() && (api.temporal || api.frames === Infinity) && api.count < api.frames && api.count < limit) {
106
+ api.update();
107
+ api.count++;
108
+ }
109
+ });
110
+ return api;
111
+ }
112
+ export class AccumulativeShadowsConsumer {
113
+ constructor() {
114
+ inject(NGTS_ACCUMULATIVE_SHADOWS_API);
115
+ }
116
+ }
117
+ AccumulativeShadowsConsumer.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: AccumulativeShadowsConsumer, deps: [], target: i0.ɵɵFactoryTarget.Directive });
118
+ AccumulativeShadowsConsumer.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.3", type: AccumulativeShadowsConsumer, isStandalone: true, selector: "ngts-accumulative-shadows-consumer", ngImport: i0 });
119
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: AccumulativeShadowsConsumer, decorators: [{
120
+ type: Directive,
121
+ args: [{ selector: 'ngts-accumulative-shadows-consumer', standalone: true }]
122
+ }], ctorParameters: function () { return []; } });
123
+ export class NgtsAccumulativeShadows extends NgtRxStore {
124
+ constructor() {
125
+ super(...arguments);
126
+ this.nullTraverse = () => null;
127
+ this.Math = Math;
128
+ this.store = inject(NgtStore);
129
+ this.pLM = new ProgressiveLightMap(this.store.get('gl'), this.store.get('scene'), this.get('resolution'));
130
+ this.accumulativeShadowsRef = injectNgtRef();
131
+ this.meshRef = injectNgtRef();
132
+ }
133
+ /** How many frames it can render, more yields cleaner results but takes more time, 40 */
134
+ set frames(frames) {
135
+ this.set({ frames });
136
+ }
137
+ /** If frames === Infinity blend controls the refresh ratio, 100 */
138
+ set blend(blend) {
139
+ this.set({ blend });
140
+ }
141
+ /** Can limit the amount of frames rendered if frames === Infinity, usually to get some performance back once a movable scene has settled, Infinity */
142
+ set limit(limit) {
143
+ this.set({ limit });
144
+ }
145
+ /** Scale of the plane, */
146
+ set scale(scale) {
147
+ this.set({ scale });
148
+ }
149
+ /** Temporal accumulates shadows over time which is more performant but has a visual regression over instant results, false */
150
+ set temporal(temporal) {
151
+ this.set({ temporal });
152
+ }
153
+ /** Opacity of the plane, 1 */
154
+ set opacity(opacity) {
155
+ this.set({ opacity });
156
+ }
157
+ /** Discards alpha pixels, 0.65 */
158
+ set alphaTest(alphaTest) {
159
+ this.set({ alphaTest });
160
+ }
161
+ /** Shadow color, black */
162
+ set color(color) {
163
+ this.set({ color });
164
+ }
165
+ /** Colorblend, how much colors turn to black, 0 is black, 2 */
166
+ set colorBlend(colorBlend) {
167
+ this.set({ colorBlend });
168
+ }
169
+ /** Buffer resolution, 1024 */
170
+ set resolution(resolution) {
171
+ this.set({ resolution });
172
+ }
173
+ /** Texture tonemapping */
174
+ set toneMapped(toneMapped) {
175
+ this.set({ toneMapped });
176
+ }
177
+ initialize() {
178
+ super.initialize();
179
+ this.set({
180
+ frames: 40,
181
+ limit: Infinity,
182
+ blend: 20,
183
+ scale: 10,
184
+ opacity: 1,
185
+ alphaTest: 0.75,
186
+ color: 'black',
187
+ colorBlend: 2,
188
+ resolution: 1024,
189
+ toneMapped: true,
190
+ });
191
+ }
192
+ }
193
+ NgtsAccumulativeShadows.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsAccumulativeShadows, deps: null, target: i0.ɵɵFactoryTarget.Component });
194
+ NgtsAccumulativeShadows.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.3", 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: [
195
+ {
196
+ provide: NGTS_ACCUMULATIVE_SHADOWS_API,
197
+ useFactory: accumulativeShadowsApiFactory,
198
+ deps: [NgtsAccumulativeShadows],
199
+ },
200
+ ], usesInheritance: true, ngImport: i0, template: `
201
+ <ngt-group ngtCompound>
202
+ <ngt-group [ref]="accumulativeShadowsRef" [traverse]="nullTraverse">
203
+ <ng-content />
204
+ <ngts-accumulative-shadows-consumer />
205
+ </ngt-group>
206
+ <ngt-mesh [receiveShadow]="true" [ref]="meshRef" [scale]="get('scale')" [rotation]="[-Math.PI / 2, 0, 0]">
207
+ <ngt-plane-geometry />
208
+ <ngt-soft-shadow-material
209
+ [transparent]="true"
210
+ [depthWrite]="false"
211
+ [color]="get('color')"
212
+ [toneMapped]="get('toneMapped')"
213
+ [blend]="get('colorBlend')"
214
+ [map]="pLM.progressiveLightMap2.texture"
215
+ />
216
+ </ngt-mesh>
217
+ </ngt-group>
218
+ `, isInline: true, dependencies: [{ kind: "directive", type: AccumulativeShadowsConsumer, selector: "ngts-accumulative-shadows-consumer" }] });
219
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsAccumulativeShadows, decorators: [{
220
+ type: Component,
221
+ args: [{
222
+ selector: 'ngts-accumulative-shadows',
223
+ standalone: true,
224
+ template: `
225
+ <ngt-group ngtCompound>
226
+ <ngt-group [ref]="accumulativeShadowsRef" [traverse]="nullTraverse">
227
+ <ng-content />
228
+ <ngts-accumulative-shadows-consumer />
229
+ </ngt-group>
230
+ <ngt-mesh [receiveShadow]="true" [ref]="meshRef" [scale]="get('scale')" [rotation]="[-Math.PI / 2, 0, 0]">
231
+ <ngt-plane-geometry />
232
+ <ngt-soft-shadow-material
233
+ [transparent]="true"
234
+ [depthWrite]="false"
235
+ [color]="get('color')"
236
+ [toneMapped]="get('toneMapped')"
237
+ [blend]="get('colorBlend')"
238
+ [map]="pLM.progressiveLightMap2.texture"
239
+ />
240
+ </ngt-mesh>
241
+ </ngt-group>
242
+ `,
243
+ imports: [AccumulativeShadowsConsumer],
244
+ providers: [
245
+ {
246
+ provide: NGTS_ACCUMULATIVE_SHADOWS_API,
247
+ useFactory: accumulativeShadowsApiFactory,
248
+ deps: [NgtsAccumulativeShadows],
249
+ },
250
+ ],
251
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
252
+ }]
253
+ }], propDecorators: { frames: [{
254
+ type: Input
255
+ }], blend: [{
256
+ type: Input
257
+ }], limit: [{
258
+ type: Input
259
+ }], scale: [{
260
+ type: Input
261
+ }], temporal: [{
262
+ type: Input
263
+ }], opacity: [{
264
+ type: Input
265
+ }], alphaTest: [{
266
+ type: Input
267
+ }], color: [{
268
+ type: Input
269
+ }], colorBlend: [{
270
+ type: Input
271
+ }], resolution: [{
272
+ type: Input
273
+ }], toneMapped: [{
274
+ type: Input
275
+ }] } });
276
+ //# 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, injectBeforeRender, injectNgtRef, NgtRxStore, NgtStore } from 'angular-three';\nimport { shaderMaterial } from 'angular-three-soba/shaders';\nimport { combineLatest } from 'rxjs';\nimport * as THREE from 'three';\nimport { Group, Mesh, PlaneGeometry } from 'three';\nimport { ProgressiveLightMap } from './progressive-light-map';\n\nconst SoftShadowMaterial = shaderMaterial(\n    {\n        color: new THREE.Color(),\n        blend: 2.0,\n        alphaTest: 0.75,\n        opacity: 0,\n        map: null,\n    },\n    // language=GLSL\n    `\nvarying vec2 vUv;\nvoid main() {\n  gl_Position = projectionMatrix * viewMatrix * modeLMatrix * vec4(position, 1.);\n  vUv = uv;\n}\n  `,\n    // language=GLSL\n    `\nvarying vec2 vUv;\nuniform sampler2D map;\nuniform vec3 color;\nuniform float blend;\nuniform float opacity;\nuniform float alphaTest;\nvoid main() {\n  vec4 sampleDiffuseColor = texture2D(map, vUv):\n  gl_FragColor = vec4(color * sampledDiffuseColor.r * blend, max(0.0, (1.0 - (sampledDiffuseColor.r + sampledDiffuseColor.g + sampledDiffuseColor.b) / alphaTest)) * opacity);\n  #include <tonemapping_fragment>\n  #include <encodings_fragment>\n}\n  `\n);\n\ntype SoftShadowMaterialInputs = {\n    map: THREE.Texture;\n    color?: THREE.ColorRepresentation;\n    alphaTest?: number;\n    blend?: number;\n};\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    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\n    injectBeforeRender(() => {\n        const limit = accumulativeShadows.get('limit');\n        if (api.getMesh() && (api.temporal || api.frames === Infinity) && api.count < api.frames && api.count < limit) {\n            api.update();\n            api.count++;\n        }\n    });\n\n    return api;\n}\n\n@Directive({ selector: 'ngts-accumulative-shadows-consumer', 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                <ngts-accumulative-shadows-consumer />\n            </ngt-group>\n            <ngt-mesh [receiveShadow]=\"true\" [ref]=\"meshRef\" [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,109 @@
1
+ import { shaderMaterial } from 'angular-three-soba/shaders';
2
+ import * as THREE from 'three';
3
+ function isLight(object) {
4
+ return object.isLight;
5
+ }
6
+ function isGeometry(object) {
7
+ return !!object.geometry;
8
+ }
9
+ const DiscardMaterial = shaderMaterial({}, 'void main() { gl_Position = vec4((uv - 0.5) * 2.0, 1.0, 1.0); }', 'void main() { discard; }');
10
+ export class ProgressiveLightMap {
11
+ constructor(renderer, scene, res = 1024) {
12
+ this.renderer = renderer;
13
+ this.res = res;
14
+ this.scene = scene;
15
+ this.buffer1Active = false;
16
+ this.lights = [];
17
+ this.meshes = [];
18
+ this.object = null;
19
+ this.clearColor = new THREE.Color();
20
+ this.clearAlpha = 0;
21
+ // Create the Progressive LightMap Texture
22
+ const format = /(Android|iPad|iPhone|iPod)/g.test(navigator.userAgent) ? THREE.HalfFloatType : THREE.FloatType;
23
+ this.progressiveLightMap1 = new THREE.WebGLRenderTarget(this.res, this.res, {
24
+ type: format,
25
+ encoding: renderer.outputEncoding,
26
+ });
27
+ this.progressiveLightMap2 = new THREE.WebGLRenderTarget(this.res, this.res, {
28
+ type: format,
29
+ encoding: renderer.outputEncoding,
30
+ });
31
+ // Inject some spicy new logic into a standard phong material
32
+ this.discardMat = new DiscardMaterial();
33
+ this.targetMat = new THREE.MeshLambertMaterial({ fog: false });
34
+ this.previousShadowMap = { value: this.progressiveLightMap1.texture };
35
+ this.averagingWindow = { value: 100 };
36
+ this.targetMat.onBeforeCompile = (shader) => {
37
+ // Vertex Shader: Set Vertex Positions to the Unwrapped UV Positions
38
+ shader.vertexShader =
39
+ 'varying vec2 vUv;\n' +
40
+ shader.vertexShader.slice(0, -1) +
41
+ 'vUv = uv; gl_Position = vec4((uv - 0.5) * 2.0, 1.0, 1.0); }';
42
+ // Fragment Shader: Set Pixels to average in the Previous frame's Shadows
43
+ const bodyStart = shader.fragmentShader.indexOf('void main() {');
44
+ shader.fragmentShader =
45
+ 'varying vec2 vUv;\n' +
46
+ shader.fragmentShader.slice(0, bodyStart) +
47
+ 'uniform sampler2D previousShadowMap;\n uniform float averagingWindow;\n' +
48
+ shader.fragmentShader.slice(bodyStart - 1, -1) +
49
+ `\nvec3 texelOld = texture2D(previousShadowMap, vUv).rgb;
50
+ gl_FragColor.rgb = mix(texelOld, gl_FragColor.rgb, 1.0/ averagingWindow);
51
+ }`;
52
+ // Set the Previous Frame's Texture Buffer and Averaging Window
53
+ shader.uniforms['previousShadowMap'] = this.previousShadowMap;
54
+ shader.uniforms['averagingWindow'] = this.averagingWindow;
55
+ };
56
+ }
57
+ clear() {
58
+ this.renderer.getClearColor(this.clearColor);
59
+ this.clearAlpha = this.renderer.getClearAlpha();
60
+ this.renderer.setClearColor('black', 1);
61
+ this.renderer.setRenderTarget(this.progressiveLightMap1);
62
+ this.renderer.clear();
63
+ this.renderer.setRenderTarget(this.progressiveLightMap2);
64
+ this.renderer.clear();
65
+ this.renderer.setRenderTarget(null);
66
+ this.renderer.setClearColor(this.clearColor, this.clearAlpha);
67
+ this.lights = [];
68
+ this.meshes = [];
69
+ this.scene.traverse((object) => {
70
+ if (isGeometry(object)) {
71
+ this.meshes.push({ object, material: object.material });
72
+ }
73
+ else if (isLight(object)) {
74
+ this.lights.push({ object, intensity: object.intensity });
75
+ }
76
+ });
77
+ }
78
+ prepare() {
79
+ this.lights.forEach((light) => (light.object.intensity = 0));
80
+ this.meshes.forEach((mesh) => (mesh.object.material = this.discardMat));
81
+ }
82
+ finish() {
83
+ this.lights.forEach((light) => (light.object.intensity = light.intensity));
84
+ this.meshes.forEach((mesh) => (mesh.object.material = mesh.material));
85
+ }
86
+ configure(object) {
87
+ this.object = object;
88
+ }
89
+ update(camera, blendWindow = 100) {
90
+ if (!this.object)
91
+ return;
92
+ // Set each object's material to the UV Unwrapped Surface Mapping Version
93
+ this.averagingWindow.value = blendWindow;
94
+ this.object.material = this.targetMat;
95
+ // Ping-pong two surface buffers for reading/writing
96
+ const activeMap = this.buffer1Active ? this.progressiveLightMap1 : this.progressiveLightMap2;
97
+ const inactiveMap = this.buffer1Active ? this.progressiveLightMap2 : this.progressiveLightMap1;
98
+ // Render the object's surface maps
99
+ const oldBg = this.scene.background;
100
+ this.scene.background = null;
101
+ this.renderer.setRenderTarget(activeMap);
102
+ this.previousShadowMap.value = inactiveMap.texture;
103
+ this.buffer1Active = !this.buffer1Active;
104
+ this.renderer.render(this.scene, camera);
105
+ this.renderer.setRenderTarget(null);
106
+ this.scene.background = oldBg;
107
+ }
108
+ }
109
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"progressive-light-map.js","sourceRoot":"","sources":["../../../../../../../libs/angular-three-soba/staging/src/lib/accumulative-shadows/progressive-light-map.ts"],"names":[],"mappings":"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","sourcesContent":["import { shaderMaterial } from 'angular-three-soba/shaders';\nimport * as THREE from 'three';\n\nfunction isLight(object: any): object is THREE.Light {\n    return object.isLight;\n}\n\nfunction isGeometry(object: any): object is THREE.Mesh {\n    return !!object.geometry;\n}\n\nconst DiscardMaterial = shaderMaterial(\n    {},\n    'void main() { gl_Position = vec4((uv - 0.5) * 2.0, 1.0, 1.0); }',\n    'void main() { discard; }'\n);\n\nexport class ProgressiveLightMap {\n    renderer: THREE.WebGLRenderer;\n    res: number;\n    scene: THREE.Scene;\n    object: THREE.Mesh | null;\n    buffer1Active: boolean;\n    progressiveLightMap1: THREE.WebGLRenderTarget;\n    progressiveLightMap2: THREE.WebGLRenderTarget;\n    discardMat: THREE.ShaderMaterial;\n    targetMat: THREE.MeshLambertMaterial;\n    previousShadowMap: { value: THREE.Texture };\n    averagingWindow: { value: number };\n    clearColor: THREE.Color;\n    clearAlpha: number;\n    lights: { object: THREE.Light; intensity: number }[];\n    meshes: { object: THREE.Mesh; material: THREE.Material | THREE.Material[] }[];\n\n    constructor(renderer: THREE.WebGLRenderer, scene: THREE.Scene, res: number = 1024) {\n        this.renderer = renderer;\n        this.res = res;\n        this.scene = scene;\n        this.buffer1Active = false;\n        this.lights = [];\n        this.meshes = [];\n        this.object = null;\n        this.clearColor = new THREE.Color();\n        this.clearAlpha = 0;\n\n        // Create the Progressive LightMap Texture\n        const format = /(Android|iPad|iPhone|iPod)/g.test(navigator.userAgent) ? THREE.HalfFloatType : THREE.FloatType;\n        this.progressiveLightMap1 = new THREE.WebGLRenderTarget(this.res, this.res, {\n            type: format,\n            encoding: renderer.outputEncoding,\n        });\n        this.progressiveLightMap2 = new THREE.WebGLRenderTarget(this.res, this.res, {\n            type: format,\n            encoding: renderer.outputEncoding,\n        });\n\n        // Inject some spicy new logic into a standard phong material\n        this.discardMat = new DiscardMaterial();\n        this.targetMat = new THREE.MeshLambertMaterial({ fog: false });\n        this.previousShadowMap = { value: this.progressiveLightMap1.texture };\n        this.averagingWindow = { value: 100 };\n        this.targetMat.onBeforeCompile = (shader) => {\n            // Vertex Shader: Set Vertex Positions to the Unwrapped UV Positions\n            shader.vertexShader =\n                'varying vec2 vUv;\\n' +\n                shader.vertexShader.slice(0, -1) +\n                'vUv = uv; gl_Position = vec4((uv - 0.5) * 2.0, 1.0, 1.0); }';\n\n            // Fragment Shader: Set Pixels to average in the Previous frame's Shadows\n            const bodyStart = shader.fragmentShader.indexOf('void main() {');\n            shader.fragmentShader =\n                'varying vec2 vUv;\\n' +\n                shader.fragmentShader.slice(0, bodyStart) +\n                'uniform sampler2D previousShadowMap;\\n\tuniform float averagingWindow;\\n' +\n                shader.fragmentShader.slice(bodyStart - 1, -1) +\n                `\\nvec3 texelOld = texture2D(previousShadowMap, vUv).rgb;\n        gl_FragColor.rgb = mix(texelOld, gl_FragColor.rgb, 1.0/ averagingWindow);\n      }`;\n\n            // Set the Previous Frame's Texture Buffer and Averaging Window\n            shader.uniforms['previousShadowMap'] = this.previousShadowMap;\n            shader.uniforms['averagingWindow'] = this.averagingWindow;\n        };\n    }\n\n    clear() {\n        this.renderer.getClearColor(this.clearColor);\n        this.clearAlpha = this.renderer.getClearAlpha();\n        this.renderer.setClearColor('black', 1);\n        this.renderer.setRenderTarget(this.progressiveLightMap1);\n        this.renderer.clear();\n        this.renderer.setRenderTarget(this.progressiveLightMap2);\n        this.renderer.clear();\n        this.renderer.setRenderTarget(null);\n        this.renderer.setClearColor(this.clearColor, this.clearAlpha);\n\n        this.lights = [];\n        this.meshes = [];\n        this.scene.traverse((object) => {\n            if (isGeometry(object)) {\n                this.meshes.push({ object, material: object.material });\n            } else if (isLight(object)) {\n                this.lights.push({ object, intensity: object.intensity });\n            }\n        });\n    }\n\n    prepare() {\n        this.lights.forEach((light) => (light.object.intensity = 0));\n        this.meshes.forEach((mesh) => (mesh.object.material = this.discardMat));\n    }\n\n    finish() {\n        this.lights.forEach((light) => (light.object.intensity = light.intensity));\n        this.meshes.forEach((mesh) => (mesh.object.material = mesh.material));\n    }\n\n    configure(object: any) {\n        this.object = object;\n    }\n\n    update(camera: any, blendWindow = 100) {\n        if (!this.object) return;\n        // Set each object's material to the UV Unwrapped Surface Mapping Version\n        this.averagingWindow.value = blendWindow;\n        this.object.material = this.targetMat;\n        // Ping-pong two surface buffers for reading/writing\n        const activeMap = this.buffer1Active ? this.progressiveLightMap1 : this.progressiveLightMap2;\n        const inactiveMap = this.buffer1Active ? this.progressiveLightMap2 : this.progressiveLightMap1;\n        // Render the object's surface maps\n        const oldBg = this.scene.background;\n        this.scene.background = null;\n        this.renderer.setRenderTarget(activeMap);\n        this.previousShadowMap.value = inactiveMap.texture;\n        this.buffer1Active = !this.buffer1Active;\n        this.renderer.render(this.scene, camera);\n        this.renderer.setRenderTarget(null);\n        this.scene.background = oldBg;\n    }\n}\n"]}