angular-three-soba 2.0.0-beta.237 → 2.0.0-beta.239
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/cameras/index.d.ts +1 -0
- package/cameras/lib/orthographic-camera.d.ts +35 -0
- package/esm2022/cameras/index.mjs +2 -1
- package/esm2022/cameras/lib/orthographic-camera.mjs +123 -0
- package/esm2022/misc/index.mjs +2 -1
- package/esm2022/staging/index.mjs +3 -1
- package/esm2022/staging/lib/environment.mjs +455 -0
- package/esm2022/staging/lib/float.mjs +70 -0
- package/fesm2022/angular-three-soba-cameras.mjs +116 -2
- package/fesm2022/angular-three-soba-cameras.mjs.map +1 -1
- package/fesm2022/angular-three-soba-misc.mjs +16 -1
- package/fesm2022/angular-three-soba-misc.mjs.map +1 -1
- package/fesm2022/angular-three-soba-staging.mjs +519 -3
- package/fesm2022/angular-three-soba-staging.mjs.map +1 -1
- package/misc/index.d.ts +1 -0
- package/package.json +17 -11
- package/staging/index.d.ts +2 -0
- package/staging/lib/environment.d.ts +168 -0
- package/staging/lib/float.d.ts +19 -0
package/cameras/index.d.ts
CHANGED
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { TemplateRef } from '@angular/core';
|
|
2
|
+
import { Group, OrthographicCamera, Texture } from 'three';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export interface NgtsOrthographicCameraOptions extends Partial<OrthographicCamera> {
|
|
5
|
+
/** Registers the camera as the system default, fiber will start rendering with it */
|
|
6
|
+
makeDefault?: boolean;
|
|
7
|
+
/** Making it manual will stop responsiveness and you have to calculate aspect ratio yourself. */
|
|
8
|
+
manual?: boolean;
|
|
9
|
+
/** Number of frames to render, Infinity */
|
|
10
|
+
frames: number;
|
|
11
|
+
/** Resolution of the FBO, 256 */
|
|
12
|
+
resolution: number;
|
|
13
|
+
/** Optional environment map for functional use */
|
|
14
|
+
envMap?: Texture;
|
|
15
|
+
}
|
|
16
|
+
export declare class NgtsOrthographicCamera {
|
|
17
|
+
cameraRef: import("@angular/core").InputSignal<import("angular-three").NgtInjectedRef<OrthographicCamera>>;
|
|
18
|
+
options: import("@angular/core").InputSignalWithTransform<NgtsOrthographicCameraOptions, "" | Partial<NgtsOrthographicCameraOptions>>;
|
|
19
|
+
parameters: import("@angular/core").Signal<NgtsOrthographicCameraOptions>;
|
|
20
|
+
content: import("@angular/core").Signal<TemplateRef<any> | undefined>;
|
|
21
|
+
withTextureContent: import("@angular/core").Signal<TemplateRef<any> | undefined>;
|
|
22
|
+
groupRef: import("angular-three").NgtInjectedRef<Group<import("three").Object3DEventMap>>;
|
|
23
|
+
private autoEffect;
|
|
24
|
+
private store;
|
|
25
|
+
private camera;
|
|
26
|
+
size: import("@angular/core").Signal<import("angular-three").NgtSize>;
|
|
27
|
+
private manual;
|
|
28
|
+
private makeDefault;
|
|
29
|
+
private resolution;
|
|
30
|
+
private fbo;
|
|
31
|
+
texture: import("@angular/core").Signal<Texture>;
|
|
32
|
+
constructor();
|
|
33
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NgtsOrthographicCamera, never>;
|
|
34
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NgtsOrthographicCamera, "ngts-orthographic-camera", never, { "cameraRef": { "alias": "cameraRef"; "required": false; "isSignal": true; }; "options": { "alias": "options"; "required": false; "isSignal": true; }; }, {}, ["content", "withTextureContent"], never, true, never>;
|
|
35
|
+
}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
1
|
export * from './lib/camera-content';
|
|
2
|
+
export * from './lib/orthographic-camera';
|
|
2
3
|
export * from './lib/perspective-camera';
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL3NvYmEvY2FtZXJhcy9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsMEJBQTBCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9jYW1lcmEtY29udGVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9vcnRob2dyYXBoaWMtY2FtZXJhJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3BlcnNwZWN0aXZlLWNhbWVyYSc7XG4iXX0=
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import { NgTemplateOutlet } from '@angular/common';
|
|
2
|
+
import { CUSTOM_ELEMENTS_SCHEMA, ChangeDetectionStrategy, Component, TemplateRef, afterNextRender, computed, contentChild, input, untracked, } from '@angular/core';
|
|
3
|
+
import { extend, injectBeforeRender, injectNgtRef, injectNgtStore, makeParameters } from 'angular-three';
|
|
4
|
+
import { NgtsContent, injectFBO } from 'angular-three-soba/misc';
|
|
5
|
+
import { injectAutoEffect } from 'ngxtension/auto-effect';
|
|
6
|
+
import { mergeInputs } from 'ngxtension/inject-inputs';
|
|
7
|
+
import { Group, OrthographicCamera } from 'three';
|
|
8
|
+
import { NgtsCameraContentWithFboTexture } from './camera-content';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
extend({ OrthographicCamera, Group });
|
|
11
|
+
const defaultOptions = {
|
|
12
|
+
frames: Infinity,
|
|
13
|
+
resolution: 256,
|
|
14
|
+
makeDefault: false,
|
|
15
|
+
manual: false,
|
|
16
|
+
};
|
|
17
|
+
export class NgtsOrthographicCamera {
|
|
18
|
+
constructor() {
|
|
19
|
+
this.cameraRef = input(injectNgtRef());
|
|
20
|
+
this.options = input(defaultOptions, { transform: mergeInputs(defaultOptions) });
|
|
21
|
+
this.parameters = makeParameters(this.options, ['envMap', 'makeDefault', 'manual', 'frames', 'resolution']);
|
|
22
|
+
this.content = contentChild(NgtsContent, { read: TemplateRef });
|
|
23
|
+
this.withTextureContent = contentChild(NgtsCameraContentWithFboTexture, { read: TemplateRef });
|
|
24
|
+
this.groupRef = injectNgtRef();
|
|
25
|
+
this.autoEffect = injectAutoEffect();
|
|
26
|
+
this.store = injectNgtStore();
|
|
27
|
+
this.camera = this.store.select('camera');
|
|
28
|
+
this.size = this.store.select('size');
|
|
29
|
+
this.manual = computed(() => this.options().manual);
|
|
30
|
+
this.makeDefault = computed(() => this.options().makeDefault);
|
|
31
|
+
this.resolution = computed(() => this.options().resolution);
|
|
32
|
+
this.fbo = injectFBO(() => ({ width: this.resolution() }));
|
|
33
|
+
this.texture = computed(() => this.fbo().texture);
|
|
34
|
+
afterNextRender(() => {
|
|
35
|
+
this.autoEffect(() => {
|
|
36
|
+
if (!this.manual()) {
|
|
37
|
+
this.cameraRef().nativeElement.updateProjectionMatrix();
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
this.autoEffect(() => {
|
|
41
|
+
if (this.makeDefault()) {
|
|
42
|
+
const oldCam = untracked(this.camera);
|
|
43
|
+
this.store.update({ camera: this.cameraRef().nativeElement });
|
|
44
|
+
return () => this.store.update(() => ({ camera: oldCam }));
|
|
45
|
+
}
|
|
46
|
+
return;
|
|
47
|
+
});
|
|
48
|
+
this.cameraRef().nativeElement.updateProjectionMatrix();
|
|
49
|
+
});
|
|
50
|
+
let count = 0;
|
|
51
|
+
let oldEnvMap = null;
|
|
52
|
+
injectBeforeRender(({ gl, scene }) => {
|
|
53
|
+
const [{ frames, envMap }, group, camera, fbo] = [
|
|
54
|
+
this.options(),
|
|
55
|
+
this.groupRef.nativeElement,
|
|
56
|
+
this.cameraRef().nativeElement,
|
|
57
|
+
this.fbo(),
|
|
58
|
+
];
|
|
59
|
+
if (this.withTextureContent() && group && camera && fbo && (frames === Infinity || count < frames)) {
|
|
60
|
+
group.visible = false;
|
|
61
|
+
gl.setRenderTarget(fbo);
|
|
62
|
+
oldEnvMap = scene.background;
|
|
63
|
+
if (envMap)
|
|
64
|
+
scene.background = envMap;
|
|
65
|
+
gl.render(scene, camera);
|
|
66
|
+
scene.background = oldEnvMap;
|
|
67
|
+
gl.setRenderTarget(null);
|
|
68
|
+
group.visible = true;
|
|
69
|
+
count++;
|
|
70
|
+
}
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: NgtsOrthographicCamera, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
74
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.3", type: NgtsOrthographicCamera, isStandalone: true, selector: "ngts-orthographic-camera", inputs: { cameraRef: { classPropertyName: "cameraRef", publicName: "cameraRef", isSignal: true, isRequired: false, transformFunction: null }, options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, queries: [{ propertyName: "content", first: true, predicate: NgtsContent, descendants: true, read: TemplateRef, isSignal: true }, { propertyName: "withTextureContent", first: true, predicate: NgtsCameraContentWithFboTexture, descendants: true, read: TemplateRef, isSignal: true }], ngImport: i0, template: `
|
|
75
|
+
<ngt-orthographic-camera
|
|
76
|
+
[ref]="cameraRef()"
|
|
77
|
+
[left]="size().width / -2"
|
|
78
|
+
[right]="size().width / 2"
|
|
79
|
+
[top]="size().height / 2"
|
|
80
|
+
[bottom]="size().height / -2"
|
|
81
|
+
[parameters]="parameters()"
|
|
82
|
+
>
|
|
83
|
+
@if (content(); as template) {
|
|
84
|
+
<ng-container [ngTemplateOutlet]="template" />
|
|
85
|
+
}
|
|
86
|
+
</ngt-orthographic-camera>
|
|
87
|
+
<ngt-group [ref]="groupRef">
|
|
88
|
+
@if (withTextureContent(); as withTextureTemplate) {
|
|
89
|
+
<ng-container [ngTemplateOutlet]="withTextureTemplate" [ngTemplateOutletContext]="{ $implicit: texture }" />
|
|
90
|
+
}
|
|
91
|
+
</ngt-group>
|
|
92
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
93
|
+
}
|
|
94
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: NgtsOrthographicCamera, decorators: [{
|
|
95
|
+
type: Component,
|
|
96
|
+
args: [{
|
|
97
|
+
selector: 'ngts-orthographic-camera',
|
|
98
|
+
standalone: true,
|
|
99
|
+
template: `
|
|
100
|
+
<ngt-orthographic-camera
|
|
101
|
+
[ref]="cameraRef()"
|
|
102
|
+
[left]="size().width / -2"
|
|
103
|
+
[right]="size().width / 2"
|
|
104
|
+
[top]="size().height / 2"
|
|
105
|
+
[bottom]="size().height / -2"
|
|
106
|
+
[parameters]="parameters()"
|
|
107
|
+
>
|
|
108
|
+
@if (content(); as template) {
|
|
109
|
+
<ng-container [ngTemplateOutlet]="template" />
|
|
110
|
+
}
|
|
111
|
+
</ngt-orthographic-camera>
|
|
112
|
+
<ngt-group [ref]="groupRef">
|
|
113
|
+
@if (withTextureContent(); as withTextureTemplate) {
|
|
114
|
+
<ng-container [ngTemplateOutlet]="withTextureTemplate" [ngTemplateOutletContext]="{ $implicit: texture }" />
|
|
115
|
+
}
|
|
116
|
+
</ngt-group>
|
|
117
|
+
`,
|
|
118
|
+
imports: [NgTemplateOutlet],
|
|
119
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
120
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
121
|
+
}]
|
|
122
|
+
}], ctorParameters: () => [] });
|
|
123
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"orthographic-camera.js","sourceRoot":"","sources":["../../../../../../libs/soba/cameras/src/lib/orthographic-camera.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport {\n\tCUSTOM_ELEMENTS_SCHEMA,\n\tChangeDetectionStrategy,\n\tComponent,\n\tTemplateRef,\n\tafterNextRender,\n\tcomputed,\n\tcontentChild,\n\tinput,\n\tuntracked,\n} from '@angular/core';\nimport { extend, injectBeforeRender, injectNgtRef, injectNgtStore, makeParameters } from 'angular-three';\nimport { NgtsContent, injectFBO } from 'angular-three-soba/misc';\nimport { injectAutoEffect } from 'ngxtension/auto-effect';\nimport { mergeInputs } from 'ngxtension/inject-inputs';\nimport { Color, Group, OrthographicCamera, Texture } from 'three';\nimport { NgtsCameraContentWithFboTexture } from './camera-content';\n\nextend({ OrthographicCamera, Group });\n\nexport interface NgtsOrthographicCameraOptions extends Partial<OrthographicCamera> {\n\t/** Registers the camera as the system default, fiber will start rendering with it */\n\tmakeDefault?: boolean;\n\t/** Making it manual will stop responsiveness and you have to calculate aspect ratio yourself. */\n\tmanual?: boolean;\n\t/** Number of frames to render, Infinity */\n\tframes: number;\n\t/** Resolution of the FBO, 256 */\n\tresolution: number;\n\t/** Optional environment map for functional use */\n\tenvMap?: Texture;\n}\n\nconst defaultOptions: NgtsOrthographicCameraOptions = {\n\tframes: Infinity,\n\tresolution: 256,\n\tmakeDefault: false,\n\tmanual: false,\n};\n\n@Component({\n\tselector: 'ngts-orthographic-camera',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ngt-orthographic-camera\n\t\t\t[ref]=\"cameraRef()\"\n\t\t\t[left]=\"size().width / -2\"\n\t\t\t[right]=\"size().width / 2\"\n\t\t\t[top]=\"size().height / 2\"\n\t\t\t[bottom]=\"size().height / -2\"\n\t\t\t[parameters]=\"parameters()\"\n\t\t>\n\t\t\t@if (content(); as template) {\n\t\t\t\t<ng-container [ngTemplateOutlet]=\"template\" />\n\t\t\t}\n\t\t</ngt-orthographic-camera>\n\t\t<ngt-group [ref]=\"groupRef\">\n\t\t\t@if (withTextureContent(); as withTextureTemplate) {\n\t\t\t\t<ng-container [ngTemplateOutlet]=\"withTextureTemplate\" [ngTemplateOutletContext]=\"{ $implicit: texture }\" />\n\t\t\t}\n\t\t</ngt-group>\n\t`,\n\timports: [NgTemplateOutlet],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsOrthographicCamera {\n\tcameraRef = input(injectNgtRef<OrthographicCamera>());\n\toptions = input(defaultOptions, { transform: mergeInputs(defaultOptions) });\n\tparameters = makeParameters(this.options, ['envMap', 'makeDefault', 'manual', 'frames', 'resolution']);\n\n\tcontent = contentChild(NgtsContent, { read: TemplateRef });\n\twithTextureContent = contentChild(NgtsCameraContentWithFboTexture, { read: TemplateRef });\n\n\tgroupRef = injectNgtRef<Group>();\n\n\tprivate autoEffect = injectAutoEffect();\n\tprivate store = injectNgtStore();\n\n\tprivate camera = this.store.select('camera');\n\tsize = this.store.select('size');\n\n\tprivate manual = computed(() => this.options().manual);\n\tprivate makeDefault = computed(() => this.options().makeDefault);\n\tprivate resolution = computed(() => this.options().resolution);\n\tprivate fbo = injectFBO(() => ({ width: this.resolution() }));\n\ttexture = computed(() => this.fbo().texture);\n\n\tconstructor() {\n\t\tafterNextRender(() => {\n\t\t\tthis.autoEffect(() => {\n\t\t\t\tif (!this.manual()) {\n\t\t\t\t\tthis.cameraRef().nativeElement.updateProjectionMatrix();\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tthis.autoEffect(() => {\n\t\t\t\tif (this.makeDefault()) {\n\t\t\t\t\tconst oldCam = untracked(this.camera);\n\t\t\t\t\tthis.store.update({ camera: this.cameraRef().nativeElement });\n\t\t\t\t\treturn () => this.store.update(() => ({ camera: oldCam }));\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t});\n\n\t\t\tthis.cameraRef().nativeElement.updateProjectionMatrix();\n\t\t});\n\n\t\tlet count = 0;\n\t\tlet oldEnvMap: Color | Texture | null = null;\n\t\tinjectBeforeRender(({ gl, scene }) => {\n\t\t\tconst [{ frames, envMap }, group, camera, fbo] = [\n\t\t\t\tthis.options(),\n\t\t\t\tthis.groupRef.nativeElement,\n\t\t\t\tthis.cameraRef().nativeElement,\n\t\t\t\tthis.fbo(),\n\t\t\t];\n\t\t\tif (this.withTextureContent() && group && camera && fbo && (frames === Infinity || count < frames)) {\n\t\t\t\tgroup.visible = false;\n\t\t\t\tgl.setRenderTarget(fbo);\n\t\t\t\toldEnvMap = scene.background;\n\t\t\t\tif (envMap) scene.background = envMap;\n\t\t\t\tgl.render(scene, camera);\n\t\t\t\tscene.background = oldEnvMap;\n\t\t\t\tgl.setRenderTarget(null);\n\t\t\t\tgroup.visible = true;\n\t\t\t\tcount++;\n\t\t\t}\n\t\t});\n\t}\n}\n"]}
|
package/esm2022/misc/index.mjs
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
export * from './lib/animations';
|
|
2
2
|
export * from './lib/content';
|
|
3
|
+
export * from './lib/deprecated';
|
|
3
4
|
export * from './lib/fbo';
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL3NvYmEvbWlzYy9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsV0FBVyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvYW5pbWF0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb250ZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RlcHJlY2F0ZWQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmJvJztcbiJdfQ==
|
|
@@ -1,2 +1,4 @@
|
|
|
1
|
+
export * from './lib/environment';
|
|
2
|
+
export * from './lib/float';
|
|
1
3
|
export * from './lib/matcap-texture';
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL3NvYmEvc3RhZ2luZy9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLHNCQUFzQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvZW52aXJvbm1lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmxvYXQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWF0Y2FwLXRleHR1cmUnO1xuIl19
|