t3d-ez.gl 0.0.1 → 0.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (29) hide show
  1. package/dist/core/Controls/TTControls/TTControls.cjs.js +1 -0
  2. package/dist/core/Controls/TTControls/TTControls.esm.js +1 -0
  3. package/dist/core/Controls/index.cjs.js +1 -1
  4. package/dist/core/Controls/index.esm.js +1 -1
  5. package/dist/core/MarkerHtmlUI/index.cjs.js +1 -1
  6. package/dist/core/MarkerHtmlUI/index.esm.js +1 -1
  7. package/dist/core/Meshes/Builders/CapsuleBuilder.cjs.js +1 -0
  8. package/dist/core/Meshes/Builders/CapsuleBuilder.esm.js +1 -0
  9. package/dist/core/Meshes/index.cjs.js +1 -1
  10. package/dist/core/Meshes/index.esm.js +1 -1
  11. package/dist/core/WebGLEngine/index.cjs.js +1 -1
  12. package/dist/core/WebGLEngine/index.esm.js +1 -1
  13. package/dist/helpers/InfiniteGridHelper.cjs.js +1 -1
  14. package/dist/helpers/InfiniteGridHelper.esm.js +1 -1
  15. package/dist/node_modules/.pnpm/three@0.182.0/node_modules/three/build/three.core.cjs.js +1 -1
  16. package/dist/node_modules/.pnpm/three@0.182.0/node_modules/three/build/three.core.esm.js +1 -1
  17. package/dist/node_modules/.pnpm/three@0.182.0/node_modules/three/build/three.module.cjs.js +1 -1
  18. package/dist/node_modules/.pnpm/three@0.182.0/node_modules/three/build/three.module.esm.js +1 -1
  19. package/dist/package.json +4 -1
  20. package/dist/t3d-ez.gl.cjs.js +1 -1
  21. package/dist/t3d-ez.gl.esm.js +1 -1
  22. package/dist/types/core/Controls/TTControls/TTControls.d.ts +332 -0
  23. package/dist/types/core/Controls/index.d.ts +3 -2
  24. package/dist/types/core/Meshes/Builders/CapsuleBuilder.d.ts +19 -0
  25. package/dist/types/core/Meshes/Builders/index.d.ts +1 -0
  26. package/dist/types/core/Meshes/index.d.ts +3 -1
  27. package/dist/types/core/WebGLEngine/index.d.ts +2 -2
  28. package/dist/types/utils/index.d.ts +9 -0
  29. package/package.json +4 -1
package/dist/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "t3d-ez.gl",
3
- "version": "0.0.1",
3
+ "version": "0.0.2",
4
4
  "description": "",
5
5
  "main": "./dist/t3d-ez.gl.cjs.js",
6
6
  "module": "./dist/t3d-ez.gl.esm.js",
@@ -32,5 +32,8 @@
32
32
  },
33
33
  "dependencies": {
34
34
  "d3-geo": "^3.1.1"
35
+ },
36
+ "peerDependencies": {
37
+ "three": ">=0.150.0"
35
38
  }
36
39
  }
@@ -1 +1 @@
1
- "use strict";var e=require("./utils/index.cjs.js"),r=require("./core/Meshes/index.cjs.js"),s=require("./core/WebGLEngine/index.cjs.js"),o=require("./core/Controls/index.cjs.js"),t=require("./core/Lights/index.cjs.js"),i=require("./core/Resource/ResourceManager.cjs.js"),c=require("./core/Resource/types.cjs.js"),a=require("./core/Resource/loaders.cjs.js"),l=require("./core/Materials/index.cjs.js"),n=require("./core/DynamicSky/index.cjs.js"),u=require("./core/Map/index.cjs.js"),d=require("./node_modules/.pnpm/three@0.182.0/node_modules/three/examples/jsm/physics/AmmoPhysics.cjs.js"),p=require("./core/PostProcessor/index.cjs.js"),j=require("./helpers/InfiniteGridHelper.cjs.js"),x=require("./utils/FpsMeter/index.cjs.js"),f=require("./utils/Logger.cjs.js"),P=require("./core/Meshes/Builders/BoxBuilder.cjs.js"),h=require("./core/Meshes/Builders/SphereBuilder.cjs.js"),m=require("./core/Meshes/Builders/PlaneBuilder.cjs.js"),B=require("./core/Lights/Builders/DirectionalLightBuilder.cjs.js"),M=require("./core/Lights/Builders/PointLightBuilder.cjs.js"),g=require("./node_modules/.pnpm/three@0.182.0/node_modules/three/examples/jsm/loaders/GLTFLoader.cjs.js"),q=require("./core/Materials/GradationMaterial.cjs.js"),E=require("./core/Materials/FresnelMaterial.cjs.js"),L=require("./core/PostProcessor/effects/PotateEffect.cjs.js"),y=require("./core/PostProcessor/effects/SAOEffect.cjs.js"),T=require("./core/PostProcessor/effects/OutlineEffect.cjs.js"),S=require("./core/PostProcessor/effects/UnrealBloomEffect.cjs.js");exports.destroyModel=e.destroyModel,exports.disposeApp=e.disposeApp,exports.flyTo=e.flyTo,exports.focusTo=e.focusTo,exports.getContainerElement=e.getContainerElement,exports.loadHdrToScene=e.loadHdrToScene,exports.setDefaultEnvironment=e.setDefaultEnvironment,exports.throttleTimer=e.throttleTimer,exports.MeshBuilder=r.MeshBuilder,exports.PotatoEngine=s.PotatoEngine,Object.defineProperty(exports,"CONTROL_TYPE",{enumerable:!0,get:function(){return o.CONTROL_TYPE}}),exports.ControlsManager=o.ControlsManager,exports.LightBuilder=t.LightBuilder,exports.ResourceManager=i.ResourceManager,exports.RESOURCE_TYPE=c.RESOURCE_TYPE,exports.LoaderMaps=a.LoaderMaps,exports.MaterialsLibrary=l.MaterialsLibrary,exports.DynamicSky=n.DynamicSky,exports.PotatoMap=u.PotatoMap,exports.AmmoPhysics=d.AmmoPhysics,exports.PostProcessor=p.PostProcessor,exports.InfiniteGridHelper=j.InfiniteGridHelper,exports.PerformanceStats=x.PerformanceStats,exports.Logger=f.Logger,exports.BoxBuilder=P.BoxBuilder,exports.SphereBuilder=h.SphereBuilder,exports.PlaneBuilder=m.PlaneBuilder,exports.DirectionalLightBuilder=B.DirectionalLightBuilder,exports.PointLightBuilder=M.PointLightBuilder,exports.GLTFLoader=g.GLTFLoader,exports.GradationMaterial=q.GradationMaterial,exports.FresnelMaterial=E.FresnelMaterial,exports.PotateEffect=L.PotateEffect,exports.SAOEffect=y.SAOEffect,exports.OutlineEffect=T.OutlineEffect,exports.UnrealBloomEffect=S.UnrealBloomEffect;
1
+ "use strict";var e=require("./utils/index.cjs.js"),r=require("./core/Meshes/index.cjs.js"),s=require("./core/WebGLEngine/index.cjs.js"),o=require("./core/Controls/index.cjs.js"),t=require("./core/Lights/index.cjs.js"),i=require("./core/Resource/ResourceManager.cjs.js"),c=require("./core/Resource/types.cjs.js"),l=require("./core/Resource/loaders.cjs.js"),a=require("./core/Materials/index.cjs.js"),n=require("./core/DynamicSky/index.cjs.js"),u=require("./core/Map/index.cjs.js"),d=require("./node_modules/.pnpm/three@0.182.0/node_modules/three/examples/jsm/physics/AmmoPhysics.cjs.js"),p=require("./core/PostProcessor/index.cjs.js"),j=require("./helpers/InfiniteGridHelper.cjs.js"),x=require("./utils/FpsMeter/index.cjs.js"),f=require("./utils/Logger.cjs.js"),P=require("./core/Meshes/Builders/BoxBuilder.cjs.js"),B=require("./core/Meshes/Builders/SphereBuilder.cjs.js"),h=require("./core/Meshes/Builders/PlaneBuilder.cjs.js"),m=require("./core/Meshes/Builders/CapsuleBuilder.cjs.js"),M=require("./core/Controls/TTControls/TTControls.cjs.js"),q=require("./core/Lights/Builders/DirectionalLightBuilder.cjs.js"),g=require("./core/Lights/Builders/PointLightBuilder.cjs.js"),E=require("./node_modules/.pnpm/three@0.182.0/node_modules/three/examples/jsm/loaders/GLTFLoader.cjs.js"),L=require("./core/Materials/GradationMaterial.cjs.js"),T=require("./core/Materials/FresnelMaterial.cjs.js"),y=require("./core/PostProcessor/effects/PotateEffect.cjs.js"),C=require("./core/PostProcessor/effects/SAOEffect.cjs.js"),S=require("./core/PostProcessor/effects/OutlineEffect.cjs.js"),O=require("./core/PostProcessor/effects/UnrealBloomEffect.cjs.js");exports.destroyModel=e.destroyModel,exports.disposeApp=e.disposeApp,exports.flyTo=e.flyTo,exports.focusTo=e.focusTo,exports.getContainerElement=e.getContainerElement,exports.loadHdrToScene=e.loadHdrToScene,exports.setDefaultEnvironment=e.setDefaultEnvironment,exports.throttleTimer=e.throttleTimer,exports.MeshBuilder=r.MeshBuilder,exports.PotatoEngine=s.PotatoEngine,Object.defineProperty(exports,"CONTROL_TYPE",{enumerable:!0,get:function(){return o.CONTROL_TYPE}}),exports.ControlsManager=o.ControlsManager,exports.LightBuilder=t.LightBuilder,exports.ResourceManager=i.ResourceManager,exports.RESOURCE_TYPE=c.RESOURCE_TYPE,exports.LoaderMaps=l.LoaderMaps,exports.MaterialsLibrary=a.MaterialsLibrary,exports.DynamicSky=n.DynamicSky,exports.PotatoMap=u.PotatoMap,exports.AmmoPhysics=d.AmmoPhysics,exports.PostProcessor=p.PostProcessor,exports.InfiniteGridHelper=j.InfiniteGridHelper,exports.PerformanceStats=x.PerformanceStats,exports.Logger=f.Logger,exports.BoxBuilder=P.BoxBuilder,exports.SphereBuilder=B.SphereBuilder,exports.PlaneBuilder=h.PlaneBuilder,exports.CapsuleBuilder=m.CapsuleBuilder,exports.TTControls=M.TTControls,exports.DirectionalLightBuilder=q.DirectionalLightBuilder,exports.PointLightBuilder=g.PointLightBuilder,exports.GLTFLoader=E.GLTFLoader,exports.GradationMaterial=L.GradationMaterial,exports.FresnelMaterial=T.FresnelMaterial,exports.PotateEffect=y.PotateEffect,exports.SAOEffect=C.SAOEffect,exports.OutlineEffect=S.OutlineEffect,exports.UnrealBloomEffect=O.UnrealBloomEffect;
@@ -1 +1 @@
1
- export{destroyModel,disposeApp,flyTo,focusTo,getContainerElement,loadHdrToScene,setDefaultEnvironment,throttleTimer}from"./utils/index.esm.js";export{MeshBuilder}from"./core/Meshes/index.esm.js";export{PotatoEngine}from"./core/WebGLEngine/index.esm.js";export{CONTROL_TYPE,ControlsManager}from"./core/Controls/index.esm.js";export{LightBuilder}from"./core/Lights/index.esm.js";export{ResourceManager}from"./core/Resource/ResourceManager.esm.js";export{RESOURCE_TYPE}from"./core/Resource/types.esm.js";export{LoaderMaps}from"./core/Resource/loaders.esm.js";export{MaterialsLibrary}from"./core/Materials/index.esm.js";export{DynamicSky}from"./core/DynamicSky/index.esm.js";export{PotatoMap}from"./core/Map/index.esm.js";export{AmmoPhysics}from"./node_modules/.pnpm/three@0.182.0/node_modules/three/examples/jsm/physics/AmmoPhysics.esm.js";export{PostProcessor}from"./core/PostProcessor/index.esm.js";export{InfiniteGridHelper}from"./helpers/InfiniteGridHelper.esm.js";export{PerformanceStats}from"./utils/FpsMeter/index.esm.js";export{Logger}from"./utils/Logger.esm.js";export{BoxBuilder}from"./core/Meshes/Builders/BoxBuilder.esm.js";export{SphereBuilder}from"./core/Meshes/Builders/SphereBuilder.esm.js";export{PlaneBuilder}from"./core/Meshes/Builders/PlaneBuilder.esm.js";export{DirectionalLightBuilder}from"./core/Lights/Builders/DirectionalLightBuilder.esm.js";export{PointLightBuilder}from"./core/Lights/Builders/PointLightBuilder.esm.js";export{GLTFLoader}from"./node_modules/.pnpm/three@0.182.0/node_modules/three/examples/jsm/loaders/GLTFLoader.esm.js";export{GradationMaterial}from"./core/Materials/GradationMaterial.esm.js";export{FresnelMaterial}from"./core/Materials/FresnelMaterial.esm.js";export{PotateEffect}from"./core/PostProcessor/effects/PotateEffect.esm.js";export{SAOEffect}from"./core/PostProcessor/effects/SAOEffect.esm.js";export{OutlineEffect}from"./core/PostProcessor/effects/OutlineEffect.esm.js";export{UnrealBloomEffect}from"./core/PostProcessor/effects/UnrealBloomEffect.esm.js";
1
+ export{destroyModel,disposeApp,flyTo,focusTo,getContainerElement,loadHdrToScene,setDefaultEnvironment,throttleTimer}from"./utils/index.esm.js";export{MeshBuilder}from"./core/Meshes/index.esm.js";export{PotatoEngine}from"./core/WebGLEngine/index.esm.js";export{CONTROL_TYPE,ControlsManager}from"./core/Controls/index.esm.js";export{LightBuilder}from"./core/Lights/index.esm.js";export{ResourceManager}from"./core/Resource/ResourceManager.esm.js";export{RESOURCE_TYPE}from"./core/Resource/types.esm.js";export{LoaderMaps}from"./core/Resource/loaders.esm.js";export{MaterialsLibrary}from"./core/Materials/index.esm.js";export{DynamicSky}from"./core/DynamicSky/index.esm.js";export{PotatoMap}from"./core/Map/index.esm.js";export{AmmoPhysics}from"./node_modules/.pnpm/three@0.182.0/node_modules/three/examples/jsm/physics/AmmoPhysics.esm.js";export{PostProcessor}from"./core/PostProcessor/index.esm.js";export{InfiniteGridHelper}from"./helpers/InfiniteGridHelper.esm.js";export{PerformanceStats}from"./utils/FpsMeter/index.esm.js";export{Logger}from"./utils/Logger.esm.js";export{BoxBuilder}from"./core/Meshes/Builders/BoxBuilder.esm.js";export{SphereBuilder}from"./core/Meshes/Builders/SphereBuilder.esm.js";export{PlaneBuilder}from"./core/Meshes/Builders/PlaneBuilder.esm.js";export{CapsuleBuilder}from"./core/Meshes/Builders/CapsuleBuilder.esm.js";export{TTControls}from"./core/Controls/TTControls/TTControls.esm.js";export{DirectionalLightBuilder}from"./core/Lights/Builders/DirectionalLightBuilder.esm.js";export{PointLightBuilder}from"./core/Lights/Builders/PointLightBuilder.esm.js";export{GLTFLoader}from"./node_modules/.pnpm/three@0.182.0/node_modules/three/examples/jsm/loaders/GLTFLoader.esm.js";export{GradationMaterial}from"./core/Materials/GradationMaterial.esm.js";export{FresnelMaterial}from"./core/Materials/FresnelMaterial.esm.js";export{PotateEffect}from"./core/PostProcessor/effects/PotateEffect.esm.js";export{SAOEffect}from"./core/PostProcessor/effects/SAOEffect.esm.js";export{OutlineEffect}from"./core/PostProcessor/effects/OutlineEffect.esm.js";export{UnrealBloomEffect}from"./core/PostProcessor/effects/UnrealBloomEffect.esm.js";
@@ -0,0 +1,332 @@
1
+ import { Controls, Mesh, Object3D, Raycaster, Camera, Vector2, Color } from 'three';
2
+ export type TransformControlsMode = "translate" | "rotate" | "scale";
3
+ export interface TransformControlsEventMap {
4
+ /**
5
+ * Fires if any type of change (object or property change) is performed. Property changes are separate events you
6
+ * can add event listeners to. The event type is "propertyname-changed".
7
+ */
8
+ change: {};
9
+ /**
10
+ * Fires if a pointer (mouse/touch) becomes active.
11
+ */
12
+ mouseDown: {
13
+ mode: TransformControlsMode;
14
+ };
15
+ /**
16
+ * Fires if a pointer (mouse/touch) is no longer active.
17
+ */
18
+ mouseUp: {
19
+ mode: TransformControlsMode;
20
+ };
21
+ /**
22
+ * Fires if the controlled 3D object is changed.
23
+ */
24
+ objectChange: {};
25
+ "camera-changed": {
26
+ value: unknown;
27
+ };
28
+ "object-changed": {
29
+ value: unknown;
30
+ };
31
+ "enabled-changed": {
32
+ value: unknown;
33
+ };
34
+ "axis-changed": {
35
+ value: unknown;
36
+ };
37
+ "mode-changed": {
38
+ value: unknown;
39
+ };
40
+ "translationSnap-changed": {
41
+ value: unknown;
42
+ };
43
+ "rotationSnap-changed": {
44
+ value: unknown;
45
+ };
46
+ "scaleSnap-changed": {
47
+ value: unknown;
48
+ };
49
+ "space-changed": {
50
+ value: unknown;
51
+ };
52
+ "size-changed": {
53
+ value: unknown;
54
+ };
55
+ "dragging-changed": {
56
+ value: unknown;
57
+ };
58
+ "showX-changed": {
59
+ value: unknown;
60
+ };
61
+ "showY-changed": {
62
+ value: unknown;
63
+ };
64
+ "showZ-changed": {
65
+ value: unknown;
66
+ };
67
+ "minX-changed": {
68
+ value: unknown;
69
+ };
70
+ "maxX-changed": {
71
+ value: unknown;
72
+ };
73
+ "minY-changed": {
74
+ value: unknown;
75
+ };
76
+ "maxY-changed": {
77
+ value: unknown;
78
+ };
79
+ "minZ-changed": {
80
+ value: unknown;
81
+ };
82
+ "maxZ-changed": {
83
+ value: unknown;
84
+ };
85
+ "worldPosition-changed": {
86
+ value: unknown;
87
+ };
88
+ "worldPositionStart-changed": {
89
+ value: unknown;
90
+ };
91
+ "worldQuaternion-changed": {
92
+ value: unknown;
93
+ };
94
+ "worldQuaternionStart-changed": {
95
+ value: unknown;
96
+ };
97
+ "cameraPosition-changed": {
98
+ value: unknown;
99
+ };
100
+ "cameraQuaternion-changed": {
101
+ value: unknown;
102
+ };
103
+ "pointStart-changed": {
104
+ value: unknown;
105
+ };
106
+ "pointEnd-changed": {
107
+ value: unknown;
108
+ };
109
+ "rotationAxis-changed": {
110
+ value: unknown;
111
+ };
112
+ "rotationAngle-changed": {
113
+ value: unknown;
114
+ };
115
+ "eye-changed": {
116
+ value: unknown;
117
+ };
118
+ }
119
+ type axisType = "X" | "Y" | "Z" | "E" | "XY" | "YZ" | "XZ" | "XYZ" | "XYZE" | null;
120
+ interface IPointerType {
121
+ x: number;
122
+ y: number;
123
+ button: number;
124
+ }
125
+ type axisColorType = number | Color | string;
126
+ /**
127
+ * This class can be used to transform objects in 3D space by adapting a similar interaction model
128
+ * of DCC tools like Blender. Unlike other controls, it is not intended to transform the scene's camera.
129
+ *
130
+ * `TransformControls` expects that its attached 3D object is part of the scene graph.
131
+ *
132
+ * @augments Controls
133
+ * @three_import import { TransformControls } from 'three/addons/controls/TransformControls.js';
134
+ */
135
+ declare class TTControls extends Controls<TransformControlsEventMap> {
136
+ [key: string]: any;
137
+ /**
138
+ * The camera of the rendered scene.
139
+ */
140
+ camera: Camera;
141
+ /**
142
+ * The current transformation axis.
143
+ */
144
+ axis: axisType | string;
145
+ /**
146
+ * The current transformation mode. Possible values are "translate", "rotate" and "scale". Default is `translate`.
147
+ */
148
+ mode: TransformControlsMode;
149
+ /**
150
+ * By default, 3D objects are continuously translated. If you set this property to a numeric value (world units),
151
+ * you can define in which steps the 3D object should be translated. Default is `null`.
152
+ */
153
+ translationSnap: number | null;
154
+ /**
155
+ * By default, 3D objects are continuously rotated. If you set this property to a numeric value (radians), you can
156
+ * define in which steps the 3D object should be rotated. Default is `null`.
157
+ */
158
+ rotationSnap: number | null;
159
+ /**
160
+ * By default, 3D objects are continuously scaled. If you set this property to a numeric value, you can define in
161
+ * which steps the 3D object should be scaled. Default is `null`.
162
+ */
163
+ scaleSnap: number | null;
164
+ /**
165
+ * Defines in which coordinate space transformations should be performed. Possible values are "world" and "local".
166
+ * Default is `world`.
167
+ */
168
+ space: "world" | "local";
169
+ /**
170
+ * The size of the helper UI (axes/planes). Default is *1*.
171
+ */
172
+ size: number;
173
+ /**
174
+ * Whether or not dragging is currently performed. Read-only property.
175
+ */
176
+ dragging: boolean;
177
+ /**
178
+ * Whether or not the x-axis helper should be visible. Default is `true`.
179
+ */
180
+ showX: boolean;
181
+ /**
182
+ * Whether or not the y-axis helper should be visible. Default is `true`.
183
+ */
184
+ showY: boolean;
185
+ /**
186
+ * Whether or not the z-axis helper should be visible. Default is `true`.
187
+ */
188
+ showZ: boolean;
189
+ /**
190
+ * The minimum allowed X position during translation. Default is `-Infinity`.
191
+ */
192
+ minx: number;
193
+ /**
194
+ * The maximum allowed X position during translation. Default is `Infinity`.
195
+ */
196
+ maxX: number;
197
+ /**
198
+ * The minimum allowed Y position during translation. Default is `-Infinity`.
199
+ */
200
+ minY: number;
201
+ /**
202
+ * The maximum allowed Y position during translation. Default is `Infinity`.
203
+ */
204
+ maxY: number;
205
+ /**
206
+ * The minimum allowed Z position during translation. Default is `-Infinity`.
207
+ */
208
+ minZ: number;
209
+ /**
210
+ * The maximum allowed Z position during translation. Default is `Infinity`.
211
+ */
212
+ maxZ: number;
213
+ private _root;
214
+ private _gizmo;
215
+ private _plane;
216
+ /**
217
+ * Constructs a new controls instance.
218
+ *
219
+ * @param {Camera} camera - The camera of the rendered scene.
220
+ * @param {?HTMLElement} domElement - The HTML element used for event listeners.
221
+ */
222
+ constructor(camera: Camera, domElement?: HTMLElement | SVGElement | null);
223
+ connect(element: HTMLElement | SVGElement): void;
224
+ disconnect(): void;
225
+ /**
226
+ * Returns the visual representation of the controls. Add the helper to your scene to
227
+ * visually transform the attached 3D object.
228
+ *
229
+ * @return {TransformControlsRoot} The helper.
230
+ */
231
+ getHelper(): TransformControlsRoot;
232
+ pointerHover(pointer: Vector2): void;
233
+ pointerDown(pointer: IPointerType): void;
234
+ pointerMove(pointer: IPointerType): void;
235
+ pointerUp(pointer: IPointerType): void;
236
+ dispose(): void;
237
+ /**
238
+ * Sets the 3D object that should be transformed and ensures the controls UI is visible.
239
+ *
240
+ * @param {Object3D} object - The 3D object that should be transformed.
241
+ * @return {TransformControls} A reference to this controls.
242
+ */
243
+ attach(object: Object3D): this;
244
+ /**
245
+ * Removes the current 3D object from the controls and makes the helper UI invisible.
246
+ *
247
+ * @return {TransformControls} A reference to this controls.
248
+ */
249
+ detach(): this;
250
+ /**
251
+ * Resets the object's position, rotation and scale to when the current transform began.
252
+ */
253
+ reset(): void;
254
+ /**
255
+ * Returns the raycaster that is used for user interaction. This object is shared between all
256
+ * instances of `TransformControls`.
257
+ *
258
+ * @returns {Raycaster} The internal raycaster.
259
+ */
260
+ getRaycaster(): Raycaster;
261
+ /**
262
+ * Returns the transformation mode.
263
+ *
264
+ * @returns {'translate'|'rotate'|'scale'} The transformation mode.
265
+ */
266
+ getMode(): TransformControlsMode;
267
+ /**
268
+ * Sets the given transformation mode.
269
+ *
270
+ * @param {'translate'|'rotate'|'scale'} mode - The transformation mode to set.
271
+ */
272
+ setMode(mode: TransformControlsMode): void;
273
+ /**
274
+ * Sets the translation snap.
275
+ *
276
+ * @param {?number} translationSnap - The translation snap to set.
277
+ */
278
+ setTranslationSnap(translationSnap: number): void;
279
+ /**
280
+ * Sets the rotation snap.
281
+ *
282
+ * @param {?number} rotationSnap - The rotation snap to set.
283
+ */
284
+ setRotationSnap(rotationSnap: number): void;
285
+ /**
286
+ * Sets the scale snap.
287
+ *
288
+ * @param {?number} scaleSnap - The scale snap to set.
289
+ */
290
+ setScaleSnap(scaleSnap: number): void;
291
+ /**
292
+ * Sets the size of the helper UI.
293
+ *
294
+ * @param {number} size - The size to set.
295
+ */
296
+ setSize(size: number): void;
297
+ /**
298
+ * Sets the coordinate space in which transformations are applied.
299
+ *
300
+ * @param {'world'|'local'} space - The space to set.
301
+ */
302
+ setSpace(space: 'world' | 'local'): void;
303
+ /**
304
+ * Sets the colors of the control's gizmo.
305
+ *
306
+ * @param {number|Color|string} xAxis - The x-axis color.
307
+ * @param {number|Color|string} yAxis - The y-axis color.
308
+ * @param {number|Color|string} zAxis - The z-axis color.
309
+ * @param {number|Color|string} active - The color for active elements.
310
+ */
311
+ setColors(xAxis: axisColorType, yAxis: axisColorType, zAxis: axisColorType, active: axisColorType): void;
312
+ }
313
+ declare class TransformControlsRoot extends Object3D {
314
+ isTransformControlsRoot: boolean;
315
+ controls: TTControls;
316
+ constructor(controls: TTControls);
317
+ updateMatrixWorld(force: any): void;
318
+ dispose(): void;
319
+ }
320
+ declare class TransformControlsGizmo extends Object3D {
321
+ [key: string]: any;
322
+ type: string;
323
+ constructor();
324
+ updateMatrixWorld(force: any): void;
325
+ }
326
+ declare class TransformControlsPlane extends Mesh {
327
+ [key: string]: any;
328
+ type: string;
329
+ constructor();
330
+ updateMatrixWorld(force: any): void;
331
+ }
332
+ export { TTControls, TransformControlsGizmo, TransformControlsPlane };
@@ -2,7 +2,8 @@ import { OrbitControls } from "three/examples/jsm/controls/OrbitControls.js";
2
2
  import { TrackballControls } from "three/examples/jsm/controls/TrackballControls.js";
3
3
  import { FirstControls } from "./controlsLibs/FirstControls";
4
4
  import { Camera } from "three";
5
- import { PotatoEngine } from "../WebGLEngine";
5
+ import { PotatoEngine } from "../WebGLEngine/index";
6
+ import { TTControls } from "./TTControls/TTControls";
6
7
  export declare enum CONTROL_TYPE {
7
8
  ORBIT = 0,
8
9
  TRACKBALL = 1,
@@ -33,4 +34,4 @@ export declare class ControlsManager implements ControlManager {
33
34
  initFirstpersonControls(camera: Camera, domElement: HTMLElement): FirstControls;
34
35
  initTrackballControls(camera: Camera, domElement: HTMLElement): TrackballControls;
35
36
  }
36
- export {};
37
+ export { ControlManager, TTControls };
@@ -0,0 +1,19 @@
1
+ import { Scene, Material } from "three";
2
+ import { MeshBuilder } from "./MeshBuilder";
3
+ type boxMeshType = {
4
+ radius?: number;
5
+ height?: number;
6
+ capSegments?: number;
7
+ radialSegments?: number;
8
+ heightSegments?: number;
9
+ material?: Material;
10
+ };
11
+ export declare class CapsuleBuilder extends MeshBuilder {
12
+ options: boxMeshType;
13
+ type: string;
14
+ constructor(name: string | undefined, options: boxMeshType | undefined, scene: Scene);
15
+ private static createGeometry;
16
+ private static createMaterial;
17
+ }
18
+ export declare function createCapsule(name: string | undefined, options: boxMeshType | undefined, scene: Scene): CapsuleBuilder;
19
+ export {};
@@ -1,3 +1,4 @@
1
1
  export * from "./BoxBuilder";
2
2
  export * from "./SphereBuilder";
3
3
  export * from "./PlaneBuilder";
4
+ export * from "./CapsuleBuilder";
@@ -1,9 +1,11 @@
1
1
  import { BoxBuilder, createBox } from "./Builders/index";
2
2
  import { SphereBuilder, createSphere } from "./Builders/index";
3
3
  import { PlaneBuilder, createPlane } from "./Builders/index";
4
+ import { CapsuleBuilder, createCapsule } from "./Builders/index";
4
5
  export declare const MeshBuilder: {
5
6
  createBox: typeof createBox;
6
7
  createSphere: typeof createSphere;
7
8
  createPlane: typeof createPlane;
9
+ createCapsule: typeof createCapsule;
8
10
  };
9
- export { BoxBuilder, SphereBuilder, PlaneBuilder };
11
+ export { BoxBuilder, SphereBuilder, PlaneBuilder, CapsuleBuilder };
@@ -2,9 +2,9 @@ import { Scene, PerspectiveCamera, WebGLRenderer, Camera, OrthographicCamera } f
2
2
  import { IPotatoEngineParameters, IPotatoEngine } from "./types/index";
3
3
  import { ControlsManager, CONTROL_TYPE } from "../Controls/index";
4
4
  import { ResourceManager } from "../Resource/ResourceManager";
5
- import { PostProcessor } from "../PostProcessor";
5
+ import { PostProcessor } from "../PostProcessor/index";
6
6
  import { OrbitControls } from "three/examples/jsm/controls/OrbitControls.js";
7
- import { MarkerHtmlUI } from "../MarkerHtmlUI";
7
+ import { MarkerHtmlUI } from "../MarkerHtmlUI/index";
8
8
  type TrunParams = (params: {
9
9
  sceneGraph: Scene;
10
10
  camera: Camera;
@@ -29,6 +29,15 @@ export declare function getContainerElement(cube: HTMLElement | string): HTMLEle
29
29
  * @param comleteCallback
30
30
  */
31
31
  export declare function flyTo(engine: PotatoEngine, position?: THREE.Vector3, target?: THREE.Vector3, index?: number, ease?: string, startCallback?: () => void, comleteCallback?: () => void): void;
32
+ /**
33
+ * 相机移动动画
34
+ * @param position
35
+ * @param target
36
+ * @param index
37
+ * @param ease
38
+ * @param startCallback
39
+ * @param comleteCallback
40
+ */
32
41
  /**
33
42
  * 聚焦到具体模型位置函数
34
43
  * @param target
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "t3d-ez.gl",
3
- "version": "0.0.1",
3
+ "version": "0.0.2",
4
4
  "description": "",
5
5
  "main": "./dist/t3d-ez.gl.cjs.js",
6
6
  "module": "./dist/t3d-ez.gl.esm.js",
@@ -32,5 +32,8 @@
32
32
  },
33
33
  "dependencies": {
34
34
  "d3-geo": "^3.1.1"
35
+ },
36
+ "peerDependencies": {
37
+ "three": ">=0.150.0"
35
38
  }
36
39
  }