angular-three-soba 1.10.0 → 1.11.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/abstractions/index.d.ts +1 -0
- package/abstractions/lib/edges/edges.d.ts +18 -0
- package/cameras/index.d.ts +1 -0
- package/cameras/lib/camera/camera-content.d.ts +1 -1
- package/cameras/lib/cube-camera/cube-camera.d.ts +27 -0
- package/esm2020/abstractions/index.mjs +2 -1
- package/esm2020/abstractions/lib/edges/edges.mjs +95 -0
- package/esm2020/cameras/index.mjs +2 -1
- package/esm2020/cameras/lib/camera/camera-content.mjs +1 -1
- package/esm2020/cameras/lib/cube-camera/cube-camera.mjs +130 -0
- package/esm2020/materials/index.mjs +3 -1
- package/esm2020/materials/lib/mesh-refraction-material/mesh-refraction-material.mjs +157 -0
- package/esm2020/materials/lib/mesh-transmission-material/mesh-transmission-material.mjs +240 -0
- package/esm2020/misc/lib/fbo/fbo.mjs +5 -4
- package/esm2020/shaders/index.mjs +5 -1
- package/esm2020/shaders/lib/caustics-material/caustics-material.mjs +128 -0
- package/esm2020/shaders/lib/caustics-projection-material/caustics-projection-material.mjs +33 -0
- package/esm2020/shaders/lib/discard-material/discard-material.mjs +3 -0
- package/esm2020/shaders/lib/mesh-transmission-material/mesh-transmission-material.mjs +268 -0
- package/esm2020/staging/index.mjs +2 -1
- package/esm2020/staging/lib/accumulative-shadows/progressive-light-map.mjs +2 -3
- package/esm2020/staging/lib/caustics/caustics.mjs +364 -0
- package/fesm2015/angular-three-soba-abstractions.mjs +91 -2
- package/fesm2015/angular-three-soba-abstractions.mjs.map +1 -1
- package/fesm2015/angular-three-soba-cameras.mjs +127 -4
- package/fesm2015/angular-three-soba-cameras.mjs.map +1 -1
- package/fesm2015/angular-three-soba-materials.mjs +389 -2
- package/fesm2015/angular-three-soba-materials.mjs.map +1 -1
- package/fesm2015/angular-three-soba-misc.mjs +4 -3
- package/fesm2015/angular-three-soba-misc.mjs.map +1 -1
- package/fesm2015/angular-three-soba-shaders.mjs +454 -31
- package/fesm2015/angular-three-soba-shaders.mjs.map +1 -1
- package/fesm2015/angular-three-soba-staging.mjs +363 -9
- package/fesm2015/angular-three-soba-staging.mjs.map +1 -1
- package/fesm2020/angular-three-soba-abstractions.mjs +91 -2
- package/fesm2020/angular-three-soba-abstractions.mjs.map +1 -1
- package/fesm2020/angular-three-soba-cameras.mjs +127 -4
- package/fesm2020/angular-three-soba-cameras.mjs.map +1 -1
- package/fesm2020/angular-three-soba-materials.mjs +387 -2
- package/fesm2020/angular-three-soba-materials.mjs.map +1 -1
- package/fesm2020/angular-three-soba-misc.mjs +4 -3
- package/fesm2020/angular-three-soba-misc.mjs.map +1 -1
- package/fesm2020/angular-three-soba-shaders.mjs +460 -34
- package/fesm2020/angular-three-soba-shaders.mjs.map +1 -1
- package/fesm2020/angular-three-soba-staging.mjs +362 -9
- package/fesm2020/angular-three-soba-staging.mjs.map +1 -1
- package/materials/index.d.ts +2 -0
- package/materials/lib/mesh-refraction-material/mesh-refraction-material.d.ts +28 -0
- package/materials/lib/mesh-transmission-material/mesh-transmission-material.d.ts +47 -0
- package/misc/lib/fbo/fbo.d.ts +8 -6
- package/package.json +2 -2
- package/plugin/package.json +1 -1
- package/shaders/index.d.ts +4 -0
- package/shaders/lib/caustics-material/caustics-material.d.ts +4 -0
- package/shaders/lib/caustics-projection-material/caustics-projection-material.d.ts +4 -0
- package/shaders/lib/discard-material/discard-material.d.ts +3 -0
- package/shaders/lib/mesh-transmission-material/mesh-transmission-material.d.ts +25 -0
- package/staging/index.d.ts +1 -0
- package/staging/lib/caustics/caustics.d.ts +48 -0
- package/staging/lib/environment/environment-cube.d.ts +1 -1
- package/staging/lib/environment/environment-ground.d.ts +1 -1
- package/staging/lib/environment/utils.d.ts +1 -1
package/abstractions/index.d.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
export * from './lib/billboard/billboard';
|
|
2
2
|
export * from './lib/catmull-rom-line/catmull-rom-line';
|
|
3
3
|
export * from './lib/cubic-bezier-line/cubic-bezier-line';
|
|
4
|
+
export * from './lib/edges/edges';
|
|
4
5
|
export * from './lib/gizmo-helper/gizmo-helper';
|
|
5
6
|
export * from './lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube';
|
|
6
7
|
export * from './lib/gizmo-helper/gizmo-viewport/gizmo-viewport';
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { OnInit } from '@angular/core';
|
|
2
|
+
import { NgtAnyRecord, NgtRxStore } from 'angular-three';
|
|
3
|
+
import * as THREE from 'three';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export declare class NgtsEdges extends NgtRxStore implements OnInit {
|
|
6
|
+
edgesRef: import("angular-three").NgtInjectedRef<THREE.LineSegments<THREE.BufferGeometry, THREE.Material | THREE.Material[]>>;
|
|
7
|
+
set threshold(threshold: number);
|
|
8
|
+
set color(color: THREE.ColorRepresentation);
|
|
9
|
+
set geometry(geometry: THREE.BufferGeometry);
|
|
10
|
+
set userData(userData: NgtAnyRecord);
|
|
11
|
+
withChildren: boolean;
|
|
12
|
+
readonly noop: () => null;
|
|
13
|
+
initialize(): void;
|
|
14
|
+
ngOnInit(): void;
|
|
15
|
+
private setupGeometry;
|
|
16
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NgtsEdges, never>;
|
|
17
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NgtsEdges, "ngts-edges", never, { "edgesRef": "edgesRef"; "threshold": "threshold"; "color": "color"; "geometry": "geometry"; "userData": "userData"; "withChildren": "withChildren"; }, {}, never, ["*"], true, never>;
|
|
18
|
+
}
|
package/cameras/index.d.ts
CHANGED
|
@@ -5,7 +5,7 @@ export declare class NgtsCameraContent {
|
|
|
5
5
|
readonly template: TemplateRef<any>;
|
|
6
6
|
ngtsCameraContent: boolean | '';
|
|
7
7
|
static ngTemplateContextGuard(_: NgtsCameraContent, ctx: unknown): ctx is {
|
|
8
|
-
|
|
8
|
+
fbo: THREE.WebGLRenderTarget;
|
|
9
9
|
group?: THREE.Group;
|
|
10
10
|
};
|
|
11
11
|
static ɵfac: i0.ɵɵFactoryDeclaration<NgtsCameraContent, never>;
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { ElementRef } from '@angular/core';
|
|
2
|
+
import { NgtRxStore } from 'angular-three';
|
|
3
|
+
import * as THREE from 'three';
|
|
4
|
+
import { NgtsCameraContent } from '../camera/camera-content';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export declare class NgtsCubeCamera extends NgtRxStore {
|
|
7
|
+
groupRef: ElementRef<THREE.Group>;
|
|
8
|
+
cameraContent?: NgtsCameraContent;
|
|
9
|
+
readonly cameraRef: import("angular-three").NgtInjectedRef<THREE.CubeCamera>;
|
|
10
|
+
/** Number of frames to render, Infinity */
|
|
11
|
+
set frames(frames: number);
|
|
12
|
+
/** Resolution of the FBO, 256 */
|
|
13
|
+
set resolution(resolution: number);
|
|
14
|
+
/** Camera near, 0.1 */
|
|
15
|
+
set near(near: number);
|
|
16
|
+
/** Camera far, 1000 */
|
|
17
|
+
set far(far: number);
|
|
18
|
+
/** Custom environment map that is temporarily set as the scenes background */
|
|
19
|
+
set envMap(envMap: THREE.Texture);
|
|
20
|
+
/** Custom fog that is temporarily set as the scenes fog */
|
|
21
|
+
set fog(fog: THREE.Fog | THREE.FogExp2);
|
|
22
|
+
private readonly store;
|
|
23
|
+
initialize(): void;
|
|
24
|
+
constructor();
|
|
25
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NgtsCubeCamera, never>;
|
|
26
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NgtsCubeCamera, "ngts-cube-camera", never, { "frames": "frames"; "resolution": "resolution"; "near": "near"; "far": "far"; "envMap": "envMap"; "fog": "fog"; }, {}, ["cameraContent"], never, true, never>;
|
|
27
|
+
}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
export * from './lib/billboard/billboard';
|
|
2
2
|
export * from './lib/catmull-rom-line/catmull-rom-line';
|
|
3
3
|
export * from './lib/cubic-bezier-line/cubic-bezier-line';
|
|
4
|
+
export * from './lib/edges/edges';
|
|
4
5
|
export * from './lib/gizmo-helper/gizmo-helper';
|
|
5
6
|
export * from './lib/gizmo-helper/gizmo-viewcube/gizmo-viewcube';
|
|
6
7
|
export * from './lib/gizmo-helper/gizmo-viewport/gizmo-viewport';
|
|
@@ -8,4 +9,4 @@ export * from './lib/line/line';
|
|
|
8
9
|
export * from './lib/quadratic-bezier-line/quadratic-bezier-line';
|
|
9
10
|
export * from './lib/text-3d/text-3d';
|
|
10
11
|
export * from './lib/text/text';
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUtc29iYS9hYnN0cmFjdGlvbnMvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxpQkFBaUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2JpbGxib2FyZC9iaWxsYm9hcmQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2F0bXVsbC1yb20tbGluZS9jYXRtdWxsLXJvbS1saW5lJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2N1YmljLWJlemllci1saW5lL2N1YmljLWJlemllci1saW5lJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VkZ2VzL2VkZ2VzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2dpem1vLWhlbHBlci9naXptby1oZWxwZXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZ2l6bW8taGVscGVyL2dpem1vLXZpZXdjdWJlL2dpem1vLXZpZXdjdWJlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2dpem1vLWhlbHBlci9naXptby12aWV3cG9ydC9naXptby12aWV3cG9ydCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9saW5lL2xpbmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcXVhZHJhdGljLWJlemllci1saW5lL3F1YWRyYXRpYy1iZXppZXItbGluZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90ZXh0LTNkL3RleHQtM2QnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGV4dC90ZXh0JztcbiJdfQ==
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
import { NgIf } from '@angular/common';
|
|
2
|
+
import { Component, CUSTOM_ELEMENTS_SCHEMA, Input } from '@angular/core';
|
|
3
|
+
import { extend, injectNgtRef, NgtRxStore } from 'angular-three';
|
|
4
|
+
import * as THREE from 'three';
|
|
5
|
+
import { LineBasicMaterial, LineSegments } from 'three';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
extend({ LineSegments, LineBasicMaterial });
|
|
8
|
+
export class NgtsEdges extends NgtRxStore {
|
|
9
|
+
constructor() {
|
|
10
|
+
super(...arguments);
|
|
11
|
+
this.edgesRef = injectNgtRef();
|
|
12
|
+
this.withChildren = false;
|
|
13
|
+
this.noop = () => null;
|
|
14
|
+
}
|
|
15
|
+
set threshold(threshold) {
|
|
16
|
+
this.set({ threshold });
|
|
17
|
+
}
|
|
18
|
+
set color(color) {
|
|
19
|
+
this.set({ color });
|
|
20
|
+
}
|
|
21
|
+
set geometry(geometry) {
|
|
22
|
+
this.set({ geometry });
|
|
23
|
+
}
|
|
24
|
+
set userData(userData) {
|
|
25
|
+
this.set({ userData });
|
|
26
|
+
}
|
|
27
|
+
initialize() {
|
|
28
|
+
super.initialize();
|
|
29
|
+
this.set({
|
|
30
|
+
threshold: 15,
|
|
31
|
+
color: 'black',
|
|
32
|
+
userData: {},
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
ngOnInit() {
|
|
36
|
+
this.setupGeometry();
|
|
37
|
+
}
|
|
38
|
+
setupGeometry() {
|
|
39
|
+
this.hold(this.edgesRef.$, (segments) => {
|
|
40
|
+
const parent = segments.parent;
|
|
41
|
+
if (parent) {
|
|
42
|
+
const geom = this.get('geometry') || parent.geometry;
|
|
43
|
+
const threshold = this.get('threshold');
|
|
44
|
+
if (geom !== segments.userData['currentGeom'] || threshold !== segments.userData['currentThreshold']) {
|
|
45
|
+
segments.userData['currentGeom'] = geom;
|
|
46
|
+
segments.userData['currentThreshold'] = threshold;
|
|
47
|
+
segments.geometry = new THREE.EdgesGeometry(geom, threshold);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
NgtsEdges.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgtsEdges, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
54
|
+
NgtsEdges.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.0", type: NgtsEdges, isStandalone: true, selector: "ngts-edges", inputs: { edgesRef: "edgesRef", threshold: "threshold", color: "color", geometry: "geometry", userData: "userData", withChildren: "withChildren" }, usesInheritance: true, ngImport: i0, template: `
|
|
55
|
+
<ngt-line-segments [ref]="edgesRef" [raycast]="noop" ngtCompound>
|
|
56
|
+
<ng-container *ngIf="withChildren; else noChildren">
|
|
57
|
+
<ng-content />
|
|
58
|
+
</ng-container>
|
|
59
|
+
<ng-template #noChildren>
|
|
60
|
+
<ngt-line-basic-material [color]="color" />
|
|
61
|
+
</ng-template>
|
|
62
|
+
</ngt-line-segments>
|
|
63
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
64
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgtsEdges, decorators: [{
|
|
65
|
+
type: Component,
|
|
66
|
+
args: [{
|
|
67
|
+
selector: 'ngts-edges',
|
|
68
|
+
standalone: true,
|
|
69
|
+
template: `
|
|
70
|
+
<ngt-line-segments [ref]="edgesRef" [raycast]="noop" ngtCompound>
|
|
71
|
+
<ng-container *ngIf="withChildren; else noChildren">
|
|
72
|
+
<ng-content />
|
|
73
|
+
</ng-container>
|
|
74
|
+
<ng-template #noChildren>
|
|
75
|
+
<ngt-line-basic-material [color]="color" />
|
|
76
|
+
</ng-template>
|
|
77
|
+
</ngt-line-segments>
|
|
78
|
+
`,
|
|
79
|
+
imports: [NgIf],
|
|
80
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
81
|
+
}]
|
|
82
|
+
}], propDecorators: { edgesRef: [{
|
|
83
|
+
type: Input
|
|
84
|
+
}], threshold: [{
|
|
85
|
+
type: Input
|
|
86
|
+
}], color: [{
|
|
87
|
+
type: Input
|
|
88
|
+
}], geometry: [{
|
|
89
|
+
type: Input
|
|
90
|
+
}], userData: [{
|
|
91
|
+
type: Input
|
|
92
|
+
}], withChildren: [{
|
|
93
|
+
type: Input
|
|
94
|
+
}] } });
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRnZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUtc29iYS9hYnN0cmFjdGlvbnMvc3JjL2xpYi9lZGdlcy9lZGdlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDdkMsT0FBTyxFQUFFLFNBQVMsRUFBRSxzQkFBc0IsRUFBRSxLQUFLLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFDakYsT0FBTyxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQWdCLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMvRSxPQUFPLEtBQUssS0FBSyxNQUFNLE9BQU8sQ0FBQztBQUMvQixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsWUFBWSxFQUFFLE1BQU0sT0FBTyxDQUFDOztBQUV4RCxNQUFNLENBQUMsRUFBRSxZQUFZLEVBQUUsaUJBQWlCLEVBQUUsQ0FBQyxDQUFDO0FBa0I1QyxNQUFNLE9BQU8sU0FBVSxTQUFRLFVBQVU7SUFoQnpDOztRQWlCYSxhQUFRLEdBQUcsWUFBWSxFQUFzQixDQUFDO1FBa0I5QyxpQkFBWSxHQUFHLEtBQUssQ0FBQztRQUVyQixTQUFJLEdBQUcsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDO0tBNkI5QjtJQS9DRyxJQUFhLFNBQVMsQ0FBQyxTQUFpQjtRQUNwQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQztJQUM1QixDQUFDO0lBRUQsSUFBYSxLQUFLLENBQUMsS0FBZ0M7UUFDL0MsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDeEIsQ0FBQztJQUVELElBQWEsUUFBUSxDQUFDLFFBQThCO1FBQ2hELElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFDO0lBQzNCLENBQUM7SUFFRCxJQUFhLFFBQVEsQ0FBQyxRQUFzQjtRQUN4QyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsUUFBUSxFQUFFLENBQUMsQ0FBQztJQUMzQixDQUFDO0lBTVEsVUFBVTtRQUNmLEtBQUssQ0FBQyxVQUFVLEVBQUUsQ0FBQztRQUNuQixJQUFJLENBQUMsR0FBRyxDQUFDO1lBQ0wsU0FBUyxFQUFFLEVBQUU7WUFDYixLQUFLLEVBQUUsT0FBTztZQUNkLFFBQVEsRUFBRSxFQUFFO1NBQ2YsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFFBQVE7UUFDSixJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDekIsQ0FBQztJQUVPLGFBQWE7UUFDakIsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsRUFBRSxDQUFDLFFBQVEsRUFBRSxFQUFFO1lBQ3BDLE1BQU0sTUFBTSxHQUFHLFFBQVEsQ0FBQyxNQUFvQixDQUFDO1lBQzdDLElBQUksTUFBTSxFQUFFO2dCQUNSLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLElBQUksTUFBTSxDQUFDLFFBQVEsQ0FBQztnQkFDckQsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsQ0FBQztnQkFDeEMsSUFBSSxJQUFJLEtBQUssUUFBUSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsSUFBSSxTQUFTLEtBQUssUUFBUSxDQUFDLFFBQVEsQ0FBQyxrQkFBa0IsQ0FBQyxFQUFFO29CQUNsRyxRQUFRLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxHQUFHLElBQUksQ0FBQztvQkFDeEMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxrQkFBa0IsQ0FBQyxHQUFHLFNBQVMsQ0FBQztvQkFDbEQsUUFBUSxDQUFDLFFBQVEsR0FBRyxJQUFJLEtBQUssQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDO2lCQUNoRTthQUNKO1FBQ0wsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDOztzR0FqRFEsU0FBUzswRkFBVCxTQUFTLGlQQWJSOzs7Ozs7Ozs7S0FTVCw0REFDUyxJQUFJOzJGQUdMLFNBQVM7a0JBaEJyQixTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxZQUFZO29CQUN0QixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFOzs7Ozs7Ozs7S0FTVDtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxJQUFJLENBQUM7b0JBQ2YsT0FBTyxFQUFFLENBQUMsc0JBQXNCLENBQUM7aUJBQ3BDOzhCQUVZLFFBQVE7c0JBQWhCLEtBQUs7Z0JBRU8sU0FBUztzQkFBckIsS0FBSztnQkFJTyxLQUFLO3NCQUFqQixLQUFLO2dCQUlPLFFBQVE7c0JBQXBCLEtBQUs7Z0JBSU8sUUFBUTtzQkFBcEIsS0FBSztnQkFJRyxZQUFZO3NCQUFwQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdJZiB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIENVU1RPTV9FTEVNRU5UU19TQ0hFTUEsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGV4dGVuZCwgaW5qZWN0Tmd0UmVmLCBOZ3RBbnlSZWNvcmQsIE5ndFJ4U3RvcmUgfSBmcm9tICdhbmd1bGFyLXRocmVlJztcbmltcG9ydCAqIGFzIFRIUkVFIGZyb20gJ3RocmVlJztcbmltcG9ydCB7IExpbmVCYXNpY01hdGVyaWFsLCBMaW5lU2VnbWVudHMgfSBmcm9tICd0aHJlZSc7XG5cbmV4dGVuZCh7IExpbmVTZWdtZW50cywgTGluZUJhc2ljTWF0ZXJpYWwgfSk7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnbmd0cy1lZGdlcycsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICB0ZW1wbGF0ZTogYFxuICAgICAgICA8bmd0LWxpbmUtc2VnbWVudHMgW3JlZl09XCJlZGdlc1JlZlwiIFtyYXljYXN0XT1cIm5vb3BcIiBuZ3RDb21wb3VuZD5cbiAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJ3aXRoQ2hpbGRyZW47IGVsc2Ugbm9DaGlsZHJlblwiPlxuICAgICAgICAgICAgICAgIDxuZy1jb250ZW50IC8+XG4gICAgICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgICAgIDxuZy10ZW1wbGF0ZSAjbm9DaGlsZHJlbj5cbiAgICAgICAgICAgICAgICA8bmd0LWxpbmUtYmFzaWMtbWF0ZXJpYWwgW2NvbG9yXT1cImNvbG9yXCIgLz5cbiAgICAgICAgICAgIDwvbmctdGVtcGxhdGU+XG4gICAgICAgIDwvbmd0LWxpbmUtc2VnbWVudHM+XG4gICAgYCxcbiAgICBpbXBvcnRzOiBbTmdJZl0sXG4gICAgc2NoZW1hczogW0NVU1RPTV9FTEVNRU5UU19TQ0hFTUFdLFxufSlcbmV4cG9ydCBjbGFzcyBOZ3RzRWRnZXMgZXh0ZW5kcyBOZ3RSeFN0b3JlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBASW5wdXQoKSBlZGdlc1JlZiA9IGluamVjdE5ndFJlZjxUSFJFRS5MaW5lU2VnbWVudHM+KCk7XG5cbiAgICBASW5wdXQoKSBzZXQgdGhyZXNob2xkKHRocmVzaG9sZDogbnVtYmVyKSB7XG4gICAgICAgIHRoaXMuc2V0KHsgdGhyZXNob2xkIH0pO1xuICAgIH1cblxuICAgIEBJbnB1dCgpIHNldCBjb2xvcihjb2xvcjogVEhSRUUuQ29sb3JSZXByZXNlbnRhdGlvbikge1xuICAgICAgICB0aGlzLnNldCh7IGNvbG9yIH0pO1xuICAgIH1cblxuICAgIEBJbnB1dCgpIHNldCBnZW9tZXRyeShnZW9tZXRyeTogVEhSRUUuQnVmZmVyR2VvbWV0cnkpIHtcbiAgICAgICAgdGhpcy5zZXQoeyBnZW9tZXRyeSB9KTtcbiAgICB9XG5cbiAgICBASW5wdXQoKSBzZXQgdXNlckRhdGEodXNlckRhdGE6IE5ndEFueVJlY29yZCkge1xuICAgICAgICB0aGlzLnNldCh7IHVzZXJEYXRhIH0pO1xuICAgIH1cblxuICAgIEBJbnB1dCgpIHdpdGhDaGlsZHJlbiA9IGZhbHNlO1xuXG4gICAgcmVhZG9ubHkgbm9vcCA9ICgpID0+IG51bGw7XG5cbiAgICBvdmVycmlkZSBpbml0aWFsaXplKCk6IHZvaWQge1xuICAgICAgICBzdXBlci5pbml0aWFsaXplKCk7XG4gICAgICAgIHRoaXMuc2V0KHtcbiAgICAgICAgICAgIHRocmVzaG9sZDogMTUsXG4gICAgICAgICAgICBjb2xvcjogJ2JsYWNrJyxcbiAgICAgICAgICAgIHVzZXJEYXRhOiB7fSxcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuc2V0dXBHZW9tZXRyeSgpO1xuICAgIH1cblxuICAgIHByaXZhdGUgc2V0dXBHZW9tZXRyeSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5ob2xkKHRoaXMuZWRnZXNSZWYuJCwgKHNlZ21lbnRzKSA9PiB7XG4gICAgICAgICAgICBjb25zdCBwYXJlbnQgPSBzZWdtZW50cy5wYXJlbnQgYXMgVEhSRUUuTWVzaDtcbiAgICAgICAgICAgIGlmIChwYXJlbnQpIHtcbiAgICAgICAgICAgICAgICBjb25zdCBnZW9tID0gdGhpcy5nZXQoJ2dlb21ldHJ5JykgfHwgcGFyZW50Lmdlb21ldHJ5O1xuICAgICAgICAgICAgICAgIGNvbnN0IHRocmVzaG9sZCA9IHRoaXMuZ2V0KCd0aHJlc2hvbGQnKTtcbiAgICAgICAgICAgICAgICBpZiAoZ2VvbSAhPT0gc2VnbWVudHMudXNlckRhdGFbJ2N1cnJlbnRHZW9tJ10gfHwgdGhyZXNob2xkICE9PSBzZWdtZW50cy51c2VyRGF0YVsnY3VycmVudFRocmVzaG9sZCddKSB7XG4gICAgICAgICAgICAgICAgICAgIHNlZ21lbnRzLnVzZXJEYXRhWydjdXJyZW50R2VvbSddID0gZ2VvbTtcbiAgICAgICAgICAgICAgICAgICAgc2VnbWVudHMudXNlckRhdGFbJ2N1cnJlbnRUaHJlc2hvbGQnXSA9IHRocmVzaG9sZDtcbiAgICAgICAgICAgICAgICAgICAgc2VnbWVudHMuZ2VvbWV0cnkgPSBuZXcgVEhSRUUuRWRnZXNHZW9tZXRyeShnZW9tLCB0aHJlc2hvbGQpO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgfVxufVxuIl19
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
export * from './lib/camera/camera-content';
|
|
2
|
+
export * from './lib/cube-camera/cube-camera';
|
|
2
3
|
export * from './lib/orthographic-camera/orthographic-camera';
|
|
3
4
|
export * from './lib/perspective-camera/perspective-camera';
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUtc29iYS9jYW1lcmFzL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLDZDQUE2QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvY2FtZXJhL2NhbWVyYS1jb250ZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2N1YmUtY2FtZXJhL2N1YmUtY2FtZXJhJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL29ydGhvZ3JhcGhpYy1jYW1lcmEvb3J0aG9ncmFwaGljLWNhbWVyYSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wZXJzcGVjdGl2ZS1jYW1lcmEvcGVyc3BlY3RpdmUtY2FtZXJhJztcbiJdfQ==
|
|
@@ -17,4 +17,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImpor
|
|
|
17
17
|
}], propDecorators: { ngtsCameraContent: [{
|
|
18
18
|
type: Input
|
|
19
19
|
}] } });
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FtZXJhLWNvbnRlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUtc29iYS9jYW1lcmFzL3NyYy9saWIvY2FtZXJhL2NhbWVyYS1jb250ZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBSXRFLE1BQU0sT0FBTyxpQkFBaUI7SUFEOUI7UUFFYSxhQUFRLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQy9CLHNCQUFpQixHQUFpQixFQUFFLENBQUM7S0FRakQ7SUFORyxNQUFNLENBQUMsc0JBQXNCLENBQ3pCLENBQW9CLEVBQ3BCLEdBQVk7UUFFWixPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDOzs4R0FUUSxpQkFBaUI7a0dBQWpCLGlCQUFpQjsyRkFBakIsaUJBQWlCO2tCQUQ3QixTQUFTO21CQUFDLEVBQUUsUUFBUSxFQUFFLGdDQUFnQyxFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUU7OEJBRzlELGlCQUFpQjtzQkFBekIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgaW5qZWN0LCBJbnB1dCwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCAqIGFzIFRIUkVFIGZyb20gJ3RocmVlJztcblxuQERpcmVjdGl2ZSh7IHNlbGVjdG9yOiAnbmctdGVtcGxhdGVbbmd0c0NhbWVyYUNvbnRlbnRdJywgc3RhbmRhbG9uZTogdHJ1ZSB9KVxuZXhwb3J0IGNsYXNzIE5ndHNDYW1lcmFDb250ZW50IHtcbiAgICByZWFkb25seSB0ZW1wbGF0ZSA9IGluamVjdChUZW1wbGF0ZVJlZik7XG4gICAgQElucHV0KCkgbmd0c0NhbWVyYUNvbnRlbnQ6IGJvb2xlYW4gfCAnJyA9ICcnO1xuXG4gICAgc3RhdGljIG5nVGVtcGxhdGVDb250ZXh0R3VhcmQoXG4gICAgICAgIF86IE5ndHNDYW1lcmFDb250ZW50LFxuICAgICAgICBjdHg6IHVua25vd25cbiAgICApOiBjdHggaXMgeyBmYm86IFRIUkVFLldlYkdMUmVuZGVyVGFyZ2V0OyBncm91cD86IFRIUkVFLkdyb3VwIH0ge1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import { NgIf, NgTemplateOutlet } from '@angular/common';
|
|
2
|
+
import { Component, ContentChild, CUSTOM_ELEMENTS_SCHEMA, ElementRef, inject, Input, ViewChild } from '@angular/core';
|
|
3
|
+
import { extend, injectBeforeRender, injectNgtRef, NgtArgs, NgtRxStore, NgtStore } from 'angular-three';
|
|
4
|
+
import { combineLatest, map } from 'rxjs';
|
|
5
|
+
import * as THREE from 'three';
|
|
6
|
+
import { CubeCamera, Group } from 'three';
|
|
7
|
+
import { NgtsCameraContent } from '../camera/camera-content';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
extend({ Group, CubeCamera });
|
|
10
|
+
export class NgtsCubeCamera extends NgtRxStore {
|
|
11
|
+
/** Number of frames to render, Infinity */
|
|
12
|
+
set frames(frames) {
|
|
13
|
+
this.set({ frames });
|
|
14
|
+
}
|
|
15
|
+
/** Resolution of the FBO, 256 */
|
|
16
|
+
set resolution(resolution) {
|
|
17
|
+
this.set({ resolution });
|
|
18
|
+
}
|
|
19
|
+
/** Camera near, 0.1 */
|
|
20
|
+
set near(near) {
|
|
21
|
+
this.set({ near });
|
|
22
|
+
}
|
|
23
|
+
/** Camera far, 1000 */
|
|
24
|
+
set far(far) {
|
|
25
|
+
this.set({ far });
|
|
26
|
+
}
|
|
27
|
+
/** Custom environment map that is temporarily set as the scenes background */
|
|
28
|
+
set envMap(envMap) {
|
|
29
|
+
this.set({ envMap });
|
|
30
|
+
}
|
|
31
|
+
/** Custom fog that is temporarily set as the scenes fog */
|
|
32
|
+
set fog(fog) {
|
|
33
|
+
this.set({ fog });
|
|
34
|
+
}
|
|
35
|
+
initialize() {
|
|
36
|
+
super.initialize();
|
|
37
|
+
this.set({
|
|
38
|
+
frames: Infinity,
|
|
39
|
+
resolution: 256,
|
|
40
|
+
near: 0.1,
|
|
41
|
+
far: 1000,
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
constructor() {
|
|
45
|
+
super();
|
|
46
|
+
this.cameraRef = injectNgtRef();
|
|
47
|
+
this.store = inject(NgtStore);
|
|
48
|
+
this.connect('fbo', this.select('resolution').pipe(map((resolution) => {
|
|
49
|
+
const fbo = new THREE.WebGLCubeRenderTarget(resolution);
|
|
50
|
+
fbo.texture.encoding = this.store.get('gl').outputEncoding;
|
|
51
|
+
fbo.texture.type = THREE.HalfFloatType;
|
|
52
|
+
return fbo;
|
|
53
|
+
})));
|
|
54
|
+
this.connect('cameraArgs', combineLatest([this.select('near'), this.select('far'), this.select('fbo')]));
|
|
55
|
+
let count = 0;
|
|
56
|
+
let originalFog;
|
|
57
|
+
let originalBackground;
|
|
58
|
+
injectBeforeRender(({ scene, gl }) => {
|
|
59
|
+
const { frames, envMap, fog } = this.get();
|
|
60
|
+
if (envMap &&
|
|
61
|
+
this.cameraRef.nativeElement &&
|
|
62
|
+
this.groupRef.nativeElement &&
|
|
63
|
+
(frames === Infinity || count < frames)) {
|
|
64
|
+
this.groupRef.nativeElement.visible = false;
|
|
65
|
+
originalFog = scene.fog;
|
|
66
|
+
originalBackground = scene.background;
|
|
67
|
+
scene.background = envMap || originalBackground;
|
|
68
|
+
scene.fog = fog || originalFog;
|
|
69
|
+
this.cameraRef.nativeElement.update(gl, scene);
|
|
70
|
+
scene.fog = originalFog;
|
|
71
|
+
scene.background = originalBackground;
|
|
72
|
+
this.groupRef.nativeElement.visible = true;
|
|
73
|
+
count++;
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
NgtsCubeCamera.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgtsCubeCamera, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
79
|
+
NgtsCubeCamera.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.0", type: NgtsCubeCamera, isStandalone: true, selector: "ngts-cube-camera", inputs: { frames: "frames", resolution: "resolution", near: "near", far: "far", envMap: "envMap", fog: "fog" }, queries: [{ propertyName: "cameraContent", first: true, predicate: NgtsCameraContent, descendants: true }], viewQueries: [{ propertyName: "groupRef", first: true, predicate: ["group"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: `
|
|
80
|
+
<ngt-group ngtCompound>
|
|
81
|
+
<ngt-cube-camera [ref]="cameraRef" *args="get('cameraArgs')" />
|
|
82
|
+
<ngt-group #group>
|
|
83
|
+
<ng-container
|
|
84
|
+
*ngIf="cameraContent && cameraContent.ngtsCameraContent && get('fbo')"
|
|
85
|
+
[ngTemplateOutlet]="cameraContent.template"
|
|
86
|
+
[ngTemplateOutletContext]="{ fbo: get('fbo').texture, group }"
|
|
87
|
+
/>
|
|
88
|
+
</ngt-group>
|
|
89
|
+
</ngt-group>
|
|
90
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: NgtArgs, selector: "[args]", inputs: ["args"] }] });
|
|
91
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgtsCubeCamera, decorators: [{
|
|
92
|
+
type: Component,
|
|
93
|
+
args: [{
|
|
94
|
+
selector: 'ngts-cube-camera',
|
|
95
|
+
standalone: true,
|
|
96
|
+
template: `
|
|
97
|
+
<ngt-group ngtCompound>
|
|
98
|
+
<ngt-cube-camera [ref]="cameraRef" *args="get('cameraArgs')" />
|
|
99
|
+
<ngt-group #group>
|
|
100
|
+
<ng-container
|
|
101
|
+
*ngIf="cameraContent && cameraContent.ngtsCameraContent && get('fbo')"
|
|
102
|
+
[ngTemplateOutlet]="cameraContent.template"
|
|
103
|
+
[ngTemplateOutletContext]="{ fbo: get('fbo').texture, group }"
|
|
104
|
+
/>
|
|
105
|
+
</ngt-group>
|
|
106
|
+
</ngt-group>
|
|
107
|
+
`,
|
|
108
|
+
imports: [NgIf, NgTemplateOutlet, NgtArgs],
|
|
109
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
110
|
+
}]
|
|
111
|
+
}], ctorParameters: function () { return []; }, propDecorators: { groupRef: [{
|
|
112
|
+
type: ViewChild,
|
|
113
|
+
args: ['group', { static: true }]
|
|
114
|
+
}], cameraContent: [{
|
|
115
|
+
type: ContentChild,
|
|
116
|
+
args: [NgtsCameraContent]
|
|
117
|
+
}], frames: [{
|
|
118
|
+
type: Input
|
|
119
|
+
}], resolution: [{
|
|
120
|
+
type: Input
|
|
121
|
+
}], near: [{
|
|
122
|
+
type: Input
|
|
123
|
+
}], far: [{
|
|
124
|
+
type: Input
|
|
125
|
+
}], envMap: [{
|
|
126
|
+
type: Input
|
|
127
|
+
}], fog: [{
|
|
128
|
+
type: Input
|
|
129
|
+
}] } });
|
|
130
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cube-camera.js","sourceRoot":"","sources":["../../../../../../../libs/angular-three-soba/cameras/src/lib/cube-camera/cube-camera.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgIf, NgTemplateOutlet } from '@angular/common';\nimport { Component, ContentChild, CUSTOM_ELEMENTS_SCHEMA, ElementRef, inject, Input, ViewChild } from '@angular/core';\nimport { extend, injectBeforeRender, injectNgtRef, NgtArgs, NgtRxStore, NgtStore } from 'angular-three';\nimport { combineLatest, map } from 'rxjs';\nimport * as THREE from 'three';\nimport { CubeCamera, Group } from 'three';\nimport { NgtsCameraContent } from '../camera/camera-content';\n\nextend({ Group, CubeCamera });\n\n@Component({\n    selector: 'ngts-cube-camera',\n    standalone: true,\n    template: `\n        <ngt-group ngtCompound>\n            <ngt-cube-camera [ref]=\"cameraRef\" *args=\"get('cameraArgs')\" />\n            <ngt-group #group>\n                <ng-container\n                    *ngIf=\"cameraContent && cameraContent.ngtsCameraContent && get('fbo')\"\n                    [ngTemplateOutlet]=\"cameraContent.template\"\n                    [ngTemplateOutletContext]=\"{ fbo: get('fbo').texture, group }\"\n                />\n            </ngt-group>\n        </ngt-group>\n    `,\n    imports: [NgIf, NgTemplateOutlet, NgtArgs],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsCubeCamera extends NgtRxStore {\n    @ViewChild('group', { static: true }) groupRef!: ElementRef<THREE.Group>;\n    @ContentChild(NgtsCameraContent) cameraContent?: NgtsCameraContent;\n\n    readonly cameraRef = injectNgtRef<THREE.CubeCamera>();\n\n    /** Number of frames to render, Infinity */\n    @Input() set frames(frames: number) {\n        this.set({ frames });\n    }\n    /** Resolution of the FBO, 256 */\n    @Input() set resolution(resolution: number) {\n        this.set({ resolution });\n    }\n    /** Camera near, 0.1 */\n    @Input() set near(near: number) {\n        this.set({ near });\n    }\n    /** Camera far, 1000 */\n    @Input() set far(far: number) {\n        this.set({ far });\n    }\n    /** Custom environment map that is temporarily set as the scenes background */\n    @Input() set envMap(envMap: THREE.Texture) {\n        this.set({ envMap });\n    }\n    /** Custom fog that is temporarily set as the scenes fog */\n    @Input() set fog(fog: THREE.Fog | THREE.FogExp2) {\n        this.set({ fog });\n    }\n\n    private readonly store = inject(NgtStore);\n\n    override initialize(): void {\n        super.initialize();\n        this.set({\n            frames: Infinity,\n            resolution: 256,\n            near: 0.1,\n            far: 1000,\n        });\n    }\n\n    constructor() {\n        super();\n        this.connect(\n            'fbo',\n            this.select('resolution').pipe(\n                map((resolution) => {\n                    const fbo = new THREE.WebGLCubeRenderTarget(resolution);\n                    fbo.texture.encoding = this.store.get('gl').outputEncoding;\n                    fbo.texture.type = THREE.HalfFloatType;\n                    return fbo;\n                })\n            )\n        );\n        this.connect('cameraArgs', combineLatest([this.select('near'), this.select('far'), this.select('fbo')]));\n\n        let count = 0;\n        let originalFog: THREE.Scene['fog'];\n        let originalBackground: THREE.Scene['background'];\n        injectBeforeRender(({ scene, gl }) => {\n            const { frames, envMap, fog } = this.get();\n            if (\n                envMap &&\n                this.cameraRef.nativeElement &&\n                this.groupRef.nativeElement &&\n                (frames === Infinity || count < frames)\n            ) {\n                this.groupRef.nativeElement.visible = false;\n                originalFog = scene.fog;\n                originalBackground = scene.background;\n                scene.background = envMap || originalBackground;\n                scene.fog = fog || originalFog;\n                this.cameraRef.nativeElement.update(gl, scene);\n                scene.fog = originalFog;\n                scene.background = originalBackground;\n                this.groupRef.nativeElement.visible = true;\n                count++;\n            }\n        });\n    }\n}\n"]}
|
|
@@ -1,4 +1,6 @@
|
|
|
1
1
|
export * from './lib/mesh-distort-material/mesh-distort-material';
|
|
2
2
|
export * from './lib/mesh-reflector-material/mesh-reflector-material';
|
|
3
|
+
export * from './lib/mesh-refraction-material/mesh-refraction-material';
|
|
4
|
+
export * from './lib/mesh-transmission-material/mesh-transmission-material';
|
|
3
5
|
export * from './lib/mesh-wobble-material/mesh-wobble-material';
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItdGhyZWUtc29iYS9tYXRlcmlhbHMvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyx1REFBdUQsQ0FBQztBQUN0RSxjQUFjLHlEQUF5RCxDQUFDO0FBQ3hFLGNBQWMsNkRBQTZELENBQUM7QUFDNUUsY0FBYyxpREFBaUQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL21lc2gtZGlzdG9ydC1tYXRlcmlhbC9tZXNoLWRpc3RvcnQtbWF0ZXJpYWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWVzaC1yZWZsZWN0b3ItbWF0ZXJpYWwvbWVzaC1yZWZsZWN0b3ItbWF0ZXJpYWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWVzaC1yZWZyYWN0aW9uLW1hdGVyaWFsL21lc2gtcmVmcmFjdGlvbi1tYXRlcmlhbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZXNoLXRyYW5zbWlzc2lvbi1tYXRlcmlhbC9tZXNoLXRyYW5zbWlzc2lvbi1tYXRlcmlhbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZXNoLXdvYmJsZS1tYXRlcmlhbC9tZXNoLXdvYmJsZS1tYXRlcmlhbCc7XG4iXX0=
|
|
@@ -0,0 +1,157 @@
|
|
|
1
|
+
import { NgIf } from '@angular/common';
|
|
2
|
+
import { Component, CUSTOM_ELEMENTS_SCHEMA, inject, Input } from '@angular/core';
|
|
3
|
+
import { extend, getLocalState, injectBeforeRender, injectNgtRef, NgtPush, NgtRxStore, NgtStore } from 'angular-three';
|
|
4
|
+
import { MeshRefractionMaterial } from 'angular-three-soba/shaders';
|
|
5
|
+
import { combineLatest, map } from 'rxjs';
|
|
6
|
+
import { MeshBVH, SAH } from 'three-mesh-bvh';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
extend({ MeshRefractionMaterial });
|
|
9
|
+
const isCubeTexture = (def) => def && def.isCubeTexture;
|
|
10
|
+
export class NgtsMeshRefractionMaterial extends NgtRxStore {
|
|
11
|
+
/** Environment map */
|
|
12
|
+
set envMap(envMap) {
|
|
13
|
+
this.set({ envMap });
|
|
14
|
+
}
|
|
15
|
+
/** Number of ray-cast bounces, it can be expensive to have too many, 2 */
|
|
16
|
+
set bounces(bounces) {
|
|
17
|
+
this.set({ bounces });
|
|
18
|
+
}
|
|
19
|
+
/** Refraction index, 2.4 */
|
|
20
|
+
set ior(ior) {
|
|
21
|
+
this.set({ ior });
|
|
22
|
+
}
|
|
23
|
+
/** Fresnel (strip light), 0 */
|
|
24
|
+
set fresnel(fresnel) {
|
|
25
|
+
this.set({ fresnel });
|
|
26
|
+
}
|
|
27
|
+
/** RGB shift intensity, can be expensive, 0 */
|
|
28
|
+
set aberrationStrength(aberrationStrength) {
|
|
29
|
+
this.set({ aberrationStrength });
|
|
30
|
+
}
|
|
31
|
+
/** Color, white */
|
|
32
|
+
set color(color) {
|
|
33
|
+
this.set({ color });
|
|
34
|
+
}
|
|
35
|
+
/** If this is on it uses fewer ray casts for the RGB shift sacrificing physical accuracy, true */
|
|
36
|
+
set fastChroma(fastChroma) {
|
|
37
|
+
this.set({ fastChroma });
|
|
38
|
+
}
|
|
39
|
+
initialize() {
|
|
40
|
+
super.initialize();
|
|
41
|
+
this.set({
|
|
42
|
+
aberrationStrength: 0,
|
|
43
|
+
fastChroma: true,
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
constructor() {
|
|
47
|
+
super();
|
|
48
|
+
this.materialRef = injectNgtRef();
|
|
49
|
+
this.defines$ = this.select('defines');
|
|
50
|
+
this.store = inject(NgtStore);
|
|
51
|
+
this.connect('defines', combineLatest([this.select('aberrationStrength'), this.select('fastChroma'), this.select('envMap')]).pipe(map(([aberrationStrength, fastChroma, envMap]) => {
|
|
52
|
+
const temp = {};
|
|
53
|
+
// Sampler2D and SamplerCube need different defines
|
|
54
|
+
const isCubeMap = isCubeTexture(envMap);
|
|
55
|
+
const w = (isCubeMap ? envMap.image[0]?.width : envMap.image.width) ?? 1024;
|
|
56
|
+
const cubeSize = w / 4;
|
|
57
|
+
const _lodMax = Math.floor(Math.log2(cubeSize));
|
|
58
|
+
const _cubeSize = Math.pow(2, _lodMax);
|
|
59
|
+
const width = 3 * Math.max(_cubeSize, 16 * 7);
|
|
60
|
+
const height = 4 * _cubeSize;
|
|
61
|
+
if (isCubeMap)
|
|
62
|
+
temp['ENVMAP_TYPE_CUBEM'] = '';
|
|
63
|
+
temp['CUBEUV_TEXEL_WIDTH'] = `${1.0 / width}`;
|
|
64
|
+
temp['CUBEUV_TEXEL_HEIGHT'] = `${1.0 / height}`;
|
|
65
|
+
temp['CUBEUV_MAX_MIP'] = `${_lodMax}.0`;
|
|
66
|
+
// Add defines from chromatic aberration
|
|
67
|
+
if (aberrationStrength > 0)
|
|
68
|
+
temp['CHROMATIC_ABERRATIONS'] = '';
|
|
69
|
+
if (fastChroma)
|
|
70
|
+
temp['FAST_CHROMA'] = '';
|
|
71
|
+
return temp;
|
|
72
|
+
})));
|
|
73
|
+
this.connect('resolution', this.store.select('size').pipe(map((size) => [size.width, size.height])));
|
|
74
|
+
injectBeforeRender(({ camera }) => {
|
|
75
|
+
if (this.materialRef.nativeElement) {
|
|
76
|
+
this.materialRef.nativeElement.viewMatrixInverse = camera.matrixWorld;
|
|
77
|
+
this.materialRef.nativeElement.projectionMatrixInverse = camera.projectionMatrixInverse;
|
|
78
|
+
}
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
ngOnInit() {
|
|
82
|
+
this.setupGeometry();
|
|
83
|
+
}
|
|
84
|
+
setupGeometry() {
|
|
85
|
+
this.hold(this.materialRef.$, (material) => {
|
|
86
|
+
const geometry = getLocalState(material).parent?.geometry;
|
|
87
|
+
if (geometry) {
|
|
88
|
+
material.bvh.updateFrom(new MeshBVH(geometry.toNonIndexed(), { lazyGeneration: false, strategy: SAH }));
|
|
89
|
+
}
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
NgtsMeshRefractionMaterial.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgtsMeshRefractionMaterial, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
94
|
+
NgtsMeshRefractionMaterial.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.0", type: NgtsMeshRefractionMaterial, isStandalone: true, selector: "ngts-mesh-refraction-material", inputs: { materialRef: "materialRef", envMap: "envMap", bounces: "bounces", ior: "ior", fresnel: "fresnel", aberrationStrength: "aberrationStrength", color: "color", fastChroma: "fastChroma" }, usesInheritance: true, ngImport: i0, template: `
|
|
95
|
+
<ngt-mesh-refraction-material
|
|
96
|
+
*ngIf="defines$ | ngtPush as defines"
|
|
97
|
+
[ref]="materialRef"
|
|
98
|
+
[defines]="defines"
|
|
99
|
+
[resolution]="get('resolution')"
|
|
100
|
+
[aberrationStrength]="get('aberrationStrength')"
|
|
101
|
+
[envMap]="get('envMap')"
|
|
102
|
+
[bounces]="get('bounces')"
|
|
103
|
+
[ior]="get('ior')"
|
|
104
|
+
[fresnel]="get('fresnel')"
|
|
105
|
+
[color]="get('color')"
|
|
106
|
+
[fastChroma]="get('fastChroma')"
|
|
107
|
+
ngtCompound
|
|
108
|
+
attach="material"
|
|
109
|
+
>
|
|
110
|
+
<ng-content />
|
|
111
|
+
</ngt-mesh-refraction-material>
|
|
112
|
+
`, isInline: true, dependencies: [{ kind: "pipe", type: NgtPush, name: "ngtPush" }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
113
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgtsMeshRefractionMaterial, decorators: [{
|
|
114
|
+
type: Component,
|
|
115
|
+
args: [{
|
|
116
|
+
selector: 'ngts-mesh-refraction-material',
|
|
117
|
+
standalone: true,
|
|
118
|
+
template: `
|
|
119
|
+
<ngt-mesh-refraction-material
|
|
120
|
+
*ngIf="defines$ | ngtPush as defines"
|
|
121
|
+
[ref]="materialRef"
|
|
122
|
+
[defines]="defines"
|
|
123
|
+
[resolution]="get('resolution')"
|
|
124
|
+
[aberrationStrength]="get('aberrationStrength')"
|
|
125
|
+
[envMap]="get('envMap')"
|
|
126
|
+
[bounces]="get('bounces')"
|
|
127
|
+
[ior]="get('ior')"
|
|
128
|
+
[fresnel]="get('fresnel')"
|
|
129
|
+
[color]="get('color')"
|
|
130
|
+
[fastChroma]="get('fastChroma')"
|
|
131
|
+
ngtCompound
|
|
132
|
+
attach="material"
|
|
133
|
+
>
|
|
134
|
+
<ng-content />
|
|
135
|
+
</ngt-mesh-refraction-material>
|
|
136
|
+
`,
|
|
137
|
+
imports: [NgtPush, NgIf],
|
|
138
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
139
|
+
}]
|
|
140
|
+
}], ctorParameters: function () { return []; }, propDecorators: { materialRef: [{
|
|
141
|
+
type: Input
|
|
142
|
+
}], envMap: [{
|
|
143
|
+
type: Input
|
|
144
|
+
}], bounces: [{
|
|
145
|
+
type: Input
|
|
146
|
+
}], ior: [{
|
|
147
|
+
type: Input
|
|
148
|
+
}], fresnel: [{
|
|
149
|
+
type: Input
|
|
150
|
+
}], aberrationStrength: [{
|
|
151
|
+
type: Input
|
|
152
|
+
}], color: [{
|
|
153
|
+
type: Input
|
|
154
|
+
}], fastChroma: [{
|
|
155
|
+
type: Input
|
|
156
|
+
}] } });
|
|
157
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mesh-refraction-material.js","sourceRoot":"","sources":["../../../../../../../libs/angular-three-soba/materials/src/lib/mesh-refraction-material/mesh-refraction-material.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgIf } from '@angular/common';\nimport { Component, CUSTOM_ELEMENTS_SCHEMA, inject, Input, OnInit } from '@angular/core';\nimport { extend, getLocalState, injectBeforeRender, injectNgtRef, NgtPush, NgtRxStore, NgtStore } from 'angular-three';\nimport { MeshRefractionMaterial } from 'angular-three-soba/shaders';\nimport { combineLatest, map } from 'rxjs';\nimport { MeshBVH, SAH } from 'three-mesh-bvh';\n\nextend({ MeshRefractionMaterial });\n\nconst isCubeTexture = (def: THREE.CubeTexture | THREE.Texture): def is THREE.CubeTexture =>\n    def && (def as THREE.CubeTexture).isCubeTexture;\n\n@Component({\n    selector: 'ngts-mesh-refraction-material',\n    standalone: true,\n    template: `\n        <ngt-mesh-refraction-material\n            *ngIf=\"defines$ | ngtPush as defines\"\n            [ref]=\"materialRef\"\n            [defines]=\"defines\"\n            [resolution]=\"get('resolution')\"\n            [aberrationStrength]=\"get('aberrationStrength')\"\n            [envMap]=\"get('envMap')\"\n            [bounces]=\"get('bounces')\"\n            [ior]=\"get('ior')\"\n            [fresnel]=\"get('fresnel')\"\n            [color]=\"get('color')\"\n            [fastChroma]=\"get('fastChroma')\"\n            ngtCompound\n            attach=\"material\"\n        >\n            <ng-content />\n        </ngt-mesh-refraction-material>\n    `,\n    imports: [NgtPush, NgIf],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsMeshRefractionMaterial extends NgtRxStore implements OnInit {\n    @Input() materialRef = injectNgtRef<typeof MeshRefractionMaterial.prototype>();\n    /** Environment map */\n    @Input() set envMap(envMap: THREE.CubeTexture | THREE.Texture) {\n        this.set({ envMap });\n    }\n    /** Number of ray-cast bounces, it can be expensive to have too many, 2 */\n    @Input() set bounces(bounces: number) {\n        this.set({ bounces });\n    }\n    /** Refraction index, 2.4 */\n    @Input() set ior(ior: number) {\n        this.set({ ior });\n    }\n    /** Fresnel (strip light), 0 */\n    @Input() set fresnel(fresnel: number) {\n        this.set({ fresnel });\n    }\n    /** RGB shift intensity, can be expensive, 0 */\n    @Input() set aberrationStrength(aberrationStrength: number) {\n        this.set({ aberrationStrength });\n    }\n    /** Color, white */\n    @Input() set color(color: THREE.ColorRepresentation) {\n        this.set({ color });\n    }\n    /** If this is on it uses fewer ray casts for the RGB shift sacrificing physical accuracy, true */\n    @Input() set fastChroma(fastChroma: boolean) {\n        this.set({ fastChroma });\n    }\n\n    readonly defines$ = this.select('defines');\n\n    private readonly store = inject(NgtStore);\n\n    override initialize(): void {\n        super.initialize();\n        this.set({\n            aberrationStrength: 0,\n            fastChroma: true,\n        });\n    }\n\n    constructor() {\n        super();\n        this.connect(\n            'defines',\n            combineLatest([this.select('aberrationStrength'), this.select('fastChroma'), this.select('envMap')]).pipe(\n                map(([aberrationStrength, fastChroma, envMap]) => {\n                    const temp = {} as { [key: string]: string };\n                    // Sampler2D and SamplerCube need different defines\n                    const isCubeMap = isCubeTexture(envMap);\n                    const w = (isCubeMap ? envMap.image[0]?.width : envMap.image.width) ?? 1024;\n                    const cubeSize = w / 4;\n                    const _lodMax = Math.floor(Math.log2(cubeSize));\n                    const _cubeSize = Math.pow(2, _lodMax);\n                    const width = 3 * Math.max(_cubeSize, 16 * 7);\n                    const height = 4 * _cubeSize;\n                    if (isCubeMap) temp['ENVMAP_TYPE_CUBEM'] = '';\n                    temp['CUBEUV_TEXEL_WIDTH'] = `${1.0 / width}`;\n                    temp['CUBEUV_TEXEL_HEIGHT'] = `${1.0 / height}`;\n                    temp['CUBEUV_MAX_MIP'] = `${_lodMax}.0`;\n                    // Add defines from chromatic aberration\n                    if (aberrationStrength > 0) temp['CHROMATIC_ABERRATIONS'] = '';\n                    if (fastChroma) temp['FAST_CHROMA'] = '';\n                    return temp;\n                })\n            )\n        );\n        this.connect('resolution', this.store.select('size').pipe(map((size) => [size.width, size.height])));\n\n        injectBeforeRender(({ camera }) => {\n            if (this.materialRef.nativeElement) {\n                (this.materialRef.nativeElement as any)!.viewMatrixInverse = camera.matrixWorld;\n                (this.materialRef.nativeElement as any)!.projectionMatrixInverse = camera.projectionMatrixInverse;\n            }\n        });\n    }\n\n    ngOnInit() {\n        this.setupGeometry();\n    }\n\n    private setupGeometry() {\n        this.hold(this.materialRef.$, (material) => {\n            const geometry = getLocalState(material).parent?.geometry;\n            if (geometry) {\n                (material as any).bvh.updateFrom(\n                    new MeshBVH(geometry.toNonIndexed(), { lazyGeneration: false, strategy: SAH } as any)\n                );\n            }\n        });\n    }\n}\n"]}
|