@tresjs/cientos 3.4.1 → 3.5.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/dist/core/abstractions/GlobalAudio.d.ts +50 -0
- package/dist/core/abstractions/index.d.ts +4 -1
- package/dist/core/abstractions/useFBO/component.vue.d.ts +37 -0
- package/dist/core/abstractions/useFBO/index.d.ts +10 -0
- package/dist/core/directives/index.d.ts +2 -1
- package/dist/core/directives/vDistanceTo.d.ts +4 -0
- package/dist/core/directives/vLog.d.ts +1 -1
- package/dist/core/loaders/SVG/component.vue.d.ts +8 -8
- package/dist/core/misc/Stats.d.ts +13 -1
- package/dist/core/misc/html/HTML.vue.d.ts +133 -0
- package/dist/core/misc/html/utils.d.ts +18 -0
- package/dist/core/misc/index.d.ts +2 -1
- package/dist/core/shapes/CatmullRomCurve3.vue.d.ts +112 -0
- package/dist/core/shapes/Line2.vue.d.ts +120 -0
- package/dist/core/shapes/index.d.ts +3 -1
- package/dist/core/staging/index.d.ts +1 -1
- package/dist/core/staging/useEnvironment/const.d.ts +51 -0
- package/dist/core/staging/useEnvironment/index.d.ts +1 -15
- package/dist/trescientos.js +36289 -7189
- package/dist/trescientos.umd.cjs +1393 -22
- package/dist/utils/index.d.ts +2 -0
- package/package.json +23 -16
- package/dist/core/staging/useEnvironment/component.d.ts +0 -4
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
export interface AudioProps {
|
|
2
|
+
/**
|
|
3
|
+
* Path to your audio file.
|
|
4
|
+
* @type {string}
|
|
5
|
+
* @memberof AudioProps
|
|
6
|
+
*
|
|
7
|
+
*/
|
|
8
|
+
src: string;
|
|
9
|
+
/**
|
|
10
|
+
* Id of the DOM element that trigger the play/pause state.
|
|
11
|
+
* @type {string}
|
|
12
|
+
* @memberof AudioProps
|
|
13
|
+
* @default renderer.domElement
|
|
14
|
+
*
|
|
15
|
+
*/
|
|
16
|
+
playTrigger?: string;
|
|
17
|
+
/**
|
|
18
|
+
* Id of the DOM element that trigger the stop state.
|
|
19
|
+
* @type {string}
|
|
20
|
+
* @memberof AudioProps
|
|
21
|
+
* @default
|
|
22
|
+
*
|
|
23
|
+
*/
|
|
24
|
+
stopTrigger?: string;
|
|
25
|
+
/**
|
|
26
|
+
* If the audio must be replayed when ends.
|
|
27
|
+
* @type {boolean}
|
|
28
|
+
* @memberof AudioProps
|
|
29
|
+
* @default false
|
|
30
|
+
*
|
|
31
|
+
*/
|
|
32
|
+
loop?: boolean;
|
|
33
|
+
/**
|
|
34
|
+
* Volume of the audio.
|
|
35
|
+
* @type {number}
|
|
36
|
+
* @memberof AudioProps
|
|
37
|
+
* @default 0.5
|
|
38
|
+
*
|
|
39
|
+
*/
|
|
40
|
+
volume?: number;
|
|
41
|
+
/**
|
|
42
|
+
* PlaybackRate of the audio.
|
|
43
|
+
* @type {number}
|
|
44
|
+
* @memberof AudioProps
|
|
45
|
+
* @default 1
|
|
46
|
+
*
|
|
47
|
+
*/
|
|
48
|
+
playbackRate?: number;
|
|
49
|
+
}
|
|
50
|
+
export declare const GlobalAudio: import("vue").DefineComponent<AudioProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<AudioProps>, {}, {}>;
|
|
@@ -2,6 +2,9 @@ import Text3D from './Text3D.vue';
|
|
|
2
2
|
import { useAnimations } from './useAnimations';
|
|
3
3
|
import Levioso from './Levioso.vue';
|
|
4
4
|
import MouseParallax from './MouseParallax.vue';
|
|
5
|
+
import { GlobalAudio } from './GlobalAudio';
|
|
5
6
|
import Lensflare from './Lensflare/component.vue';
|
|
7
|
+
import Fbo from './useFBO/component.vue';
|
|
8
|
+
export * from './useFBO/';
|
|
6
9
|
export * from '../staging/useEnvironment';
|
|
7
|
-
export { Text3D, useAnimations, MouseParallax, Levioso, Lensflare, };
|
|
10
|
+
export { Text3D, useAnimations, MouseParallax, Levioso, Lensflare, GlobalAudio, Fbo, };
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
declare const _default: import("vue").DefineComponent<{
|
|
2
|
+
width: {
|
|
3
|
+
type: import("vue").PropType<number>;
|
|
4
|
+
};
|
|
5
|
+
height: {
|
|
6
|
+
type: import("vue").PropType<number>;
|
|
7
|
+
};
|
|
8
|
+
settings: {
|
|
9
|
+
type: import("vue").PropType<import("three").WebGLRenderTargetOptions>;
|
|
10
|
+
default: undefined;
|
|
11
|
+
};
|
|
12
|
+
depth: {
|
|
13
|
+
type: import("vue").PropType<boolean>;
|
|
14
|
+
default: boolean;
|
|
15
|
+
};
|
|
16
|
+
}, {
|
|
17
|
+
value: import("vue").Ref<import("three").WebGLRenderTarget<import("three").Texture> | null>;
|
|
18
|
+
}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
|
|
19
|
+
width: {
|
|
20
|
+
type: import("vue").PropType<number>;
|
|
21
|
+
};
|
|
22
|
+
height: {
|
|
23
|
+
type: import("vue").PropType<number>;
|
|
24
|
+
};
|
|
25
|
+
settings: {
|
|
26
|
+
type: import("vue").PropType<import("three").WebGLRenderTargetOptions>;
|
|
27
|
+
default: undefined;
|
|
28
|
+
};
|
|
29
|
+
depth: {
|
|
30
|
+
type: import("vue").PropType<boolean>;
|
|
31
|
+
default: boolean;
|
|
32
|
+
};
|
|
33
|
+
}>>, {
|
|
34
|
+
settings: import("three").WebGLRenderTargetOptions;
|
|
35
|
+
depth: boolean;
|
|
36
|
+
}, {}>;
|
|
37
|
+
export default _default;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { WebGLRenderTargetOptions } from 'three';
|
|
2
|
+
import { WebGLRenderTarget } from 'three';
|
|
3
|
+
import type { Ref } from 'vue';
|
|
4
|
+
export interface FboOptions {
|
|
5
|
+
width?: number;
|
|
6
|
+
height?: number;
|
|
7
|
+
depth?: boolean;
|
|
8
|
+
settings?: WebGLRenderTargetOptions;
|
|
9
|
+
}
|
|
10
|
+
export declare function useFBO(options: FboOptions): Ref<WebGLRenderTarget<import("three").Texture> | null>;
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { vLog } from './vLog';
|
|
2
2
|
import { vLightHelper } from './vLightHelper';
|
|
3
3
|
import { vAlwaysLookAt } from './vAlwaysLookAt';
|
|
4
|
-
|
|
4
|
+
import { vDistanceTo } from './vDistanceTo';
|
|
5
|
+
export { vLog, vLightHelper, vAlwaysLookAt, vDistanceTo };
|
|
@@ -1,6 +1,10 @@
|
|
|
1
1
|
import type { TresOptions } from '@tresjs/core';
|
|
2
2
|
import type { MeshBasicMaterialParameters } from 'three';
|
|
3
3
|
declare const _default: import("vue").DefineComponent<{
|
|
4
|
+
depth: {
|
|
5
|
+
type: import("vue").PropType<number | "flat" | "renderOrder" | "offsetZ">;
|
|
6
|
+
default: string;
|
|
7
|
+
};
|
|
4
8
|
src: {
|
|
5
9
|
type: import("vue").PropType<string>;
|
|
6
10
|
required: true;
|
|
@@ -25,13 +29,13 @@ declare const _default: import("vue").DefineComponent<{
|
|
|
25
29
|
strokeMeshProps: {
|
|
26
30
|
type: import("vue").PropType<TresOptions>;
|
|
27
31
|
};
|
|
32
|
+
}, {
|
|
33
|
+
value: import("vue").ShallowRef<any>;
|
|
34
|
+
}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
|
|
28
35
|
depth: {
|
|
29
36
|
type: import("vue").PropType<number | "flat" | "renderOrder" | "offsetZ">;
|
|
30
37
|
default: string;
|
|
31
38
|
};
|
|
32
|
-
}, {
|
|
33
|
-
value: import("vue").ShallowRef<any>;
|
|
34
|
-
}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
|
|
35
39
|
src: {
|
|
36
40
|
type: import("vue").PropType<string>;
|
|
37
41
|
required: true;
|
|
@@ -56,13 +60,9 @@ declare const _default: import("vue").DefineComponent<{
|
|
|
56
60
|
strokeMeshProps: {
|
|
57
61
|
type: import("vue").PropType<TresOptions>;
|
|
58
62
|
};
|
|
59
|
-
depth: {
|
|
60
|
-
type: import("vue").PropType<number | "flat" | "renderOrder" | "offsetZ">;
|
|
61
|
-
default: string;
|
|
62
|
-
};
|
|
63
63
|
}>>, {
|
|
64
|
+
depth: number | "flat" | "renderOrder" | "offsetZ";
|
|
64
65
|
skipStrokes: boolean;
|
|
65
66
|
skipFills: boolean;
|
|
66
|
-
depth: number | "flat" | "renderOrder" | "offsetZ";
|
|
67
67
|
}, {}>;
|
|
68
68
|
export default _default;
|
|
@@ -1 +1,13 @@
|
|
|
1
|
-
export declare const Stats: (
|
|
1
|
+
export declare const Stats: import("vue").DefineComponent<{
|
|
2
|
+
showPanel: {
|
|
3
|
+
type: NumberConstructor;
|
|
4
|
+
default: number;
|
|
5
|
+
};
|
|
6
|
+
}, null, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
|
|
7
|
+
showPanel: {
|
|
8
|
+
type: NumberConstructor;
|
|
9
|
+
default: number;
|
|
10
|
+
};
|
|
11
|
+
}>>, {
|
|
12
|
+
showPanel: number;
|
|
13
|
+
}, {}>;
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
import type { Ref } from 'vue';
|
|
2
|
+
import { PlaneGeometry } from 'three';
|
|
3
|
+
import type { TresObject3D } from '@tresjs/core';
|
|
4
|
+
import type { Mutable } from '@vueuse/core';
|
|
5
|
+
export interface HTMLProps {
|
|
6
|
+
geometry?: any;
|
|
7
|
+
material?: any;
|
|
8
|
+
as?: string;
|
|
9
|
+
transform?: boolean;
|
|
10
|
+
portal?: Mutable<HTMLElement>;
|
|
11
|
+
wrapperClass?: string;
|
|
12
|
+
eps?: number;
|
|
13
|
+
distanceFactor?: number;
|
|
14
|
+
fullscreen?: boolean;
|
|
15
|
+
center?: boolean;
|
|
16
|
+
pointerEvents?: PointerEventsProperties;
|
|
17
|
+
sprite?: boolean;
|
|
18
|
+
zIndexRange?: Array<number>;
|
|
19
|
+
occlude?: Ref<TresObject3D>[] | boolean | 'raycast' | 'blending';
|
|
20
|
+
}
|
|
21
|
+
type PointerEventsProperties = 'auto' | 'none' | 'visiblePainted' | 'visibleFill' | 'visibleStroke' | 'visible' | 'painted' | 'fill' | 'stroke' | 'all' | 'inherit';
|
|
22
|
+
declare const _default: import("vue").DefineComponent<{
|
|
23
|
+
material: {
|
|
24
|
+
type: import("vue").PropType<any>;
|
|
25
|
+
};
|
|
26
|
+
sprite: {
|
|
27
|
+
type: import("vue").PropType<boolean>;
|
|
28
|
+
default: boolean;
|
|
29
|
+
};
|
|
30
|
+
center: {
|
|
31
|
+
type: import("vue").PropType<boolean>;
|
|
32
|
+
};
|
|
33
|
+
geometry: {
|
|
34
|
+
type: import("vue").PropType<any>;
|
|
35
|
+
default: PlaneGeometry;
|
|
36
|
+
};
|
|
37
|
+
as: {
|
|
38
|
+
type: import("vue").PropType<string>;
|
|
39
|
+
default: string;
|
|
40
|
+
};
|
|
41
|
+
transform: {
|
|
42
|
+
type: import("vue").PropType<boolean>;
|
|
43
|
+
default: boolean;
|
|
44
|
+
};
|
|
45
|
+
portal: {
|
|
46
|
+
type: import("vue").PropType<Mutable<HTMLElement>>;
|
|
47
|
+
};
|
|
48
|
+
wrapperClass: {
|
|
49
|
+
type: import("vue").PropType<string>;
|
|
50
|
+
};
|
|
51
|
+
eps: {
|
|
52
|
+
type: import("vue").PropType<number>;
|
|
53
|
+
default: number;
|
|
54
|
+
};
|
|
55
|
+
distanceFactor: {
|
|
56
|
+
type: import("vue").PropType<number>;
|
|
57
|
+
};
|
|
58
|
+
fullscreen: {
|
|
59
|
+
type: import("vue").PropType<boolean>;
|
|
60
|
+
};
|
|
61
|
+
pointerEvents: {
|
|
62
|
+
type: import("vue").PropType<PointerEventsProperties>;
|
|
63
|
+
default: string;
|
|
64
|
+
};
|
|
65
|
+
zIndexRange: {
|
|
66
|
+
type: import("vue").PropType<number[]>;
|
|
67
|
+
default: () => number[];
|
|
68
|
+
};
|
|
69
|
+
occlude: {
|
|
70
|
+
type: import("vue").PropType<boolean | "raycast" | "blending" | Ref<TresObject3D>[]>;
|
|
71
|
+
};
|
|
72
|
+
}, {}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, "onOcclude"[], "onOcclude", import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
|
|
73
|
+
material: {
|
|
74
|
+
type: import("vue").PropType<any>;
|
|
75
|
+
};
|
|
76
|
+
sprite: {
|
|
77
|
+
type: import("vue").PropType<boolean>;
|
|
78
|
+
default: boolean;
|
|
79
|
+
};
|
|
80
|
+
center: {
|
|
81
|
+
type: import("vue").PropType<boolean>;
|
|
82
|
+
};
|
|
83
|
+
geometry: {
|
|
84
|
+
type: import("vue").PropType<any>;
|
|
85
|
+
default: PlaneGeometry;
|
|
86
|
+
};
|
|
87
|
+
as: {
|
|
88
|
+
type: import("vue").PropType<string>;
|
|
89
|
+
default: string;
|
|
90
|
+
};
|
|
91
|
+
transform: {
|
|
92
|
+
type: import("vue").PropType<boolean>;
|
|
93
|
+
default: boolean;
|
|
94
|
+
};
|
|
95
|
+
portal: {
|
|
96
|
+
type: import("vue").PropType<Mutable<HTMLElement>>;
|
|
97
|
+
};
|
|
98
|
+
wrapperClass: {
|
|
99
|
+
type: import("vue").PropType<string>;
|
|
100
|
+
};
|
|
101
|
+
eps: {
|
|
102
|
+
type: import("vue").PropType<number>;
|
|
103
|
+
default: number;
|
|
104
|
+
};
|
|
105
|
+
distanceFactor: {
|
|
106
|
+
type: import("vue").PropType<number>;
|
|
107
|
+
};
|
|
108
|
+
fullscreen: {
|
|
109
|
+
type: import("vue").PropType<boolean>;
|
|
110
|
+
};
|
|
111
|
+
pointerEvents: {
|
|
112
|
+
type: import("vue").PropType<PointerEventsProperties>;
|
|
113
|
+
default: string;
|
|
114
|
+
};
|
|
115
|
+
zIndexRange: {
|
|
116
|
+
type: import("vue").PropType<number[]>;
|
|
117
|
+
default: () => number[];
|
|
118
|
+
};
|
|
119
|
+
occlude: {
|
|
120
|
+
type: import("vue").PropType<boolean | "raycast" | "blending" | Ref<TresObject3D>[]>;
|
|
121
|
+
};
|
|
122
|
+
}>> & {
|
|
123
|
+
onOnOcclude?: ((...args: any[]) => any) | undefined;
|
|
124
|
+
}, {
|
|
125
|
+
sprite: boolean;
|
|
126
|
+
geometry: any;
|
|
127
|
+
as: string;
|
|
128
|
+
transform: boolean;
|
|
129
|
+
eps: number;
|
|
130
|
+
pointerEvents: PointerEventsProperties;
|
|
131
|
+
zIndexRange: number[];
|
|
132
|
+
}, {}>;
|
|
133
|
+
export default _default;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { TresCamera, TresObject3D } from '@tresjs/core';
|
|
2
|
+
import type { Matrix4, Raycaster } from 'three';
|
|
3
|
+
import { Vector3 } from 'three';
|
|
4
|
+
export declare const v1: Vector3;
|
|
5
|
+
export declare const v2: Vector3;
|
|
6
|
+
export declare const v3: Vector3;
|
|
7
|
+
export declare function calculatePosition(instance: TresObject3D, camera: TresCamera, size: {
|
|
8
|
+
width: number;
|
|
9
|
+
height: number;
|
|
10
|
+
}): number[];
|
|
11
|
+
export declare function isObjectBehindCamera(el: TresObject3D, camera: TresCamera): boolean;
|
|
12
|
+
export declare function isObjectVisible(el: TresObject3D, camera: TresCamera, raycaster: Raycaster, occlude: any): boolean;
|
|
13
|
+
export declare function objectScale(el: TresObject3D, camera: TresCamera): number;
|
|
14
|
+
export declare function objectZIndex(el: TresObject3D, camera: TresCamera, zIndexRange: Array<number>): number | undefined;
|
|
15
|
+
export declare const epsilon: (value: number) => number;
|
|
16
|
+
export declare function getCSSMatrix(matrix: Matrix4, multipliers: number[], prepend?: string): string;
|
|
17
|
+
export declare const getCameraCSSMatrix: (matrix: Matrix4) => string;
|
|
18
|
+
export declare const getObjectCSSMatrix: (matrix: Matrix4, factor: number) => string;
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
import { Vector3 } from 'three';
|
|
2
|
+
type CurveType = 'centripetal' | 'chordal' | 'catmullrom';
|
|
3
|
+
type Points = Array<Vector3 | [number, number, number]>;
|
|
4
|
+
declare const _default: import("vue").DefineComponent<{
|
|
5
|
+
color: {
|
|
6
|
+
type: import("vue").PropType<import("three").ColorRepresentation | [r: number, g: number, b: number]>;
|
|
7
|
+
};
|
|
8
|
+
points: {
|
|
9
|
+
type: import("vue").PropType<Points>;
|
|
10
|
+
required: true;
|
|
11
|
+
};
|
|
12
|
+
alphaToCoverage: {
|
|
13
|
+
type: import("vue").PropType<boolean>;
|
|
14
|
+
};
|
|
15
|
+
vertexColors: {
|
|
16
|
+
type: import("vue").PropType<(import("three").ColorRepresentation | [r: number, g: number, b: number])[]>;
|
|
17
|
+
};
|
|
18
|
+
lineWidth: {
|
|
19
|
+
type: import("vue").PropType<number>;
|
|
20
|
+
};
|
|
21
|
+
worldUnits: {
|
|
22
|
+
type: import("vue").PropType<boolean>;
|
|
23
|
+
};
|
|
24
|
+
dashed: {
|
|
25
|
+
type: import("vue").PropType<boolean>;
|
|
26
|
+
};
|
|
27
|
+
dashSize: {
|
|
28
|
+
type: import("vue").PropType<number>;
|
|
29
|
+
};
|
|
30
|
+
gapSize: {
|
|
31
|
+
type: import("vue").PropType<number>;
|
|
32
|
+
};
|
|
33
|
+
dashScale: {
|
|
34
|
+
type: import("vue").PropType<number>;
|
|
35
|
+
};
|
|
36
|
+
dashOffset: {
|
|
37
|
+
type: import("vue").PropType<number>;
|
|
38
|
+
};
|
|
39
|
+
segments: {
|
|
40
|
+
type: import("vue").PropType<number>;
|
|
41
|
+
default: number;
|
|
42
|
+
};
|
|
43
|
+
closed: {
|
|
44
|
+
type: import("vue").PropType<boolean>;
|
|
45
|
+
default: boolean;
|
|
46
|
+
};
|
|
47
|
+
curveType: {
|
|
48
|
+
type: import("vue").PropType<CurveType>;
|
|
49
|
+
default: string;
|
|
50
|
+
};
|
|
51
|
+
tension: {
|
|
52
|
+
type: import("vue").PropType<number>;
|
|
53
|
+
default: number;
|
|
54
|
+
};
|
|
55
|
+
}, {}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
|
|
56
|
+
color: {
|
|
57
|
+
type: import("vue").PropType<import("three").ColorRepresentation | [r: number, g: number, b: number]>;
|
|
58
|
+
};
|
|
59
|
+
points: {
|
|
60
|
+
type: import("vue").PropType<Points>;
|
|
61
|
+
required: true;
|
|
62
|
+
};
|
|
63
|
+
alphaToCoverage: {
|
|
64
|
+
type: import("vue").PropType<boolean>;
|
|
65
|
+
};
|
|
66
|
+
vertexColors: {
|
|
67
|
+
type: import("vue").PropType<(import("three").ColorRepresentation | [r: number, g: number, b: number])[]>;
|
|
68
|
+
};
|
|
69
|
+
lineWidth: {
|
|
70
|
+
type: import("vue").PropType<number>;
|
|
71
|
+
};
|
|
72
|
+
worldUnits: {
|
|
73
|
+
type: import("vue").PropType<boolean>;
|
|
74
|
+
};
|
|
75
|
+
dashed: {
|
|
76
|
+
type: import("vue").PropType<boolean>;
|
|
77
|
+
};
|
|
78
|
+
dashSize: {
|
|
79
|
+
type: import("vue").PropType<number>;
|
|
80
|
+
};
|
|
81
|
+
gapSize: {
|
|
82
|
+
type: import("vue").PropType<number>;
|
|
83
|
+
};
|
|
84
|
+
dashScale: {
|
|
85
|
+
type: import("vue").PropType<number>;
|
|
86
|
+
};
|
|
87
|
+
dashOffset: {
|
|
88
|
+
type: import("vue").PropType<number>;
|
|
89
|
+
};
|
|
90
|
+
segments: {
|
|
91
|
+
type: import("vue").PropType<number>;
|
|
92
|
+
default: number;
|
|
93
|
+
};
|
|
94
|
+
closed: {
|
|
95
|
+
type: import("vue").PropType<boolean>;
|
|
96
|
+
default: boolean;
|
|
97
|
+
};
|
|
98
|
+
curveType: {
|
|
99
|
+
type: import("vue").PropType<CurveType>;
|
|
100
|
+
default: string;
|
|
101
|
+
};
|
|
102
|
+
tension: {
|
|
103
|
+
type: import("vue").PropType<number>;
|
|
104
|
+
default: number;
|
|
105
|
+
};
|
|
106
|
+
}>>, {
|
|
107
|
+
segments: number;
|
|
108
|
+
closed: boolean;
|
|
109
|
+
curveType: CurveType;
|
|
110
|
+
tension: number;
|
|
111
|
+
}, {}>;
|
|
112
|
+
export default _default;
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
import { Vector2, Vector3 } from 'three';
|
|
2
|
+
import type { TresColor } from '@tresjs/core';
|
|
3
|
+
type Points = (Vector3 | Vector2 | [number, number, number] | [number, number] | number)[];
|
|
4
|
+
type VertexColors = Array<TresColor>;
|
|
5
|
+
export interface LineProps {
|
|
6
|
+
points: Points;
|
|
7
|
+
vertexColors?: VertexColors | null;
|
|
8
|
+
color?: TresColor;
|
|
9
|
+
lineWidth?: number;
|
|
10
|
+
worldUnits?: boolean;
|
|
11
|
+
alphaToCoverage?: boolean;
|
|
12
|
+
dashed?: boolean;
|
|
13
|
+
dashSize?: number;
|
|
14
|
+
gapSize?: number;
|
|
15
|
+
dashScale?: number;
|
|
16
|
+
dashOffset?: number;
|
|
17
|
+
}
|
|
18
|
+
declare const _default: import("vue").DefineComponent<{
|
|
19
|
+
color: {
|
|
20
|
+
type: import("vue").PropType<import("three").ColorRepresentation | [r: number, g: number, b: number]>;
|
|
21
|
+
default: string;
|
|
22
|
+
};
|
|
23
|
+
points: {
|
|
24
|
+
type: import("vue").PropType<Points>;
|
|
25
|
+
required: true;
|
|
26
|
+
};
|
|
27
|
+
alphaToCoverage: {
|
|
28
|
+
type: import("vue").PropType<boolean>;
|
|
29
|
+
default: boolean;
|
|
30
|
+
};
|
|
31
|
+
vertexColors: {
|
|
32
|
+
type: import("vue").PropType<VertexColors | null>;
|
|
33
|
+
default: null;
|
|
34
|
+
};
|
|
35
|
+
lineWidth: {
|
|
36
|
+
type: import("vue").PropType<number>;
|
|
37
|
+
default: number;
|
|
38
|
+
};
|
|
39
|
+
worldUnits: {
|
|
40
|
+
type: import("vue").PropType<boolean>;
|
|
41
|
+
default: boolean;
|
|
42
|
+
};
|
|
43
|
+
dashed: {
|
|
44
|
+
type: import("vue").PropType<boolean>;
|
|
45
|
+
default: boolean;
|
|
46
|
+
};
|
|
47
|
+
dashSize: {
|
|
48
|
+
type: import("vue").PropType<number>;
|
|
49
|
+
default: number;
|
|
50
|
+
};
|
|
51
|
+
gapSize: {
|
|
52
|
+
type: import("vue").PropType<number>;
|
|
53
|
+
default: number;
|
|
54
|
+
};
|
|
55
|
+
dashScale: {
|
|
56
|
+
type: import("vue").PropType<number>;
|
|
57
|
+
default: number;
|
|
58
|
+
};
|
|
59
|
+
dashOffset: {
|
|
60
|
+
type: import("vue").PropType<number>;
|
|
61
|
+
default: number;
|
|
62
|
+
};
|
|
63
|
+
}, {}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
|
|
64
|
+
color: {
|
|
65
|
+
type: import("vue").PropType<import("three").ColorRepresentation | [r: number, g: number, b: number]>;
|
|
66
|
+
default: string;
|
|
67
|
+
};
|
|
68
|
+
points: {
|
|
69
|
+
type: import("vue").PropType<Points>;
|
|
70
|
+
required: true;
|
|
71
|
+
};
|
|
72
|
+
alphaToCoverage: {
|
|
73
|
+
type: import("vue").PropType<boolean>;
|
|
74
|
+
default: boolean;
|
|
75
|
+
};
|
|
76
|
+
vertexColors: {
|
|
77
|
+
type: import("vue").PropType<VertexColors | null>;
|
|
78
|
+
default: null;
|
|
79
|
+
};
|
|
80
|
+
lineWidth: {
|
|
81
|
+
type: import("vue").PropType<number>;
|
|
82
|
+
default: number;
|
|
83
|
+
};
|
|
84
|
+
worldUnits: {
|
|
85
|
+
type: import("vue").PropType<boolean>;
|
|
86
|
+
default: boolean;
|
|
87
|
+
};
|
|
88
|
+
dashed: {
|
|
89
|
+
type: import("vue").PropType<boolean>;
|
|
90
|
+
default: boolean;
|
|
91
|
+
};
|
|
92
|
+
dashSize: {
|
|
93
|
+
type: import("vue").PropType<number>;
|
|
94
|
+
default: number;
|
|
95
|
+
};
|
|
96
|
+
gapSize: {
|
|
97
|
+
type: import("vue").PropType<number>;
|
|
98
|
+
default: number;
|
|
99
|
+
};
|
|
100
|
+
dashScale: {
|
|
101
|
+
type: import("vue").PropType<number>;
|
|
102
|
+
default: number;
|
|
103
|
+
};
|
|
104
|
+
dashOffset: {
|
|
105
|
+
type: import("vue").PropType<number>;
|
|
106
|
+
default: number;
|
|
107
|
+
};
|
|
108
|
+
}>>, {
|
|
109
|
+
color: import("three").ColorRepresentation | [r: number, g: number, b: number];
|
|
110
|
+
alphaToCoverage: boolean;
|
|
111
|
+
vertexColors: VertexColors | null;
|
|
112
|
+
lineWidth: number;
|
|
113
|
+
worldUnits: boolean;
|
|
114
|
+
dashed: boolean;
|
|
115
|
+
dashSize: number;
|
|
116
|
+
gapSize: number;
|
|
117
|
+
dashScale: number;
|
|
118
|
+
dashOffset: number;
|
|
119
|
+
}, {}>;
|
|
120
|
+
export default _default;
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
import Box from './Box.vue';
|
|
2
|
+
import CatmullRomCurve3 from './CatmullRomCurve3.vue';
|
|
2
3
|
import Circle from './Circle.vue';
|
|
3
4
|
import Cone from './Cone.vue';
|
|
4
5
|
import Dodecahedron from './Dodecahedron.vue';
|
|
5
6
|
import Icosahedron from './Icosahedron.vue';
|
|
7
|
+
import Line2 from './Line2.vue';
|
|
6
8
|
import Octahedron from './Octahedron.vue';
|
|
7
9
|
import Plane from './Plane.vue';
|
|
8
10
|
import Ring from './Ring.vue';
|
|
@@ -11,4 +13,4 @@ import Tetrahedron from './Tetrahedron.vue';
|
|
|
11
13
|
import Torus from './Torus.vue';
|
|
12
14
|
import TorusKnot from './TorusKnot.vue';
|
|
13
15
|
import Tube from './Tube.vue';
|
|
14
|
-
export { Box, Circle, Cone, Dodecahedron, Icosahedron, Octahedron, Plane, Ring, Sphere, Tetrahedron, Torus, TorusKnot, Tube, };
|
|
16
|
+
export { Box, CatmullRomCurve3, Circle, Cone, Dodecahedron, Icosahedron, Line2, Octahedron, Plane, Ring, Sphere, Tetrahedron, Torus, TorusKnot, Tube, };
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
export interface EnvironmentOptions {
|
|
2
|
+
/**
|
|
3
|
+
* If true, the environment will be set as the scene's background.
|
|
4
|
+
*
|
|
5
|
+
* @type {boolean}
|
|
6
|
+
* @default false
|
|
7
|
+
*/
|
|
8
|
+
background?: boolean | string;
|
|
9
|
+
/**
|
|
10
|
+
* The blur radius of the environment.
|
|
11
|
+
*
|
|
12
|
+
* @type {number}
|
|
13
|
+
* @default 0
|
|
14
|
+
*/
|
|
15
|
+
blur?: number;
|
|
16
|
+
/**
|
|
17
|
+
* The files to load. If a string is provided, it will be loaded as an equirectangular texture.
|
|
18
|
+
* If an array is provided, it will be loaded as a cube texture.
|
|
19
|
+
*
|
|
20
|
+
* @type {(string | string[])}
|
|
21
|
+
*/
|
|
22
|
+
files?: string | string[];
|
|
23
|
+
/**
|
|
24
|
+
* The path to the files.
|
|
25
|
+
*
|
|
26
|
+
* @type {string}
|
|
27
|
+
* @default '/'
|
|
28
|
+
*/
|
|
29
|
+
path?: string;
|
|
30
|
+
/**
|
|
31
|
+
* The preset to use. If provided, the files and path props will be ignored.
|
|
32
|
+
*
|
|
33
|
+
* @type {EnvironmentPresetsType}
|
|
34
|
+
*/
|
|
35
|
+
preset?: EnvironmentPresetsType;
|
|
36
|
+
}
|
|
37
|
+
export declare const environmentPresets: {
|
|
38
|
+
sunset: string;
|
|
39
|
+
studio: string;
|
|
40
|
+
city: string;
|
|
41
|
+
umbrellas: string;
|
|
42
|
+
night: string;
|
|
43
|
+
forest: string;
|
|
44
|
+
snow: string;
|
|
45
|
+
dawn: string;
|
|
46
|
+
hangar: string;
|
|
47
|
+
urban: string;
|
|
48
|
+
modern: string;
|
|
49
|
+
shangai: string;
|
|
50
|
+
};
|
|
51
|
+
export type EnvironmentPresetsType = keyof typeof environmentPresets;
|
|
@@ -1,17 +1,3 @@
|
|
|
1
1
|
import type { CubeTexture, Texture } from 'three';
|
|
2
2
|
import type { EnvironmentOptions } from './const';
|
|
3
|
-
|
|
4
|
-
* Component that loads an environment map and sets it as the scene's background and environment.
|
|
5
|
-
*
|
|
6
|
-
* @export
|
|
7
|
-
* @param {Partial<EnvironmentOptions>} {
|
|
8
|
-
* files = ['/px.png', '/nx.png', '/py.png', '/ny.png', '/pz.png', '/nz.png'],
|
|
9
|
-
* blur = 0,
|
|
10
|
-
* background = false,
|
|
11
|
-
* path = undefined,
|
|
12
|
-
* preset = undefined,
|
|
13
|
-
* colorSpace = undefined,
|
|
14
|
-
* }
|
|
15
|
-
* @return {*} {(Promise<Texture | CubeTexture>)}
|
|
16
|
-
*/
|
|
17
|
-
export declare function useEnvironment({ files, blur, background, path, preset, }: Partial<EnvironmentOptions>): Promise<Texture | CubeTexture>;
|
|
3
|
+
export declare function useEnvironment(options: Partial<EnvironmentOptions>): Promise<Texture | CubeTexture>;
|