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,142 @@
1
+ import { Component, CUSTOM_ELEMENTS_SCHEMA, EventEmitter, Input, Output } from '@angular/core';
2
+ import { extend, injectNgtRef, NgtRxStore } from 'angular-three';
3
+ import { combineLatest } from 'rxjs';
4
+ import { Box3, Group, Sphere, Vector3 } from 'three';
5
+ import * as i0 from "@angular/core";
6
+ extend({ Group });
7
+ export class NgtsCenter extends NgtRxStore {
8
+ constructor() {
9
+ super(...arguments);
10
+ this.centerRef = injectNgtRef();
11
+ this.outerRef = injectNgtRef();
12
+ this.innerRef = injectNgtRef();
13
+ this.centered = new EventEmitter();
14
+ }
15
+ set top(top) {
16
+ this.set({ top });
17
+ }
18
+ set right(right) {
19
+ this.set({ right });
20
+ }
21
+ set bottom(bottom) {
22
+ this.set({ bottom });
23
+ }
24
+ set left(left) {
25
+ this.set({ left });
26
+ }
27
+ set front(front) {
28
+ this.set({ front });
29
+ }
30
+ set back(back) {
31
+ this.set({ back });
32
+ }
33
+ set disableX(disableX) {
34
+ this.set({ disableX });
35
+ }
36
+ set disableY(disableY) {
37
+ this.set({ disableY });
38
+ }
39
+ set disableZ(disableZ) {
40
+ this.set({ disableZ });
41
+ }
42
+ set disabled(disabled) {
43
+ this.set({ disabled });
44
+ }
45
+ set precise(precise) {
46
+ this.set({ precise });
47
+ }
48
+ initialize() {
49
+ super.initialize();
50
+ this.set({ precise: true });
51
+ }
52
+ ngOnInit() {
53
+ this.setPosition();
54
+ }
55
+ setPosition() {
56
+ this.hold(combineLatest([this.innerRef.$, this.innerRef.children$()]), ([innerGroup]) => {
57
+ const { precise, top, left, front, disabled, disableX, disableY, disableZ, back, bottom, right } = this.get();
58
+ this.outerRef.nativeElement.matrixWorld.identity();
59
+ const box3 = new Box3().setFromObject(innerGroup, precise);
60
+ const center = new Vector3();
61
+ const sphere = new Sphere();
62
+ const width = box3.max.x - box3.min.x;
63
+ const height = box3.max.y - box3.min.y;
64
+ const depth = box3.max.z - box3.min.z;
65
+ box3.getCenter(center);
66
+ box3.getBoundingSphere(sphere);
67
+ const vAlign = top ? height / 2 : bottom ? -height / 2 : 0;
68
+ const hAlign = left ? -width / 2 : right ? width / 2 : 0;
69
+ const dAlign = front ? depth / 2 : back ? -depth / 2 : 0;
70
+ this.outerRef.nativeElement.position.set(disabled || disableX ? 0 : -center.x + hAlign, disabled || disableY ? 0 : -center.y + vAlign, disabled || disableZ ? 0 : -center.z + dAlign);
71
+ if (this.centered.observed) {
72
+ this.centered.emit({
73
+ parent: this.centerRef.nativeElement.parent,
74
+ container: this.centerRef.nativeElement,
75
+ width,
76
+ height,
77
+ depth,
78
+ boundingBox: box3,
79
+ boundingSphere: sphere,
80
+ center: center,
81
+ verticalAlignment: vAlign,
82
+ horizontalAlignment: hAlign,
83
+ depthAlignment: dAlign,
84
+ });
85
+ }
86
+ });
87
+ }
88
+ }
89
+ NgtsCenter.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsCenter, deps: null, target: i0.ɵɵFactoryTarget.Component });
90
+ NgtsCenter.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.3", type: NgtsCenter, isStandalone: true, selector: "ngts-center", inputs: { centerRef: "centerRef", top: "top", right: "right", bottom: "bottom", left: "left", front: "front", back: "back", disableX: "disableX", disableY: "disableY", disableZ: "disableZ", disabled: "disabled", precise: "precise" }, outputs: { centered: "centered" }, usesInheritance: true, ngImport: i0, template: `
91
+ <ngt-group ngtCompound [ref]="centerRef">
92
+ <ngt-group [ref]="outerRef">
93
+ <ngt-group [ref]="innerRef">
94
+ <ng-content />
95
+ </ngt-group>
96
+ </ngt-group>
97
+ </ngt-group>
98
+ `, isInline: true });
99
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsCenter, decorators: [{
100
+ type: Component,
101
+ args: [{
102
+ selector: 'ngts-center',
103
+ standalone: true,
104
+ template: `
105
+ <ngt-group ngtCompound [ref]="centerRef">
106
+ <ngt-group [ref]="outerRef">
107
+ <ngt-group [ref]="innerRef">
108
+ <ng-content />
109
+ </ngt-group>
110
+ </ngt-group>
111
+ </ngt-group>
112
+ `,
113
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
114
+ }]
115
+ }], propDecorators: { centerRef: [{
116
+ type: Input
117
+ }], top: [{
118
+ type: Input
119
+ }], right: [{
120
+ type: Input
121
+ }], bottom: [{
122
+ type: Input
123
+ }], left: [{
124
+ type: Input
125
+ }], front: [{
126
+ type: Input
127
+ }], back: [{
128
+ type: Input
129
+ }], disableX: [{
130
+ type: Input
131
+ }], disableY: [{
132
+ type: Input
133
+ }], disableZ: [{
134
+ type: Input
135
+ }], disabled: [{
136
+ type: Input
137
+ }], precise: [{
138
+ type: Input
139
+ }], centered: [{
140
+ type: Output
141
+ }] } });
142
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"center.js","sourceRoot":"","sources":["../../../../../../../libs/angular-three-soba/staging/src/lib/center/center.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, CUSTOM_ELEMENTS_SCHEMA, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { extend, injectNgtRef, NgtRxStore } from 'angular-three';\nimport { combineLatest } from 'rxjs';\nimport { Box3, Group, Sphere, Vector3 } from 'three';\n\nextend({ Group });\n\n@Component({\n    selector: 'ngts-center',\n    standalone: true,\n    template: `\n        <ngt-group ngtCompound [ref]=\"centerRef\">\n            <ngt-group [ref]=\"outerRef\">\n                <ngt-group [ref]=\"innerRef\">\n                    <ng-content />\n                </ngt-group>\n            </ngt-group>\n        </ngt-group>\n    `,\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsCenter extends NgtRxStore implements OnInit {\n    @Input() centerRef = injectNgtRef<Group>();\n\n    readonly outerRef = injectNgtRef<Group>();\n    readonly innerRef = injectNgtRef<Group>();\n\n    @Input() set top(top: boolean) {\n        this.set({ top });\n    }\n\n    @Input() set right(right: boolean) {\n        this.set({ right });\n    }\n\n    @Input() set bottom(bottom: boolean) {\n        this.set({ bottom });\n    }\n\n    @Input() set left(left: boolean) {\n        this.set({ left });\n    }\n\n    @Input() set front(front: boolean) {\n        this.set({ front });\n    }\n\n    @Input() set back(back: boolean) {\n        this.set({ back });\n    }\n\n    @Input() set disableX(disableX: boolean) {\n        this.set({ disableX });\n    }\n\n    @Input() set disableY(disableY: boolean) {\n        this.set({ disableY });\n    }\n\n    @Input() set disableZ(disableZ: boolean) {\n        this.set({ disableZ });\n    }\n\n    @Input() set disabled(disabled: boolean) {\n        this.set({ disabled });\n    }\n\n    @Input() set precise(precise: boolean) {\n        this.set({ precise });\n    }\n\n    @Output() centered = new EventEmitter<{\n        /** The next parent above <Center> */\n        parent: THREE.Object3D;\n        /** The outmost container group of the <Center> component */\n        container: THREE.Object3D;\n        width: number;\n        height: number;\n        depth: number;\n        boundingBox: THREE.Box3;\n        boundingSphere: THREE.Sphere;\n        center: THREE.Vector3;\n        verticalAlignment: number;\n        horizontalAlignment: number;\n        depthAlignment: number;\n    }>();\n\n    override initialize(): void {\n        super.initialize();\n        this.set({ precise: true });\n    }\n\n    ngOnInit(): void {\n        this.setPosition();\n    }\n\n    private setPosition() {\n        this.hold(combineLatest([this.innerRef.$, this.innerRef.children$()]), ([innerGroup]) => {\n            const { precise, top, left, front, disabled, disableX, disableY, disableZ, back, bottom, right } =\n                this.get();\n            this.outerRef.nativeElement.matrixWorld.identity();\n            const box3 = new Box3().setFromObject(innerGroup, precise);\n            const center = new Vector3();\n            const sphere = new Sphere();\n            const width = box3.max.x - box3.min.x;\n            const height = box3.max.y - box3.min.y;\n            const depth = box3.max.z - box3.min.z;\n\n            box3.getCenter(center);\n            box3.getBoundingSphere(sphere);\n\n            const vAlign = top ? height / 2 : bottom ? -height / 2 : 0;\n            const hAlign = left ? -width / 2 : right ? width / 2 : 0;\n            const dAlign = front ? depth / 2 : back ? -depth / 2 : 0;\n\n            this.outerRef.nativeElement.position.set(\n                disabled || disableX ? 0 : -center.x + hAlign,\n                disabled || disableY ? 0 : -center.y + vAlign,\n                disabled || disableZ ? 0 : -center.z + dAlign\n            );\n\n            if (this.centered.observed) {\n                this.centered.emit({\n                    parent: this.centerRef.nativeElement.parent!,\n                    container: this.centerRef.nativeElement,\n                    width,\n                    height,\n                    depth,\n                    boundingBox: box3,\n                    boundingSphere: sphere,\n                    center: center,\n                    verticalAlignment: vAlign,\n                    horizontalAlignment: hAlign,\n                    depthAlignment: dAlign,\n                });\n            }\n        });\n    }\n}\n"]}
@@ -0,0 +1,227 @@
1
+ import { NgIf } from '@angular/common';
2
+ import { Component, CUSTOM_ELEMENTS_SCHEMA, inject, Input } from '@angular/core';
3
+ import { extend, injectBeforeRender, injectNgtRef, NgtArgs, NgtPush, NgtRxStore, NgtStore, } from 'angular-three';
4
+ import * as THREE from 'three';
5
+ import { Group, Mesh, MeshBasicMaterial, OrthographicCamera } from 'three';
6
+ import { HorizontalBlurShader, VerticalBlurShader } from 'three-stdlib';
7
+ import * as i0 from "@angular/core";
8
+ extend({ Group, Mesh, MeshBasicMaterial, OrthographicCamera });
9
+ export class NgtsContactShadows extends NgtRxStore {
10
+ set opacity(opacity) {
11
+ this.set({ opacity });
12
+ }
13
+ set width(width) {
14
+ this.set({ width });
15
+ }
16
+ set height(height) {
17
+ this.set({ height });
18
+ }
19
+ set blur(blur) {
20
+ this.set({ blur });
21
+ }
22
+ set far(far) {
23
+ this.set({ far });
24
+ }
25
+ set smooth(smooth) {
26
+ this.set({ smooth });
27
+ }
28
+ set resolution(resolution) {
29
+ this.set({ resolution });
30
+ }
31
+ set frames(frames) {
32
+ this.set({ frames });
33
+ }
34
+ set scale(scale) {
35
+ this.set({ scale });
36
+ }
37
+ set color(color) {
38
+ this.set({ color });
39
+ }
40
+ set depthWrite(depthWrite) {
41
+ this.set({ depthWrite });
42
+ }
43
+ set renderOrder(renderOrder) {
44
+ this.set({ renderOrder });
45
+ }
46
+ constructor() {
47
+ super();
48
+ this.store = inject(NgtStore);
49
+ this.shadowCameraRef = injectNgtRef();
50
+ this.encoding = this.store.get('gl', 'outputEncoding');
51
+ this.contactShadows$ = this.select('contactShadows');
52
+ this.Math = Math;
53
+ this.contactShadowsRef = injectNgtRef();
54
+ injectBeforeRender(this.onBeforeRender.bind(this, 0));
55
+ }
56
+ initialize() {
57
+ super.initialize();
58
+ this.set({
59
+ scale: 10,
60
+ frames: Infinity,
61
+ opacity: 1,
62
+ width: 1,
63
+ height: 1,
64
+ blur: 1,
65
+ far: 10,
66
+ resolution: 512,
67
+ smooth: true,
68
+ color: '#000000',
69
+ depthWrite: false,
70
+ renderOrder: 0,
71
+ });
72
+ this.connect('scaledWidth', this.select(['width', 'scale'], ({ width, scale }) => width * (Array.isArray(scale) ? scale[0] : scale || 1)));
73
+ this.connect('scaledHeight', this.select(['height', 'scale'], ({ height, scale }) => height * (Array.isArray(scale) ? scale[1] : scale || 1)));
74
+ this.connect('cameraArgs', this.select(['scaledWidth', 'scaledHeight', 'far'], ({ scaledWidth: width, scaledHeight: height, far }) => {
75
+ return [-width / 2, width / 2, height / 2, -height / 2, 0, far];
76
+ }));
77
+ this.connect('contactShadows', this.select(['resolution', 'scaledWidth', 'scaledHeight', 'scale', 'color'], ({ resolution, scaledWidth: width, scaledHeight: height, color }) => {
78
+ const renderTarget = new THREE.WebGLRenderTarget(resolution, resolution);
79
+ const renderTargetBlur = new THREE.WebGLRenderTarget(resolution, resolution);
80
+ renderTargetBlur.texture.generateMipmaps = renderTarget.texture.generateMipmaps = false;
81
+ const planeGeometry = new THREE.PlaneGeometry(width, height).rotateX(Math.PI / 2);
82
+ const blurPlane = new Mesh(planeGeometry);
83
+ const depthMaterial = new THREE.MeshDepthMaterial();
84
+ depthMaterial.depthTest = depthMaterial.depthWrite = false;
85
+ depthMaterial.onBeforeCompile = (shader) => {
86
+ shader.uniforms = {
87
+ ...shader.uniforms,
88
+ ucolor: { value: new THREE.Color(color) },
89
+ };
90
+ shader.fragmentShader = shader.fragmentShader.replace(`void main() {`, //
91
+ `uniform vec3 ucolor;
92
+ void main() {
93
+ `);
94
+ shader.fragmentShader = shader.fragmentShader.replace('vec4( vec3( 1.0 - fragCoordZ ), opacity );',
95
+ // Colorize the shadow, multiply by the falloff so that the center can remain darker
96
+ 'vec4( ucolor * fragCoordZ * 2.0, ( 1.0 - fragCoordZ ) * 1.0 );');
97
+ };
98
+ const horizontalBlurMaterial = new THREE.ShaderMaterial(HorizontalBlurShader);
99
+ const verticalBlurMaterial = new THREE.ShaderMaterial(VerticalBlurShader);
100
+ verticalBlurMaterial.depthTest = horizontalBlurMaterial.depthTest = false;
101
+ return {
102
+ renderTarget,
103
+ planeGeometry,
104
+ depthMaterial,
105
+ blurPlane,
106
+ horizontalBlurMaterial,
107
+ verticalBlurMaterial,
108
+ renderTargetBlur,
109
+ };
110
+ }));
111
+ }
112
+ onBeforeRender(count, { scene, gl }) {
113
+ const { frames, blur, contactShadows: { depthMaterial, renderTarget }, smooth, } = this.get();
114
+ if (this.shadowCameraRef.nativeElement && (frames === Infinity || count < frames)) {
115
+ const initialBackground = scene.background;
116
+ scene.background = null;
117
+ const initialOverrideMaterial = scene.overrideMaterial;
118
+ scene.overrideMaterial = depthMaterial;
119
+ gl.setRenderTarget(renderTarget);
120
+ gl.render(scene, this.shadowCameraRef.nativeElement);
121
+ scene.overrideMaterial = initialOverrideMaterial;
122
+ this.blurShadows(blur);
123
+ if (smooth)
124
+ this.blurShadows(blur * 0.4);
125
+ gl.setRenderTarget(null);
126
+ scene.background = initialBackground;
127
+ count++;
128
+ }
129
+ }
130
+ blurShadows(blur) {
131
+ const { blurPlane, horizontalBlurMaterial, verticalBlurMaterial, renderTargetBlur, renderTarget } = this.get('contactShadows');
132
+ const gl = this.store.get('gl');
133
+ blurPlane.visible = true;
134
+ blurPlane.material = horizontalBlurMaterial;
135
+ horizontalBlurMaterial.uniforms.tDiffuse.value = renderTarget.texture;
136
+ horizontalBlurMaterial.uniforms.h.value = (blur * 1) / 256;
137
+ gl.setRenderTarget(renderTargetBlur);
138
+ gl.render(blurPlane, this.shadowCameraRef.nativeElement);
139
+ blurPlane.material = verticalBlurMaterial;
140
+ verticalBlurMaterial.uniforms.tDiffuse.value = renderTargetBlur.texture;
141
+ verticalBlurMaterial.uniforms.v.value = (blur * 1) / 256;
142
+ gl.setRenderTarget(renderTarget);
143
+ gl.render(blurPlane, this.shadowCameraRef.nativeElement);
144
+ blurPlane.visible = false;
145
+ }
146
+ }
147
+ NgtsContactShadows.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsContactShadows, deps: [], target: i0.ɵɵFactoryTarget.Component });
148
+ NgtsContactShadows.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.3", type: NgtsContactShadows, isStandalone: true, selector: "ngts-contact-shadows", inputs: { contactShadowsRef: "contactShadowsRef", opacity: "opacity", width: "width", height: "height", blur: "blur", far: "far", smooth: "smooth", resolution: "resolution", frames: "frames", scale: "scale", color: "color", depthWrite: "depthWrite", renderOrder: "renderOrder" }, usesInheritance: true, ngImport: i0, template: `
149
+ <ngt-group ngtCompound [ref]="contactShadowsRef" [rotation]="[Math.PI / 2, 0, 0]">
150
+ <ng-container *ngIf="contactShadows$ | ngtPush : null as contactShadows">
151
+ <ngt-mesh
152
+ [renderOrder]="get('renderOrder')"
153
+ [geometry]="contactShadows.planeGeometry"
154
+ [scale]="[1, -1, 1]"
155
+ [rotation]="[-Math.PI / 2, 0, 0]"
156
+ >
157
+ <ngt-mesh-basic-material
158
+ [map]="contactShadows.renderTarget.texture"
159
+ transparent
160
+ [opacity]="get('opacity')"
161
+ [depthWrite]="get('depthWrite')"
162
+ >
163
+ <ngt-value [rawValue]="encoding" attach="map.encoding" />
164
+ </ngt-mesh-basic-material>
165
+ </ngt-mesh>
166
+ <ngt-orthographic-camera *args="get('cameraArgs')" [ref]="shadowCameraRef" />
167
+ </ng-container>
168
+ </ngt-group>
169
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: NgtPush, name: "ngtPush" }, { kind: "directive", type: NgtArgs, selector: "[args]", inputs: ["args"] }] });
170
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsContactShadows, decorators: [{
171
+ type: Component,
172
+ args: [{
173
+ selector: 'ngts-contact-shadows',
174
+ standalone: true,
175
+ template: `
176
+ <ngt-group ngtCompound [ref]="contactShadowsRef" [rotation]="[Math.PI / 2, 0, 0]">
177
+ <ng-container *ngIf="contactShadows$ | ngtPush : null as contactShadows">
178
+ <ngt-mesh
179
+ [renderOrder]="get('renderOrder')"
180
+ [geometry]="contactShadows.planeGeometry"
181
+ [scale]="[1, -1, 1]"
182
+ [rotation]="[-Math.PI / 2, 0, 0]"
183
+ >
184
+ <ngt-mesh-basic-material
185
+ [map]="contactShadows.renderTarget.texture"
186
+ transparent
187
+ [opacity]="get('opacity')"
188
+ [depthWrite]="get('depthWrite')"
189
+ >
190
+ <ngt-value [rawValue]="encoding" attach="map.encoding" />
191
+ </ngt-mesh-basic-material>
192
+ </ngt-mesh>
193
+ <ngt-orthographic-camera *args="get('cameraArgs')" [ref]="shadowCameraRef" />
194
+ </ng-container>
195
+ </ngt-group>
196
+ `,
197
+ imports: [NgIf, NgtPush, NgtArgs],
198
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
199
+ }]
200
+ }], ctorParameters: function () { return []; }, propDecorators: { contactShadowsRef: [{
201
+ type: Input
202
+ }], opacity: [{
203
+ type: Input
204
+ }], width: [{
205
+ type: Input
206
+ }], height: [{
207
+ type: Input
208
+ }], blur: [{
209
+ type: Input
210
+ }], far: [{
211
+ type: Input
212
+ }], smooth: [{
213
+ type: Input
214
+ }], resolution: [{
215
+ type: Input
216
+ }], frames: [{
217
+ type: Input
218
+ }], scale: [{
219
+ type: Input
220
+ }], color: [{
221
+ type: Input
222
+ }], depthWrite: [{
223
+ type: Input
224
+ }], renderOrder: [{
225
+ type: Input
226
+ }] } });
227
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contact-shadows.js","sourceRoot":"","sources":["../../../../../../../libs/angular-three-soba/staging/src/lib/contact-shadows/contact-shadows.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgIf } from '@angular/common';\nimport { Component, CUSTOM_ELEMENTS_SCHEMA, inject, Input } from '@angular/core';\nimport {\n    extend,\n    injectBeforeRender,\n    injectNgtRef,\n    NgtArgs,\n    NgtPush,\n    NgtRenderState,\n    NgtRxStore,\n    NgtStore,\n} from 'angular-three';\nimport * as THREE from 'three';\nimport { Group, Mesh, MeshBasicMaterial, OrthographicCamera } from 'three';\nimport { HorizontalBlurShader, VerticalBlurShader } from 'three-stdlib';\n\nextend({ Group, Mesh, MeshBasicMaterial, OrthographicCamera });\n\n@Component({\n    selector: 'ngts-contact-shadows',\n    standalone: true,\n    template: `\n        <ngt-group ngtCompound [ref]=\"contactShadowsRef\" [rotation]=\"[Math.PI / 2, 0, 0]\">\n            <ng-container *ngIf=\"contactShadows$ | ngtPush : null as contactShadows\">\n                <ngt-mesh\n                    [renderOrder]=\"get('renderOrder')\"\n                    [geometry]=\"contactShadows.planeGeometry\"\n                    [scale]=\"[1, -1, 1]\"\n                    [rotation]=\"[-Math.PI / 2, 0, 0]\"\n                >\n                    <ngt-mesh-basic-material\n                        [map]=\"contactShadows.renderTarget.texture\"\n                        transparent\n                        [opacity]=\"get('opacity')\"\n                        [depthWrite]=\"get('depthWrite')\"\n                    >\n                        <ngt-value [rawValue]=\"encoding\" attach=\"map.encoding\" />\n                    </ngt-mesh-basic-material>\n                </ngt-mesh>\n                <ngt-orthographic-camera *args=\"get('cameraArgs')\" [ref]=\"shadowCameraRef\" />\n            </ng-container>\n        </ngt-group>\n    `,\n    imports: [NgIf, NgtPush, NgtArgs],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsContactShadows extends NgtRxStore {\n    private readonly store = inject(NgtStore);\n    readonly shadowCameraRef = injectNgtRef<OrthographicCamera>();\n    readonly encoding = this.store.get('gl', 'outputEncoding');\n    readonly contactShadows$ = this.select('contactShadows');\n    readonly Math = Math;\n\n    @Input() contactShadowsRef = injectNgtRef<Group>();\n\n    @Input() set opacity(opacity: number) {\n        this.set({ opacity });\n    }\n\n    @Input() set width(width: number) {\n        this.set({ width });\n    }\n\n    @Input() set height(height: number) {\n        this.set({ height });\n    }\n\n    @Input() set blur(blur: number) {\n        this.set({ blur });\n    }\n\n    @Input() set far(far: number) {\n        this.set({ far });\n    }\n\n    @Input() set smooth(smooth: boolean) {\n        this.set({ smooth });\n    }\n\n    @Input() set resolution(resolution: number) {\n        this.set({ resolution });\n    }\n\n    @Input() set frames(frames: number) {\n        this.set({ frames });\n    }\n\n    @Input() set scale(scale: number | [x: number, y: number]) {\n        this.set({ scale });\n    }\n\n    @Input() set color(color: THREE.ColorRepresentation) {\n        this.set({ color });\n    }\n\n    @Input() set depthWrite(depthWrite: boolean) {\n        this.set({ depthWrite });\n    }\n\n    @Input() set renderOrder(renderOrder: number) {\n        this.set({ renderOrder });\n    }\n\n    constructor() {\n        super();\n        injectBeforeRender(this.onBeforeRender.bind(this, 0));\n    }\n\n    override initialize() {\n        super.initialize();\n        this.set({\n            scale: 10,\n            frames: Infinity,\n            opacity: 1,\n            width: 1,\n            height: 1,\n            blur: 1,\n            far: 10,\n            resolution: 512,\n            smooth: true,\n            color: '#000000',\n            depthWrite: false,\n            renderOrder: 0,\n        });\n        this.connect(\n            'scaledWidth',\n            this.select(\n                ['width', 'scale'],\n                ({ width, scale }) => width * (Array.isArray(scale) ? scale[0] : scale || 1)\n            )\n        );\n        this.connect(\n            'scaledHeight',\n            this.select(\n                ['height', 'scale'],\n                ({ height, scale }) => height * (Array.isArray(scale) ? scale[1] : scale || 1)\n            )\n        );\n        this.connect(\n            'cameraArgs',\n            this.select(['scaledWidth', 'scaledHeight', 'far'], ({ scaledWidth: width, scaledHeight: height, far }) => {\n                return [-width / 2, width / 2, height / 2, -height / 2, 0, far];\n            })\n        );\n        this.connect(\n            'contactShadows',\n            this.select(\n                ['resolution', 'scaledWidth', 'scaledHeight', 'scale', 'color'],\n                ({ resolution, scaledWidth: width, scaledHeight: height, color }) => {\n                    const renderTarget = new THREE.WebGLRenderTarget(resolution, resolution);\n                    const renderTargetBlur = new THREE.WebGLRenderTarget(resolution, resolution);\n                    renderTargetBlur.texture.generateMipmaps = renderTarget.texture.generateMipmaps = false;\n                    const planeGeometry = new THREE.PlaneGeometry(width, height).rotateX(Math.PI / 2);\n                    const blurPlane = new Mesh(planeGeometry);\n                    const depthMaterial = new THREE.MeshDepthMaterial();\n                    depthMaterial.depthTest = depthMaterial.depthWrite = false;\n                    depthMaterial.onBeforeCompile = (shader) => {\n                        shader.uniforms = {\n                            ...shader.uniforms,\n                            ucolor: { value: new THREE.Color(color) },\n                        };\n                        shader.fragmentShader = shader.fragmentShader.replace(\n                            `void main() {`, //\n                            `uniform vec3 ucolor;\n                             void main() {\n                            `\n                        );\n                        shader.fragmentShader = shader.fragmentShader.replace(\n                            'vec4( vec3( 1.0 - fragCoordZ ), opacity );',\n                            // Colorize the shadow, multiply by the falloff so that the center can remain darker\n                            'vec4( ucolor * fragCoordZ * 2.0, ( 1.0 - fragCoordZ ) * 1.0 );'\n                        );\n                    };\n\n                    const horizontalBlurMaterial = new THREE.ShaderMaterial(HorizontalBlurShader);\n                    const verticalBlurMaterial = new THREE.ShaderMaterial(VerticalBlurShader);\n                    verticalBlurMaterial.depthTest = horizontalBlurMaterial.depthTest = false;\n\n                    return {\n                        renderTarget,\n                        planeGeometry,\n                        depthMaterial,\n                        blurPlane,\n                        horizontalBlurMaterial,\n                        verticalBlurMaterial,\n                        renderTargetBlur,\n                    };\n                }\n            )\n        );\n    }\n\n    private onBeforeRender(count: number, { scene, gl }: NgtRenderState) {\n        const {\n            frames,\n            blur,\n            contactShadows: { depthMaterial, renderTarget },\n            smooth,\n        } = this.get();\n\n        if (this.shadowCameraRef.nativeElement && (frames === Infinity || count < frames)) {\n            const initialBackground = scene.background;\n            scene.background = null;\n            const initialOverrideMaterial = scene.overrideMaterial;\n            scene.overrideMaterial = depthMaterial;\n            gl.setRenderTarget(renderTarget);\n            gl.render(scene, this.shadowCameraRef.nativeElement);\n            scene.overrideMaterial = initialOverrideMaterial;\n\n            this.blurShadows(blur);\n            if (smooth) this.blurShadows(blur * 0.4);\n\n            gl.setRenderTarget(null);\n            scene.background = initialBackground;\n            count++;\n        }\n    }\n\n    private blurShadows(blur: number) {\n        const { blurPlane, horizontalBlurMaterial, verticalBlurMaterial, renderTargetBlur, renderTarget } =\n            this.get('contactShadows');\n        const gl = this.store.get('gl');\n\n        blurPlane.visible = true;\n\n        blurPlane.material = horizontalBlurMaterial;\n        horizontalBlurMaterial.uniforms.tDiffuse.value = renderTarget.texture;\n        horizontalBlurMaterial.uniforms.h.value = (blur * 1) / 256;\n\n        gl.setRenderTarget(renderTargetBlur);\n        gl.render(blurPlane, this.shadowCameraRef.nativeElement);\n\n        blurPlane.material = verticalBlurMaterial;\n        verticalBlurMaterial.uniforms.tDiffuse.value = renderTargetBlur.texture;\n        verticalBlurMaterial.uniforms.v.value = (blur * 1) / 256;\n\n        gl.setRenderTarget(renderTarget);\n        gl.render(blurPlane, this.shadowCameraRef.nativeElement);\n\n        blurPlane.visible = false;\n    }\n}\n"]}
@@ -0,0 +1,13 @@
1
+ export const ngtsEnvironmentPresetsObj = {
2
+ sunset: 'venice/venice_sunset_1k.hdr',
3
+ dawn: 'kiara/kiara_1_dawn_1k.hdr',
4
+ night: 'dikhololo/dikhololo_night_1k.hdr',
5
+ warehouse: 'empty-wharehouse/empty_warehouse_01_1k.hdr',
6
+ forest: 'forrest-slope/forest_slope_1k.hdr',
7
+ apartment: 'lebombo/lebombo_1k.hdr',
8
+ studio: 'studio-small-3/studio_small_03_1k.hdr',
9
+ city: 'potsdamer-platz/potsdamer_platz_1k.hdr',
10
+ park: 'rooitou/rooitou_park_1k.hdr',
11
+ lobby: 'st-fagans/st_fagans_interior_1k.hdr',
12
+ };
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLXRocmVlLXNvYmEvc3RhZ2luZy9zcmMvbGliL2Vudmlyb25tZW50L2Fzc2V0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSx5QkFBeUIsR0FBRztJQUNyQyxNQUFNLEVBQUUsNkJBQTZCO0lBQ3JDLElBQUksRUFBRSwyQkFBMkI7SUFDakMsS0FBSyxFQUFFLGtDQUFrQztJQUN6QyxTQUFTLEVBQUUsNENBQTRDO0lBQ3ZELE1BQU0sRUFBRSxtQ0FBbUM7SUFDM0MsU0FBUyxFQUFFLHdCQUF3QjtJQUNuQyxNQUFNLEVBQUUsdUNBQXVDO0lBQy9DLElBQUksRUFBRSx3Q0FBd0M7SUFDOUMsSUFBSSxFQUFFLDZCQUE2QjtJQUNuQyxLQUFLLEVBQUUscUNBQXFDO0NBQy9DLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3Qgbmd0c0Vudmlyb25tZW50UHJlc2V0c09iaiA9IHtcbiAgICBzdW5zZXQ6ICd2ZW5pY2UvdmVuaWNlX3N1bnNldF8xay5oZHInLFxuICAgIGRhd246ICdraWFyYS9raWFyYV8xX2Rhd25fMWsuaGRyJyxcbiAgICBuaWdodDogJ2Rpa2hvbG9sby9kaWtob2xvbG9fbmlnaHRfMWsuaGRyJyxcbiAgICB3YXJlaG91c2U6ICdlbXB0eS13aGFyZWhvdXNlL2VtcHR5X3dhcmVob3VzZV8wMV8xay5oZHInLFxuICAgIGZvcmVzdDogJ2ZvcnJlc3Qtc2xvcGUvZm9yZXN0X3Nsb3BlXzFrLmhkcicsXG4gICAgYXBhcnRtZW50OiAnbGVib21iby9sZWJvbWJvXzFrLmhkcicsXG4gICAgc3R1ZGlvOiAnc3R1ZGlvLXNtYWxsLTMvc3R1ZGlvX3NtYWxsXzAzXzFrLmhkcicsXG4gICAgY2l0eTogJ3BvdHNkYW1lci1wbGF0ei9wb3RzZGFtZXJfcGxhdHpfMWsuaGRyJyxcbiAgICBwYXJrOiAncm9vaXRvdS9yb29pdG91X3BhcmtfMWsuaGRyJyxcbiAgICBsb2JieTogJ3N0LWZhZ2Fucy9zdF9mYWdhbnNfaW50ZXJpb3JfMWsuaGRyJyxcbn07XG5cbmV4cG9ydCB0eXBlIE5ndHNFbnZpcm9ubWVudFByZXNldHNUeXBlID0ga2V5b2YgdHlwZW9mIG5ndHNFbnZpcm9ubWVudFByZXNldHNPYmo7XG4iXX0=
@@ -0,0 +1,40 @@
1
+ import { Directive } from '@angular/core';
2
+ import { startWithUndefined } from 'angular-three';
3
+ import { combineLatest, startWith } from 'rxjs';
4
+ import { NgtsEnvironmentInputs } from './environment-inputs';
5
+ import { injectNgtsEnvironment, setEnvProps } from './utils';
6
+ import * as i0 from "@angular/core";
7
+ export class NgtsEnvironmentCube extends NgtsEnvironmentInputs {
8
+ constructor() {
9
+ super(...arguments);
10
+ this.textureRef = injectNgtsEnvironment((params) => this.select().pipe(startWith(params)));
11
+ }
12
+ initialize() {
13
+ super.initialize();
14
+ this.set({ background: false });
15
+ }
16
+ ngOnInit() {
17
+ this.setEnvProps();
18
+ }
19
+ setEnvProps() {
20
+ this.effect(combineLatest([
21
+ this.store.select('scene'),
22
+ this.select('scene').pipe(startWithUndefined()),
23
+ this.select('background'),
24
+ this.select('blur').pipe(startWithUndefined()),
25
+ this.textureRef.$,
26
+ ]), ([defaultScene, scene, background, blur, texture]) => {
27
+ return setEnvProps(background, scene, defaultScene, texture, blur);
28
+ });
29
+ }
30
+ }
31
+ NgtsEnvironmentCube.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsEnvironmentCube, deps: null, target: i0.ɵɵFactoryTarget.Directive });
32
+ NgtsEnvironmentCube.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.3", type: NgtsEnvironmentCube, isStandalone: true, selector: "ngts-environment-cube", usesInheritance: true, ngImport: i0 });
33
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsEnvironmentCube, decorators: [{
34
+ type: Directive,
35
+ args: [{
36
+ selector: 'ngts-environment-cube',
37
+ standalone: true,
38
+ }]
39
+ }] });
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW52aXJvbm1lbnQtY3ViZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci10aHJlZS1zb2JhL3N0YWdpbmcvc3JjL2xpYi9lbnZpcm9ubWVudC9lbnZpcm9ubWVudC1jdWJlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFDbEQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25ELE9BQU8sRUFBRSxhQUFhLEVBQUUsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQ2hELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQzdELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxXQUFXLEVBQUUsTUFBTSxTQUFTLENBQUM7O0FBTTdELE1BQU0sT0FBTyxtQkFBb0IsU0FBUSxxQkFBcUI7SUFKOUQ7O1FBS2EsZUFBVSxHQUFHLHFCQUFxQixDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7S0F5QmxHO0lBdkJZLFVBQVU7UUFDZixLQUFLLENBQUMsVUFBVSxFQUFFLENBQUM7UUFDbkIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLFVBQVUsRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFFRCxRQUFRO1FBQ0osSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ3ZCLENBQUM7SUFFTyxXQUFXO1FBQ2YsSUFBSSxDQUFDLE1BQU0sQ0FDUCxhQUFhLENBQUM7WUFDVixJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUM7WUFDMUIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyxJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztZQUMvQyxJQUFJLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQztZQUN6QixJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLElBQUksQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO1lBQzlDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztTQUNwQixDQUFDLEVBQ0YsQ0FBQyxDQUFDLFlBQVksRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFLElBQUksRUFBRSxPQUFPLENBQUMsRUFBRSxFQUFFO1lBQ2pELE9BQU8sV0FBVyxDQUFDLFVBQVUsRUFBRSxLQUFLLEVBQUUsWUFBWSxFQUFFLE9BQU8sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUN2RSxDQUFDLENBQ0osQ0FBQztJQUNOLENBQUM7O2dIQXpCUSxtQkFBbUI7b0dBQW5CLG1CQUFtQjsyRkFBbkIsbUJBQW1CO2tCQUovQixTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSx1QkFBdUI7b0JBQ2pDLFVBQVUsRUFBRSxJQUFJO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBzdGFydFdpdGhVbmRlZmluZWQgfSBmcm9tICdhbmd1bGFyLXRocmVlJztcbmltcG9ydCB7IGNvbWJpbmVMYXRlc3QsIHN0YXJ0V2l0aCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgTmd0c0Vudmlyb25tZW50SW5wdXRzIH0gZnJvbSAnLi9lbnZpcm9ubWVudC1pbnB1dHMnO1xuaW1wb3J0IHsgaW5qZWN0Tmd0c0Vudmlyb25tZW50LCBzZXRFbnZQcm9wcyB9IGZyb20gJy4vdXRpbHMnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ25ndHMtZW52aXJvbm1lbnQtY3ViZScsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgTmd0c0Vudmlyb25tZW50Q3ViZSBleHRlbmRzIE5ndHNFbnZpcm9ubWVudElucHV0cyBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgcmVhZG9ubHkgdGV4dHVyZVJlZiA9IGluamVjdE5ndHNFbnZpcm9ubWVudCgocGFyYW1zKSA9PiB0aGlzLnNlbGVjdCgpLnBpcGUoc3RhcnRXaXRoKHBhcmFtcykpKTtcblxuICAgIG92ZXJyaWRlIGluaXRpYWxpemUoKTogdm9pZCB7XG4gICAgICAgIHN1cGVyLmluaXRpYWxpemUoKTtcbiAgICAgICAgdGhpcy5zZXQoeyBiYWNrZ3JvdW5kOiBmYWxzZSB9KTtcbiAgICB9XG5cbiAgICBuZ09uSW5pdCgpIHtcbiAgICAgICAgdGhpcy5zZXRFbnZQcm9wcygpO1xuICAgIH1cblxuICAgIHByaXZhdGUgc2V0RW52UHJvcHMoKSB7XG4gICAgICAgIHRoaXMuZWZmZWN0KFxuICAgICAgICAgICAgY29tYmluZUxhdGVzdChbXG4gICAgICAgICAgICAgICAgdGhpcy5zdG9yZS5zZWxlY3QoJ3NjZW5lJyksXG4gICAgICAgICAgICAgICAgdGhpcy5zZWxlY3QoJ3NjZW5lJykucGlwZShzdGFydFdpdGhVbmRlZmluZWQoKSksXG4gICAgICAgICAgICAgICAgdGhpcy5zZWxlY3QoJ2JhY2tncm91bmQnKSxcbiAgICAgICAgICAgICAgICB0aGlzLnNlbGVjdCgnYmx1cicpLnBpcGUoc3RhcnRXaXRoVW5kZWZpbmVkKCkpLFxuICAgICAgICAgICAgICAgIHRoaXMudGV4dHVyZVJlZi4kLFxuICAgICAgICAgICAgXSksXG4gICAgICAgICAgICAoW2RlZmF1bHRTY2VuZSwgc2NlbmUsIGJhY2tncm91bmQsIGJsdXIsIHRleHR1cmVdKSA9PiB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHNldEVudlByb3BzKGJhY2tncm91bmQsIHNjZW5lLCBkZWZhdWx0U2NlbmUsIHRleHR1cmUsIGJsdXIpO1xuICAgICAgICAgICAgfVxuICAgICAgICApO1xuICAgIH1cbn1cbiJdfQ==
@@ -0,0 +1,66 @@
1
+ import { NgIf } from '@angular/common';
2
+ import { Component, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
3
+ import { extend, NgtArgs, startWithUndefined } from 'angular-three';
4
+ import { combineLatest, map, startWith } from 'rxjs';
5
+ import { GroundProjectedEnv } from 'three-stdlib';
6
+ import { NgtsEnvironmentInputs } from './environment-inputs';
7
+ import { NgtsEnvironmentMap } from './environment-map';
8
+ import { injectNgtsEnvironment } from './utils';
9
+ import * as i0 from "@angular/core";
10
+ extend({ GroundProjectedEnv });
11
+ export class NgtsEnvironmentGround extends NgtsEnvironmentInputs {
12
+ constructor() {
13
+ super(...arguments);
14
+ this.defaultTexture = injectNgtsEnvironment((params) => this.select().pipe(startWith(params)));
15
+ }
16
+ ngOnInit() {
17
+ this.connect('texture', combineLatest([this.select('map').pipe(startWithUndefined()), this.defaultTexture.$]).pipe(map(([map, texture]) => map || texture)));
18
+ this.connect('groundArgs', this.select('texture').pipe(map((texture) => [texture])));
19
+ this.connect('groundHeight', this.select(['ground'], ({ ground }) => ground?.height));
20
+ this.connect('groundRadius', this.select(['ground'], ({ ground }) => ground?.radius));
21
+ this.connect('groundScale', this.select(['ground'], ({ ground }) => ground?.scale ?? 1000));
22
+ }
23
+ }
24
+ NgtsEnvironmentGround.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsEnvironmentGround, deps: null, target: i0.ɵɵFactoryTarget.Component });
25
+ NgtsEnvironmentGround.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.3", type: NgtsEnvironmentGround, isStandalone: true, selector: "ngts-environment-ground", usesInheritance: true, ngImport: i0, template: `
26
+ <ngts-environment-map
27
+ [background]="get('background')"
28
+ [blur]="get('blur')"
29
+ [scene]="get('scene')"
30
+ [map]="get('texture')"
31
+ />
32
+ <ng-container *ngIf="get('groundArgs') as groundArgs">
33
+ <ngt-ground-projected-env
34
+ *args="groundArgs"
35
+ [scale]="get('groundScale')"
36
+ [height]="get('groundHeight')"
37
+ [radius]="get('groundRadius')"
38
+ />
39
+ </ng-container>
40
+ `, isInline: true, dependencies: [{ kind: "directive", type: NgtsEnvironmentMap, selector: "ngts-environment-map" }, { kind: "directive", type: NgtArgs, selector: "[args]", inputs: ["args"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
41
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsEnvironmentGround, decorators: [{
42
+ type: Component,
43
+ args: [{
44
+ selector: 'ngts-environment-ground',
45
+ standalone: true,
46
+ template: `
47
+ <ngts-environment-map
48
+ [background]="get('background')"
49
+ [blur]="get('blur')"
50
+ [scene]="get('scene')"
51
+ [map]="get('texture')"
52
+ />
53
+ <ng-container *ngIf="get('groundArgs') as groundArgs">
54
+ <ngt-ground-projected-env
55
+ *args="groundArgs"
56
+ [scale]="get('groundScale')"
57
+ [height]="get('groundHeight')"
58
+ [radius]="get('groundRadius')"
59
+ />
60
+ </ng-container>
61
+ `,
62
+ imports: [NgtsEnvironmentMap, NgtArgs, NgIf],
63
+ schemas: [CUSTOM_ELEMENTS_SCHEMA],
64
+ }]
65
+ }] });
66
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW52aXJvbm1lbnQtZ3JvdW5kLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLXRocmVlLXNvYmEvc3RhZ2luZy9zcmMvbGliL2Vudmlyb25tZW50L2Vudmlyb25tZW50LWdyb3VuZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDdkMsT0FBTyxFQUFFLFNBQVMsRUFBRSxzQkFBc0IsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUMxRSxPQUFPLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNwRSxPQUFPLEVBQUUsYUFBYSxFQUFFLEdBQUcsRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDckQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ2xELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQzdELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLFNBQVMsQ0FBQzs7QUFFaEQsTUFBTSxDQUFDLEVBQUUsa0JBQWtCLEVBQUUsQ0FBQyxDQUFDO0FBd0IvQixNQUFNLE9BQU8scUJBQXNCLFNBQVEscUJBQXFCO0lBdEJoRTs7UUF1QmEsbUJBQWMsR0FBRyxxQkFBcUIsQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBdUJ0RztJQXJCRyxRQUFRO1FBQ0osSUFBSSxDQUFDLE9BQU8sQ0FDUixTQUFTLEVBQ1QsYUFBYSxDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQyxFQUFFLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQ3RGLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxFQUFFLE9BQU8sQ0FBQyxFQUFFLEVBQUUsQ0FBQyxHQUFHLElBQUksT0FBTyxDQUFDLENBQzFDLENBQ0osQ0FBQztRQUNGLElBQUksQ0FBQyxPQUFPLENBQUMsWUFBWSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNyRixJQUFJLENBQUMsT0FBTyxDQUNSLGNBQWMsRUFDZCxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxFQUFFLE1BQU0sRUFBRSxFQUFFLEVBQUUsQ0FBQyxNQUFNLEVBQUUsTUFBTSxDQUFDLENBQzFELENBQUM7UUFDRixJQUFJLENBQUMsT0FBTyxDQUNSLGNBQWMsRUFDZCxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxFQUFFLE1BQU0sRUFBRSxFQUFFLEVBQUUsQ0FBQyxNQUFNLEVBQUUsTUFBTSxDQUFDLENBQzFELENBQUM7UUFDRixJQUFJLENBQUMsT0FBTyxDQUNSLGFBQWEsRUFDYixJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxFQUFFLE1BQU0sRUFBRSxFQUFFLEVBQUUsQ0FBQyxNQUFNLEVBQUUsS0FBSyxJQUFJLElBQUksQ0FBQyxDQUNqRSxDQUFDO0lBQ04sQ0FBQzs7a0hBdkJRLHFCQUFxQjtzR0FBckIscUJBQXFCLDBHQW5CcEI7Ozs7Ozs7Ozs7Ozs7OztLQWVULDREQUNTLGtCQUFrQixpRUFBRSxPQUFPLHFFQUFFLElBQUk7MkZBR2xDLHFCQUFxQjtrQkF0QmpDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLHlCQUF5QjtvQkFDbkMsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRTs7Ozs7Ozs7Ozs7Ozs7O0tBZVQ7b0JBQ0QsT0FBTyxFQUFFLENBQUMsa0JBQWtCLEVBQUUsT0FBTyxFQUFFLElBQUksQ0FBQztvQkFDNUMsT0FBTyxFQUFFLENBQUMsc0JBQXNCLENBQUM7aUJBQ3BDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdJZiB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIENVU1RPTV9FTEVNRU5UU19TQ0hFTUEsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgZXh0ZW5kLCBOZ3RBcmdzLCBzdGFydFdpdGhVbmRlZmluZWQgfSBmcm9tICdhbmd1bGFyLXRocmVlJztcbmltcG9ydCB7IGNvbWJpbmVMYXRlc3QsIG1hcCwgc3RhcnRXaXRoIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBHcm91bmRQcm9qZWN0ZWRFbnYgfSBmcm9tICd0aHJlZS1zdGRsaWInO1xuaW1wb3J0IHsgTmd0c0Vudmlyb25tZW50SW5wdXRzIH0gZnJvbSAnLi9lbnZpcm9ubWVudC1pbnB1dHMnO1xuaW1wb3J0IHsgTmd0c0Vudmlyb25tZW50TWFwIH0gZnJvbSAnLi9lbnZpcm9ubWVudC1tYXAnO1xuaW1wb3J0IHsgaW5qZWN0Tmd0c0Vudmlyb25tZW50IH0gZnJvbSAnLi91dGlscyc7XG5cbmV4dGVuZCh7IEdyb3VuZFByb2plY3RlZEVudiB9KTtcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICduZ3RzLWVudmlyb25tZW50LWdyb3VuZCcsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICB0ZW1wbGF0ZTogYFxuICAgICAgICA8bmd0cy1lbnZpcm9ubWVudC1tYXBcbiAgICAgICAgICAgIFtiYWNrZ3JvdW5kXT1cImdldCgnYmFja2dyb3VuZCcpXCJcbiAgICAgICAgICAgIFtibHVyXT1cImdldCgnYmx1cicpXCJcbiAgICAgICAgICAgIFtzY2VuZV09XCJnZXQoJ3NjZW5lJylcIlxuICAgICAgICAgICAgW21hcF09XCJnZXQoJ3RleHR1cmUnKVwiXG4gICAgICAgIC8+XG4gICAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJnZXQoJ2dyb3VuZEFyZ3MnKSBhcyBncm91bmRBcmdzXCI+XG4gICAgICAgICAgICA8bmd0LWdyb3VuZC1wcm9qZWN0ZWQtZW52XG4gICAgICAgICAgICAgICAgKmFyZ3M9XCJncm91bmRBcmdzXCJcbiAgICAgICAgICAgICAgICBbc2NhbGVdPVwiZ2V0KCdncm91bmRTY2FsZScpXCJcbiAgICAgICAgICAgICAgICBbaGVpZ2h0XT1cImdldCgnZ3JvdW5kSGVpZ2h0JylcIlxuICAgICAgICAgICAgICAgIFtyYWRpdXNdPVwiZ2V0KCdncm91bmRSYWRpdXMnKVwiXG4gICAgICAgICAgICAvPlxuICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICBgLFxuICAgIGltcG9ydHM6IFtOZ3RzRW52aXJvbm1lbnRNYXAsIE5ndEFyZ3MsIE5nSWZdLFxuICAgIHNjaGVtYXM6IFtDVVNUT01fRUxFTUVOVFNfU0NIRU1BXSxcbn0pXG5leHBvcnQgY2xhc3MgTmd0c0Vudmlyb25tZW50R3JvdW5kIGV4dGVuZHMgTmd0c0Vudmlyb25tZW50SW5wdXRzIGltcGxlbWVudHMgT25Jbml0IHtcbiAgICByZWFkb25seSBkZWZhdWx0VGV4dHVyZSA9IGluamVjdE5ndHNFbnZpcm9ubWVudCgocGFyYW1zKSA9PiB0aGlzLnNlbGVjdCgpLnBpcGUoc3RhcnRXaXRoKHBhcmFtcykpKTtcblxuICAgIG5nT25Jbml0KCkge1xuICAgICAgICB0aGlzLmNvbm5lY3QoXG4gICAgICAgICAgICAndGV4dHVyZScsXG4gICAgICAgICAgICBjb21iaW5lTGF0ZXN0KFt0aGlzLnNlbGVjdCgnbWFwJykucGlwZShzdGFydFdpdGhVbmRlZmluZWQoKSksIHRoaXMuZGVmYXVsdFRleHR1cmUuJF0pLnBpcGUoXG4gICAgICAgICAgICAgICAgbWFwKChbbWFwLCB0ZXh0dXJlXSkgPT4gbWFwIHx8IHRleHR1cmUpXG4gICAgICAgICAgICApXG4gICAgICAgICk7XG4gICAgICAgIHRoaXMuY29ubmVjdCgnZ3JvdW5kQXJncycsIHRoaXMuc2VsZWN0KCd0ZXh0dXJlJykucGlwZShtYXAoKHRleHR1cmUpID0+IFt0ZXh0dXJlXSkpKTtcbiAgICAgICAgdGhpcy5jb25uZWN0KFxuICAgICAgICAgICAgJ2dyb3VuZEhlaWdodCcsXG4gICAgICAgICAgICB0aGlzLnNlbGVjdChbJ2dyb3VuZCddLCAoeyBncm91bmQgfSkgPT4gZ3JvdW5kPy5oZWlnaHQpXG4gICAgICAgICk7XG4gICAgICAgIHRoaXMuY29ubmVjdChcbiAgICAgICAgICAgICdncm91bmRSYWRpdXMnLFxuICAgICAgICAgICAgdGhpcy5zZWxlY3QoWydncm91bmQnXSwgKHsgZ3JvdW5kIH0pID0+IGdyb3VuZD8ucmFkaXVzKVxuICAgICAgICApO1xuICAgICAgICB0aGlzLmNvbm5lY3QoXG4gICAgICAgICAgICAnZ3JvdW5kU2NhbGUnLFxuICAgICAgICAgICAgdGhpcy5zZWxlY3QoWydncm91bmQnXSwgKHsgZ3JvdW5kIH0pID0+IGdyb3VuZD8uc2NhbGUgPz8gMTAwMClcbiAgICAgICAgKTtcbiAgICB9XG59XG4iXX0=