@yschindel/ara3d-webgl 1.3.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.
Files changed (31) hide show
  1. package/LICENSE +23 -0
  2. package/README.md +108 -0
  3. package/dist/ara3d-webgl.mjs +35785 -0
  4. package/dist/ara3d-webgl.mjs.map +1 -0
  5. package/dist/ara3d-webgl.umd.js +5020 -0
  6. package/dist/ara3d-webgl.umd.js.map +1 -0
  7. package/dist/types/images.d.ts +4 -0
  8. package/dist/types/index.d.ts +7 -0
  9. package/dist/types/loader/bimGeometry.d.ts +28 -0
  10. package/dist/types/loader/bimOpenSchemaLoader.d.ts +14 -0
  11. package/dist/types/loader/buildGeometryGroup.d.ts +14 -0
  12. package/dist/types/loader/gltfLoader.d.ts +8 -0
  13. package/dist/types/viewer/camera/camera.d.ts +86 -0
  14. package/dist/types/viewer/camera/cameraMovement.d.ts +19 -0
  15. package/dist/types/viewer/camera/cameraMovementDo.d.ts +20 -0
  16. package/dist/types/viewer/camera/cameraMovementLerp.d.ts +24 -0
  17. package/dist/types/viewer/camera/orthographic.d.ts +8 -0
  18. package/dist/types/viewer/camera/perspective.d.ts +9 -0
  19. package/dist/types/viewer/environment.d.ts +39 -0
  20. package/dist/types/viewer/gizmos/gizmoAxes.d.ts +77 -0
  21. package/dist/types/viewer/gizmos/gizmoOrbit.d.ts +68 -0
  22. package/dist/types/viewer/inputs/input.d.ts +62 -0
  23. package/dist/types/viewer/inputs/inputHandler.d.ts +26 -0
  24. package/dist/types/viewer/inputs/keyboard.d.ts +107 -0
  25. package/dist/types/viewer/inputs/mouse.d.ts +40 -0
  26. package/dist/types/viewer/inputs/touch.d.ts +33 -0
  27. package/dist/types/viewer/rendering/renderer.d.ts +22 -0
  28. package/dist/types/viewer/viewer.d.ts +28 -0
  29. package/dist/types/viewer/viewerSettings.d.ts +109 -0
  30. package/dist/types/viewer/viewport.d.ts +41 -0
  31. package/package.json +76 -0
@@ -0,0 +1,4 @@
1
+ /**
2
+ * A circular alpha gradient used as floor under model
3
+ */
4
+ export declare const floor = "\n\n";
@@ -0,0 +1,7 @@
1
+ export * as THREE from 'three';
2
+ export * from './viewer/viewer';
3
+ export type { PointerMode } from './viewer/inputs/input';
4
+ export { DefaultInputScheme, KEYS } from './viewer/inputs/input';
5
+ export * from './viewer/viewerSettings';
6
+ export * from './loader/gltfLoader';
7
+ export * from './loader/bimOpenSchemaLoader';
@@ -0,0 +1,28 @@
1
+ export interface BimGeometry {
2
+ InstanceEntityIndex: Int32Array;
3
+ InstanceMaterialIndex: Int32Array;
4
+ InstanceMeshIndex: Int32Array;
5
+ InstanceTransformIndex: Int32Array;
6
+ VertexX: Int32Array;
7
+ VertexY: Int32Array;
8
+ VertexZ: Int32Array;
9
+ IndexBuffer: Int32Array;
10
+ MeshVertexOffset: Int32Array;
11
+ MeshIndexOffset: Int32Array;
12
+ MaterialRed: Uint8Array;
13
+ MaterialGreen: Uint8Array;
14
+ MaterialBlue: Uint8Array;
15
+ MaterialAlpha: Uint8Array;
16
+ MaterialRoughness: Uint8Array;
17
+ MaterialMetallic: Uint8Array;
18
+ TransformTX: Float32Array;
19
+ TransformTY: Float32Array;
20
+ TransformTZ: Float32Array;
21
+ TransformQX: Float32Array;
22
+ TransformQY: Float32Array;
23
+ TransformQZ: Float32Array;
24
+ TransformQW: Float32Array;
25
+ TransformSX: Float32Array;
26
+ TransformSY: Float32Array;
27
+ TransformSZ: Float32Array;
28
+ }
@@ -0,0 +1,14 @@
1
+ import * as THREE from 'three';
2
+ import JSZip from 'jszip';
3
+ import { BimGeometry } from './bimGeometry';
4
+ /**
5
+ * Loader that takes a URL to a .ZIP or .BOS file containing BIM Open Schema geometry parquet tables:
6
+ */
7
+ export declare class BimOpenSchemaLoader {
8
+ load(source: string): Promise<THREE.Group>;
9
+ }
10
+ /**
11
+ * Reads the BOS parquet tables from a JSZip archive into a BimGeometry object.
12
+ * This is the same idea as the previous browser version, just using package imports.
13
+ */
14
+ export declare function loadBimGeometryFromZip(zip: JSZip): Promise<BimGeometry>;
@@ -0,0 +1,14 @@
1
+ import * as THREE from 'three';
2
+ import { BimGeometry } from './bimGeometry';
3
+ type InstanceGroup = {
4
+ meshIndex: number;
5
+ materialIndex: number;
6
+ instanceIndices: number[];
7
+ };
8
+ export declare function buildGeometry(bim: BimGeometry): THREE.Group;
9
+ export declare function createMergedAndSingleMeshes(bim: BimGeometry, geometries: Array<THREE.BufferGeometry>, materials: Array<THREE.Material>, transforms: Array<THREE.Matrix4>, materialGroups: Map<number, number[]>): Array<THREE.Mesh>;
10
+ export declare function computeTransforms(bim: BimGeometry): any[];
11
+ export declare function mergeGeometries(geometries: Array<THREE.BufferGeometry>): THREE.BufferGeometry;
12
+ export declare function gatherSingleInstancesByMaterial(instanceGroups: Array<InstanceGroup>): Map<number, number[]>;
13
+ export declare function createInstances(bim: BimGeometry, geometries: Array<THREE.BufferGeometry>, materials: Array<THREE.Material>, transforms: Array<THREE.Matrix4>, instanceGroups: Array<InstanceGroup>): Array<THREE.InstancedMesh>;
14
+ export {};
@@ -0,0 +1,8 @@
1
+ import * as THREE from 'three';
2
+ export declare class GltfLoader {
3
+ private loader;
4
+ constructor();
5
+ load(source: string): Promise<THREE.Group>;
6
+ private loadFromUrlOrZip;
7
+ private loadFromZipUrl;
8
+ }
@@ -0,0 +1,86 @@
1
+ import * as THREE from 'three';
2
+ import { Viewport } from '../viewport';
3
+ import { Settings } from '../viewerSettings';
4
+ import { ISignal } from 'ste-signals';
5
+ import { PerspectiveWrapper } from './perspective';
6
+ import { OrthographicWrapper } from './orthographic';
7
+ import { CameraMovement } from './cameraMovement';
8
+ /**
9
+ * Manages viewer camera movement and position
10
+ */
11
+ export declare class Camera {
12
+ camPerspective: PerspectiveWrapper;
13
+ camOrthographic: OrthographicWrapper;
14
+ private _viewport;
15
+ private _lerp;
16
+ private _movement;
17
+ private _inputVelocity;
18
+ private _velocity;
19
+ private _speed;
20
+ private _orthographic;
21
+ private _target;
22
+ private _lastPosition;
23
+ private _lastQuaternion;
24
+ private _lastTarget;
25
+ _savedPosition: THREE.Vector3;
26
+ _savedTarget: THREE.Vector3;
27
+ private _onValueChanged;
28
+ get onValueChanged(): ISignal;
29
+ private _hasMoved;
30
+ get hasMoved(): boolean;
31
+ private _onMoved;
32
+ get onMoved(): ISignal;
33
+ /** Ignore movement permissions when true */
34
+ private _force;
35
+ /** Vector3 of 0 or 1 to enable/disable movement along each axis */
36
+ private _allowedMovement;
37
+ get allowedMovement(): THREE.Vector3;
38
+ set allowedMovement(axes: THREE.Vector3);
39
+ /** Vector2 of 0 or 1 to enable/disable rotation around x or y. */
40
+ get allowedRotation(): THREE.Vector2;
41
+ set allowedRotation(axes: THREE.Vector2);
42
+ private _allowedRotation;
43
+ private _defaultForward;
44
+ get defaultForward(): THREE.Vector3;
45
+ set defaultForward(value: THREE.Vector3);
46
+ private _velocityBlendFactor;
47
+ private _moveSpeed;
48
+ constructor(viewport: Viewport, settings: Settings);
49
+ /**
50
+ * Interface to move camera instantaneously
51
+ * @param force Set to true to ignore locked axis and rotation.
52
+ */
53
+ do(force?: boolean): CameraMovement;
54
+ /**
55
+ * Interface to move camera over time
56
+ * @param force Set to true to ignore locked axis and rotation.
57
+ */
58
+ lerp(duration?: number, force?: boolean): CameraMovement;
59
+ frustrumSizeAt(point: THREE.Vector3): any;
60
+ notifyMovement(): void;
61
+ get three(): any;
62
+ get quaternion(): any;
63
+ get position(): any;
64
+ get matrix(): any;
65
+ get forward(): any;
66
+ get speed(): number;
67
+ set speed(value: number);
68
+ get localVelocity(): THREE.Vector3;
69
+ /**
70
+ * Set current velocity of the camera.
71
+ */
72
+ set localVelocity(vector: THREE.Vector3);
73
+ stop(): void;
74
+ get target(): any;
75
+ applySettings(settings: Settings): void;
76
+ get orbitDistance(): any;
77
+ save(): void;
78
+ private updateProjection;
79
+ get orthographic(): boolean;
80
+ set orthographic(value: boolean);
81
+ update(deltaTime: number): boolean;
82
+ private applyVelocity;
83
+ private updateOrthographic;
84
+ private getVelocityMultiplier;
85
+ private checkForMovement;
86
+ }
@@ -0,0 +1,19 @@
1
+ import { Camera } from './camera';
2
+ import * as THREE from 'three';
3
+ export declare abstract class CameraMovement {
4
+ protected _camera: Camera;
5
+ constructor(camera: Camera);
6
+ abstract move3(vector: THREE.Vector3): void;
7
+ move2(vector: THREE.Vector2, axes: 'XY' | 'XZ'): void;
8
+ move1(amount: number, axis: 'X' | 'Y' | 'Z'): void;
9
+ abstract rotate(angle: THREE.Vector2): void;
10
+ abstract zoom(amount: number): void;
11
+ abstract setDistance(dist: number): void;
12
+ abstract orbit(vector: THREE.Vector2): void;
13
+ orbitTowards(direction: THREE.Vector3): void;
14
+ abstract target(target: THREE.Vector3): void;
15
+ abstract reset(): void;
16
+ abstract set(position: THREE.Vector3, target?: THREE.Vector3): any;
17
+ frame(target: THREE.Sphere | THREE.Box3 | 'all' | undefined, forward?: THREE.Vector3): void;
18
+ protected frameSphere(sphere: THREE.Sphere, forward: THREE.Vector3): void;
19
+ }
@@ -0,0 +1,20 @@
1
+ import { CameraMovement } from './cameraMovement';
2
+ import * as THREE from 'three';
3
+ export declare class CameraMovementDo extends CameraMovement {
4
+ /**
5
+ * Moves the camera closer or farther away from orbit target.
6
+ * @param amount movement size.
7
+ */
8
+ zoom(amount: number): void;
9
+ reset(): void;
10
+ setDistance(dist: number): void;
11
+ rotate(angle: THREE.Vector2): void;
12
+ applyRotation(quaternion: THREE.Quaternion): void;
13
+ target(pos: THREE.Vector3): void;
14
+ orbit(angle: THREE.Vector2): void;
15
+ move3(vector: THREE.Vector3): void;
16
+ set(position: THREE.Vector3, target?: THREE.Vector3): void;
17
+ private lockVector;
18
+ predictOrbit(angle: THREE.Vector2): any;
19
+ predictRotate(angle: THREE.Vector2): any;
20
+ }
@@ -0,0 +1,24 @@
1
+ import * as THREE from 'three';
2
+ import { Camera } from './camera';
3
+ import { CameraMovementDo } from './cameraMovementDo';
4
+ import { CameraMovement } from './cameraMovement';
5
+ export declare class CameraLerp extends CameraMovement {
6
+ _movement: CameraMovementDo;
7
+ _clock: any;
8
+ onProgress: ((progress: number) => void) | undefined;
9
+ _duration: number;
10
+ constructor(camera: Camera, movement: CameraMovementDo);
11
+ init(duration: number): void;
12
+ cancel(): void;
13
+ animate(): void;
14
+ easeOutCubic(x: number): number;
15
+ update(): void;
16
+ move3(vector: THREE.Vector3): void;
17
+ rotate(angle: THREE.Vector2): void;
18
+ zoom(amount: number): void;
19
+ setDistance(dist: number): void;
20
+ orbit(angle: THREE.Vector2): void;
21
+ target(target: THREE.Vector3): void;
22
+ reset(): void;
23
+ set(position: THREE.Vector3, target?: THREE.Vector3): void;
24
+ }
@@ -0,0 +1,8 @@
1
+ import * as THREE from 'three';
2
+ import { Settings } from '../viewerSettings';
3
+ export declare class OrthographicWrapper {
4
+ camera: THREE.OrthographicCamera;
5
+ constructor(camera: THREE.OrthographicCamera);
6
+ applySettings(settings: Settings): void;
7
+ updateProjection(size: THREE.Vector2, aspect: number): void;
8
+ }
@@ -0,0 +1,9 @@
1
+ import * as THREE from 'three';
2
+ import { Settings } from '../viewerSettings';
3
+ export declare class PerspectiveWrapper {
4
+ camera: THREE.PerspectiveCamera;
5
+ constructor(camera: THREE.PerspectiveCamera);
6
+ applySettings(settings: Settings): void;
7
+ updateProjection(aspect: number): void;
8
+ frustrumSizeAt(point: THREE.Vector3): any;
9
+ }
@@ -0,0 +1,39 @@
1
+ import * as THREE from 'three';
2
+ import { TextureEncoding, Settings } from './viewerSettings';
3
+ import { Box3 } from 'three';
4
+ export declare class GroundPlane {
5
+ mesh: THREE.Mesh;
6
+ private _source;
7
+ private _size;
8
+ private readonly _geometry;
9
+ private readonly _material;
10
+ private _texture;
11
+ constructor();
12
+ applyViewerSettings(settings: Settings): void;
13
+ adaptToContent(box: THREE.Box3): void;
14
+ applyTexture(encoding: 'url' | 'base64' | undefined, source: string): void;
15
+ dispose(): void;
16
+ }
17
+ export declare class Environment {
18
+ skyLight: THREE.HemisphereLight;
19
+ sunLights: THREE.DirectionalLight[];
20
+ private _groundPlane;
21
+ get groundPlane(): THREE.Mesh;
22
+ constructor(settings: Settings);
23
+ loadGroundTexture(encoding: TextureEncoding, url: string): void;
24
+ /**
25
+ * Returns all three objects composing the environment
26
+ */
27
+ getObjects(): THREE.Object3D[];
28
+ applySettings(settings: Settings): void;
29
+ /**
30
+ * Adjust scale so that it matches box dimensions.
31
+ */
32
+ adaptToContent(box: Box3): void;
33
+ dispose(): void;
34
+ }
35
+ export interface IEnvironment {
36
+ skyLight: THREE.HemisphereLight;
37
+ sunLights: THREE.DirectionalLight[];
38
+ groundPlane: THREE.Mesh;
39
+ }
@@ -0,0 +1,77 @@
1
+ import * as THREE from 'three';
2
+ import { Camera } from '../camera/camera';
3
+ export declare class Axis {
4
+ axis: string;
5
+ direction: THREE.Vector3;
6
+ size: number;
7
+ color: string;
8
+ colorSub: string;
9
+ position: THREE.Vector3;
10
+ label: string | undefined;
11
+ line: number | undefined;
12
+ constructor(init: Axis);
13
+ }
14
+ export declare class GizmoOptions {
15
+ size: number;
16
+ padding: number;
17
+ bubbleSizePrimary: number;
18
+ bubbleSizeSecondary: number;
19
+ lineWidth: number;
20
+ fontSize: string;
21
+ fontFamily: string;
22
+ fontWeight: string;
23
+ fontColor: string;
24
+ className: string;
25
+ colorX: string;
26
+ colorY: string;
27
+ colorZ: string;
28
+ colorXSub: string;
29
+ colorYSub: string;
30
+ colorZSub: string;
31
+ constructor(init?: Partial<GizmoOptions>);
32
+ }
33
+ /**
34
+ * Axes gizmo with user interaction.
35
+ * It draws on its own canvas.
36
+ */
37
+ export declare class GizmoAxes {
38
+ options: GizmoOptions;
39
+ axes: Axis[];
40
+ camera: Camera;
41
+ canvas: HTMLCanvasElement;
42
+ context: CanvasRenderingContext2D;
43
+ rect: DOMRect;
44
+ isDragging: boolean;
45
+ isDragSignificant: boolean;
46
+ dragStart: THREE.Vector2;
47
+ dragLast: THREE.Vector2;
48
+ pointer: THREE.Vector3;
49
+ center: THREE.Vector3;
50
+ invRotMat: THREE.Matrix4;
51
+ selectedAxis: Axis | null;
52
+ constructor(camera: Camera, options?: Partial<GizmoOptions>);
53
+ animate(): void;
54
+ createAxes(): Axis[];
55
+ createCanvas(): HTMLCanvasElement;
56
+ onTouchStart: (e: TouchEvent) => void;
57
+ onTouchMove: (e: TouchEvent) => void;
58
+ onTouchEnd: (e: TouchEvent) => void;
59
+ onPointerDown: (e: MouseEvent) => void;
60
+ onPointerUp: (event: PointerEvent) => void;
61
+ onPointerEnter: () => void;
62
+ onPointerMove: (e: MouseEvent) => void;
63
+ toMouseVector(e: MouseEvent, target: THREE.Vector3): any;
64
+ onPointerDrag: (e: MouseEvent) => void;
65
+ initDrag(x: number, y: number): void;
66
+ updateDrag(x: number, y: number): void;
67
+ endDrag(): void;
68
+ onMouseClick: () => void;
69
+ update: () => void;
70
+ drawLayers(clear: boolean): void;
71
+ drawCircle(pos: THREE.Vector3, radius?: number, color?: string): void;
72
+ drawLine(p1: THREE.Vector2, p2: THREE.Vector2, width?: number, color?: string): void;
73
+ setAxisPosition(axis: Axis): void;
74
+ private pickAxes;
75
+ dispose: () => void;
76
+ }
77
+ export { GizmoAxes as OrbitControlsGizmo };
@@ -0,0 +1,68 @@
1
+ import * as THREE from 'three';
2
+ import { Renderer } from '../rendering/renderer';
3
+ import { Camera } from '../camera/camera';
4
+ import { Settings } from '../viewerSettings';
5
+ import { Input } from '../inputs/input';
6
+ /**
7
+ * Manages the camera target gizmo
8
+ */
9
+ export declare class GizmoOrbit {
10
+ private _renderer;
11
+ private _camera;
12
+ private _inputs;
13
+ private _size;
14
+ private _fov;
15
+ private _color;
16
+ private _opacity;
17
+ private _opacityAlways;
18
+ private _fadeDurationMs;
19
+ private _showDurationMs;
20
+ private _box;
21
+ private _wireframe;
22
+ private _material;
23
+ private _materialAlways;
24
+ private _gizmos;
25
+ private _disconnectCamera;
26
+ private _timeout;
27
+ private _fadeEnd;
28
+ private _active;
29
+ private _animation;
30
+ constructor(renderer: Renderer, camera: Camera, input: Input, settings: Settings);
31
+ private connect;
32
+ private onUpdate;
33
+ /**
34
+ * Disposes all resources.
35
+ */
36
+ dispose(): void;
37
+ /**
38
+ * Orbit gizmo will only show when enabled is true.
39
+ */
40
+ get enabled(): boolean;
41
+ set enabled(value: boolean);
42
+ /**
43
+ * Show/Hide the gizmo for a brief delay if the gizmo is actives.
44
+ */
45
+ show(show?: boolean): void;
46
+ private fadeOut;
47
+ /**
48
+ * Updates the position of the orbit gizmo
49
+ */
50
+ setPosition(position: THREE.Vector3): void;
51
+ /**
52
+ * Updates the size of the orbit gizmo
53
+ */
54
+ setSize(size: number): void;
55
+ /**
56
+ * Updates opacity of the orbit gizmo
57
+ * @opacity opacity of the non occluded part.
58
+ * @opacityAlways opacity of the occluded part.
59
+ */
60
+ setOpacity(opacity: number, opacityAlways: number): void;
61
+ /**
62
+ * Updates color of the orbit gizmo
63
+ */
64
+ setColor(color: THREE.Color): void;
65
+ applySettings(settings: Settings): void;
66
+ private updateScale;
67
+ private createGizmo;
68
+ }
@@ -0,0 +1,62 @@
1
+ import * as THREE from 'three';
2
+ import { Viewer } from '../viewer';
3
+ import { KeyboardHandler } from './keyboard';
4
+ import { TouchHandler } from './touch';
5
+ import { MouseHandler } from './mouse';
6
+ export { KEYS } from './keyboard';
7
+ /** Pointers mode supported by the viewer */
8
+ export type PointerMode = 'orbit' | 'look' | 'pan' | 'zoom' | 'rect';
9
+ export declare class DefaultInputScheme {
10
+ private _viewer;
11
+ constructor(viewer: Viewer);
12
+ onKeyAction(key: number): boolean;
13
+ }
14
+ /**
15
+ * Manages and registers all viewer user inputs for mouse, keyboard and touch
16
+ */
17
+ export declare class Input {
18
+ private _viewer;
19
+ private _scheme;
20
+ touch: TouchHandler;
21
+ mouse: MouseHandler;
22
+ keyboard: KeyboardHandler;
23
+ private _pointerActive;
24
+ private _pointerFallback;
25
+ private _pointerOverride;
26
+ constructor(viewer: Viewer);
27
+ /**
28
+ * Returns the last main mode (orbit, look) that was active.
29
+ */
30
+ get pointerFallback(): PointerMode;
31
+ /**
32
+ * Returns current pointer mode.
33
+ */
34
+ get pointerActive(): PointerMode;
35
+ /**
36
+ * A temporary pointer mode used for temporary icons.
37
+ */
38
+ get pointerOverride(): PointerMode | undefined;
39
+ set pointerOverride(value: PointerMode | undefined);
40
+ /**
41
+ * Changes pointer interaction mode. Look mode will set camera orbitMode to false.
42
+ */
43
+ set pointerActive(value: PointerMode);
44
+ private _onPointerModeChanged;
45
+ /**
46
+ * Event called when pointer interaction mode changes.
47
+ */
48
+ get onPointerModeChanged(): import("ste-signals").ISignal;
49
+ private _onPointerOverrideChanged;
50
+ /**
51
+ * Event called when the pointer is temporarily overriden.
52
+ */
53
+ get onPointerOverrideChanged(): import("ste-signals").ISignal;
54
+ private _onContextMenu;
55
+ get onContextMenu(): import("ste-simple-events").ISimpleEvent<any>;
56
+ get scheme(): DefaultInputScheme;
57
+ KeyAction(key: number): boolean;
58
+ ContextMenu(position: THREE.Vector2 | undefined): void;
59
+ registerAll(): void;
60
+ unregisterAll: () => void;
61
+ resetAll(): void;
62
+ }
@@ -0,0 +1,26 @@
1
+ import { Viewer } from '../viewer';
2
+ /**
3
+ * Base class for various input handlers.
4
+ * It provides convenience to register to and unregister from events.
5
+ */
6
+ export declare class InputHandler {
7
+ protected _viewer: Viewer;
8
+ protected _unregisters: Function[];
9
+ constructor(viewer: Viewer);
10
+ protected reg: (handler: any, type: string, listener: (event: any) => void) => void;
11
+ /**
12
+ * Register handler to related browser events
13
+ * Prevents double registrations
14
+ */
15
+ register(): void;
16
+ protected addListeners(): void;
17
+ /**
18
+ * Unregister handler from related browser events
19
+ * Prevents double unregistration
20
+ */
21
+ unregister(): void;
22
+ /**
23
+ * Reset handler states such as button down, drag, etc.
24
+ */
25
+ reset(): void;
26
+ }