angular-three-soba 2.10.7 → 2.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/lib/catmull-rom-line.d.ts +38 -38
- package/abstractions/lib/edges.d.ts +58 -58
- package/abstractions/lib/gradient-texture.d.ts +1 -1
- package/abstractions/lib/grid.d.ts +33 -33
- package/abstractions/lib/line.d.ts +2 -2
- package/abstractions/lib/prism-geometry.d.ts +2 -2
- package/abstractions/lib/rounded-box.d.ts +3 -2
- package/abstractions/lib/text-3d.d.ts +36 -36
- package/esm2022/abstractions/lib/rounded-box.mjs +11 -4
- package/fesm2022/angular-three-soba-abstractions.mjs +9 -2
- package/fesm2022/angular-three-soba-abstractions.mjs.map +1 -1
- package/materials/lib/custom-shader-material.d.ts +3 -3
- package/materials/lib/mesh-portal-material.d.ts +25 -25
- package/materials/lib/mesh-refraction-material.d.ts +2 -2
- package/materials/lib/mesh-transmission-material.d.ts +1 -1
- package/package.json +7 -7
|
@@ -16,7 +16,7 @@ export type NgtsLineOptions = Omit<LineMaterialParameters, 'vertexColors' | 'col
|
|
|
16
16
|
color?: ColorRepresentation;
|
|
17
17
|
};
|
|
18
18
|
export declare class NgtsLine {
|
|
19
|
-
points: import("@angular/core").InputSignal<(number | Vector3 | [number, number, number] |
|
|
19
|
+
points: import("@angular/core").InputSignal<(number | Vector3 | Vector2 | [number, number, number] | [number, number])[]>;
|
|
20
20
|
options: import("@angular/core").InputSignalWithTransform<NgtsLineOptions, "" | Partial<NgtsLineOptions>>;
|
|
21
21
|
parameters: import("@angular/core").Signal<Omit<NgtsLineOptions, "color" | "dashed" | "linewidth" | "vertexColors" | "lineWidth" | "segments">>;
|
|
22
22
|
lineRef: import("@angular/core").Signal<ElementRef<Line2 | LineSegments2> | undefined>;
|
|
@@ -33,7 +33,7 @@ export declare class NgtsLine {
|
|
|
33
33
|
line2: import("@angular/core").Signal<LineSegments2>;
|
|
34
34
|
lineMaterial: LineMaterial;
|
|
35
35
|
protected actualLineWidth: import("@angular/core").Signal<number>;
|
|
36
|
-
protected itemSize: import("@angular/core").Signal<
|
|
36
|
+
protected itemSize: import("@angular/core").Signal<4 | 3>;
|
|
37
37
|
lineGeometry: import("@angular/core").Signal<LineSegmentsGeometry>;
|
|
38
38
|
onGeometryAttached({ parent }: NgtAfterAttach<LineGeometry, Line2 | LineSegments2>): void;
|
|
39
39
|
constructor();
|
|
@@ -14,13 +14,13 @@ export declare class NgtsPrismGeometry {
|
|
|
14
14
|
depth: number;
|
|
15
15
|
/** Height */
|
|
16
16
|
height: number;
|
|
17
|
-
|
|
17
|
+
bevelSegments?: number | undefined;
|
|
18
18
|
steps?: number | undefined;
|
|
19
|
+
curveSegments?: number | undefined;
|
|
19
20
|
bevelEnabled?: boolean | undefined;
|
|
20
21
|
bevelThickness?: number | undefined;
|
|
21
22
|
bevelSize?: number | undefined;
|
|
22
23
|
bevelOffset?: number | undefined;
|
|
23
|
-
bevelSegments?: number | undefined;
|
|
24
24
|
extrudePath?: import("three").Curve<import("three").Vector3> | undefined;
|
|
25
25
|
UVGenerator?: import("three").UVGenerator | undefined;
|
|
26
26
|
}>;
|
|
@@ -2,6 +2,7 @@ import { ElementRef } from '@angular/core';
|
|
|
2
2
|
import { NgtMesh } from 'angular-three';
|
|
3
3
|
import { ExtrudeGeometry, Mesh, Shape } from 'three';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "angular-three";
|
|
5
6
|
export interface NgtsRoundedBoxOptions extends Partial<NgtMesh> {
|
|
6
7
|
width: number;
|
|
7
8
|
height: number;
|
|
@@ -14,7 +15,7 @@ export interface NgtsRoundedBoxOptions extends Partial<NgtMesh> {
|
|
|
14
15
|
}
|
|
15
16
|
export declare class NgtsRoundedBox {
|
|
16
17
|
options: import("@angular/core").InputSignalWithTransform<NgtsRoundedBoxOptions, "" | Partial<NgtsRoundedBoxOptions>>;
|
|
17
|
-
parameters: import("@angular/core").Signal<Omit<NgtsRoundedBoxOptions, "width" | "height" | "depth" | "
|
|
18
|
+
parameters: import("@angular/core").Signal<Omit<NgtsRoundedBoxOptions, "width" | "height" | "depth" | "radius" | "smoothness" | "bevelSegments" | "steps" | "creaseAngle">>;
|
|
18
19
|
private width;
|
|
19
20
|
private height;
|
|
20
21
|
private depth;
|
|
@@ -37,5 +38,5 @@ export declare class NgtsRoundedBox {
|
|
|
37
38
|
}>;
|
|
38
39
|
constructor();
|
|
39
40
|
static ɵfac: i0.ɵɵFactoryDeclaration<NgtsRoundedBox, never>;
|
|
40
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<NgtsRoundedBox, "ngts-rounded-box", never, { "options": { "alias": "options"; "required": false; "isSignal": true; }; }, {}, never, ["*"], true,
|
|
41
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NgtsRoundedBox, "ngts-rounded-box", never, { "options": { "alias": "options"; "required": false; "isSignal": true; }; }, {}, never, ["*"], true, [{ directive: typeof i1.NgtObjectEvents; inputs: {}; outputs: {}; }]>;
|
|
41
42
|
}
|
|
@@ -15,11 +15,21 @@ export declare class NgtsText3D {
|
|
|
15
15
|
removeEventListener: (<TEventKey extends keyof import("angular-three").NgtNodeEventMap<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>>(type: TEventKey, listener: (this: import("angular-three").NgtNodeElement<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>, typeof Mesh>, ev: import("angular-three").NgtNodeEventMap<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>[TEventKey]) => any) => void) & (<TEventKey extends keyof import("angular-three").NgtAllObject3DEventsMap>(type: TEventKey, listener: (this: any, ev: import("angular-three").NgtAllObject3DEventsMap[TEventKey]) => any) => void);
|
|
16
16
|
attach: string | string[] | import("angular-three").NgtAttachFunction;
|
|
17
17
|
__ngt_args__: [geometry?: import("three").BufferGeometry<import("three").NormalBufferAttributes> | undefined, material?: import("three").Material | import("three").Material[] | undefined];
|
|
18
|
+
readonly isMesh?: true | undefined;
|
|
19
|
+
readonly type?: string | undefined;
|
|
20
|
+
geometry?: import("three").BufferGeometry<import("three").NormalBufferAttributes> | undefined;
|
|
21
|
+
material?: import("three").Material | import("three").Material[] | undefined;
|
|
22
|
+
morphTargetInfluences?: number[] | undefined;
|
|
23
|
+
morphTargetDictionary?: {
|
|
24
|
+
[key: string]: number;
|
|
25
|
+
} | undefined;
|
|
26
|
+
updateMorphTargets?: (() => void) | undefined;
|
|
27
|
+
getVertexPosition?: ((index: number, target: import("three").Vector3) => import("three").Vector3) | undefined;
|
|
28
|
+
toJSON?: ((meta?: import("three").JSONMeta) => import("three").MeshJSON) | undefined;
|
|
18
29
|
readonly isObject3D?: true | undefined;
|
|
19
30
|
readonly id?: number | undefined;
|
|
20
31
|
uuid?: string | undefined;
|
|
21
32
|
name?: string | undefined;
|
|
22
|
-
readonly type?: string | undefined;
|
|
23
33
|
parent?: import("three").Object3D<import("three").Object3DEventMap> | null | undefined;
|
|
24
34
|
children?: import("three").Object3D<import("three").Object3DEventMap>[] | undefined;
|
|
25
35
|
readonly modelViewMatrix?: import("three").Matrix4 | undefined;
|
|
@@ -80,20 +90,10 @@ export declare class NgtsText3D {
|
|
|
80
90
|
updateMatrix?: (() => void) | undefined;
|
|
81
91
|
updateMatrixWorld?: ((force?: boolean) => void) | undefined;
|
|
82
92
|
updateWorldMatrix?: ((updateParents: boolean, updateChildren: boolean) => void) | undefined;
|
|
83
|
-
toJSON?: ((meta?: import("three").JSONMeta) => import("three").MeshJSON) | undefined;
|
|
84
93
|
clone?: ((recursive?: boolean) => Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>) | undefined;
|
|
85
94
|
copy?: ((object: import("three").Object3D, recursive?: boolean) => Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>) | undefined;
|
|
86
95
|
hasEventListener?: (<T extends keyof import("three").Object3DEventMap>(type: T, listener: import("three").EventListener<import("three").Object3DEventMap[T], T, Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>) => boolean) | undefined;
|
|
87
96
|
dispatchEvent?: (<T extends keyof import("three").Object3DEventMap>(event: import("three").BaseEvent<T> & import("three").Object3DEventMap[T]) => void) | undefined;
|
|
88
|
-
geometry?: import("three").BufferGeometry<import("three").NormalBufferAttributes> | undefined;
|
|
89
|
-
material?: import("three").Material | import("three").Material[] | undefined;
|
|
90
|
-
readonly isMesh?: true | undefined;
|
|
91
|
-
morphTargetInfluences?: number[] | undefined;
|
|
92
|
-
morphTargetDictionary?: {
|
|
93
|
-
[key: string]: number;
|
|
94
|
-
} | undefined;
|
|
95
|
-
updateMorphTargets?: (() => void) | undefined;
|
|
96
|
-
getVertexPosition?: ((index: number, target: import("three").Vector3) => import("three").Vector3) | undefined;
|
|
97
97
|
position: import("angular-three").NgtVector3;
|
|
98
98
|
up: import("angular-three").NgtVector3;
|
|
99
99
|
scale: import("angular-three").NgtVector3;
|
|
@@ -108,11 +108,21 @@ export declare class NgtsText3D {
|
|
|
108
108
|
removeEventListener: (<TEventKey extends keyof import("angular-three").NgtNodeEventMap<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>>(type: TEventKey, listener: (this: import("angular-three").NgtNodeElement<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>, typeof Mesh>, ev: import("angular-three").NgtNodeEventMap<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>[TEventKey]) => any) => void) & (<TEventKey extends keyof import("angular-three").NgtAllObject3DEventsMap>(type: TEventKey, listener: (this: any, ev: import("angular-three").NgtAllObject3DEventsMap[TEventKey]) => any) => void);
|
|
109
109
|
attach: string | string[] | import("angular-three").NgtAttachFunction;
|
|
110
110
|
__ngt_args__: [geometry?: import("three").BufferGeometry<import("three").NormalBufferAttributes> | undefined, material?: import("three").Material | import("three").Material[] | undefined];
|
|
111
|
+
readonly isMesh?: true | undefined;
|
|
112
|
+
readonly type?: string | undefined;
|
|
113
|
+
geometry?: import("three").BufferGeometry<import("three").NormalBufferAttributes> | undefined;
|
|
114
|
+
material?: import("three").Material | import("three").Material[] | undefined;
|
|
115
|
+
morphTargetInfluences?: number[] | undefined;
|
|
116
|
+
morphTargetDictionary?: {
|
|
117
|
+
[key: string]: number;
|
|
118
|
+
} | undefined;
|
|
119
|
+
updateMorphTargets?: (() => void) | undefined;
|
|
120
|
+
getVertexPosition?: ((index: number, target: import("three").Vector3) => import("three").Vector3) | undefined;
|
|
121
|
+
toJSON?: ((meta?: import("three").JSONMeta) => import("three").MeshJSON) | undefined;
|
|
111
122
|
readonly isObject3D?: true | undefined;
|
|
112
123
|
readonly id?: number | undefined;
|
|
113
124
|
uuid?: string | undefined;
|
|
114
125
|
name?: string | undefined;
|
|
115
|
-
readonly type?: string | undefined;
|
|
116
126
|
parent?: import("three").Object3D<import("three").Object3DEventMap> | null | undefined;
|
|
117
127
|
children?: import("three").Object3D<import("three").Object3DEventMap>[] | undefined;
|
|
118
128
|
readonly modelViewMatrix?: import("three").Matrix4 | undefined;
|
|
@@ -173,20 +183,10 @@ export declare class NgtsText3D {
|
|
|
173
183
|
updateMatrix?: (() => void) | undefined;
|
|
174
184
|
updateMatrixWorld?: ((force?: boolean) => void) | undefined;
|
|
175
185
|
updateWorldMatrix?: ((updateParents: boolean, updateChildren: boolean) => void) | undefined;
|
|
176
|
-
toJSON?: ((meta?: import("three").JSONMeta) => import("three").MeshJSON) | undefined;
|
|
177
186
|
clone?: ((recursive?: boolean) => Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>) | undefined;
|
|
178
187
|
copy?: ((object: import("three").Object3D, recursive?: boolean) => Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>) | undefined;
|
|
179
188
|
hasEventListener?: (<T extends keyof import("three").Object3DEventMap>(type: T, listener: import("three").EventListener<import("three").Object3DEventMap[T], T, Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>) => boolean) | undefined;
|
|
180
189
|
dispatchEvent?: (<T extends keyof import("three").Object3DEventMap>(event: import("three").BaseEvent<T> & import("three").Object3DEventMap[T]) => void) | undefined;
|
|
181
|
-
geometry?: import("three").BufferGeometry<import("three").NormalBufferAttributes> | undefined;
|
|
182
|
-
material?: import("three").Material | import("three").Material[] | undefined;
|
|
183
|
-
readonly isMesh?: true | undefined;
|
|
184
|
-
morphTargetInfluences?: number[] | undefined;
|
|
185
|
-
morphTargetDictionary?: {
|
|
186
|
-
[key: string]: number;
|
|
187
|
-
} | undefined;
|
|
188
|
-
updateMorphTargets?: (() => void) | undefined;
|
|
189
|
-
getVertexPosition?: ((index: number, target: import("three").Vector3) => import("three").Vector3) | undefined;
|
|
190
190
|
position: import("angular-three").NgtVector3;
|
|
191
191
|
up: import("angular-three").NgtVector3;
|
|
192
192
|
scale: import("angular-three").NgtVector3;
|
|
@@ -202,11 +202,21 @@ export declare class NgtsText3D {
|
|
|
202
202
|
removeEventListener: (<TEventKey extends keyof import("angular-three").NgtNodeEventMap<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>>(type: TEventKey, listener: (this: import("angular-three").NgtNodeElement<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>, typeof Mesh>, ev: import("angular-three").NgtNodeEventMap<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>[TEventKey]) => any) => void) & (<TEventKey extends keyof import("angular-three").NgtAllObject3DEventsMap>(type: TEventKey, listener: (this: any, ev: import("angular-three").NgtAllObject3DEventsMap[TEventKey]) => any) => void);
|
|
203
203
|
attach: string | string[] | import("angular-three").NgtAttachFunction;
|
|
204
204
|
__ngt_args__: [geometry?: import("three").BufferGeometry<import("three").NormalBufferAttributes> | undefined, material?: import("three").Material | import("three").Material[] | undefined];
|
|
205
|
+
readonly isMesh?: true | undefined;
|
|
206
|
+
readonly type?: string | undefined;
|
|
207
|
+
geometry?: import("three").BufferGeometry<import("three").NormalBufferAttributes> | undefined;
|
|
208
|
+
material?: import("three").Material | import("three").Material[] | undefined;
|
|
209
|
+
morphTargetInfluences?: number[] | undefined;
|
|
210
|
+
morphTargetDictionary?: {
|
|
211
|
+
[key: string]: number;
|
|
212
|
+
} | undefined;
|
|
213
|
+
updateMorphTargets?: (() => void) | undefined;
|
|
214
|
+
getVertexPosition?: ((index: number, target: import("three").Vector3) => import("three").Vector3) | undefined;
|
|
215
|
+
toJSON?: ((meta?: import("three").JSONMeta) => import("three").MeshJSON) | undefined;
|
|
205
216
|
readonly isObject3D?: true | undefined;
|
|
206
217
|
readonly id?: number | undefined;
|
|
207
218
|
uuid?: string | undefined;
|
|
208
219
|
name?: string | undefined;
|
|
209
|
-
readonly type?: string | undefined;
|
|
210
220
|
parent?: import("three").Object3D<import("three").Object3DEventMap> | null | undefined;
|
|
211
221
|
children?: import("three").Object3D<import("three").Object3DEventMap>[] | undefined;
|
|
212
222
|
readonly modelViewMatrix?: import("three").Matrix4 | undefined;
|
|
@@ -267,20 +277,10 @@ export declare class NgtsText3D {
|
|
|
267
277
|
updateMatrix?: (() => void) | undefined;
|
|
268
278
|
updateMatrixWorld?: ((force?: boolean) => void) | undefined;
|
|
269
279
|
updateWorldMatrix?: ((updateParents: boolean, updateChildren: boolean) => void) | undefined;
|
|
270
|
-
toJSON?: ((meta?: import("three").JSONMeta) => import("three").MeshJSON) | undefined;
|
|
271
280
|
clone?: ((recursive?: boolean) => Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>) | undefined;
|
|
272
281
|
copy?: ((object: import("three").Object3D, recursive?: boolean) => Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>) | undefined;
|
|
273
282
|
hasEventListener?: (<T extends keyof import("three").Object3DEventMap>(type: T, listener: import("three").EventListener<import("three").Object3DEventMap[T], T, Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>) => boolean) | undefined;
|
|
274
283
|
dispatchEvent?: (<T extends keyof import("three").Object3DEventMap>(event: import("three").BaseEvent<T> & import("three").Object3DEventMap[T]) => void) | undefined;
|
|
275
|
-
geometry?: import("three").BufferGeometry<import("three").NormalBufferAttributes> | undefined;
|
|
276
|
-
material?: import("three").Material | import("three").Material[] | undefined;
|
|
277
|
-
readonly isMesh?: true | undefined;
|
|
278
|
-
morphTargetInfluences?: number[] | undefined;
|
|
279
|
-
morphTargetDictionary?: {
|
|
280
|
-
[key: string]: number;
|
|
281
|
-
} | undefined;
|
|
282
|
-
updateMorphTargets?: (() => void) | undefined;
|
|
283
|
-
getVertexPosition?: ((index: number, target: import("three").Vector3) => import("three").Vector3) | undefined;
|
|
284
284
|
position: import("angular-three").NgtVector3;
|
|
285
285
|
up: import("angular-three").NgtVector3;
|
|
286
286
|
scale: import("angular-three").NgtVector3;
|
|
@@ -290,21 +290,21 @@ export declare class NgtsText3D {
|
|
|
290
290
|
layers: import("angular-three").NgtLayers;
|
|
291
291
|
dispose: (() => void) | null;
|
|
292
292
|
raycast: import("three").Object3D["raycast"] | null;
|
|
293
|
-
}> & NgtsText3DOptions, "
|
|
293
|
+
}> & NgtsText3DOptions, "height" | "bevelSegments" | "size" | "curveSegments" | "bevelEnabled" | "bevelThickness" | "bevelSize" | "bevelOffset" | "lineHeight" | "letterSpacing" | "smooth">>;
|
|
294
294
|
meshRef: import("@angular/core").Signal<ElementRef<Mesh<import("three").BufferGeometry<import("three").NormalBufferAttributes>, import("three").Material | import("three").Material[], import("three").Object3DEventMap>>>;
|
|
295
295
|
private textGeometryRef;
|
|
296
296
|
loadedFont: import("@angular/core").Signal<import("three-stdlib").Font | null>;
|
|
297
297
|
private smooth;
|
|
298
298
|
private textOptions;
|
|
299
299
|
textArgs: import("@angular/core").Signal<(string | {
|
|
300
|
-
size?: number | undefined;
|
|
301
300
|
height?: number | undefined;
|
|
301
|
+
bevelSegments: number;
|
|
302
|
+
size?: number | undefined;
|
|
302
303
|
curveSegments?: number | undefined;
|
|
303
304
|
bevelEnabled?: boolean | undefined;
|
|
304
305
|
bevelThickness?: number | undefined;
|
|
305
306
|
bevelSize?: number | undefined;
|
|
306
307
|
bevelOffset?: number | undefined;
|
|
307
|
-
bevelSegments: number;
|
|
308
308
|
lineHeight?: number | undefined;
|
|
309
309
|
letterSpacing?: number | undefined;
|
|
310
310
|
font: import("three-stdlib").Font;
|
|
@@ -1,9 +1,10 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, computed, CUSTOM_ELEMENTS_SCHEMA, effect, input, untracked, viewChild, } from '@angular/core';
|
|
2
|
-
import { extend, NgtArgs, omit, pick } from 'angular-three';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, CUSTOM_ELEMENTS_SCHEMA, effect, inject, input, untracked, viewChild, } from '@angular/core';
|
|
2
|
+
import { extend, NgtArgs, NgtObjectEvents, NgtObjectEventsOutputs, omit, pick } from 'angular-three';
|
|
3
3
|
import { mergeInputs } from 'ngxtension/inject-inputs';
|
|
4
4
|
import { ExtrudeGeometry, Mesh, Shape } from 'three';
|
|
5
5
|
import { toCreasedNormals } from 'three-stdlib';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "angular-three";
|
|
7
8
|
const eps = 0.00001;
|
|
8
9
|
function createShape(width, height, radius0) {
|
|
9
10
|
const shape = new Shape();
|
|
@@ -70,6 +71,11 @@ export class NgtsRoundedBox {
|
|
|
70
71
|
};
|
|
71
72
|
});
|
|
72
73
|
extend({ ExtrudeGeometry, Mesh });
|
|
74
|
+
const objectEvents = inject(NgtObjectEvents, { host: true });
|
|
75
|
+
effect(() => {
|
|
76
|
+
const mesh = this.meshRef().nativeElement;
|
|
77
|
+
objectEvents.ngtObjectEvents.set(mesh);
|
|
78
|
+
}, { allowSignalWrites: true });
|
|
73
79
|
effect(() => {
|
|
74
80
|
const geometry = this.geometryRef()?.nativeElement;
|
|
75
81
|
if (!geometry)
|
|
@@ -79,7 +85,7 @@ export class NgtsRoundedBox {
|
|
|
79
85
|
});
|
|
80
86
|
}
|
|
81
87
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NgtsRoundedBox, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
82
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.11", type: NgtsRoundedBox, isStandalone: true, selector: "ngts-rounded-box", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "meshRef", first: true, predicate: ["mesh"], descendants: true, isSignal: true }, { propertyName: "geometryRef", first: true, predicate: ["geometry"], descendants: true, isSignal: true }], ngImport: i0, template: `
|
|
88
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.11", type: NgtsRoundedBox, isStandalone: true, selector: "ngts-rounded-box", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "meshRef", first: true, predicate: ["mesh"], descendants: true, isSignal: true }, { propertyName: "geometryRef", first: true, predicate: ["geometry"], descendants: true, isSignal: true }], hostDirectives: [{ directive: i1.NgtObjectEvents }], ngImport: i0, template: `
|
|
83
89
|
<ngt-mesh #mesh [parameters]="parameters()">
|
|
84
90
|
<ngt-extrude-geometry #geometry *args="[shape(), params()]" />
|
|
85
91
|
<ng-content />
|
|
@@ -100,6 +106,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImpo
|
|
|
100
106
|
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
101
107
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
102
108
|
imports: [NgtArgs],
|
|
109
|
+
hostDirectives: [{ directive: NgtObjectEvents, outputs: NgtObjectEventsOutputs }],
|
|
103
110
|
}]
|
|
104
111
|
}], ctorParameters: () => [] });
|
|
105
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rounded-box.js","sourceRoot":"","sources":["../../../../../../libs/soba/abstractions/src/lib/rounded-box.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tChangeDetectionStrategy,\n\tComponent,\n\tcomputed,\n\tCUSTOM_ELEMENTS_SCHEMA,\n\teffect,\n\tElementRef,\n\tinput,\n\tuntracked,\n\tviewChild,\n} from '@angular/core';\nimport { extend, NgtArgs, NgtMesh, omit, pick } from 'angular-three';\nimport { mergeInputs } from 'ngxtension/inject-inputs';\nimport { ExtrudeGeometry, Mesh, Shape } from 'three';\nimport { toCreasedNormals } from 'three-stdlib';\n\nconst eps = 0.00001;\n\nfunction createShape(width: number, height: number, radius0: number) {\n\tconst shape = new Shape();\n\tconst radius = radius0 - eps;\n\tshape.absarc(eps, eps, eps, -Math.PI / 2, -Math.PI, true);\n\tshape.absarc(eps, height - radius * 2, eps, Math.PI, Math.PI / 2, true);\n\tshape.absarc(width - radius * 2, height - radius * 2, eps, Math.PI / 2, 0, true);\n\tshape.absarc(width - radius * 2, eps, eps, 0, -Math.PI / 2, true);\n\treturn shape;\n}\n\nexport interface NgtsRoundedBoxOptions extends Partial<NgtMesh> {\n\twidth: number;\n\theight: number;\n\tdepth: number;\n\tradius: number;\n\tsmoothness: number;\n\tbevelSegments: number;\n\tsteps: number;\n\tcreaseAngle: number;\n}\n\nconst defaultOptions: NgtsRoundedBoxOptions = {\n\twidth: 1,\n\theight: 1,\n\tdepth: 1,\n\tradius: 0.05,\n\tsmoothness: 4,\n\tbevelSegments: 4,\n\tcreaseAngle: 0.4,\n\tsteps: 1,\n};\n\n@Component({\n\tselector: 'ngts-rounded-box',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ngt-mesh #mesh [parameters]=\"parameters()\">\n\t\t\t<ngt-extrude-geometry #geometry *args=\"[shape(), params()]\" />\n\t\t\t<ng-content />\n\t\t</ngt-mesh>\n\t`,\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [NgtArgs],\n})\nexport class NgtsRoundedBox {\n\toptions = input(defaultOptions, { transform: mergeInputs(defaultOptions) });\n\tparameters = omit(this.options, [\n\t\t'width',\n\t\t'height',\n\t\t'depth',\n\t\t'radius',\n\t\t'smoothness',\n\t\t'bevelSegments',\n\t\t'steps',\n\t\t'creaseAngle',\n\t]);\n\n\tprivate width = pick(this.options, 'width');\n\tprivate height = pick(this.options, 'height');\n\tprivate depth = pick(this.options, 'depth');\n\tprivate radius = pick(this.options, 'radius');\n\tprivate smoothness = pick(this.options, 'smoothness');\n\tprivate bevelSegments = pick(this.options, 'bevelSegments');\n\tprivate steps = pick(this.options, 'steps');\n\tprivate creaseAngle = pick(this.options, 'creaseAngle');\n\n\tmeshRef = viewChild.required<ElementRef<Mesh>>('mesh');\n\tgeometryRef = viewChild<ElementRef<ExtrudeGeometry>>('geometry');\n\n\tprotected shape = computed(() => {\n\t\tconst [width, height, radius] = [this.width(), this.height(), this.radius()];\n\t\treturn createShape(width, height, radius);\n\t});\n\tprotected params = computed(() => {\n\t\tconst [depth, radius, smoothness, bevelSegments, steps] = [\n\t\t\tthis.depth(),\n\t\t\tthis.radius(),\n\t\t\tthis.smoothness(),\n\t\t\tuntracked(this.bevelSegments),\n\t\t\tuntracked(this.steps),\n\t\t];\n\n\t\treturn {\n\t\t\tdepth: depth - radius * 2,\n\t\t\tbevelEnabled: true,\n\t\t\tbevelSegments: bevelSegments * 2,\n\t\t\tsteps,\n\t\t\tbevelSize: radius - eps,\n\t\t\tbevelThickness: radius,\n\t\t\tcurveSegments: smoothness,\n\t\t};\n\t});\n\n\tconstructor() {\n\t\textend({ ExtrudeGeometry, Mesh });\n\n\t\teffect(() => {\n\t\t\tconst geometry = this.geometryRef()?.nativeElement;\n\t\t\tif (!geometry) return;\n\n\t\t\tgeometry.center();\n\t\t\ttoCreasedNormals(geometry, untracked(this.creaseAngle));\n\t\t});\n\t}\n}\n"]}
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rounded-box.js","sourceRoot":"","sources":["../../../../../../libs/soba/abstractions/src/lib/rounded-box.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tChangeDetectionStrategy,\n\tComponent,\n\tcomputed,\n\tCUSTOM_ELEMENTS_SCHEMA,\n\teffect,\n\tElementRef,\n\tinject,\n\tinput,\n\tuntracked,\n\tviewChild,\n} from '@angular/core';\nimport { extend, NgtArgs, NgtMesh, NgtObjectEvents, NgtObjectEventsOutputs, omit, pick } from 'angular-three';\nimport { mergeInputs } from 'ngxtension/inject-inputs';\nimport { ExtrudeGeometry, Mesh, Shape } from 'three';\nimport { toCreasedNormals } from 'three-stdlib';\n\nconst eps = 0.00001;\n\nfunction createShape(width: number, height: number, radius0: number) {\n\tconst shape = new Shape();\n\tconst radius = radius0 - eps;\n\tshape.absarc(eps, eps, eps, -Math.PI / 2, -Math.PI, true);\n\tshape.absarc(eps, height - radius * 2, eps, Math.PI, Math.PI / 2, true);\n\tshape.absarc(width - radius * 2, height - radius * 2, eps, Math.PI / 2, 0, true);\n\tshape.absarc(width - radius * 2, eps, eps, 0, -Math.PI / 2, true);\n\treturn shape;\n}\n\nexport interface NgtsRoundedBoxOptions extends Partial<NgtMesh> {\n\twidth: number;\n\theight: number;\n\tdepth: number;\n\tradius: number;\n\tsmoothness: number;\n\tbevelSegments: number;\n\tsteps: number;\n\tcreaseAngle: number;\n}\n\nconst defaultOptions: NgtsRoundedBoxOptions = {\n\twidth: 1,\n\theight: 1,\n\tdepth: 1,\n\tradius: 0.05,\n\tsmoothness: 4,\n\tbevelSegments: 4,\n\tcreaseAngle: 0.4,\n\tsteps: 1,\n};\n\n@Component({\n\tselector: 'ngts-rounded-box',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ngt-mesh #mesh [parameters]=\"parameters()\">\n\t\t\t<ngt-extrude-geometry #geometry *args=\"[shape(), params()]\" />\n\t\t\t<ng-content />\n\t\t</ngt-mesh>\n\t`,\n\tschemas: [CUSTOM_ELEMENTS_SCHEMA],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\timports: [NgtArgs],\n\thostDirectives: [{ directive: NgtObjectEvents, outputs: NgtObjectEventsOutputs }],\n})\nexport class NgtsRoundedBox {\n\toptions = input(defaultOptions, { transform: mergeInputs(defaultOptions) });\n\tparameters = omit(this.options, [\n\t\t'width',\n\t\t'height',\n\t\t'depth',\n\t\t'radius',\n\t\t'smoothness',\n\t\t'bevelSegments',\n\t\t'steps',\n\t\t'creaseAngle',\n\t]);\n\n\tprivate width = pick(this.options, 'width');\n\tprivate height = pick(this.options, 'height');\n\tprivate depth = pick(this.options, 'depth');\n\tprivate radius = pick(this.options, 'radius');\n\tprivate smoothness = pick(this.options, 'smoothness');\n\tprivate bevelSegments = pick(this.options, 'bevelSegments');\n\tprivate steps = pick(this.options, 'steps');\n\tprivate creaseAngle = pick(this.options, 'creaseAngle');\n\n\tmeshRef = viewChild.required<ElementRef<Mesh>>('mesh');\n\tgeometryRef = viewChild<ElementRef<ExtrudeGeometry>>('geometry');\n\n\tprotected shape = computed(() => {\n\t\tconst [width, height, radius] = [this.width(), this.height(), this.radius()];\n\t\treturn createShape(width, height, radius);\n\t});\n\tprotected params = computed(() => {\n\t\tconst [depth, radius, smoothness, bevelSegments, steps] = [\n\t\t\tthis.depth(),\n\t\t\tthis.radius(),\n\t\t\tthis.smoothness(),\n\t\t\tuntracked(this.bevelSegments),\n\t\t\tuntracked(this.steps),\n\t\t];\n\n\t\treturn {\n\t\t\tdepth: depth - radius * 2,\n\t\t\tbevelEnabled: true,\n\t\t\tbevelSegments: bevelSegments * 2,\n\t\t\tsteps,\n\t\t\tbevelSize: radius - eps,\n\t\t\tbevelThickness: radius,\n\t\t\tcurveSegments: smoothness,\n\t\t};\n\t});\n\n\tconstructor() {\n\t\textend({ ExtrudeGeometry, Mesh });\n\n\t\tconst objectEvents = inject(NgtObjectEvents, { host: true });\n\n\t\teffect(\n\t\t\t() => {\n\t\t\t\tconst mesh = this.meshRef().nativeElement;\n\t\t\t\tobjectEvents.ngtObjectEvents.set(mesh);\n\t\t\t},\n\t\t\t{ allowSignalWrites: true },\n\t\t);\n\n\t\teffect(() => {\n\t\t\tconst geometry = this.geometryRef()?.nativeElement;\n\t\t\tif (!geometry) return;\n\n\t\t\tgeometry.center();\n\t\t\ttoCreasedNormals(geometry, untracked(this.creaseAngle));\n\t\t});\n\t}\n}\n"]}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
2
|
import { input, viewChild, Component, CUSTOM_ELEMENTS_SCHEMA, ChangeDetectionStrategy, computed, effect, untracked, inject, output, DestroyRef } from '@angular/core';
|
|
3
|
-
import
|
|
3
|
+
import * as i1 from 'angular-three';
|
|
4
|
+
import { omit, extend, injectBeforeRender, injectStore, pick, checkNeedsUpdate, NgtArgs, getLocalState, resolveRef, NgtObjectEvents, NgtObjectEventsOutputs } from 'angular-three';
|
|
4
5
|
import { mergeInputs } from 'ngxtension/inject-inputs';
|
|
5
6
|
import { Group, Quaternion, Vector3, Vector4, Vector2, Color, CatmullRomCurve3, CubicBezierCurve3, EdgesGeometry, CanvasTexture, BackSide, Plane, Mesh, PlaneGeometry, Object3D, Shape, ExtrudeGeometry, QuadraticBezierCurve3 } from 'three';
|
|
6
7
|
import { LineSegments2, Line2, LineMaterial, LineSegmentsGeometry, LineGeometry, toCreasedNormals, TextGeometry, mergeVertices } from 'three-stdlib';
|
|
@@ -791,6 +792,11 @@ class NgtsRoundedBox {
|
|
|
791
792
|
};
|
|
792
793
|
});
|
|
793
794
|
extend({ ExtrudeGeometry, Mesh });
|
|
795
|
+
const objectEvents = inject(NgtObjectEvents, { host: true });
|
|
796
|
+
effect(() => {
|
|
797
|
+
const mesh = this.meshRef().nativeElement;
|
|
798
|
+
objectEvents.ngtObjectEvents.set(mesh);
|
|
799
|
+
}, { allowSignalWrites: true });
|
|
794
800
|
effect(() => {
|
|
795
801
|
const geometry = this.geometryRef()?.nativeElement;
|
|
796
802
|
if (!geometry)
|
|
@@ -800,7 +806,7 @@ class NgtsRoundedBox {
|
|
|
800
806
|
});
|
|
801
807
|
}
|
|
802
808
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: NgtsRoundedBox, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
803
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.11", type: NgtsRoundedBox, isStandalone: true, selector: "ngts-rounded-box", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "meshRef", first: true, predicate: ["mesh"], descendants: true, isSignal: true }, { propertyName: "geometryRef", first: true, predicate: ["geometry"], descendants: true, isSignal: true }], ngImport: i0, template: `
|
|
809
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.11", type: NgtsRoundedBox, isStandalone: true, selector: "ngts-rounded-box", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "meshRef", first: true, predicate: ["mesh"], descendants: true, isSignal: true }, { propertyName: "geometryRef", first: true, predicate: ["geometry"], descendants: true, isSignal: true }], hostDirectives: [{ directive: i1.NgtObjectEvents }], ngImport: i0, template: `
|
|
804
810
|
<ngt-mesh #mesh [parameters]="parameters()">
|
|
805
811
|
<ngt-extrude-geometry #geometry *args="[shape(), params()]" />
|
|
806
812
|
<ng-content />
|
|
@@ -821,6 +827,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImpo
|
|
|
821
827
|
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
822
828
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
823
829
|
imports: [NgtArgs],
|
|
830
|
+
hostDirectives: [{ directive: NgtObjectEvents, outputs: NgtObjectEventsOutputs }],
|
|
824
831
|
}]
|
|
825
832
|
}], ctorParameters: () => [] });
|
|
826
833
|
|