@inweb/viewer-three 26.6.6 → 26.7.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 (75) hide show
  1. package/dist/plugins/components/AxesHelperComponent.js +5 -5
  2. package/dist/plugins/components/AxesHelperComponent.js.map +1 -1
  3. package/dist/plugins/components/AxesHelperComponent.min.js +1 -1
  4. package/dist/plugins/components/AxesHelperComponent.module.js +5 -5
  5. package/dist/plugins/components/AxesHelperComponent.module.js.map +1 -1
  6. package/dist/plugins/components/ExtentsHelperComponent.js +15 -7
  7. package/dist/plugins/components/ExtentsHelperComponent.js.map +1 -1
  8. package/dist/plugins/components/ExtentsHelperComponent.min.js +1 -1
  9. package/dist/plugins/components/ExtentsHelperComponent.module.js +15 -7
  10. package/dist/plugins/components/ExtentsHelperComponent.module.js.map +1 -1
  11. package/dist/plugins/components/LightHelperComponent.js +5 -5
  12. package/dist/plugins/components/LightHelperComponent.js.map +1 -1
  13. package/dist/plugins/components/LightHelperComponent.min.js +1 -1
  14. package/dist/plugins/components/LightHelperComponent.module.js +5 -5
  15. package/dist/plugins/components/LightHelperComponent.module.js.map +1 -1
  16. package/dist/plugins/loaders/GLTFCloudLoader.js +4840 -0
  17. package/dist/plugins/loaders/GLTFCloudLoader.js.map +1 -0
  18. package/dist/plugins/loaders/GLTFCloudLoader.min.js +1 -0
  19. package/dist/plugins/loaders/GLTFCloudLoader.module.js +49 -0
  20. package/dist/plugins/loaders/GLTFCloudLoader.module.js.map +1 -0
  21. package/dist/plugins/loaders/IFCXLoader.js +12 -6
  22. package/dist/plugins/loaders/IFCXLoader.js.map +1 -1
  23. package/dist/plugins/loaders/IFCXLoader.min.js +1 -1
  24. package/dist/plugins/loaders/IFCXLoader.module.js +13 -7
  25. package/dist/plugins/loaders/IFCXLoader.module.js.map +1 -1
  26. package/dist/viewer-three.js +3131 -459
  27. package/dist/viewer-three.js.map +1 -1
  28. package/dist/viewer-three.min.js +2 -2
  29. package/dist/viewer-three.module.js +2326 -264
  30. package/dist/viewer-three.module.js.map +1 -1
  31. package/lib/Viewer/Viewer.d.ts +6 -5
  32. package/lib/Viewer/components/HighlighterComponent.d.ts +4 -3
  33. package/lib/Viewer/components/SelectionComponent.d.ts +8 -5
  34. package/lib/Viewer/draggers/CuttingPlaneDragger.d.ts +1 -1
  35. package/lib/Viewer/loaders/DynamicGltfLoader/DynamicModelImpl.d.ts +20 -0
  36. package/lib/Viewer/loaders/GLTFCloudDynamicLoader.d.ts +15 -0
  37. package/lib/Viewer/model/IModelImpl.d.ts +27 -0
  38. package/lib/Viewer/model/ModelImpl.d.ts +30 -0
  39. package/lib/Viewer/model/index.d.ts +2 -0
  40. package/lib/index.d.ts +1 -0
  41. package/package.json +11 -7
  42. package/plugins/components/AxesHelperComponent.ts +5 -5
  43. package/plugins/components/ExtentsHelperComponent.ts +15 -7
  44. package/plugins/components/LightHelperComponent.ts +5 -5
  45. package/{src/Viewer/loaders/GLTFCloudModelLoader.ts → plugins/loaders/GLTFCloudLoader.ts} +15 -12
  46. package/plugins/loaders/{IFCXCloudFileLoader.ts → IFCXCloudLoader.ts} +8 -4
  47. package/plugins/loaders/IFCXFileLoader.ts +7 -3
  48. package/plugins/loaders/IFCXLoader.ts +2 -2
  49. package/src/Viewer/Viewer.ts +32 -36
  50. package/src/Viewer/commands/ClearSelected.ts +2 -3
  51. package/src/Viewer/commands/Explode.ts +1 -47
  52. package/src/Viewer/commands/GetModels.ts +1 -1
  53. package/src/Viewer/commands/GetSelected.ts +3 -1
  54. package/src/Viewer/commands/HideSelected.ts +3 -4
  55. package/src/Viewer/commands/IsolateSelected.ts +1 -7
  56. package/src/Viewer/commands/SelectModel.ts +9 -1
  57. package/src/Viewer/commands/SetSelected.ts +8 -10
  58. package/src/Viewer/commands/ShowAll.ts +1 -1
  59. package/src/Viewer/components/BackgroundComponent.ts +1 -0
  60. package/src/Viewer/components/ExtentsComponent.ts +5 -3
  61. package/src/Viewer/components/HighlighterComponent.ts +79 -48
  62. package/src/Viewer/components/SelectionComponent.ts +67 -21
  63. package/src/Viewer/draggers/CuttingPlaneDragger.ts +7 -3
  64. package/src/Viewer/draggers/MeasureLineDragger.ts +2 -0
  65. package/src/Viewer/loaders/DynamicGltfLoader/DynamicGltfLoader.js +1628 -0
  66. package/src/Viewer/loaders/DynamicGltfLoader/DynamicModelImpl.ts +102 -0
  67. package/src/Viewer/loaders/DynamicGltfLoader/GltfStructure.js +450 -0
  68. package/src/Viewer/loaders/GLTFCloudDynamicLoader.ts +145 -0
  69. package/src/Viewer/loaders/GLTFFileLoader.ts +7 -2
  70. package/src/Viewer/loaders/index.ts +2 -2
  71. package/src/Viewer/model/IModelImpl.ts +67 -0
  72. package/src/Viewer/model/ModelImpl.ts +215 -0
  73. package/src/Viewer/model/index.ts +25 -0
  74. package/src/index.ts +1 -0
  75. package/lib/Viewer/loaders/GLTFCloudModelLoader.d.ts +0 -8
@@ -1 +1 @@
1
- {"version":3,"file":"viewer-three.module.js","sources":["../src/Viewer/helpers/PlaneHelper.ts","../src/Viewer/controls/OrbitControls.js","../src/Viewer/draggers/OrbitDragger.ts","../src/Viewer/draggers/CuttingPlaneDragger.ts","../src/Viewer/draggers/CuttingPlaneXAxis.ts","../src/Viewer/draggers/CuttingPlaneYAxis.ts","../src/Viewer/draggers/CuttingPlaneZAxis.ts","../src/Viewer/draggers/MeasureLineDragger.ts","../src/Viewer/draggers/PanDragger.ts","../src/Viewer/controls/WalkControls.ts","../src/Viewer/draggers/WalkDragger.ts","../src/Viewer/draggers/ZoomDragger.ts","../src/Viewer/draggers/index.ts","../src/Viewer/commands/ApplyModelTransform.ts","../src/Viewer/commands/ClearMarkup.ts","../src/Viewer/commands/ClearSelected.ts","../src/Viewer/commands/ClearSlices.ts","../src/Viewer/commands/CreatePreview.ts","../src/Viewer/commands/Explode.ts","../src/Viewer/commands/ZoomTo.ts","../src/Viewer/commands/SetDefaultViewPosition.ts","../src/Viewer/commands/GetDefaultViewPositions.ts","../src/Viewer/commands/GetModels.ts","../src/Viewer/commands/GetSelected.ts","../src/Viewer/components/SelectionComponent.ts","../src/Viewer/commands/HideSelected.ts","../src/Viewer/commands/IsolateSelected.ts","../src/Viewer/commands/RegenerateAll.ts","../src/Viewer/commands/ResetView.ts","../src/Viewer/commands/SelectModel.ts","../src/Viewer/commands/SetActiveDragger.ts","../src/Viewer/commands/SetMarkupColor.ts","../src/Viewer/commands/SetSelected.ts","../src/Viewer/commands/ShowAll.ts","../src/Viewer/commands/ZoomToExtents.ts","../src/Viewer/commands/ZoomToObjects.ts","../src/Viewer/commands/ZoomToSelected.ts","../src/Viewer/commands/index.ts","../src/Viewer/components/BackgroundComponent.ts","../src/Viewer/components/CameraComponent.ts","../src/Viewer/components/ExtentsComponent.ts","../src/Viewer/components/LightComponent.ts","../src/Viewer/components/RenderLoopComponent.ts","../src/Viewer/components/ResizeCanvasComponent.ts","../src/Viewer/components/HighlighterUtils.ts","../src/Viewer/components/HighlighterComponent.ts","../src/Viewer/helpers/WCSHelper.ts","../src/Viewer/components/WCSHelperComponent.ts","../src/Viewer/components/index.ts","../src/Viewer/loaders/GLTFLoadingManager.ts","../src/Viewer/loaders/GLTFFileLoader.ts","../src/Viewer/loaders/GLTFCloudModelLoader.ts","../src/Viewer/loaders/index.ts","../src/Viewer/Viewer.ts"],"sourcesContent":["///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport {\n BufferGeometry,\n DoubleSide,\n Float32BufferAttribute,\n Line,\n LineBasicMaterial,\n Mesh,\n MeshBasicMaterial,\n Object3D,\n Plane,\n Vector3,\n} from \"three\";\n\nclass PlaneHelper extends Line {\n public plane: Plane;\n public size: number;\n public offset: Vector3;\n public helper: Object3D;\n\n constructor(plane: Plane, size = 1, color = 0xffff00, offset: Vector3 = new Vector3()) {\n // const positions = [1, -1, 0, -1, 1, 0, -1, -1, 0, 1, 1, 0, -1, 1, 0, -1, -1, 0, 1, -1, 0, 1, 1, 0];\n const positions = [1, 1, 0, -1, 1, 0, -1, -1, 0, 1, -1, 0, 1, 1, 0];\n\n const geometry = new BufferGeometry();\n geometry.setAttribute(\"position\", new Float32BufferAttribute(positions, 3));\n geometry.computeBoundingSphere();\n\n super(geometry, new LineBasicMaterial({ color, toneMapped: false }));\n\n (this as any).type = \"PlaneHelper\";\n\n this.plane = plane;\n this.size = size;\n this.offset = offset;\n\n const positions2 = [1, 1, 0, -1, 1, 0, -1, -1, 0, 1, 1, 0, -1, -1, 0, 1, -1, 0];\n\n const geometry2 = new BufferGeometry();\n geometry2.setAttribute(\"position\", new Float32BufferAttribute(positions2, 3));\n geometry2.computeBoundingSphere();\n\n this.helper = new Mesh(\n geometry2,\n new MeshBasicMaterial({\n color,\n opacity: 0.2,\n transparent: true,\n depthWrite: false,\n toneMapped: false,\n side: DoubleSide,\n })\n );\n this.add(this.helper);\n }\n\n dispose() {\n this.geometry.dispose();\n (this.material as any).dispose();\n (this.children[0] as any).geometry.dispose();\n (this.children[0] as any).material.dispose();\n }\n\n override updateMatrixWorld(force: boolean) {\n this.position.set(0, 0, 0);\n this.lookAt(this.plane.normal);\n\n this.position.copy(this.offset);\n this.translateZ(-(this.offset.dot(this.plane.normal) + this.plane.constant));\n\n this.scale.set(0.5 * this.size, 0.5 * this.size, 1);\n\n super.updateMatrixWorld(force);\n }\n}\n\nexport { PlaneHelper };\n","import { EventDispatcher, MOUSE, Quaternion, Spherical, TOUCH, Vector2, Vector3 } from \"three\";\n\n// OrbitControls performs orbiting, dollying (zooming), and panning.\n// Unlike TrackballControls, it maintains the \"up\" direction object.up (+Y by default).\n//\n// Orbit - left mouse / touch: one-finger move\n// Zoom - middle mouse, or mousewheel / touch: two-finger spread or squish\n// Pan - right mouse, or left mouse + ctrl/meta/shiftKey, or arrow keys / touch: two-finger move\n\nconst _changeEvent = { type: \"change\" };\nconst _startEvent = { type: \"start\" };\nconst _endEvent = { type: \"end\" };\n\nconst STATE = {\n NONE: -1,\n ROTATE: 0,\n DOLLY: 1,\n PAN: 2,\n TOUCH_ROTATE: 3,\n TOUCH_PAN: 4,\n TOUCH_DOLLY_PAN: 5,\n TOUCH_DOLLY_ROTATE: 6,\n};\n\nclass OrbitControls extends EventDispatcher {\n constructor(object, domElement) {\n super();\n\n this.object = object;\n this.domElement = domElement;\n this.domElement.style.touchAction = \"none\"; // disable touch scroll\n\n // Set to false to disable this control\n this.enabled = true;\n\n // \"target\" sets the location of focus, where the object orbits around\n this.target = new Vector3();\n\n // How far you can dolly in and out ( PerspectiveCamera only )\n this.minDistance = 0;\n this.maxDistance = Infinity;\n\n // How far you can zoom in and out ( OrthographicCamera only )\n this.minZoom = 0;\n this.maxZoom = Infinity;\n\n // How far you can orbit vertically, upper and lower limits.\n // Range is 0 to Math.PI radians.\n this.minPolarAngle = 0; // radians\n this.maxPolarAngle = Math.PI; // radians\n\n // How far you can orbit horizontally, upper and lower limits.\n // If set, the interval [ min, max ] must be a sub-interval of [ - 2 PI, 2 PI ], with ( max - min < 2 PI )\n this.minAzimuthAngle = -Infinity; // radians\n this.maxAzimuthAngle = Infinity; // radians\n\n // Set to true to enable damping (inertia)\n // If damping is enabled, you must call controls.update() in your animation loop\n this.enableDamping = false;\n this.dampingFactor = 0.05;\n\n // This option actually enables dollying in and out; left as \"zoom\" for backwards compatibility.\n // Set to false to disable zooming\n this.enableZoom = true;\n this.zoomSpeed = 1.0;\n\n // Set to false to disable rotating\n this.enableRotate = true;\n this.rotateSpeed = 1.0;\n\n // Set to false to disable panning\n this.enablePan = true;\n this.panSpeed = 1.0;\n this.screenSpacePanning = true; // if false, pan orthogonal to world-space direction camera.up\n this.keyPanSpeed = 7.0; // pixels moved per arrow key push\n\n // Set to true to automatically rotate around the target\n // If auto-rotate is enabled, you must call controls.update() in your animation loop\n this.autoRotate = false;\n this.autoRotateSpeed = 2.0; // 30 seconds per orbit when fps is 60\n\n // The four arrow keys\n this.keys = { LEFT: \"ArrowLeft\", UP: \"ArrowUp\", RIGHT: \"ArrowRight\", BOTTOM: \"ArrowDown\" };\n\n // Mouse buttons\n this.mouseButtons = { LEFT: MOUSE.ROTATE, MIDDLE: MOUSE.DOLLY, RIGHT: MOUSE.PAN };\n\n // Touch fingers\n this.touches = { ONE: TOUCH.ROTATE, TWO: TOUCH.DOLLY_PAN };\n\n // for reset\n this.target0 = this.target.clone();\n this.position0 = this.object.position.clone();\n this.zoom0 = this.object.zoom;\n\n // the target DOM element for key events\n this._domElementKeyEvents = null;\n\n //\n // public methods\n //\n\n this.getPolarAngle = function () {\n return spherical.phi;\n };\n\n this.getAzimuthalAngle = function () {\n return spherical.theta;\n };\n\n this.getDistance = function () {\n return this.object.position.distanceTo(this.target);\n };\n\n this.listenToKeyEvents = function (domElement) {\n domElement.addEventListener(\"keydown\", onKeyDown);\n this._domElementKeyEvents = domElement;\n };\n\n this.stopListenToKeyEvents = function () {\n this._domElementKeyEvents.removeEventListener(\"keydown\", onKeyDown);\n this._domElementKeyEvents = null;\n };\n\n this.saveState = function () {\n scope.target0.copy(scope.target);\n scope.position0.copy(scope.object.position);\n scope.zoom0 = scope.object.zoom;\n };\n\n this.reset = function () {\n scope.target.copy(scope.target0);\n scope.object.position.copy(scope.position0);\n scope.object.zoom = scope.zoom0;\n\n scope.object.updateProjectionMatrix();\n scope.dispatchEvent(_changeEvent);\n\n scope.update();\n\n scope.state = STATE.NONE;\n };\n\n // this method is exposed, but perhaps it would be better if we can make it private...\n this.update = (function () {\n const offset = new Vector3();\n\n // so camera.up is the orbit axis\n const quat = new Quaternion().setFromUnitVectors(object.up, new Vector3(0, 1, 0));\n const quatInverse = quat.clone().invert();\n\n const lastPosition = new Vector3();\n const lastQuaternion = new Quaternion();\n const lastTargetPosition = new Vector3();\n\n const twoPI = 2 * Math.PI;\n\n return function update() {\n const position = scope.object.position;\n\n offset.copy(position).sub(scope.target);\n\n // rotate offset to \"y-axis-is-up\" space\n offset.applyQuaternion(quat);\n\n // angle from z-axis around y-axis\n spherical.setFromVector3(offset);\n\n if (scope.autoRotate && scope.state === STATE.NONE) {\n rotateLeft(getAutoRotationAngle());\n }\n\n if (scope.enableDamping) {\n spherical.theta += sphericalDelta.theta * scope.dampingFactor;\n spherical.phi += sphericalDelta.phi * scope.dampingFactor;\n } else {\n spherical.theta += sphericalDelta.theta;\n spherical.phi += sphericalDelta.phi;\n }\n\n // restrict theta to be between desired limits\n\n let min = scope.minAzimuthAngle;\n let max = scope.maxAzimuthAngle;\n\n if (isFinite(min) && isFinite(max)) {\n if (min < -Math.PI) min += twoPI;\n else if (min > Math.PI) min -= twoPI;\n\n if (max < -Math.PI) max += twoPI;\n else if (max > Math.PI) max -= twoPI;\n\n if (min <= max) {\n spherical.theta = Math.max(min, Math.min(max, spherical.theta));\n } else {\n spherical.theta =\n spherical.theta > (min + max) / 2 ? Math.max(min, spherical.theta) : Math.min(max, spherical.theta);\n }\n }\n\n // restrict phi to be between desired limits\n spherical.phi = Math.max(scope.minPolarAngle, Math.min(scope.maxPolarAngle, spherical.phi));\n\n spherical.makeSafe();\n\n spherical.radius *= scope.scale;\n\n // restrict radius to be between desired limits\n spherical.radius = Math.max(scope.minDistance, Math.min(scope.maxDistance, spherical.radius));\n\n // move target to panned location\n\n if (scope.enableDamping === true) {\n scope.target.addScaledVector(scope.panOffset, scope.dampingFactor);\n } else {\n scope.target.add(scope.panOffset);\n }\n\n offset.setFromSpherical(spherical);\n\n // rotate offset back to \"camera-up-vector-is-up\" space\n offset.applyQuaternion(quatInverse);\n\n position.copy(scope.target).add(offset);\n\n scope.object.lookAt(scope.target);\n\n if (scope.enableDamping === true) {\n sphericalDelta.theta *= 1 - scope.dampingFactor;\n sphericalDelta.phi *= 1 - scope.dampingFactor;\n\n scope.panOffset.multiplyScalar(1 - scope.dampingFactor);\n } else {\n sphericalDelta.set(0, 0, 0);\n\n scope.panOffset.set(0, 0, 0);\n }\n\n scope.scale = 1;\n\n // update condition is:\n // min(camera displacement, camera rotation in radians)^2 > EPS\n // using small-angle approximation cos(x/2) = 1 - x^2 / 8\n\n if (\n scope.zoomChanged ||\n lastPosition.distanceToSquared(scope.object.position) > EPS ||\n 8 * (1 - lastQuaternion.dot(scope.object.quaternion)) > EPS ||\n lastTargetPosition.distanceToSquared(scope.target) > 0\n ) {\n scope.dispatchEvent(_changeEvent);\n\n lastPosition.copy(scope.object.position);\n lastQuaternion.copy(scope.object.quaternion);\n lastTargetPosition.copy(scope.target);\n\n scope.zoomChanged = false;\n\n return true;\n }\n\n return false;\n };\n })();\n\n this.dispose = function () {\n scope.domElement.removeEventListener(\"contextmenu\", onContextMenu);\n\n scope.domElement.removeEventListener(\"pointerdown\", onPointerDown);\n scope.domElement.removeEventListener(\"pointercancel\", onPointerUp);\n scope.domElement.removeEventListener(\"wheel\", onMouseWheel);\n\n scope.domElement.removeEventListener(\"pointermove\", onPointerMove);\n scope.domElement.removeEventListener(\"pointerup\", onPointerUp);\n\n if (scope._domElementKeyEvents !== null) {\n scope._domElementKeyEvents.removeEventListener(\"keydown\", onKeyDown);\n scope._domElementKeyEvents = null;\n }\n\n //scope.dispatchEvent( { type: 'dispose' } ); // should this be added here?\n };\n\n //\n // internals\n //\n\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n const scope = this;\n\n scope.state = STATE.NONE;\n\n const EPS = 0.000001;\n\n // current position in spherical coordinates\n const spherical = new Spherical();\n const sphericalDelta = new Spherical();\n\n scope.scale = 1;\n scope.panOffset = new Vector3();\n scope.zoomChanged = false;\n\n scope.rotateStart = new Vector2();\n scope.rotateEnd = new Vector2();\n scope.rotateDelta = new Vector2();\n\n scope.panStart = new Vector2();\n scope.panEnd = new Vector2();\n scope.panDelta = new Vector2();\n\n scope.dollyStart = new Vector2();\n scope.dollyEnd = new Vector2();\n scope.dollyDelta = new Vector2();\n scope.dollyScale = 0;\n\n scope.pointers = [];\n scope.pointerPositions = {};\n\n function getAutoRotationAngle() {\n return ((2 * Math.PI) / 60 / 60) * scope.autoRotateSpeed;\n }\n\n function getZoomScale() {\n return Math.pow(0.95, scope.zoomSpeed);\n }\n\n function rotateLeft(angle) {\n sphericalDelta.theta -= angle;\n }\n\n function rotateUp(angle) {\n sphericalDelta.phi -= angle;\n }\n\n const panLeft = (function () {\n const v = new Vector3();\n\n return function panLeft(distance, objectMatrix) {\n v.setFromMatrixColumn(objectMatrix, 0); // get X column of objectMatrix\n v.multiplyScalar(-distance);\n\n scope.panOffset.add(v);\n };\n })();\n\n const panUp = (function () {\n const v = new Vector3();\n\n return function panUp(distance, objectMatrix) {\n if (scope.screenSpacePanning === true) {\n v.setFromMatrixColumn(objectMatrix, 1);\n } else {\n v.setFromMatrixColumn(objectMatrix, 0);\n v.crossVectors(scope.object.up, v);\n }\n\n v.multiplyScalar(distance);\n\n scope.panOffset.add(v);\n };\n })();\n\n // deltaX and deltaY are in pixels; right and down are positive\n const pan = (function () {\n const offset = new Vector3();\n\n return function pan(deltaX, deltaY) {\n const element = scope.domElement;\n\n if (scope.object.isPerspectiveCamera) {\n // perspective\n const position = scope.object.position;\n offset.copy(position).sub(scope.target);\n let targetDistance = offset.length();\n\n // half of the fov is center to top of screen\n targetDistance *= Math.tan(((scope.object.fov / 2) * Math.PI) / 180.0);\n\n // we use only clientHeight here so aspect ratio does not distort speed\n panLeft((2 * deltaX * targetDistance) / element.clientHeight, scope.object.matrix);\n panUp((2 * deltaY * targetDistance) / element.clientHeight, scope.object.matrix);\n } else if (scope.object.isOrthographicCamera) {\n // orthographic\n panLeft(\n (deltaX * (scope.object.right - scope.object.left)) / scope.object.zoom / element.clientWidth,\n scope.object.matrix\n );\n panUp(\n (deltaY * (scope.object.top - scope.object.bottom)) / scope.object.zoom / element.clientHeight,\n scope.object.matrix\n );\n } else {\n // camera neither orthographic nor perspective\n console.warn(\"WARNING: OrbitControls.js encountered an unknown camera type - pan disabled.\");\n scope.enablePan = false;\n }\n };\n })();\n\n function dollyOut(dollyScale) {\n if (scope.object.isPerspectiveCamera) {\n scope.scale /= dollyScale;\n } else if (scope.object.isOrthographicCamera) {\n scope.object.zoom = Math.max(scope.minZoom, Math.min(scope.maxZoom, scope.object.zoom * dollyScale));\n scope.object.updateProjectionMatrix();\n scope.zoomChanged = true;\n } else {\n console.warn(\"WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled.\");\n scope.enableZoom = false;\n }\n }\n\n function dollyIn(dollyScale) {\n if (scope.object.isPerspectiveCamera) {\n scope.scale *= dollyScale;\n } else if (scope.object.isOrthographicCamera) {\n scope.object.zoom = Math.max(scope.minZoom, Math.min(scope.maxZoom, scope.object.zoom / dollyScale));\n scope.object.updateProjectionMatrix();\n scope.zoomChanged = true;\n } else {\n console.warn(\"WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled.\");\n scope.enableZoom = false;\n }\n }\n\n //\n // event callbacks - update the object state\n //\n\n function handleMouseDownRotate(event) {\n scope.rotateStart.set(event.clientX, event.clientY);\n }\n\n function handleMouseDownDolly(event) {\n scope.dollyStart.set(event.clientX, event.clientY);\n }\n\n function handleMouseDownPan(event) {\n scope.panStart.set(event.clientX, event.clientY);\n }\n\n function handleMouseMoveRotate(event) {\n scope.rotateEnd.set(event.clientX, event.clientY);\n\n scope.rotateDelta.subVectors(scope.rotateEnd, scope.rotateStart).multiplyScalar(scope.rotateSpeed);\n\n const element = scope.domElement;\n\n rotateLeft((2 * Math.PI * scope.rotateDelta.x) / element.clientHeight); // yes, height\n\n rotateUp((2 * Math.PI * scope.rotateDelta.y) / element.clientHeight);\n\n scope.rotateStart.copy(scope.rotateEnd);\n\n scope.update();\n }\n\n function handleMouseMoveDolly(event) {\n scope.dollyEnd.set(event.clientX, event.clientY);\n\n scope.dollyDelta.subVectors(scope.dollyEnd, scope.dollyStart);\n\n if (scope.dollyDelta.y < 0) {\n scope.dollyScale = 1 / getZoomScale();\n dollyOut(getZoomScale());\n } else if (scope.dollyDelta.y > 0) {\n scope.dollyScale = getZoomScale();\n dollyIn(getZoomScale());\n }\n\n scope.dollyStart.copy(scope.dollyEnd);\n\n scope.update();\n }\n\n function handleMouseMovePan(event) {\n scope.panEnd.set(event.clientX, event.clientY);\n\n scope.panDelta.subVectors(scope.panEnd, scope.panStart).multiplyScalar(scope.panSpeed);\n\n pan(scope.panDelta.x, scope.panDelta.y);\n\n scope.panStart.copy(scope.panEnd);\n\n scope.update();\n }\n\n function handleMouseWheel(event) {\n scope.dollyEnd.set(scope.domElement.clientWidth / 2, scope.domElement.clientHeight / 2);\n\n scope.dollyDelta.set(event.deltaX, event.deltaY);\n\n if (event.deltaY < 0) {\n scope.dollyScale = 1 / getZoomScale();\n dollyIn(getZoomScale());\n } else if (event.deltaY > 0) {\n scope.dollyScale = getZoomScale();\n dollyOut(getZoomScale());\n }\n\n scope.dollyStart.copy(scope.dollyEnd);\n\n scope.update();\n\n if (event.deltaY !== 0) {\n scope.state = STATE.DOLLY;\n scope.dispatchEvent(_changeEvent);\n scope.state = STATE.NONE;\n }\n }\n\n function handleKeyDown(event) {\n let needsUpdate = false;\n\n switch (event.code) {\n case scope.keys.UP:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n rotateUp((2 * Math.PI * scope.rotateSpeed) / scope.domElement.clientHeight);\n } else {\n pan(0, scope.keyPanSpeed);\n }\n\n needsUpdate = true;\n break;\n\n case scope.keys.BOTTOM:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n rotateUp((-2 * Math.PI * scope.rotateSpeed) / scope.domElement.clientHeight);\n } else {\n pan(0, -scope.keyPanSpeed);\n }\n\n needsUpdate = true;\n break;\n\n case scope.keys.LEFT:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n rotateLeft((2 * Math.PI * scope.rotateSpeed) / scope.domElement.clientHeight);\n } else {\n pan(scope.keyPanSpeed, 0);\n }\n\n needsUpdate = true;\n break;\n\n case scope.keys.RIGHT:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n rotateLeft((-2 * Math.PI * scope.rotateSpeed) / scope.domElement.clientHeight);\n } else {\n pan(-scope.keyPanSpeed, 0);\n }\n\n needsUpdate = true;\n break;\n }\n\n if (needsUpdate) {\n // prevent the browser from scrolling on cursor keys\n event.preventDefault();\n\n scope.update();\n }\n }\n\n function handleTouchStartRotate() {\n if (scope.pointers.length === 1) {\n scope.rotateStart.set(scope.pointers[0].pageX, scope.pointers[0].pageY);\n } else {\n const x = 0.5 * (scope.pointers[0].pageX + scope.pointers[1].pageX);\n const y = 0.5 * (scope.pointers[0].pageY + scope.pointers[1].pageY);\n\n scope.rotateStart.set(x, y);\n }\n }\n\n function handleTouchStartPan() {\n if (scope.pointers.length === 1) {\n scope.panStart.set(scope.pointers[0].pageX, scope.pointers[0].pageY);\n } else {\n const x = 0.5 * (scope.pointers[0].pageX + scope.pointers[1].pageX);\n const y = 0.5 * (scope.pointers[0].pageY + scope.pointers[1].pageY);\n\n scope.panStart.set(x, y);\n }\n }\n\n function handleTouchStartDolly() {\n const dx = scope.pointers[0].pageX - scope.pointers[1].pageX;\n const dy = scope.pointers[0].pageY - scope.pointers[1].pageY;\n\n const distance = Math.sqrt(dx * dx + dy * dy);\n\n scope.dollyStart.set(0, distance);\n }\n\n function handleTouchStartDollyPan() {\n if (scope.enableZoom) handleTouchStartDolly();\n\n if (scope.enablePan) handleTouchStartPan();\n }\n\n function handleTouchStartDollyRotate() {\n if (scope.enableZoom) handleTouchStartDolly();\n\n if (scope.enableRotate) handleTouchStartRotate();\n }\n\n function handleTouchMoveRotate(event) {\n if (scope.pointers.length == 1) {\n scope.rotateEnd.set(event.pageX, event.pageY);\n } else {\n const position = getSecondPointerPosition(event);\n\n const x = 0.5 * (event.pageX + position.x);\n const y = 0.5 * (event.pageY + position.y);\n\n scope.rotateEnd.set(x, y);\n }\n\n scope.rotateDelta.subVectors(scope.rotateEnd, scope.rotateStart).multiplyScalar(scope.rotateSpeed);\n\n const element = scope.domElement;\n\n rotateLeft((2 * Math.PI * scope.rotateDelta.x) / element.clientHeight); // yes, height\n\n rotateUp((2 * Math.PI * scope.rotateDelta.y) / element.clientHeight);\n\n scope.rotateStart.copy(scope.rotateEnd);\n }\n\n function handleTouchMovePan(event) {\n if (scope.pointers.length === 1) {\n scope.panEnd.set(event.pageX, event.pageY);\n } else {\n const position = getSecondPointerPosition(event);\n\n const x = 0.5 * (event.pageX + position.x);\n const y = 0.5 * (event.pageY + position.y);\n\n scope.panEnd.set(x, y);\n }\n\n scope.panDelta.subVectors(scope.panEnd, scope.panStart).multiplyScalar(scope.panSpeed);\n\n pan(scope.panDelta.x, scope.panDelta.y);\n\n scope.panStart.copy(scope.panEnd);\n }\n\n function handleTouchMoveDolly(event) {\n const position = getSecondPointerPosition(event);\n\n const dx = event.pageX - position.x;\n const dy = event.pageY - position.y;\n\n const distance = Math.sqrt(dx * dx + dy * dy);\n\n scope.dollyEnd.set(0, distance);\n\n scope.dollyDelta.set(0, Math.pow(scope.dollyEnd.y / scope.dollyStart.y, scope.zoomSpeed));\n\n dollyOut(scope.dollyDelta.y);\n\n scope.dollyStart.copy(scope.dollyEnd);\n }\n\n function handleTouchMoveDollyPan(event) {\n if (scope.enableZoom) handleTouchMoveDolly(event);\n\n if (scope.enablePan) handleTouchMovePan(event);\n }\n\n function handleTouchMoveDollyRotate(event) {\n if (scope.enableZoom) handleTouchMoveDolly(event);\n\n if (scope.enableRotate) handleTouchMoveRotate(event);\n }\n\n //\n // event handlers - FSM: listen for events and reset state\n //\n\n function onPointerDown(event) {\n if (scope.enabled === false) return;\n\n if (scope.pointers.length === 0) {\n scope.domElement.setPointerCapture(event.pointerId);\n\n scope.domElement.addEventListener(\"pointermove\", onPointerMove);\n scope.domElement.addEventListener(\"pointerup\", onPointerUp);\n }\n\n //\n\n addPointer(event);\n\n if (event.pointerType === \"touch\") {\n onTouchStart(event);\n } else {\n onMouseDown(event);\n }\n }\n\n function onPointerMove(event) {\n if (scope.enabled === false) return;\n\n if (event.pointerType === \"touch\") {\n onTouchMove(event);\n } else {\n onMouseMove(event);\n }\n }\n\n function onPointerUp(event) {\n removePointer(event);\n\n if (scope.pointers.length === 0) {\n scope.domElement.releasePointerCapture(event.pointerId);\n\n scope.domElement.removeEventListener(\"pointermove\", onPointerMove);\n scope.domElement.removeEventListener(\"pointerup\", onPointerUp);\n }\n\n scope.dispatchEvent(_endEvent);\n\n scope.state = STATE.NONE;\n }\n\n function onMouseDown(event) {\n let mouseAction;\n\n switch (event.button) {\n case 0:\n mouseAction = scope.mouseButtons.LEFT;\n break;\n\n case 1:\n mouseAction = scope.mouseButtons.MIDDLE;\n break;\n\n case 2:\n mouseAction = scope.mouseButtons.RIGHT;\n break;\n\n default:\n mouseAction = -1;\n }\n\n switch (mouseAction) {\n case MOUSE.DOLLY:\n if (scope.enableZoom === false) return;\n\n handleMouseDownDolly(event);\n\n scope.state = STATE.DOLLY;\n\n break;\n\n case MOUSE.ROTATE:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n if (scope.enablePan === false) return;\n\n handleMouseDownPan(event);\n\n scope.state = STATE.PAN;\n } else {\n if (scope.enableRotate === false) return;\n\n handleMouseDownRotate(event);\n\n scope.state = STATE.ROTATE;\n }\n\n break;\n\n case MOUSE.PAN:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n if (scope.enableRotate === false) return;\n\n handleMouseDownRotate(event);\n\n scope.state = STATE.ROTATE;\n } else {\n if (scope.enablePan === false) return;\n\n handleMouseDownPan(event);\n\n scope.state = STATE.PAN;\n }\n\n break;\n\n default:\n scope.state = STATE.NONE;\n }\n\n if (scope.state !== STATE.NONE) {\n scope.dispatchEvent(_startEvent);\n }\n }\n\n function onMouseMove(event) {\n switch (scope.state) {\n case STATE.ROTATE:\n if (scope.enableRotate === false) return;\n\n handleMouseMoveRotate(event);\n\n break;\n\n case STATE.DOLLY:\n if (scope.enableZoom === false) return;\n\n handleMouseMoveDolly(event);\n\n break;\n\n case STATE.PAN:\n if (scope.enablePan === false) return;\n\n handleMouseMovePan(event);\n\n break;\n }\n }\n\n function onMouseWheel(event) {\n if (scope.enabled === false || scope.enableZoom === false || scope.state !== STATE.NONE) return;\n\n event.preventDefault();\n\n scope.dispatchEvent(_startEvent);\n\n handleMouseWheel(event);\n\n scope.dispatchEvent(_endEvent);\n }\n\n function onKeyDown(event) {\n if (scope.enabled === false || scope.enablePan === false) return;\n\n handleKeyDown(event);\n }\n\n function onTouchStart(event) {\n trackPointer(event);\n\n switch (scope.pointers.length) {\n case 1:\n switch (scope.touches.ONE) {\n case TOUCH.ROTATE:\n if (scope.enableRotate === false) return;\n\n handleTouchStartRotate();\n\n scope.state = STATE.TOUCH_ROTATE;\n\n break;\n\n case TOUCH.PAN:\n if (scope.enablePan === false) return;\n\n handleTouchStartPan();\n\n scope.state = STATE.TOUCH_PAN;\n\n break;\n\n default:\n scope.state = STATE.NONE;\n }\n\n break;\n\n case 2:\n switch (scope.touches.TWO) {\n case TOUCH.DOLLY_PAN:\n if (scope.enableZoom === false && scope.enablePan === false) return;\n\n handleTouchStartDollyPan();\n\n scope.state = STATE.TOUCH_DOLLY_PAN;\n\n break;\n\n case TOUCH.DOLLY_ROTATE:\n if (scope.enableZoom === false && scope.enableRotate === false) return;\n\n handleTouchStartDollyRotate();\n\n scope.state = STATE.TOUCH_DOLLY_ROTATE;\n\n break;\n\n default:\n scope.state = STATE.NONE;\n }\n\n break;\n\n default:\n scope.state = STATE.NONE;\n }\n\n if (scope.state !== STATE.NONE) {\n scope.dispatchEvent(_startEvent);\n }\n }\n\n function onTouchMove(event) {\n trackPointer(event);\n\n switch (scope.state) {\n case STATE.TOUCH_ROTATE:\n if (scope.enableRotate === false) return;\n\n handleTouchMoveRotate(event);\n\n scope.update();\n\n break;\n\n case STATE.TOUCH_PAN:\n if (scope.enablePan === false) return;\n\n handleTouchMovePan(event);\n\n scope.update();\n\n break;\n\n case STATE.TOUCH_DOLLY_PAN:\n if (scope.enableZoom === false && scope.enablePan === false) return;\n\n handleTouchMoveDollyPan(event);\n\n scope.update();\n\n break;\n\n case STATE.TOUCH_DOLLY_ROTATE:\n if (scope.enableZoom === false && scope.enableRotate === false) return;\n\n handleTouchMoveDollyRotate(event);\n\n scope.update();\n\n break;\n\n default:\n scope.state = STATE.NONE;\n }\n }\n\n function onContextMenu(event) {\n if (scope.enabled === false) return;\n\n event.preventDefault();\n }\n\n function addPointer(event) {\n scope.pointers.push(event);\n }\n\n function removePointer(event) {\n delete scope.pointerPositions[event.pointerId];\n\n for (let i = 0; i < scope.pointers.length; i++) {\n if (scope.pointers[i].pointerId == event.pointerId) {\n scope.pointers.splice(i, 1);\n return;\n }\n }\n }\n\n function trackPointer(event) {\n let position = scope.pointerPositions[event.pointerId];\n\n if (position === undefined) {\n position = new Vector2();\n scope.pointerPositions[event.pointerId] = position;\n }\n\n position.set(event.pageX, event.pageY);\n }\n\n function getSecondPointerPosition(event) {\n const pointer = event.pointerId === scope.pointers[0].pointerId ? scope.pointers[1] : scope.pointers[0];\n\n return scope.pointerPositions[pointer.pointerId];\n }\n\n //\n\n scope.domElement.addEventListener(\"contextmenu\", onContextMenu);\n\n scope.domElement.addEventListener(\"pointerdown\", onPointerDown);\n scope.domElement.addEventListener(\"pointercancel\", onPointerUp);\n scope.domElement.addEventListener(\"wheel\", onMouseWheel, { passive: false });\n\n // force an update at start\n\n this.update();\n }\n}\n\nexport { OrbitControls, STATE };\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { MOUSE, TOUCH } from \"three\";\nimport { type IDragger } from \"@inweb/viewer-core\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { OrbitControls, STATE } from \"../controls/OrbitControls.js\";\n\nexport class OrbitDragger implements IDragger {\n protected viewer: Viewer;\n protected orbit: OrbitControls;\n protected changed: boolean;\n\n constructor(viewer: Viewer) {\n this.orbit = new OrbitControls(viewer.camera, viewer.canvas);\n this.orbit.mouseButtons = { LEFT: MOUSE.ROTATE, MIDDLE: MOUSE.PAN, RIGHT: MOUSE.PAN };\n this.orbit.touches = { ONE: TOUCH.ROTATE, TWO: TOUCH.DOLLY_PAN };\n this.orbit.screenSpacePanning = true;\n this.orbit.rotateSpeed = 0.33;\n this.orbit.addEventListener(\"start\", this.controlsStart);\n this.orbit.addEventListener(\"change\", this.controlsChange);\n this.changed = false;\n this.viewer = viewer;\n this.viewer.addEventListener(\"databasechunk\", this.updateControls);\n this.viewer.on(\"viewposition\", this.updateControls);\n this.viewer.addEventListener(\"zoom\", this.updateControls);\n this.viewer.addEventListener(\"drawviewpoint\", this.updateControls);\n this.viewer.addEventListener(\"contextmenu\", this.stopContextMenu);\n this.updateControls();\n }\n\n initialize() {}\n\n dispose(): void {\n this.viewer.removeEventListener(\"databasechunk\", this.updateControls);\n this.viewer.off(\"viewposition\", this.updateControls);\n this.viewer.removeEventListener(\"zoom\", this.updateControls);\n this.viewer.removeEventListener(\"drawviewpoint\", this.updateControls);\n this.viewer.removeEventListener(\"contextmenu\", this.stopContextMenu);\n\n this.orbit.removeEventListener(\"start\", this.controlsStart);\n this.orbit.removeEventListener(\"change\", this.controlsChange);\n this.orbit.dispose();\n }\n\n updateControls = () => {\n this.orbit.maxDistance = this.viewer.camera.far;\n this.orbit.minDistance = this.viewer.camera.near;\n this.orbit.object = this.viewer.camera;\n this.orbit.target.copy(this.viewer.target);\n this.orbit.update();\n };\n\n controlsStart = () => {\n this.changed = false;\n };\n\n controlsChange = () => {\n this.viewer.target.copy(this.orbit.target);\n this.viewer.update();\n\n switch (this.orbit.state) {\n case STATE.PAN:\n case STATE.TOUCH_PAN:\n this.viewer.emitEvent({\n type: \"pan\",\n x: this.orbit.panEnd.x,\n y: this.orbit.panEnd.y,\n dX: this.orbit.panDelta.x,\n dY: this.orbit.panDelta.y,\n });\n break;\n\n case STATE.DOLLY:\n this.viewer.emitEvent({\n type: \"zoomat\",\n data: this.orbit.dollyScale,\n x: this.orbit.dollyEnd.x,\n y: this.orbit.dollyEnd.y,\n });\n break;\n }\n\n this.changed = true;\n };\n\n stopContextMenu = (event: PointerEvent) => {\n if (this.changed) {\n event.preventDefault();\n event.stopPropagation();\n }\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Object3D, Plane, Vector3 } from \"three\";\nimport { TransformControls } from \"three/examples/jsm/controls/TransformControls.js\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { PlaneHelper } from \"../helpers/PlaneHelper\";\nimport { OrbitDragger } from \"./OrbitDragger\";\n\nexport class CuttingPlaneDragger extends OrbitDragger {\n protected plane: Plane;\n protected planeCenter: Object3D;\n protected planeHelper: PlaneHelper;\n protected transform: TransformControls;\n\n constructor(viewer: Viewer, normal: Vector3, color: number) {\n super(viewer);\n\n const size = viewer.extents.getSize(new Vector3()).length();\n const center = viewer.extents.getCenter(new Vector3());\n const constant = -center.dot(normal);\n\n this.plane = new Plane(normal, constant);\n\n if (!viewer.renderer.clippingPlanes) viewer.renderer.clippingPlanes = [];\n viewer.renderer.clippingPlanes.push(this.plane);\n\n this.planeHelper = new PlaneHelper(this.plane, size, color, center);\n this.viewer.helpers.add(this.planeHelper);\n\n this.planeCenter = new Object3D();\n this.planeCenter.position.copy(viewer.extents.getCenter(new Vector3()));\n this.viewer.helpers.add(this.planeCenter);\n\n this.transform = new TransformControls(viewer.camera, viewer.canvas);\n this.transform.showX = !!normal.x;\n this.transform.showY = !!normal.y;\n this.transform.showZ = !!normal.z;\n this.transform.attach(this.planeCenter);\n this.transform.addEventListener(\"change\", this.transformChange);\n this.transform.addEventListener(\"dragging-changed\", this.transformDrag);\n this.viewer.helpers.add(this.transform.getHelper());\n\n this.viewer.on(\"explode\", this.viewerExplode);\n this.viewer.canvas.addEventListener(\"dblclick\", this.onDoubleClick, true);\n this.viewer.update();\n }\n\n override dispose() {\n this.viewer.off(\"explode\", this.viewerExplode);\n this.viewer.canvas.removeEventListener(\"dblclick\", this.onDoubleClick, true);\n\n this.transform.removeEventListener(\"change\", this.transformChange);\n this.transform.removeEventListener(\"dragging-changed\", this.transformDrag);\n this.transform.getHelper().removeFromParent();\n this.transform.detach();\n this.transform.dispose();\n\n this.planeHelper.removeFromParent();\n this.planeHelper.dispose();\n\n this.planeCenter.removeFromParent();\n\n // this.viewer.renderer.clippingPlanes = this.viewer.renderer.clippingPlanes.filter((plane) => plane !== this.plane);\n // this.viewer.update();\n\n super.dispose();\n }\n\n transformChange = () => {\n this.plane.constant = -this.planeCenter.position.dot(this.plane.normal);\n this.viewer.update();\n };\n\n transformDrag = (event) => {\n this.orbit.enabled = !event.value;\n };\n\n viewerExplode = () => {\n this.planeHelper.size = this.viewer.extents.getSize(new Vector3()).length();\n this.viewer.update();\n };\n\n onDoubleClick = (event: PointerEvent) => {\n event.stopPropagation();\n\n this.plane.negate();\n this.viewer.update();\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Vector3 } from \"three\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { CuttingPlaneDragger } from \"./CuttingPlaneDragger\";\n\nexport class CuttingPlaneXAxisDragger extends CuttingPlaneDragger {\n constructor(viewer: Viewer) {\n super(viewer, new Vector3(1, 0, 0), 0xff0000);\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Vector3 } from \"three\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { CuttingPlaneDragger } from \"./CuttingPlaneDragger\";\n\nexport class CuttingPlaneYAxisDragger extends CuttingPlaneDragger {\n constructor(viewer: Viewer) {\n super(viewer, new Vector3(0, 1, 0), 0x00ff00);\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Vector3 } from \"three\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { CuttingPlaneDragger } from \"./CuttingPlaneDragger\";\n\nexport class CuttingPlaneZAxisDragger extends CuttingPlaneDragger {\n constructor(viewer: Viewer) {\n super(viewer, new Vector3(0, 0, 1), 0x0000ff);\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Camera, Matrix4, Object3D, Scene, Raycaster, Vector2, Vector3, Vector4 } from \"three\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { OrbitDragger } from \"./OrbitDragger\";\n\nconst PRECISION = 0.01;\n\nexport class MeasureLineDragger extends OrbitDragger {\n private overlay: MeasureOverlay;\n private line: MeasureLine;\n private snapper: MeasureSnapper;\n\n constructor(viewer: Viewer) {\n super(viewer);\n\n this.overlay = new MeasureOverlay(viewer.camera, viewer.canvas);\n this.overlay.attach();\n\n this.line = new MeasureLine(this.overlay);\n this.overlay.addLine(this.line);\n\n this.snapper = new MeasureSnapper(viewer.camera, viewer.canvas);\n this.snapper.update(viewer.scene);\n\n this.viewer.canvas.addEventListener(\"pointerdown\", this.onPointerDown);\n this.viewer.canvas.addEventListener(\"pointermove\", this.onPointerMove);\n this.viewer.canvas.addEventListener(\"pointerup\", this.onPointerUp);\n this.viewer.canvas.addEventListener(\"pointercancel\", this.onPointerCancel);\n this.viewer.canvas.addEventListener(\"pointerleave\", this.onPointerLeave);\n\n this.viewer.addEventListener(\"render\", this.renderOverlay);\n this.viewer.addEventListener(\"hide\", this.updateSnapper);\n this.viewer.addEventListener(\"isolate\", this.updateSnapper);\n this.viewer.addEventListener(\"showall\", this.updateSnapper);\n }\n\n override dispose() {\n this.viewer.canvas.removeEventListener(\"pointerdown\", this.onPointerDown);\n this.viewer.canvas.removeEventListener(\"pointermove\", this.onPointerMove);\n this.viewer.canvas.removeEventListener(\"pointerup\", this.onPointerUp);\n this.viewer.canvas.removeEventListener(\"pointercancel\", this.onPointerCancel);\n this.viewer.canvas.removeEventListener(\"pointerleave\", this.onPointerLeave);\n\n this.viewer.removeEventListener(\"render\", this.renderOverlay);\n this.viewer.removeEventListener(\"hide\", this.updateSnapper);\n this.viewer.removeEventListener(\"isolate\", this.updateSnapper);\n this.viewer.removeEventListener(\"showall\", this.updateSnapper);\n\n this.overlay.detach();\n this.overlay.dispose();\n\n super.dispose();\n }\n\n onPointerDown = (event: PointerEvent) => {\n if (event.button !== 0) return;\n\n this.line.startPoint = this.snapper.getSnapPoint(event);\n this.line.render();\n\n this.viewer.canvas.setPointerCapture(event.pointerId);\n this.orbit.enabled = !this.line.startPoint;\n };\n\n onPointerMove = (event: PointerEvent) => {\n if (this.orbit.enabled && this.orbit.state !== -1) return;\n\n this.line.endPoint = this.snapper.getSnapPoint(event);\n this.line.render();\n\n if (this.line.startPoint) this.changed = true; // <- to prevent context menu\n };\n\n onPointerUp = (event: PointerEvent) => {\n if (this.line.startPoint && this.line.endPoint && this.line.getDistance() >= PRECISION) {\n this.line = new MeasureLine(this.overlay);\n this.overlay.addLine(this.line);\n } else {\n this.line.startPoint = undefined;\n this.line.endPoint = undefined;\n this.line.render();\n }\n\n this.viewer.canvas.releasePointerCapture(event.pointerId);\n this.orbit.enabled = true;\n };\n\n onPointerCancel = (event: PointerEvent) => {\n this.viewer.canvas.dispatchEvent(new PointerEvent(\"pointerup\", event));\n };\n\n onPointerLeave = () => {\n this.line.endPoint = undefined;\n this.line.render();\n };\n\n renderOverlay = () => {\n this.overlay.render();\n };\n\n updateSnapper = () => {\n this.snapper.update(this.viewer.scene);\n };\n}\n\nclass MeasureSnapper {\n private camera: Camera;\n private canvas: HTMLCanvasElement;\n private objects: Object3D[] = [];\n private raycaster: Raycaster;\n\n constructor(camera: Camera, canvas: HTMLCanvasElement) {\n this.camera = camera;\n this.canvas = canvas;\n this.raycaster = new Raycaster();\n }\n\n getSnapPoint(event: PointerEvent): Vector3 | undefined {\n const mouse = new Vector2(event.clientX, event.clientY);\n\n const rect = this.canvas.getBoundingClientRect();\n const x = ((mouse.x - rect.left) / rect.width) * 2 - 1;\n const y = (-(mouse.y - rect.top) / rect.height) * 2 + 1;\n\n const coords = new Vector2(x, y);\n this.raycaster.setFromCamera(coords, this.camera);\n\n this.raycaster.params = {\n Mesh: {},\n Line: { threshold: 0.25 },\n Line2: { threshold: 0.25 },\n LOD: {},\n Points: { threshold: 0.1 },\n Sprite: {},\n };\n\n const intersects = this.raycaster.intersectObjects(this.objects, false);\n if (intersects.length === 0) return undefined;\n\n return intersects[0].point;\n }\n\n update(scene: Scene) {\n this.objects = [];\n scene.traverseVisible((child) => this.objects.push(child));\n }\n}\n\nclass MeasureOverlay {\n public camera: Camera;\n public canvas: HTMLCanvasElement;\n public container: HTMLElement;\n public lines: MeasureLine[] = [];\n public projector: MeasureProjector;\n\n constructor(camera: Camera, canvas: HTMLCanvasElement) {\n this.camera = camera;\n this.canvas = canvas;\n this.projector = new MeasureProjector(camera, canvas);\n }\n\n attach() {\n this.container = document.createElement(\"div\");\n this.container.id = \"measure-container\";\n this.container.style.background = \"rgba(0,0,0,0)\";\n this.container.style.position = \"absolute\";\n this.container.style.top = \"0px\";\n this.container.style.left = \"0px\";\n this.container.style.width = \"100%\";\n this.container.style.height = \"100%\";\n this.container.style.outline = \"none\";\n this.container.style.pointerEvents = \"none\";\n this.container.style.overflow = \"hidden\";\n\n this.canvas.parentElement.appendChild(this.container);\n }\n\n dispose() {\n this.clear();\n }\n\n detach() {\n this.container.remove();\n this.container = undefined;\n }\n\n clear() {\n this.lines.forEach((line) => line.dispose());\n this.lines = [];\n }\n\n render() {\n this.projector.updateProjectionMatrix();\n this.lines.forEach((line) => line.render());\n }\n\n update() {\n this.lines.forEach((line) => line.update());\n }\n\n addLine(line: MeasureLine) {\n this.lines.push(line);\n }\n\n removeLine(line: MeasureLine) {\n this.lines = this.lines.filter((x) => x !== line);\n }\n}\n\nconst _middlePoint = new Vector3();\n\nclass MeasureLine {\n private overlay: MeasureOverlay;\n\n private elementStartPoint: HTMLElement;\n private elementEndPoint: HTMLElement;\n private elementLine: HTMLElement;\n private elementLabel: HTMLElement;\n\n public startPoint: Vector3;\n public endPoint: Vector3;\n\n public id = Date.now();\n public unit = \"\";\n public scale = 1.0;\n public size = 10.0;\n public lineWidth = 2;\n\n public style = {\n border: \"2px solid #FFFFFF\",\n background: \"#009bff\",\n boxShadow: \"0 0 10px rgba(0,0,0,0.5)\",\n color: \"white\",\n font: \"1rem system-ui\",\n };\n\n constructor(overlay: MeasureOverlay) {\n this.overlay = overlay;\n\n this.elementStartPoint = overlay.container.appendChild(document.createElement(\"div\"));\n this.elementEndPoint = overlay.container.appendChild(document.createElement(\"div\"));\n this.elementLine = overlay.container.appendChild(document.createElement(\"div\"));\n this.elementLabel = overlay.container.appendChild(document.createElement(\"div\"));\n\n this.update();\n }\n\n dispose() {\n this.elementStartPoint.remove();\n this.elementEndPoint.remove();\n this.elementLine.remove();\n this.elementLabel.remove();\n }\n\n render() {\n const projector = this.overlay.projector;\n\n if (this.startPoint) {\n const { point, visible } = projector.projectPoint(this.startPoint);\n\n this.elementStartPoint.style.display = visible ? \"block\" : \"none\";\n this.elementStartPoint.style.left = `${point.x}px`;\n this.elementStartPoint.style.top = `${point.y}px`;\n } else {\n this.elementStartPoint.style.display = \"none\";\n }\n\n if (this.endPoint) {\n const { point, visible } = projector.projectPoint(this.endPoint);\n\n this.elementEndPoint.style.display = visible ? \"block\" : \"none\";\n this.elementEndPoint.style.left = `${point.x}px`;\n this.elementEndPoint.style.top = `${point.y}px`;\n } else {\n this.elementEndPoint.style.display = \"none\";\n }\n\n if (this.startPoint && this.endPoint) {\n const { point1, point2, visible } = projector.projectLine(this.startPoint, this.endPoint);\n\n point2.sub(point1);\n const angle = point2.angle();\n const width = point2.length();\n\n this.elementLine.style.display = visible ? \"block\" : \"none\";\n this.elementLine.style.left = `${point1.x}px`;\n this.elementLine.style.top = `${point1.y}px`;\n this.elementLine.style.width = `${width}px`;\n this.elementLine.style.transform = `translate(0px, ${-this.lineWidth / 2}px) rotate(${angle}rad)`;\n } else {\n this.elementLine.style.display = \"none\";\n }\n\n if (this.startPoint && this.endPoint) {\n _middlePoint.lerpVectors(this.startPoint, this.endPoint, 0.5);\n const { point, visible } = projector.projectPoint(_middlePoint);\n\n const distance = this.getDistance();\n\n this.elementLabel.style.display = visible && distance >= PRECISION ? \"block\" : \"none\";\n this.elementLabel.style.left = `${point.x}px`;\n this.elementLabel.style.top = `${point.y}px`;\n this.elementLabel.innerHTML = `${distance.toFixed(2)} ${this.unit}`;\n } else {\n this.elementLabel.style.display = \"none\";\n }\n }\n\n update() {\n this.elementStartPoint.id = `markup-dot-start-${this.id}`;\n this.elementStartPoint.style.position = \"absolute\";\n this.elementStartPoint.style.zIndex = \"2\";\n this.elementStartPoint.style.width = `${this.size}px`;\n this.elementStartPoint.style.height = `${this.size}px`;\n this.elementStartPoint.style.border = this.style.border;\n this.elementStartPoint.style.borderRadius = `${this.size}px`;\n this.elementStartPoint.style.background = this.style.background;\n this.elementStartPoint.style.boxShadow = this.style.boxShadow;\n this.elementStartPoint.style.transform = \"translate(-50%, -50%)\";\n\n this.elementEndPoint.id = `markup-dot-end-${this.id}`;\n this.elementEndPoint.style.position = \"absolute\";\n this.elementEndPoint.style.zIndex = \"2\";\n this.elementEndPoint.style.width = `${this.size}px`;\n this.elementEndPoint.style.height = `${this.size}px`;\n this.elementEndPoint.style.border = this.style.border;\n this.elementEndPoint.style.borderRadius = `${this.size}px`;\n this.elementEndPoint.style.background = this.style.background;\n this.elementEndPoint.style.boxShadow = this.style.boxShadow;\n this.elementEndPoint.style.transform = \"translate(-50%, -50%)\";\n\n this.elementLine.id = `markup-line-${this.id}`;\n this.elementLine.style.position = \"absolute\";\n this.elementLine.style.zIndex = \"1\";\n this.elementLine.style.height = `${this.lineWidth}px`;\n this.elementLine.style.background = this.style.background;\n this.elementLine.style.boxShadow = this.style.boxShadow;\n this.elementLine.style.transformOrigin = `0px ${this.lineWidth / 2}px`;\n\n this.elementLabel.id = `markup-label-${this.id}`;\n this.elementLabel.style.position = \"absolute\";\n this.elementLabel.style.zIndex = \"3\";\n this.elementLabel.style.padding = \"2px\";\n this.elementLabel.style.paddingInline = \"5px\";\n this.elementLabel.style.borderRadius = \"5px\";\n this.elementLabel.style.background = this.style.background;\n this.elementLabel.style.boxShadow = this.style.boxShadow;\n this.elementLabel.style.color = this.style.color;\n this.elementLabel.style.font = this.style.font;\n this.elementLabel.style.transform = \"translate(-50%, -50%)\";\n }\n\n getDistance(): number {\n return this.startPoint.distanceTo(this.endPoint) / this.scale;\n }\n}\n\nlet _widthHalf: number;\nlet _heightHalf: number;\nconst _viewMatrix = new Matrix4();\nconst _viewProjectionMatrix = new Matrix4();\nconst _vector = new Vector3();\nconst _vector1 = new Vector4();\nconst _vector2 = new Vector4();\nconst point = new Vector2();\nconst point1 = new Vector2();\nconst point2 = new Vector2();\n\nclass MeasureProjector {\n private camera: Camera;\n private canvas: HTMLElement;\n\n constructor(camera: Camera, canvas: HTMLCanvasElement) {\n this.camera = camera;\n this.canvas = canvas;\n }\n\n updateProjectionMatrix() {\n const rect = this.canvas.getBoundingClientRect();\n _widthHalf = rect.width / 2;\n _heightHalf = rect.height / 2;\n\n _viewMatrix.copy(this.camera.matrixWorldInverse);\n _viewProjectionMatrix.multiplyMatrices(this.camera.projectionMatrix, _viewMatrix);\n }\n\n projectPoint(p: Vector3) {\n _vector.copy(p).applyMatrix4(_viewProjectionMatrix);\n const visible = _vector.z >= -1 && _vector.z <= 1;\n\n point.x = (_vector.x + 1) * _widthHalf;\n point.y = (-_vector.y + 1) * _heightHalf;\n\n return { point, visible };\n }\n\n projectLine(p1: Vector3, p2: Vector3) {\n let visible: boolean;\n\n _vector1.copy(p1 as any).applyMatrix4(_viewProjectionMatrix);\n _vector2.copy(p2 as any).applyMatrix4(_viewProjectionMatrix);\n\n // see three/examples/jsm/renderers/Projector.js/clipLine for more details\n\n const bc1near = _vector1.z + _vector1.w;\n const bc2near = _vector2.z + _vector2.w;\n const bc1far = -_vector1.z + _vector1.w;\n const bc2far = -_vector2.z + _vector2.w;\n\n if (bc1near >= 0 && bc2near >= 0 && bc1far >= 0 && bc2far >= 0) visible = true;\n else if ((bc1near < 0 && bc2near < 0) || (bc1far < 0 && bc2far < 0)) visible = false;\n else {\n let alpha1 = 0;\n let alpha2 = 1;\n\n if (bc1near < 0) alpha1 = Math.max(alpha1, bc1near / (bc1near - bc2near));\n else if (bc2near < 0) alpha2 = Math.min(alpha2, bc1near / (bc1near - bc2near));\n\n if (bc1far < 0) alpha1 = Math.max(alpha1, bc1far / (bc1far - bc2far));\n else if (bc2far < 0) alpha2 = Math.min(alpha2, bc1far / (bc1far - bc2far));\n\n visible = alpha2 >= alpha1;\n\n if (visible) {\n _vector1.lerp(_vector2, alpha1);\n _vector2.lerp(_vector1, 1 - alpha2);\n }\n }\n\n _vector1.multiplyScalar(1 / _vector1.w);\n _vector2.multiplyScalar(1 / _vector2.w);\n\n point1.x = (_vector1.x + 1) * _widthHalf;\n point1.y = (-_vector1.y + 1) * _heightHalf;\n\n point2.x = (_vector2.x + 1) * _widthHalf;\n point2.y = (-_vector2.y + 1) * _heightHalf;\n\n return { point1, point2, visible };\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { MOUSE } from \"three\";\n\nimport { OrbitDragger } from \"./OrbitDragger\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class PanDragger extends OrbitDragger {\n constructor(viewer: Viewer) {\n super(viewer);\n this.orbit.mouseButtons = { LEFT: MOUSE.PAN, MIDDLE: MOUSE.PAN, RIGHT: MOUSE.PAN };\n // this.controls.touches = { ONE: TOUCH.PAN, TWO: TOUCH.DOLLY_ROTATE };\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Clock, Camera, Controls, Quaternion, Vector2, Vector3 } from \"three\";\n\ninterface WalkControlsEventMap {\n change: { type: \"change\" };\n walkspeedchange: { type: \"walkspeedchange\"; data: number };\n}\n\nexport class WalkControls extends Controls<WalkControlsEventMap> {\n public movementSpeed = 0.2;\n public lookSpeed = 5;\n public multiplier = 5;\n\n private moveKeys: Set<string>;\n private moveWheel = 0;\n private moveClock: Clock;\n\n private quaternion: Quaternion;\n private downPosition: Vector2;\n private mouseDragOn = false;\n public rotateDelta: Vector2;\n\n constructor(camera: Camera, canvas: HTMLElement) {\n super(camera, canvas);\n\n this.moveKeys = new Set();\n this.moveClock = new Clock();\n\n this.quaternion = camera.quaternion.clone();\n this.downPosition = new Vector2(0, 0);\n this.rotateDelta = new Vector2(0, 0);\n\n this.domElement.addEventListener(\"pointerdown\", this.onPointerDown);\n this.domElement.addEventListener(\"pointermove\", this.onPointerMove);\n this.domElement.addEventListener(\"pointerup\", this.onPointerUp);\n this.domElement.addEventListener(\"pointercancel\", this.onPointerCancel);\n this.domElement.addEventListener(\"wheel\", this.onWheel);\n\n window.addEventListener(\"keydown\", this.onKeyDown);\n window.addEventListener(\"keyup\", this.onKeyUp);\n }\n\n override dispose() {\n this.domElement.removeEventListener(\"pointerdown\", this.onPointerDown);\n this.domElement.removeEventListener(\"pointermove\", this.onPointerMove);\n this.domElement.removeEventListener(\"pointerup\", this.onPointerUp);\n this.domElement.removeEventListener(\"pointercancel\", this.onPointerCancel);\n this.domElement.removeEventListener(\"wheel\", this.onWheel);\n\n window.removeEventListener(\"keydown\", this.onKeyDown);\n window.removeEventListener(\"keyup\", this.onKeyUp);\n\n super.dispose();\n }\n\n onPointerDown = (event: PointerEvent) => {\n if (event.button !== 0) return;\n\n this.domElement.setPointerCapture(event.pointerId);\n this.downPosition.set(event.clientX, event.clientY);\n this.quaternion.copy(this.object.quaternion);\n this.mouseDragOn = true;\n };\n\n onPointerMove = (event: PointerEvent) => {\n if (!this.mouseDragOn) return;\n\n const movePosition = new Vector2(event.clientX, event.clientY);\n if (this.downPosition.distanceTo(movePosition) === 0) return;\n\n this.rotateDelta.copy(this.downPosition).sub(movePosition);\n this.rotateCamera(this.rotateDelta);\n this.dispatchEvent({ type: \"change\" });\n };\n\n onPointerUp = (event: PointerEvent) => {\n this.domElement.releasePointerCapture(event.pointerId);\n this.mouseDragOn = false;\n };\n\n onPointerCancel = (event: PointerEvent) => {\n this.domElement.dispatchEvent(new PointerEvent(\"pointerup\", event));\n };\n\n onWheel = (event: WheelEvent) => {\n this.moveWheel = event.deltaY;\n this.update();\n };\n\n onKeyDown = (event: KeyboardEvent) => {\n switch (event.code) {\n case \"NumpadSubtract\":\n case \"Minus\":\n if (this.multiplier > 1) {\n this.multiplier = this.multiplier - 1;\n this.dispatchEvent({ type: \"walkspeedchange\", data: this.multiplier });\n }\n break;\n\n case \"NumpadAdd\":\n case \"Equal\":\n if (this.multiplier < 10) {\n this.multiplier = this.multiplier + 1;\n this.dispatchEvent({ type: \"walkspeedchange\", data: this.multiplier });\n }\n break;\n\n case \"ArrowLeft\":\n case \"ArrowRight\":\n case \"ArrowUp\":\n case \"ArrowDown\":\n case \"KeyW\":\n case \"KeyS\":\n case \"KeyA\":\n case \"KeyD\":\n case \"KeyQ\":\n case \"KeyE\":\n this.moveKeys.add(event.code);\n this.update();\n break;\n }\n };\n\n onKeyUp = (event: KeyboardEvent) => {\n if (this.moveKeys.delete(event.code)) this.update();\n };\n\n override update() {\n if (this.moveKeys.size > 0) {\n const timeDelta = this.moveClock.getDelta();\n const moveDelta = timeDelta * this.movementSpeed * this.multiplier;\n\n if (this.moveKeys.has(\"KeyW\")) this.object.translateZ(-moveDelta);\n if (this.moveKeys.has(\"KeyS\")) this.object.translateZ(moveDelta);\n\n if (this.moveKeys.has(\"KeyA\")) this.object.translateX(-moveDelta);\n if (this.moveKeys.has(\"KeyD\")) this.object.translateX(moveDelta);\n\n if (this.moveKeys.has(\"KeyQ\")) this.object.translateY(moveDelta);\n if (this.moveKeys.has(\"KeyE\")) this.object.translateY(-moveDelta);\n\n const lookDelta = this.lookSpeed + (this.multiplier - 1);\n\n if (this.moveKeys.has(\"ArrowUp\")) this.rotateCamera(this.rotateDelta.add(new Vector2(0, -lookDelta / 2)));\n if (this.moveKeys.has(\"ArrowDown\")) this.rotateCamera(this.rotateDelta.add(new Vector2(0, lookDelta / 2)));\n\n if (this.moveKeys.has(\"ArrowLeft\")) this.rotateCamera(this.rotateDelta.add(new Vector2(lookDelta, 0)));\n if (this.moveKeys.has(\"ArrowRight\")) this.rotateCamera(this.rotateDelta.add(new Vector2(-lookDelta, 0)));\n\n this.moveWheel = 0;\n this.dispatchEvent({ type: \"change\" });\n }\n\n if (this.moveWheel !== 0) {\n const moveDelta = this.moveWheel * 0.0001 * this.movementSpeed * this.multiplier;\n\n this.object.translateZ(-moveDelta);\n this.moveWheel += -1 * Math.sign(this.moveWheel);\n this.dispatchEvent({ type: \"change\" });\n }\n\n if (this.moveKeys.size === 0 && this.moveWheel === 0) {\n this.moveClock.stop();\n this.moveClock.autoStart = true;\n }\n }\n\n rotateCamera(delta: Vector2) {\n const rotateX = (Math.PI * delta.x) / this.domElement.clientWidth;\n const rotateY = (Math.PI * delta.y) / this.domElement.clientHeight;\n\n const xRotation = new Quaternion();\n xRotation.setFromAxisAngle(this.object.up, rotateX);\n\n const yRotation = new Quaternion();\n yRotation.setFromAxisAngle(new Vector3(1, 0, 0), rotateY);\n\n const quaternion = this.quaternion.clone();\n quaternion.premultiply(xRotation).multiply(yRotation).normalize();\n\n this.object.setRotationFromQuaternion(quaternion);\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Vector3 } from \"three\";\nimport { type IDragger } from \"@inweb/viewer-core\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { WalkControls } from \"../controls/WalkControls\";\n\nexport class WalkDragger implements IDragger {\n protected viewer: Viewer;\n public controls: WalkControls;\n\n constructor(viewer: Viewer) {\n this.controls = new WalkControls(viewer.camera, viewer.canvas);\n this.controls.addEventListener(\"change\", this.controlsChange);\n this.controls.addEventListener(\"walkspeedchange\", this.walkspeedChange);\n this.viewer = viewer;\n this.viewer.on(\"render\", this.viewerRender);\n this.viewer.on(\"zoom\", this.viewerZoom);\n this.updateControls();\n }\n\n dispose() {\n this.viewer.off(\"render\", this.viewerRender);\n this.viewer.off(\"zoom\", this.viewerZoom);\n this.controls.removeEventListener(\"walkspeedchange\", this.walkspeedChange);\n this.controls.removeEventListener(\"change\", this.controlsChange);\n this.controls.dispose();\n }\n\n updateControls = () => {\n const size = this.viewer.extents.getSize(new Vector3());\n this.controls.movementSpeed = Math.min(size.x, size.y, size.z) / 2;\n };\n\n controlsChange = () => {\n this.viewer.update();\n };\n\n walkspeedChange = (event: any) => {\n this.viewer.emitEvent(event);\n };\n\n viewerRender = () => {\n this.controls.update();\n };\n\n viewerZoom = () => {\n this.controls.rotateDelta.set(0, 0);\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { MOUSE } from \"three\";\n\nimport { OrbitDragger } from \"./OrbitDragger\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class ZoomDragger extends OrbitDragger {\n constructor(viewer: Viewer) {\n super(viewer);\n this.orbit.mouseButtons = { LEFT: MOUSE.DOLLY, MIDDLE: MOUSE.PAN, RIGHT: MOUSE.PAN };\n // this.controls.touches = { ONE: TOUCH.DOLLY_PAN, TWO: TOUCH.DOLLY_PAN };\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { IDraggersRegistry, draggersRegistry } from \"@inweb/viewer-core\";\n\nimport { CuttingPlaneXAxisDragger } from \"./CuttingPlaneXAxis\";\nimport { CuttingPlaneYAxisDragger } from \"./CuttingPlaneYAxis\";\nimport { CuttingPlaneZAxisDragger } from \"./CuttingPlaneZAxis\";\nimport { MeasureLineDragger } from \"./MeasureLineDragger\";\nimport { OrbitDragger } from \"./OrbitDragger\";\nimport { PanDragger } from \"./PanDragger\";\nimport { WalkDragger } from \"./WalkDragger\";\nimport { ZoomDragger } from \"./ZoomDragger\";\n\n/**\n * Viewer draggers registry. Use this registry to register custom draggers.\n *\n * To implement custom dragger:\n *\n * 1. Define a dragger class implements {@link IDragger}.\n * 2. Define a constructor with a `viewer` parameter and add mouse event listeners for the specified viewer.\n * 3. Define the dragger logic in the event listeners. For example, listen for the `mousemove` event and\n * zoom in/out when the left mouse button is pressed.\n * 4. Override {@link IDragger.dispose} and remove mouse event listeners from the viewer.\n * 5. Register dragger provider in the draggers registry by calling the {@link draggers.registerDragger}.\n *\n * @example Implementing a custom dragger.\n *\n * ```javascript\n * import { IDragger, draggers, Viewer } from \"@inweb/viewer-three\";\n *\n * class MyDragger implements IDragger {\n * protected viewer: Viewer;\n *\n * constructor(viewer: Viewer) {\n * this.viewer = viewer;\n * this.viewer.addEventListener(\"pointermove\", this.onPointerMove);\n * }\n *\n * override dispose() {\n * this.viewer.removeEventListener(\"pointermove\", this.onPointerMove);\n * }\n *\n * onPointerMove = (event: PointerEvent) => {\n * // place custom logic here\n * };\n * }\n *\n * draggers.registerDragger(\"MyDragger\", (viewer): IDragger => new MyDragger(viewer));\n * ```\n *\n * @example Activating a custom dragger.\n *\n * ```javascript\n * viewer.setActiveDragger(\"MyDragger\");\n * ```\n */\nexport const draggers: IDraggersRegistry = draggersRegistry(\"threejs\");\n\n// build-in draggers\n\ndraggers.registerDragger(\"Pan\", (viewer) => new PanDragger(viewer));\ndraggers.registerDragger(\"Orbit\", (viewer) => new OrbitDragger(viewer));\ndraggers.registerDragger(\"Zoom\", (viewer) => new ZoomDragger(viewer));\ndraggers.registerDragger(\"MeasureLine\", (viewer) => new MeasureLineDragger(viewer));\ndraggers.registerDragger(\"CuttingPlaneXAxis\", (viewer) => new CuttingPlaneXAxisDragger(viewer));\ndraggers.registerDragger(\"CuttingPlaneYAxis\", (viewer) => new CuttingPlaneYAxisDragger(viewer));\ndraggers.registerDragger(\"CuttingPlaneZAxis\", (viewer) => new CuttingPlaneZAxisDragger(viewer));\ndraggers.registerDragger(\"Walk\", (viewer) => new WalkDragger(viewer));\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Model, File, Assembly } from \"@inweb/client\";\nimport type { Viewer } from \"../Viewer\";\n\nexport function applyModelTransform(viewer: Viewer, model: Model | File | Assembly) {\n console.warn(\"applyModelTransform not implemented\");\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function clearMarkup(viewer: Viewer) {\n viewer.clearOverlay();\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function clearSelected(viewer: Viewer): void {\n const selection: any = viewer.getComponent(\"SelectionComponent\");\n if (!selection) return;\n\n selection.clearSelection();\n\n viewer.update();\n viewer.emitEvent({ type: \"select\", data: undefined, handles: [] });\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function clearSlices(viewer: Viewer) {\n viewer.clearSlices();\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function createPreview(viewer: Viewer, type = \"image/jpeg\", encoderOptions = 0.25): string {\n viewer.update(true);\n return viewer.canvas.toDataURL(type, encoderOptions);\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Box3, Vector3 } from \"three\";\nimport type { Viewer } from \"../Viewer\";\n\nfunction calcExplodeDepth(object, depth: number): number {\n let res = depth;\n object.children.forEach((x) => {\n const objectDepth = calcExplodeDepth(x, depth + 1);\n if (res < objectDepth) res = objectDepth;\n });\n\n object.originalPosition = object.position.clone();\n object.originalCenter = new Box3().setFromObject(object).getCenter(new Vector3());\n object.isExplodeLocked = depth > 2 && object.children.length === 0;\n\n return res;\n}\n\nfunction explodeModel(scene, scale = 0, coeff = 4) {\n scale /= 100;\n\n if (!scene.explodeDepth) scene.explodeDepth = calcExplodeDepth(scene, 1);\n const maxDepth = scene.explodeDepth;\n\n const scaledExplodeDepth = scale * maxDepth + 1;\n const explodeDepth = 0 | scaledExplodeDepth;\n const currentSegmentFraction = scaledExplodeDepth - explodeDepth;\n\n function explodeObject(object, depth: number) {\n object.position.copy(object.originalPosition);\n\n if (depth > 0 && depth <= explodeDepth && !object.isExplodeLocked) {\n let objectScale = scale * coeff;\n if (depth === explodeDepth) objectScale *= currentSegmentFraction;\n\n const parentCenter = object.parent.originalCenter;\n const objectCenter = object.originalCenter;\n const objectOffset = objectCenter.clone().sub(parentCenter).multiplyScalar(objectScale);\n\n object.position.add(objectOffset);\n }\n\n object.children.forEach((x) => explodeObject(x, depth + 1));\n }\n\n explodeObject(scene, 0);\n}\n\nexport function explode(viewer: Viewer, index = 0): void {\n viewer.models.forEach((model) => explodeModel(model, index));\n viewer.scene.updateMatrixWorld();\n\n viewer.update();\n viewer.emitEvent({ type: \"explode\", data: index });\n}\n\nexport function collect(viewer: Viewer) {\n explode(viewer, 0);\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Box3, MathUtils, Sphere, Vector2, Vector3 } from \"three\";\nimport type { Viewer } from \"../Viewer\";\n\nexport function zoomTo(viewer: Viewer, box: Box3): void {\n if (box.isEmpty()) return;\n\n const center = box.getCenter(new Vector3());\n const sphere = box.getBoundingSphere(new Sphere());\n\n const rendererSize = viewer.renderer.getSize(new Vector2());\n const aspect = rendererSize.x / rendererSize.y;\n\n const camera = viewer.camera as any;\n\n if (camera.isPerspectiveCamera) {\n const offset = new Vector3(0, 0, 1);\n offset.applyQuaternion(camera.quaternion);\n offset.multiplyScalar(sphere.radius / Math.tan(MathUtils.DEG2RAD * camera.fov * 0.5));\n\n camera.position.copy(center).add(offset);\n camera.updateMatrixWorld();\n }\n if (camera.isOrthographicCamera) {\n camera.top = sphere.radius;\n camera.bottom = -sphere.radius;\n camera.left = camera.bottom * aspect;\n camera.right = camera.top * aspect;\n camera.zoom = 1;\n camera.updateProjectionMatrix();\n\n const offset = new Vector3(0, 0, 1);\n offset.applyQuaternion(camera.quaternion);\n offset.multiplyScalar(viewer.extents.getBoundingSphere(new Sphere()).radius * 3);\n\n camera.position.copy(center).add(offset);\n camera.updateMatrixWorld();\n }\n\n viewer.target.copy(center);\n\n viewer.update();\n viewer.emitEvent({ type: \"zoom\" });\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Sphere, Vector3 } from \"three\";\nimport type { Viewer } from \"../Viewer\";\nimport { zoomTo } from \"./ZoomTo\";\n\nexport const defaultViewPositions = {\n top: new Vector3(0, 0, 1),\n bottom: new Vector3(0, 0, -1),\n left: new Vector3(-1, 0, 0),\n right: new Vector3(1, 0, 0),\n front: new Vector3(0, -1, 0),\n back: new Vector3(0, 1, 0),\n sw: new Vector3(-0.5, -0.5, 1.0).normalize(),\n se: new Vector3(0.5, -0.5, 1.0).normalize(),\n ne: new Vector3(0.5, 0.5, 1.0).normalize(),\n nw: new Vector3(-0.5, 0.5, 1.0).normalize(),\n};\n\nexport function setDefaultViewPosition(viewer: Viewer, position: string): void {\n const direction = defaultViewPositions[position] || defaultViewPositions[\"sw\"];\n\n const center = viewer.extents.getCenter(new Vector3());\n const sphere = viewer.extents.getBoundingSphere(new Sphere());\n const offset = direction.clone().multiplyScalar(sphere.radius);\n\n const camera = viewer.camera;\n camera.position.copy(center).add(offset);\n camera.lookAt(center);\n camera.updateMatrixWorld();\n\n viewer.target.copy(center);\n\n viewer.update();\n viewer.emit({ type: \"viewposition\", data: position });\n\n zoomTo(viewer, viewer.extents);\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { defaultViewPositions } from \"./SetDefaultViewPosition\";\n\nexport function getDefaultViewPositions(): string[] {\n return Object.keys(defaultViewPositions);\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function getModels(viewer: Viewer): string[] {\n return viewer.models.map((model) => model.userData?.handle || \"\").filter((handle) => handle);\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function getSelected(viewer: Viewer): string[] {\n return viewer.selected.map((object) => object.userData?.handle).filter((handle) => handle);\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Intersection, Object3D, Raycaster, Vector2 } from \"three\";\n\nimport { IComponent } from \"@inweb/viewer-core\";\nimport { Viewer } from \"../Viewer\";\nimport { HighlighterComponent } from \"./HighlighterComponent\";\n\nexport class SelectionComponent implements IComponent {\n protected viewer: Viewer;\n protected raycaster: Raycaster;\n protected downPosition: Vector2;\n protected highlighter: HighlighterComponent;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n this.raycaster = new Raycaster();\n this.downPosition = new Vector2();\n\n this.viewer.addEventListener(\"pointerdown\", this.onPointerDown);\n this.viewer.addEventListener(\"pointerup\", this.onPointerUp);\n this.viewer.addEventListener(\"dblclick\", this.onDoubleClick);\n this.viewer.addEventListener(\"initialize\", this.initHighlighter);\n }\n\n dispose() {\n this.viewer.removeEventListener(\"pointerdown\", this.onPointerDown);\n this.viewer.removeEventListener(\"pointerup\", this.onPointerUp);\n this.viewer.removeEventListener(\"dblclick\", this.onDoubleClick);\n this.viewer.removeEventListener(\"initialize\", this.initHighlighter);\n }\n\n onPointerDown = (event: PointerEvent) => {\n if (!event.isPrimary || event.button !== 0) return;\n\n this.getMousePosition(event, this.downPosition);\n };\n\n onPointerUp = (event: PointerEvent) => {\n if (!event.isPrimary) return;\n\n const upPosition = this.getMousePosition(event, new Vector2());\n if (this.downPosition.distanceTo(upPosition) !== 0) return;\n\n const intersects = this.getPointerIntersects(upPosition);\n\n this.clearSelection();\n if (intersects.length > 0) this.select(intersects[0].object);\n\n this.viewer.update();\n this.viewer.emitEvent({ type: \"select\", data: undefined, handles: this.viewer.getSelected() });\n };\n\n onDoubleClick = (event: MouseEvent) => {\n if (event.button !== 0) return;\n\n this.viewer.executeCommand(\"zoomToSelected\");\n };\n\n getMousePosition(event: MouseEvent, target: Vector2): Vector2 {\n return target.set(event.clientX, event.clientY);\n }\n\n getPointerIntersects(mouse: Vector2): Array<Intersection<Object3D>> {\n const rect = this.viewer.canvas.getBoundingClientRect();\n const x = ((mouse.x - rect.left) / rect.width) * 2 - 1;\n const y = (-(mouse.y - rect.top) / rect.height) * 2 + 1;\n\n const coords = new Vector2(x, y);\n this.raycaster.setFromCamera(coords, this.viewer.camera);\n\n const objects = [];\n this.viewer.scene.traverseVisible((child) => objects.push(child));\n\n this.raycaster.params = this.raycaster.params = {\n Mesh: {},\n Line: { threshold: 0.25 },\n Line2: { threshold: 0.25 },\n LOD: {},\n Points: { threshold: 0.1 },\n Sprite: {},\n };\n\n return this.raycaster.intersectObjects(objects, false);\n }\n\n select(object: any) {\n if (object.isSelected) return;\n\n object.isSelected = true;\n this.highlighter.highlight(object);\n\n this.viewer.selected.push(object);\n }\n\n clearSelection() {\n this.viewer.selected.forEach((object: any) => {\n object.isSelected = false;\n this.highlighter.unhighlight(object);\n });\n this.viewer.selected.length = 0;\n }\n\n initHighlighter = () => {\n this.highlighter = this.viewer.getComponent(\"HighlighterComponent\") as any;\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\nimport { SelectionComponent } from \"../components/SelectionComponent\";\n\nexport function hideSelected(viewer: Viewer): void {\n viewer.selected.forEach((object) => (object.visible = false));\n\n const selection = new SelectionComponent(viewer);\n selection.clearSelection();\n selection.dispose();\n\n viewer.update();\n viewer.emitEvent({ type: \"hide\" });\n viewer.emitEvent({ type: \"select\", data: undefined, handles: [] });\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function isolateSelected(viewer: Viewer): void {\n const visibleSet = new Set();\n viewer.selected.forEach((object) => {\n visibleSet.add(object);\n object.traverseAncestors((object2) => visibleSet.add(object2));\n });\n\n viewer.scene.traverse((object) => (object.visible = visibleSet.has(object)));\n\n viewer.update();\n viewer.emitEvent({ type: \"isolate\" });\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function regenerateAll(viewer: Viewer): void {\n viewer.emit({ type: \"regenerateall\" });\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function resetView(viewer: Viewer): void {\n viewer.executeCommand(\"setActiveDragger\");\n viewer.executeCommand(\"clearSlices\");\n viewer.executeCommand(\"clearOverlay\");\n viewer.executeCommand(\"setMarkupColor\");\n viewer.executeCommand(\"clearSelected\");\n viewer.executeCommand(\"showAll\");\n viewer.executeCommand(\"explode\", 0);\n viewer.executeCommand(\"zoomToExtents\", true);\n viewer.executeCommand(\"k3DViewSW\");\n\n viewer.emit({ type: \"resetview\" });\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function selectModel(viewer: Viewer, handle: string): void {\n console.warn(\"selectModel not implemented\");\n viewer.emit({ type: \"select\", data: [] });\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function setActiveDragger(viewer: Viewer, dragger = \"\") {\n viewer.setActiveDragger(dragger);\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function setMarkupColor(viewer: Viewer, r = 255, g = 0, b = 0) {\n viewer.markup.setMarkupColor(r, g, b);\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function setSelected(viewer: Viewer, handles: string[] = []): void {\n const handleSet = new Set(handles);\n const objects = [];\n viewer.scene.traverseVisible((child) => {\n if (handleSet.has(child.userData?.handle)) objects.push(child);\n });\n\n const selection: any = viewer.getComponent(\"SelectionComponent\");\n if (!selection) return;\n\n selection.clearSelection();\n objects.forEach((object) => selection.select(object));\n\n viewer.update();\n viewer.emitEvent({ type: \"select\", data: undefined, handles });\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function showAll(viewer: Viewer): void {\n viewer.scene.traverse((object) => (object.visible = true));\n\n viewer.update();\n viewer.emitEvent({ type: \"showall\" });\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\nimport { zoomTo } from \"./ZoomTo\";\n\nexport function zoomToExtents(viewer: Viewer): void {\n zoomTo(viewer, viewer.extents);\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Box3 } from \"three\";\nimport type { Viewer } from \"../Viewer\";\nimport { zoomTo } from \"./ZoomTo\";\n\nexport function zoomToObjects(viewer: Viewer, handles: string[] = []): void {\n const handleSet = new Set(handles);\n const objects = [];\n viewer.scene.traverseVisible((child) => {\n if (handleSet.has(child.userData?.handle)) objects.push(child);\n });\n\n const extents = objects.reduce((result: Box3, object) => result.expandByObject(object), new Box3());\n if (extents.isEmpty()) extents.copy(viewer.extents);\n\n zoomTo(viewer, extents);\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Box3 } from \"three\";\nimport type { Viewer } from \"../Viewer\";\nimport { zoomTo } from \"./ZoomTo\";\n\nexport function zoomToSelected(viewer: Viewer): void {\n const extents = viewer.selected.reduce((result: Box3, object) => result.expandByObject(object), new Box3());\n if (extents.isEmpty()) extents.copy(viewer.extents);\n\n zoomTo(viewer, extents);\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { ICommandsRegistry, commandsRegistry } from \"@inweb/viewer-core\";\n\nimport { applyModelTransform } from \"./ApplyModelTransform\";\nimport { clearMarkup } from \"./ClearMarkup\";\nimport { clearSelected } from \"./ClearSelected\";\nimport { clearSlices } from \"./ClearSlices\";\nimport { createPreview } from \"./CreatePreview\";\nimport { explode, collect } from \"./Explode\";\nimport { getDefaultViewPositions } from \"./GetDefaultViewPositions\";\nimport { getModels } from \"./GetModels\";\nimport { getSelected } from \"./GetSelected\";\nimport { hideSelected } from \"./HideSelected\";\nimport { isolateSelected } from \"./IsolateSelected\";\nimport { regenerateAll } from \"./RegenerateAll\";\nimport { resetView } from \"./ResetView\";\nimport { selectModel } from \"./SelectModel\";\nimport { setActiveDragger } from \"./SetActiveDragger\";\nimport { setDefaultViewPosition } from \"./SetDefaultViewPosition\";\nimport { setMarkupColor } from \"./SetMarkupColor\";\nimport { setSelected } from \"./SetSelected\";\nimport { showAll } from \"./ShowAll\";\nimport { zoomToExtents } from \"./ZoomToExtents\";\nimport { zoomToObjects } from \"./ZoomToObjects\";\nimport { zoomToSelected } from \"./ZoomToSelected\";\n\n/**\n * Viewer commands registry. Use this registry to register custom commands.\n *\n * To implement custom command:\n *\n * 1. Define a command handler with a first `viewer` parameter.\n * 2. Register command handler in the commands registry by calling the {@link commands.registerCommand}.\n *\n * @example Implementing a custom command.\n *\n * ```javascript\n * import { commands, Viewer } from \"@inweb/viewer-three\";\n *\n * function commandHandler(viewer: Viewer, name = \"world\"): void {\n * console.log(`Hello ${name}!!!`);\n * }\n *\n * commands.registerCommand(\"sayHello\", commandHandler);\n * ```\n *\n * @example Calling a custom command.\n *\n * ```javascript\n * viewer.executeCommand(\"sayHello\", \"user\");\n * ```\n */\nexport const commands: ICommandsRegistry = commandsRegistry(\"threejs\");\n\n// build-in commands\n\ncommands.registerCommand(\"applyModelTransform\", applyModelTransform);\ncommands.registerCommand(\"clearMarkup\", clearMarkup);\ncommands.registerCommand(\"clearSelected\", clearSelected);\ncommands.registerCommand(\"clearSlices\", clearSlices);\ncommands.registerCommand(\"createPreview\", createPreview);\ncommands.registerCommand(\"explode\", explode);\ncommands.registerCommand(\"collect\", collect);\ncommands.registerCommand(\"getDefaultViewPositions\", getDefaultViewPositions);\ncommands.registerCommand(\"getModels\", getModels);\ncommands.registerCommand(\"getSelected\", getSelected);\ncommands.registerCommand(\"hideSelected\", hideSelected);\ncommands.registerCommand(\"isolateSelected\", isolateSelected);\ncommands.registerCommand(\"regenerateAll\", regenerateAll);\ncommands.registerCommand(\"resetView\", resetView);\ncommands.registerCommand(\"selectModel\", selectModel);\ncommands.registerCommand(\"setActiveDragger\", setActiveDragger);\ncommands.registerCommand(\"setDefaultViewPosition\", setDefaultViewPosition);\ncommands.registerCommand(\"setMarkupColor\", setMarkupColor);\ncommands.registerCommand(\"setSelected\", setSelected);\ncommands.registerCommand(\"showAll\", showAll);\ncommands.registerCommand(\"zoomToExtents\", zoomToExtents);\ncommands.registerCommand(\"zoomToObjects\", zoomToObjects);\ncommands.registerCommand(\"zoomToSelected\", zoomToSelected);\n\ncommands.registerCommand(\"top\", (viewer) => setDefaultViewPosition(viewer, \"top\"));\ncommands.registerCommand(\"bottom\", (viewer) => setDefaultViewPosition(viewer, \"bottom\"));\ncommands.registerCommand(\"left\", (viewer) => setDefaultViewPosition(viewer, \"left\"));\ncommands.registerCommand(\"right\", (viewer) => setDefaultViewPosition(viewer, \"right\"));\ncommands.registerCommand(\"front\", (viewer) => setDefaultViewPosition(viewer, \"front\"));\ncommands.registerCommand(\"back\", (viewer) => setDefaultViewPosition(viewer, \"back\"));\ncommands.registerCommand(\"sw\", (viewer) => setDefaultViewPosition(viewer, \"sw\"));\ncommands.registerCommand(\"se\", (viewer) => setDefaultViewPosition(viewer, \"se\"));\ncommands.registerCommand(\"ne\", (viewer) => setDefaultViewPosition(viewer, \"ne\"));\ncommands.registerCommand(\"nw\", (viewer) => setDefaultViewPosition(viewer, \"nw\"));\n\ncommands.registerCommandAlias(\"clearMarkup\", \"clearOverlay\");\ncommands.registerCommandAlias(\"clearSelected\", \"unselect\");\ncommands.registerCommandAlias(\"zoomToExtents\", \"zoomExtents\");\n\ncommands.registerCommandAlias(\"top\", \"k3DViewTop\");\ncommands.registerCommandAlias(\"bottom\", \"k3DViewBottom\");\ncommands.registerCommandAlias(\"left\", \"k3DViewLeft\");\ncommands.registerCommandAlias(\"right\", \"k3DViewRight\");\ncommands.registerCommandAlias(\"front\", \"k3DViewFront\");\ncommands.registerCommandAlias(\"back\", \"k3DViewBack\");\ncommands.registerCommandAlias(\"se\", \"k3DViewSE\");\ncommands.registerCommandAlias(\"sw\", \"k3DViewSW\");\ncommands.registerCommandAlias(\"ne\", \"k3DViewNE\");\ncommands.registerCommandAlias(\"nw\", \"k3DViewNW\");\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Color } from \"three\";\n\nimport { IComponent } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class BackgroundComponent implements IComponent {\n protected viewer: Viewer;\n protected backgroundColor: Color;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n\n this.backgroundColor = new Color(0xffffff);\n\n this.viewer.renderer.setClearColor(this.backgroundColor);\n this.viewer.scene.background = this.backgroundColor;\n this.viewer.addEventListener(\"optionschange\", this.syncOptions);\n }\n\n dispose() {\n this.viewer.removeEventListener(\"optionschange\", this.syncOptions);\n this.viewer.scene.background = undefined;\n }\n\n syncOptions = () => {\n this.backgroundColor.setHex(0xffffff);\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Sphere, Vector2, Vector3 } from \"three\";\n\nimport { IComponent } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class CameraComponent implements IComponent {\n protected viewer: Viewer;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n this.viewer.addEventListener(\"databasechunk\", this.geometryEnd);\n }\n\n dispose() {\n this.viewer.removeEventListener(\"databasechunk\", this.geometryEnd);\n }\n\n geometryEnd = () => {\n const extentsCenter = this.viewer.extents.getCenter(new Vector3());\n const extentsSize = this.viewer.extents.getBoundingSphere(new Sphere()).radius * 2;\n const rendererSize = this.viewer.renderer.getSize(new Vector2());\n const aspect = rendererSize.x / rendererSize.y;\n\n // TODO: do not change the camera and target after opening the second model in \"append\" mode\n let sceneCamera: any;\n this.viewer.scene.traverse((object: any) => {\n if (object.isCamera)\n if (!sceneCamera) sceneCamera = object;\n else if (object.isPerspectiveCamera && sceneCamera.isOrthographicCamera) sceneCamera = object;\n });\n if (sceneCamera) {\n this.viewer.camera = sceneCamera.clone();\n this.viewer.camera.up.set(0, 0, 1);\n this.viewer.camera.scale.set(1, 1, 1); // <- visualize fix\n }\n\n const camera = this.viewer.camera as any;\n\n if (camera.isPerspectiveCamera) {\n camera.aspect = aspect;\n camera.near = extentsSize / 100;\n camera.far = extentsSize * 100;\n camera.updateProjectionMatrix();\n }\n if (camera.isOrthographicCamera) {\n camera.left = camera.bottom * aspect;\n camera.right = camera.top * aspect;\n camera.near = 0;\n camera.far = extentsSize * 100;\n camera.updateProjectionMatrix();\n }\n\n this.viewer.target.copy(extentsCenter);\n\n if (!sceneCamera) {\n this.viewer.executeCommand(\"setDefaultViewPosition\");\n }\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Box3 } from \"three\";\n\nimport { IComponent } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class ExtentsComponent implements IComponent {\n private viewer: Viewer;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n this.viewer.addEventListener(\"databasechunk\", this.syncExtents);\n this.viewer.addEventListener(\"clear\", this.syncExtents);\n this.viewer.on(\"explode\", this.syncExtents);\n this.viewer.on(\"isolate\", this.syncExtents);\n this.viewer.on(\"hide\", this.syncExtents);\n this.viewer.on(\"showall\", this.syncExtents);\n }\n\n dispose() {\n this.viewer.removeEventListener(\"databasechunk\", this.syncExtents);\n this.viewer.removeEventListener(\"clear\", this.syncExtents);\n this.viewer.off(\"explode\", this.syncExtents);\n this.viewer.off(\"isolate\", this.syncExtents);\n this.viewer.off(\"hide\", this.syncExtents);\n this.viewer.off(\"showall\", this.syncExtents);\n }\n\n syncExtents = () => {\n const extents = new Box3();\n this.viewer.scene.traverseVisible((object) => !object.children.length && extents.expandByObject(object));\n\n this.viewer.extents.copy(extents);\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { AmbientLight, DirectionalLight, HemisphereLight, Sphere, Vector3 } from \"three\";\n\nimport { IComponent } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class LightComponent implements IComponent {\n protected viewer: Viewer;\n protected ambientLight: AmbientLight;\n protected directionalLight: DirectionalLight;\n protected frontLight: DirectionalLight;\n protected hemisphereLight: HemisphereLight;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n\n this.ambientLight = new AmbientLight(0xffffff, 1);\n this.viewer.scene.add(this.ambientLight);\n\n this.directionalLight = new DirectionalLight(0xffffff, 1);\n this.directionalLight.position.set(0.5, 0, 0.866); // ~60º\n this.viewer.scene.add(this.directionalLight);\n\n this.frontLight = new DirectionalLight(0xffffff, 1.25);\n this.frontLight.position.set(0, 1, 0);\n this.viewer.scene.add(this.frontLight);\n\n this.hemisphereLight = new HemisphereLight(0xffffff, 0x444444, 1.25);\n this.hemisphereLight.position.set(0, 0, 1);\n this.viewer.scene.add(this.hemisphereLight);\n\n this.viewer.addEventListener(\"databasechunk\", this.geometryEnd);\n this.viewer.addEventListener(\"clear\", this.geometryEnd);\n }\n\n dispose(): void {\n this.ambientLight.removeFromParent();\n this.ambientLight.dispose();\n\n this.directionalLight.removeFromParent();\n this.directionalLight.dispose();\n\n this.frontLight.removeFromParent();\n this.frontLight.dispose();\n\n this.hemisphereLight.removeFromParent();\n this.hemisphereLight.dispose();\n\n this.viewer.removeEventListener(\"databasechunk\", this.geometryEnd);\n this.viewer.removeEventListener(\"clear\", this.geometryEnd);\n }\n\n geometryEnd = () => {\n this.ambientLight.removeFromParent();\n this.directionalLight.removeFromParent();\n this.frontLight.removeFromParent();\n this.hemisphereLight.removeFromParent();\n\n if (this.viewer.extents.isEmpty()) return;\n\n const extentsCenter = this.viewer.extents.getCenter(new Vector3());\n const extentsSize = this.viewer.extents.getBoundingSphere(new Sphere()).radius;\n\n this.directionalLight.position\n .set(0.5, 0, 0.866)\n .multiplyScalar(extentsSize * 2)\n .add(extentsCenter);\n this.directionalLight.target.position.copy(extentsCenter);\n\n this.frontLight.position.set(0, extentsSize * 2, 0).add(extentsCenter);\n this.frontLight.target.position.copy(extentsCenter);\n\n this.hemisphereLight.position.set(0, extentsSize * 3, 0).add(extentsCenter);\n\n this.viewer.scene.add(this.ambientLight);\n this.viewer.scene.add(this.directionalLight);\n this.viewer.scene.add(this.frontLight);\n this.viewer.scene.add(this.hemisphereLight);\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { IComponent } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class RenderLoopComponent implements IComponent {\n protected viewer: Viewer;\n protected requestId: number;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n this.animate();\n }\n\n dispose() {\n cancelAnimationFrame(this.requestId);\n }\n\n animate = (time = 0) => {\n this.requestId = requestAnimationFrame(this.animate);\n\n this.viewer.render(time);\n this.viewer.emitEvent({ type: \"animate\", time });\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { IComponent } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class ResizeCanvasComponent implements IComponent {\n protected viewer: Viewer;\n protected resizeObserver: ResizeObserver;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n this.resizeObserver = new ResizeObserver(this.resizeViewer);\n this.resizeObserver.observe(viewer.canvas.parentElement);\n }\n\n dispose() {\n this.resizeObserver.disconnect();\n }\n\n resizeViewer = (entries: ResizeObserverEntry[]) => {\n const { width, height } = entries[0].contentRect;\n\n if (!width || !height) return; // <- invisible viewer, or viewer with parent removed\n\n const camera = this.viewer.camera as any;\n const aspect = width / height;\n\n if (camera.isPerspectiveCamera) {\n camera.aspect = aspect;\n camera.updateProjectionMatrix();\n }\n if (camera.isOrthographicCamera) {\n camera.left = camera.bottom * aspect;\n camera.right = camera.top * aspect;\n camera.updateProjectionMatrix();\n }\n\n this.viewer.renderer.setSize(width, height, true);\n\n this.viewer.update(true);\n this.viewer.emitEvent({ type: \"resize\", width, height });\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { LineSegmentsGeometry } from \"three/examples/jsm/lines/LineSegmentsGeometry.js\";\n\nexport class HighlighterUtils {\n static isBreak(positions: Float32Array, i: number) {\n return (\n isNaN(positions[i]) ||\n isNaN(positions[i + 1]) ||\n isNaN(positions[i + 2]) ||\n positions[i] === Infinity ||\n positions[i] === -Infinity ||\n positions[i + 1] === Infinity ||\n positions[i + 1] === -Infinity ||\n positions[i + 2] === Infinity ||\n positions[i + 2] === -Infinity\n );\n }\n\n static fromIndexedLine(positions: Float32Array, indices: number[]) {\n const lineGeometry = new LineSegmentsGeometry();\n const segments = [];\n\n for (let i = 0; i < indices.length; i += 2) {\n const idx1 = indices[i] * 3;\n const idx2 = indices[i + 1] * 3;\n\n if (indices[i] === -1 || indices[i + 1] === -1) {\n continue;\n }\n\n segments.push(\n positions[idx1],\n positions[idx1 + 1],\n positions[idx1 + 2],\n positions[idx2],\n positions[idx2 + 1],\n positions[idx2 + 2]\n );\n }\n\n if (segments.length === 0) return null;\n\n lineGeometry.setPositions(segments);\n return lineGeometry;\n }\n\n static fromNonIndexedLine(positions: Float32Array, isLineSegments: boolean) {\n const lineGeometry = new LineSegmentsGeometry();\n const segments = [];\n\n if (isLineSegments) {\n for (let i = 0; i < positions.length; i += 6) {\n if (i + 5 >= positions.length) break;\n\n if (HighlighterUtils.isBreak(positions, i) || HighlighterUtils.isBreak(positions, i + 3)) continue;\n\n segments.push(\n positions[i],\n positions[i + 1],\n positions[i + 2],\n positions[i + 3],\n positions[i + 4],\n positions[i + 5]\n );\n }\n } else {\n let lastValidIndex = -1;\n\n for (let i = 0; i < positions.length; i += 3) {\n if (HighlighterUtils.isBreak(positions, i)) {\n lastValidIndex = -1;\n continue;\n }\n\n if (lastValidIndex !== -1) {\n segments.push(\n positions[lastValidIndex],\n positions[lastValidIndex + 1],\n positions[lastValidIndex + 2],\n positions[i],\n positions[i + 1],\n positions[i + 2]\n );\n }\n lastValidIndex = i;\n }\n }\n\n if (segments.length === 0) return null;\n\n lineGeometry.setPositions(segments);\n return lineGeometry;\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Color, EdgesGeometry, LineBasicMaterial, MeshBasicMaterial, Vector2 } from \"three\";\nimport { LineSegmentsGeometry } from \"three/examples/jsm/lines/LineSegmentsGeometry.js\";\nimport { Wireframe } from \"three/examples/jsm/lines/Wireframe.js\";\nimport { LineMaterial } from \"three/examples/jsm/lines/LineMaterial.js\";\n\nimport { IComponent, ResizeEvent } from \"@inweb/viewer-core\";\nimport { Viewer } from \"../Viewer\";\nimport { HighlighterUtils } from \"./HighlighterUtils\";\n\nexport class HighlighterComponent implements IComponent {\n protected viewer: Viewer;\n public highlightMaterial: MeshBasicMaterial;\n public outlineMaterial: LineMaterial;\n public highlightLineMaterial: LineBasicMaterial;\n public highlightLineGlowMaterial: LineMaterial;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n\n this.viewer.addEventListener(\"databasechunk\", this.geometryEnd);\n this.viewer.addEventListener(\"optionschange\", this.optionsChange);\n this.viewer.addEventListener(\"resize\", this.viewerResize);\n\n this.geometryEnd();\n }\n\n dispose() {\n this.viewer.removeEventListener(\"databasechunk\", this.geometryEnd);\n this.viewer.removeEventListener(\"optionschange\", this.optionsChange);\n this.viewer.removeEventListener(\"resize\", this.viewerResize);\n }\n\n highlight(object: any) {\n if (object.isHighlighted) return;\n\n if (object.isLine || object.isLineSegments) {\n const positions = object.geometry.attributes.position.array;\n const indices = object.geometry.index ? object.geometry.index.array : null;\n const lineGeometry = indices\n ? HighlighterUtils.fromIndexedLine(positions, indices)\n : HighlighterUtils.fromNonIndexedLine(positions, object.isLineSegments);\n\n const wireframe = new Wireframe(lineGeometry, this.highlightLineGlowMaterial);\n wireframe.position.copy(object.position);\n wireframe.rotation.copy(object.rotation);\n wireframe.scale.copy(object.scale);\n\n object.parent.add(wireframe);\n\n object.userData.highlightwireframe = wireframe;\n object.userData.originalMaterial = object.material;\n object.material = this.highlightLineMaterial;\n object.isHighlighted = true;\n } else if (object.isMesh) {\n const edgesGeometry = new EdgesGeometry(object.geometry, 30);\n const lineGeometry = new LineSegmentsGeometry().fromEdgesGeometry(edgesGeometry);\n\n const wireframe = new Wireframe(lineGeometry, this.outlineMaterial);\n wireframe.position.copy(object.position);\n wireframe.rotation.copy(object.rotation);\n wireframe.scale.copy(object.scale);\n\n object.parent.add(wireframe);\n\n object.userData.highlightwireframe = wireframe;\n object.userData.originalMaterial = object.material;\n object.material = this.highlightMaterial;\n object.isHighlighted = true;\n }\n }\n\n unhighlight(object: any) {\n if (!object.isHighlighted) return;\n\n object.isHighlighted = false;\n object.material = object.userData.originalMaterial;\n object.userData.highlightwireframe.removeFromParent();\n\n delete object.userData.originalMaterial;\n delete object.userData.highlightwireframe;\n }\n\n geometryEnd = () => {\n const { facesColor, facesTransparancy, edgesColor } = this.viewer.options;\n\n this.highlightMaterial = new MeshBasicMaterial({\n color: new Color(facesColor.r / 255, facesColor.g / 255, facesColor.b / 255),\n transparent: true,\n opacity: (255 - facesTransparancy) / 255,\n depthTest: false,\n depthWrite: false,\n });\n\n this.outlineMaterial = new LineMaterial({\n color: new Color(edgesColor.r / 255, edgesColor.g / 255, edgesColor.b / 255),\n linewidth: 1.5,\n depthTest: false,\n depthWrite: false,\n resolution: new Vector2(window.innerWidth, window.innerHeight),\n });\n\n this.highlightLineMaterial = new LineBasicMaterial({\n color: new Color(facesColor.r / 255, facesColor.g / 255, facesColor.b / 255),\n depthTest: false,\n depthWrite: false,\n });\n\n this.highlightLineGlowMaterial = new LineMaterial({\n color: new Color(facesColor.r / 255, facesColor.g / 255, facesColor.b / 255),\n linewidth: 5,\n transparent: true,\n opacity: 0.8,\n depthTest: true,\n depthWrite: true,\n resolution: new Vector2(window.innerWidth, window.innerHeight),\n });\n };\n\n optionsChange = () => {\n const { facesColor, facesTransparancy, edgesColor } = this.viewer.options;\n\n this.highlightMaterial.color.setRGB(facesColor.r / 255, facesColor.g / 255, facesColor.b / 255);\n this.highlightMaterial.opacity = (255 - facesTransparancy) / 255;\n this.outlineMaterial.color.setRGB(edgesColor.r / 255, edgesColor.g / 255, edgesColor.b / 255);\n this.highlightLineMaterial.color.setRGB(facesColor.r / 255, facesColor.g / 255, facesColor.b / 255);\n this.highlightLineGlowMaterial.color.setRGB(facesColor.r / 255, facesColor.g / 255, facesColor.b / 255);\n\n this.viewer.update();\n };\n\n viewerResize(event: ResizeEvent) {\n if (!this.outlineMaterial) return;\n\n this.outlineMaterial.resolution.set(event.width, event.height);\n }\n}\n","import {\n Camera,\n CylinderGeometry,\n CanvasTexture,\n Color,\n Mesh,\n MeshBasicMaterial,\n Object3D,\n OrthographicCamera,\n Sprite,\n SpriteMaterial,\n SRGBColorSpace,\n Vector4,\n WebGLRenderer,\n} from \"three\";\n\nexport class WCSHelper extends Object3D {\n private camera: Camera;\n private orthoCamera: OrthographicCamera;\n public size: number;\n\n constructor(camera: Camera) {\n super();\n\n this.camera = camera;\n this.size = 160;\n\n this.orthoCamera = new OrthographicCamera(-2, 2, 2, -2, 0, 4);\n this.orthoCamera.position.set(0, 0, 2);\n\n const matRed = new MeshBasicMaterial({ toneMapped: false, color: \"#aa0000\" });\n const matGreen = new MeshBasicMaterial({ toneMapped: false, color: \"#00aa00\" });\n const matBlue = new MeshBasicMaterial({ toneMapped: false, color: \"#0000aa\" });\n\n const spriteRed = this.getSpriteMaterial(matRed.color, \"X\");\n const spriteGreen = this.getSpriteMaterial(matGreen.color, \"Y\");\n const spriteBlue = this.getSpriteMaterial(matBlue.color, \"Z\");\n\n const lineGeometry = new CylinderGeometry(0.01, 0.01, 1, 3);\n lineGeometry.translate(0, 0.5, 0);\n\n const arrowGeometry = new CylinderGeometry(0, 0.1, 0.25, 12);\n arrowGeometry.translate(0, 0.625, 0);\n\n const axesMap = {\n X: [\n [new Mesh(arrowGeometry, matRed), [0.5, 0, 0], [0, 0, -Math.PI / 2]],\n [new Mesh(lineGeometry, matRed), [0, 0, 0], [0, 0, -Math.PI / 2]],\n [new Sprite(spriteRed), [1.55, 0, 0]],\n ],\n Y: [\n [new Mesh(arrowGeometry, matGreen), [0, 0.5, 0], null],\n [new Mesh(lineGeometry, matGreen), null, null],\n [new Sprite(spriteGreen), [0, 1.55, 0]],\n ],\n Z: [\n [new Mesh(arrowGeometry, matBlue), [0, 0, 0.5], [Math.PI / 2, 0, 0]],\n [new Mesh(lineGeometry, matBlue), null, [Math.PI / 2, 0, 0]],\n [new Sprite(spriteBlue), [0, 0, 1.55]],\n ],\n };\n\n Object.keys(axesMap).forEach((key) => {\n axesMap[key].forEach((objects: any) => {\n const object = objects[0];\n const position = objects[1];\n const rotation = objects[2];\n\n object.name = key;\n if (position) object.position.set(position[0], position[1], position[2]);\n if (rotation) object.rotation.set(rotation[0], rotation[1], rotation[2]);\n object.updateMatrixWorld();\n\n this.add(object);\n });\n });\n }\n\n dispose() {\n this.traverse((object: any) => {\n if (object.geometry) object.geometry.dispose();\n if (object.material) object.material.dispose();\n });\n }\n\n getSpriteMaterial(color: Color, text: string) {\n const canvas = document.createElement(\"canvas\");\n canvas.width = 64;\n canvas.height = 64;\n\n const context = canvas.getContext(\"2d\");\n context.clearRect(0, 0, 64, 64);\n context.font = \"24px Arial\";\n context.textAlign = \"center\";\n context.fillStyle = color.getStyle();\n context.fillText(text, 32, 41);\n\n const texture = new CanvasTexture(canvas);\n texture.colorSpace = SRGBColorSpace;\n\n return new SpriteMaterial({ map: texture, toneMapped: false });\n }\n\n render(renderer: WebGLRenderer) {\n this.quaternion.copy(this.camera.quaternion).invert();\n this.updateMatrixWorld();\n\n const clippingPlanes = renderer.clippingPlanes;\n const viewport = renderer.getViewport(new Vector4());\n\n renderer.setViewport(this.position.x, this.position.y, this.size, this.size);\n renderer.clippingPlanes = [];\n renderer.clearDepth();\n renderer.render(this, this.orthoCamera);\n\n renderer.setViewport(viewport);\n renderer.clippingPlanes = clippingPlanes;\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { IComponent } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\nimport { WCSHelper } from \"../helpers/WCSHelper\";\n\nexport class WCSHelperComponent implements IComponent {\n private wcsHelper: WCSHelper;\n private viewer: Viewer;\n\n constructor(viewer: Viewer) {\n this.wcsHelper = new WCSHelper(viewer.camera);\n this.viewer = viewer;\n this.viewer.addEventListener(\"databasechunk\", this.geometryEnd);\n this.viewer.addEventListener(\"drawviewpoint\", this.geometryEnd);\n this.viewer.addEventListener(\"render\", this.viewerRender);\n }\n\n dispose() {\n this.viewer.removeEventListener(\"databasechunk\", this.geometryEnd);\n this.viewer.removeEventListener(\"drawviewpoint\", this.geometryEnd);\n this.viewer.removeEventListener(\"render\", this.viewerRender);\n this.wcsHelper.dispose();\n }\n\n geometryEnd = () => {\n this.wcsHelper.dispose();\n this.wcsHelper = new WCSHelper(this.viewer.camera);\n };\n\n viewerRender = () => {\n if (!this.viewer.options.showWCS) return;\n\n this.wcsHelper.render(this.viewer.renderer);\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { IComponentsRegistry, componentsRegistry } from \"@inweb/viewer-core\";\n\nimport { BackgroundComponent } from \"./BackgroundComponent\";\nimport { CameraComponent } from \"./CameraComponent\";\nimport { ExtentsComponent } from \"./ExtentsComponent\";\nimport { LightComponent } from \"./LightComponent\";\nimport { RenderLoopComponent } from \"./RenderLoopComponent\";\nimport { ResizeCanvasComponent } from \"./ResizeCanvasComponent\";\nimport { HighlighterComponent } from \"./HighlighterComponent\";\nimport { SelectionComponent } from \"./SelectionComponent\";\nimport { WCSHelperComponent } from \"./WCSHelperComponent\";\n\n/**\n * Viewer components registry. Use this registry to register custom components.\n *\n * To implement custom component:\n *\n * 1. Define a component class implements {@link IComponent}.\n * 2. Define a constructor with a `viewer` parameter and add mouse event listeners for the specified viewer.\n * 3. Define the component logic in the event listeners. For example, listen for the `mousedown` event and\n * select objects when the left mouse button is pressed.\n * 4. Override {@link IComponent.dispose} and remove mouse event listeners from the viewer.\n * 5. Register component provider in the components registry by calling the\n * {@link components.registerComponent}.\n *\n * @example Implementing a custom component.\n *\n * ```javascript\n * import { IComponent, components, Viewer } from \"@inweb/viewer-three\";\n *\n * class MyComponent implements IComponent {\n * protected viewer: Viewer;\n *\n * constructor(viewer: Viewer) {\n * this.viewer = viewer;\n * this.viewer.addEventListener(\"mousedown\", this.onMouseDown);\n * }\n *\n * override dispose() {\n * this.viewer.removeEventListener(\"mousedown\", this.onMouseDown);\n * }\n *\n * onMouseDown = (event: PointerEvent) => {\n * // place custom logic here\n * };\n * }\n *\n * components.registerComponent(\"MyComponent\", (viewer): IComponent => new MyComponent(viewer));\n * ```\n */\nexport const components: IComponentsRegistry = componentsRegistry(\"threejs\");\n\n// build-in components\n\ncomponents.registerComponent(\"ExtentsComponent\", (viewer) => new ExtentsComponent(viewer));\ncomponents.registerComponent(\"CameraComponent\", (viewer) => new CameraComponent(viewer));\ncomponents.registerComponent(\"BackgroundComponent\", (viewer) => new BackgroundComponent(viewer));\ncomponents.registerComponent(\"LightComponent\", (viewer) => new LightComponent(viewer));\ncomponents.registerComponent(\"ResizeCanvasComponent\", (viewer) => new ResizeCanvasComponent(viewer));\ncomponents.registerComponent(\"RenderLoopComponent\", (viewer) => new RenderLoopComponent(viewer));\ncomponents.registerComponent(\"HighlighterComponent\", (viewer) => new HighlighterComponent(viewer));\ncomponents.registerComponent(\"SelectionComponent\", (viewer) => new SelectionComponent(viewer));\ncomponents.registerComponent(\"WCSHelperComponent\", (viewer) => new WCSHelperComponent(viewer));\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { LoadingManager, LoaderUtils } from \"three\";\n\nexport type GLTFFileSource = string | globalThis.File | ArrayBuffer | Blob;\n\nexport type GLTFLoadParams = {\n path?: string;\n externalFiles?: Map<string, GLTFFileSource>;\n requestHeader?: HeadersInit;\n crossOrigin?: string;\n withCredentials?: boolean;\n};\n\nexport class GLTFLoadingManager extends LoadingManager {\n public path = \"\";\n public resourcePath = \"\";\n public fileURL = \"\";\n public dataURLs = new Map();\n\n constructor(file: GLTFFileSource, params: GLTFLoadParams = {}) {\n super();\n\n this.path = params.path || \"\";\n\n const externalFiles = params.externalFiles || new Map();\n\n if (typeof file === \"string\") {\n this.fileURL = file;\n this.resourcePath = LoaderUtils.extractUrlBase(file);\n } else {\n externalFiles.forEach((value, key) => (this.fileURL = value === file ? key : this.fileURL));\n externalFiles.set(this.fileURL, file);\n }\n\n externalFiles.forEach((value, key) => {\n let dataURL: string;\n if (typeof value === \"string\") dataURL = value;\n else dataURL = URL.createObjectURL(new Blob([value]));\n this.dataURLs.set(key, dataURL);\n });\n\n this.setURLModifier((url: string) => {\n const key = decodeURI(url)\n .replace(this.path, \"\")\n .replace(this.resourcePath, \"\")\n .replace(/^(\\.?\\/)/, \"\");\n const dataURL = this.dataURLs.get(key);\n return dataURL ?? url;\n });\n }\n\n dispose() {\n this.dataURLs.forEach(URL.revokeObjectURL);\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { GLTFLoader } from \"three/examples/jsm/loaders/GLTFLoader.js\";\nimport { Loader } from \"@inweb/viewer-core\";\n\nimport { Viewer } from \"../Viewer\";\nimport { GLTFLoadingManager, GLTFLoadParams } from \"./GLTFLoadingManager\";\n\nexport class GLTFFileLoader extends Loader {\n public viewer: Viewer;\n\n constructor(viewer: Viewer) {\n super();\n this.viewer = viewer;\n }\n\n override isSupport(file: any, format?: string): boolean {\n return (\n (typeof file === \"string\" || file instanceof globalThis.File || file instanceof ArrayBuffer) &&\n /(gltf|glb)$/i.test(format)\n );\n }\n\n override async load(file: any, format?: string, params?: GLTFLoadParams): Promise<this> {\n const manager = new GLTFLoadingManager(file, params);\n\n const loader = new GLTFLoader(manager);\n loader.setPath(manager.path);\n loader.setCrossOrigin(params.crossOrigin || loader.crossOrigin);\n loader.setWithCredentials(params.withCredentials || loader.withCredentials);\n\n const progress = (event: ProgressEvent) => {\n const { lengthComputable, loaded, total } = event;\n const progress = lengthComputable ? loaded / total : 1;\n this.viewer.emitEvent({ type: \"geometryprogress\", data: progress, file });\n };\n\n const gltf = await loader.loadAsync(manager.fileURL, progress);\n if (!this.viewer.scene) return this;\n\n this.viewer.scene.add(gltf.scene);\n this.viewer.models.push(gltf.scene);\n\n this.viewer.syncOptions();\n this.viewer.syncOverlay();\n this.viewer.update();\n\n this.viewer.emitEvent({ type: \"databasechunk\", data: gltf.scene, file });\n\n return this;\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { GLTFLoader } from \"three/examples/jsm/loaders/GLTFLoader.js\";\nimport { Loader } from \"@inweb/viewer-core\";\n\nimport { Viewer } from \"../Viewer\";\nimport { GLTFLoadingManager } from \"./GLTFLoadingManager\";\n\nexport class GLTFCloudModelLoader extends Loader {\n public viewer: Viewer;\n\n constructor(viewer: Viewer) {\n super();\n this.viewer = viewer;\n }\n\n override isSupport(model: any): boolean {\n return (\n typeof model === \"object\" &&\n typeof model.database === \"string\" &&\n typeof model.downloadResource === \"function\" &&\n /.gltf$/i.test(model.database)\n );\n }\n\n override async load(model: any): Promise<this> {\n const url = `${model.httpClient.serverUrl}${model.path}/${model.database}`;\n const manager = new GLTFLoadingManager(url);\n\n const loader = new GLTFLoader(manager);\n loader.setRequestHeader(model.httpClient.headers);\n\n const progress = (event: ProgressEvent) => {\n const { lengthComputable, loaded, total } = event;\n const progress = lengthComputable ? loaded / total : 1;\n this.viewer.emitEvent({ type: \"geometryprogress\", data: progress, file: model.file, model });\n };\n\n const gltf = await loader.loadAsync(url, progress);\n if (!this.viewer.scene) return this;\n\n this.viewer.scene.add(gltf.scene);\n this.viewer.models.push(gltf.scene);\n\n this.viewer.syncOptions();\n this.viewer.syncOverlay();\n this.viewer.update();\n\n this.viewer.emitEvent({ type: \"databasechunk\", data: gltf.scene, file: model.file, model });\n\n return this;\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { ILoadersRegistry, loadersRegistry } from \"@inweb/viewer-core\";\n\nimport { GLTFFileLoader } from \"./GLTFFileLoader\";\nimport { GLTFCloudModelLoader } from \"./GLTFCloudModelLoader\";\n\n/**\n * Viewer loaders registry. Use this registry to register custom loaders.\n *\n * To implement custom loader:\n *\n * 1. Define a loader class implements {@link ILoader}.\n * 2. Define a constructor with a `viewer` parameter.\n * 3. Override {@link ILoader.isSupport} and сheck if the loader can load the specified file.\n * 4. Override {@link ILoader.load} and define the logic for loading the model from the file.\n *\n * The loader should do:\n *\n * - Load model from file. The model must be a Three.js object of type `Object3D` or a descendant of it.\n * - Add model to the viewer `scene` and `models` list.\n * - Synchronize viewer options and overlay.\n * - Update the viewer.\n *\n * The loader must emit events:\n *\n * - `geometryprogress` - during loading. If progress is not supported, emit it once with a value of 100%\n * after the load is complete.\n * - `databasechunk` - when model is loaded and ready to render.\n * 5. Override {@link ILoader.dispose} and release loader resources, if required.\n * 6. Register loader provider in the loaders registry by calling the {@link loaders.registerLoader}.\n *\n * @example Implementing a custom loader.\n *\n * ```javascript\n * import { Loader } from \"@inweb/viewer-core\";\n * import { loaders, Viewer } from \"@inweb/viewer-three\";\n *\n * class MyLoader extends Loader {\n * public viewer: Viewer;\n *\n * constructor(viewer: Viewer) {\n * super();\n * this.viewer = viewer;\n * }\n *\n * override isSupport(file, format): Boolean {\n * // place custom logic here\n * return ...;\n * }\n *\n * override load(file, format, params): Promise<this> {\n *\n * // place custom loading logic here\n * const model = ...;\n *\n * this.viewer.scene.add(model);\n * this.viewer.models.push(model);\n *\n * this.viewer.syncOptions();\n * this.viewer.syncOverlay();\n * this.viewer.update();\n *\n * this.viewer.emitEvent({ type: \"databasechunk\", data: model, file });\n *\n * return Promise.resove(this);\n * };\n * }\n *\n * loaders.registerLoader(\"MyLoader\", (viewer) => new MyLoader(viewer));\n * ```\n */\nexport const loaders: ILoadersRegistry = loadersRegistry(\"threejs\");\n\n// build-in loaders\n\nloaders.registerLoader(\"gltf-file\", (viewer: any) => new GLTFFileLoader(viewer));\nloaders.registerLoader(\"gltf-cloud-model\", (viewer: any) => new GLTFCloudModelLoader(viewer));\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport {\n Box3,\n LinearToneMapping,\n Object3D,\n OrthographicCamera,\n PerspectiveCamera,\n Plane,\n Scene,\n Sphere,\n Vector2,\n Vector3,\n WebGLRenderer,\n} from \"three\";\n\nimport { EventEmitter2 } from \"@inweb/eventemitter2\";\nimport { Assembly, Client, Model, File } from \"@inweb/client\";\nimport {\n CANVAS_EVENTS,\n CanvasEventMap,\n FileSource,\n IClippingPlane,\n IComponent,\n IEntity,\n IDragger,\n ILoader,\n IOptions,\n IOrthogonalCamera,\n IPerspectiveCamera,\n IPoint,\n IViewer,\n IViewpoint,\n Options,\n OptionsEventMap,\n ViewerEventMap,\n} from \"@inweb/viewer-core\";\nimport { IMarkup, IWorldTransform, Markup } from \"@inweb/markup\";\n\nimport { draggers } from \"./draggers\";\nimport { commands } from \"./commands\";\nimport { components } from \"./components\";\nimport { loaders } from \"./loaders\";\n\n/**\n * 3D viewer powered by {@link https://threejs.org/ | Three.js}.\n */\nexport class Viewer\n extends EventEmitter2<ViewerEventMap & CanvasEventMap & OptionsEventMap>\n implements IViewer, IWorldTransform\n{\n public client: Client | undefined;\n protected _options: Options;\n\n private canvaseventlistener: (event: any) => void;\n\n public canvas: HTMLCanvasElement | undefined;\n public canvasEvents: string[];\n\n public scene: Scene | undefined;\n public helpers: Scene | undefined;\n public camera: PerspectiveCamera | OrthographicCamera | undefined;\n public renderer: WebGLRenderer | undefined;\n public models: Array<Object3D>;\n public loaders: Array<ILoader>;\n public selected: Array<Object3D>;\n public extents: Box3;\n public target: Vector3;\n\n private _activeDragger: IDragger | null;\n private _components: Array<IComponent>;\n\n private renderNeeded: boolean;\n private renderTime: DOMHighResTimeStamp;\n\n private _markup: IMarkup;\n\n /**\n * @param client - The `Client` instance that is used to load model reference files from the Open Cloud\n * Server. Do not specify `Client` if you need a standalone viewer instance to view `glTF` files from\n * the web or from local computer.\n */\n constructor(client?: Client) {\n super();\n this._options = new Options(this);\n\n this.client = client;\n\n this.canvasEvents = CANVAS_EVENTS;\n this.canvaseventlistener = (event: Event) => this.emit(event);\n\n this.models = [];\n this.loaders = [];\n this.selected = [];\n this.extents = new Box3();\n this.target = new Vector3();\n\n this._activeDragger = null;\n this._components = [];\n\n this.renderTime = 0;\n\n this.render = this.render.bind(this);\n this.update = this.update.bind(this);\n\n this._markup = new Markup();\n }\n\n get options(): IOptions {\n return this._options;\n }\n\n get draggers(): string[] {\n return [...draggers.getDraggers().keys()];\n }\n\n get components(): string[] {\n return [...components.getComponents().keys()];\n }\n\n /**\n * 2D markup core instance used to create markups.\n *\n * @readonly\n */\n get markup(): IMarkup {\n return this._markup;\n }\n\n initialize(canvas: HTMLCanvasElement, onProgress?: (event: ProgressEvent<EventTarget>) => void): Promise<this> {\n this.addEventListener(\"optionschange\", (event) => this.syncOptions(event.data));\n\n this.scene = new Scene();\n this.helpers = new Scene();\n\n const rect = canvas.parentElement.getBoundingClientRect();\n const width = rect.width || 1;\n const height = rect.height || 1;\n const aspect = width / height;\n this.camera = new PerspectiveCamera(45, aspect, 0.01, 1000);\n this.camera.up.set(0, 0, 1);\n\n this.renderer = new WebGLRenderer({ canvas, antialias: true, preserveDrawingBuffer: true });\n this.renderer.setPixelRatio(window.devicePixelRatio);\n this.renderer.setSize(width, height);\n this.renderer.toneMapping = LinearToneMapping;\n\n this.canvas = canvas;\n this.canvasEvents.forEach((x) => canvas.addEventListener(x, this.canvaseventlistener));\n\n this._markup.initialize(this.canvas, this.canvasEvents, this, this);\n\n for (const name of components.getComponents().keys()) {\n this._components.push(components.createComponent(name, this));\n }\n\n this.syncOptions();\n this.syncOverlay();\n\n this.renderTime = performance.now();\n this.render(this.renderTime);\n\n if (typeof onProgress === \"function\")\n onProgress(new ProgressEvent(\"progress\", { lengthComputable: true, loaded: 1, total: 1 }));\n\n this.emitEvent({ type: \"initializeprogress\", data: 1, loaded: 1, total: 1 });\n this.emitEvent({ type: \"initialize\" });\n\n return Promise.resolve(this);\n }\n\n dispose(): this {\n this.cancel();\n this.clear();\n\n this.emitEvent({ type: \"dispose\" });\n this.removeAllListeners();\n\n this.setActiveDragger();\n\n this._components.forEach((component: IComponent) => component.dispose());\n this._components = [];\n\n this._markup.dispose();\n\n if (this.canvas) {\n this.canvasEvents.forEach((x) => this.canvas.removeEventListener(x, this.canvaseventlistener));\n this.canvas = undefined;\n }\n\n if (this.renderer) this.renderer.dispose();\n\n this.helpers = undefined;\n this.scene = undefined;\n this.renderer = undefined;\n this.camera = undefined;\n\n return this;\n }\n\n isInitialized(): boolean {\n return !!this.renderer;\n }\n\n public render(time: DOMHighResTimeStamp): void {\n if (!this.renderNeeded) return;\n if (!this.renderer) return;\n\n this.renderNeeded = false;\n\n this.renderer.setViewport(0, 0, this.canvas.offsetWidth, this.canvas.offsetHeight);\n this.renderer.autoClear = true;\n this.renderer.render(this.scene, this.camera);\n\n const clippingPlanes = this.renderer.clippingPlanes;\n this.renderer.clippingPlanes = [];\n this.renderer.autoClear = false;\n this.renderer.render(this.helpers, this.camera);\n this.renderer.clippingPlanes = clippingPlanes;\n\n this._activeDragger?.updatePreview?.();\n\n const deltaTime = (time - this.renderTime) / 1000;\n this.renderTime = time;\n this.emitEvent({ type: \"render\", time, deltaTime });\n }\n\n public update(force = false): void {\n this.renderNeeded = true;\n if (force) this.render(performance.now());\n this.emitEvent({ type: \"update\", data: force });\n }\n\n public syncOptions(options: IOptions = this.options): void {\n // this.update();\n }\n\n loadReferences(model: Model | File | Assembly): Promise<this> {\n // todo: load reference as text fonts\n return Promise.resolve(this);\n }\n\n /**\n * Loads a file into the viewer.\n *\n * The viewer must be {@link initialize | initialized} before opening the file. Otherwise, `open()` does\n * nothing.\n *\n * This method requires a `Client` instance to be specified to load file from the Open Cloud Server.\n * The file geometry data on the Open Cloud Server must be converted into a format siutable for the\n * viewer, otherwise an exception will be thrown.\n *\n * For files from Open Cloud Server, the default model will be loaded. If there is no default model,\n * first availiable model will be loaded. If no models are found in the file, an exception will be\n * thrown.\n *\n * The file extension is used to determine the file format. For a `ArrayBuffer`, `Blob` and `Data URL`,\n * a file format must be specified using `params.format` parameter (see below). If no appropriate\n * loader is found for the specified format, an exception will be thrown.\n *\n * If there was an active dragger before opening the file, it will be deactivated. After opening the\n * file, you must manually activate the required dragger.\n *\n * To open a large files, enable {@link IOptions.enablePartialMode | partial streaming} mode before\n * opening. For example:\n *\n * ```javascript\n * viewer.options.enableStreamingMode = true;\n * viewer.options.enablePartialMode = true;\n * await viewer.open(file);\n * ```\n *\n * Fires:\n *\n * - {@link OpenEvent | open}\n * - {@link GeometryStartEvent | geometrystart}\n * - {@link GeometryProgressEvent | geometryprogress}\n * - {@link DatabaseChunkEvent | databasechunk}\n * - {@link GeometryChunkEvent | geometrychunk}\n * - {@link GeometryEndEvent | geometryend}\n * - {@link GeometryErrorEvent | geometryerror}\n *\n * @param file - File to load.\n * @param params - Loading parameters.\n * @param params.format - File format string. Required when loading a file as `ArrayBuffer`, `Blob` or\n * `Data URL`.\n * @param params.mode - File opening mode. Can be one of:\n *\n * - `open` - Unloads an open file and opens a new one. This is default mode.\n * - `append` - Appends a file to an already open file.\n *\n * @param params.externalFiles - External resource map such as binary data buffers or textures. Each\n * resource should be represented by a `uri` and a corresponding resource URL, or\n * {@link https://developer.mozilla.org/docs/Web/API/File | Web API File} object, or\n * {@link https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/ArrayBuffer | ArrayBuffer},\n * or {@link https://developer.mozilla.org/docs/Web/API/Blob/Blob | Blob}, or\n * {@link https://developer.mozilla.org/docs/Web/HTTP/Basics_of_HTTP/Data_URIs | Data URL} string,\n * @param params.path - The base path from which additional resources will be loaded. If not defined,\n * the base path of the file URL will be used.\n * @param params.requestHeader - The\n * {@link https://developer.mozilla.org/docs/Glossary/Request_header | request header} used in HTTP\n * request.\n * @param params.crossOrigin - The crossOrigin string to implement CORS for loading the url from a\n * different domain that allows CORS. Default is `anonymous`.\n * @param params.withCredentials - Whether the XMLHttpRequest uses credentials such as cookies,\n * authorization headers or TLS client certificates. See\n * {@link https://developer.mozilla.org/docs/Web/API/XMLHttpRequest/withCredentials | XMLHttpRequest.withCredentials}.\n */\n async open(\n file: FileSource,\n params: {\n format?: string;\n mode?: string;\n path?: string;\n externalFiles?: Map<string, string | globalThis.File | ArrayBuffer | Blob>;\n requestHeader?: HeadersInit;\n crossOrigin?: string;\n withCredentials?: boolean;\n } = {}\n ): Promise<this> {\n if (!this.renderer) return this;\n\n if (params.mode !== \"a\" && params.mode !== \"append\") {\n this.cancel();\n this.clear();\n }\n\n this.emitEvent({ type: \"open\", file });\n\n let model: any = file;\n if (model && typeof model.getModels === \"function\") {\n const models = await model.getModels();\n model = models.find((model: Model) => model.default) || models[0] || file;\n }\n if (!model) throw new Error(`Format not supported`);\n\n let format = params.format;\n if (!format && typeof model.type === \"string\") format = model.type.split(\".\").pop();\n if (!format && typeof file === \"string\") format = file.split(\".\").pop();\n if (!format && file instanceof globalThis.File) format = file.name.split(\".\").pop();\n\n const loader = loaders.createLoader(this, model, format);\n if (!loader) throw new Error(`Format not supported`);\n this.loaders.push(loader);\n\n this.emitEvent({ type: \"geometrystart\", file, model });\n try {\n await this.loadReferences(model);\n await loader.load(model, format, params);\n } catch (error: any) {\n this.emitEvent({ type: \"geometryerror\", data: error, file, model });\n throw error;\n }\n this.emitEvent({ type: \"geometryend\", file, model });\n\n return this;\n }\n\n /**\n * Deprecated since `26.4`. Use {@link open | open()} instead.\n *\n * @deprecated\n */\n openGltfFile(file, externalFiles, params: any = {}): Promise<this> {\n return this.open(file, { ...params, format: \"gltf\", externalFiles });\n }\n\n /**\n * Deprecated since `26.4`. Use {@link open | open()} instead.\n *\n * @deprecated\n */\n loadGltfFile(file, externalFiles, params: any = {}): Promise<this> {\n return this.open(file, { ...params, format: \"gltf\", externalFiles, mode: \"append\" });\n }\n\n cancel(): this {\n this.loaders.forEach((loader) => loader.cancel());\n\n this.emitEvent({ type: \"cancel\" });\n return this;\n }\n\n clear(): this {\n if (!this.renderer) return this;\n\n function disposeMaterial(material: any) {\n const materials = Array.isArray(material) ? material : [material];\n materials.forEach((material: any) => material.dispose());\n }\n\n function disposeObject(object: any) {\n if (object.geometry) object.geometry.dispose();\n if (object.material) disposeMaterial(object.material);\n }\n\n this.setActiveDragger();\n this.clearSlices();\n this.clearOverlay();\n this.clearSelected();\n\n this.helpers.traverse(disposeObject);\n this.helpers.clear();\n\n this.models.forEach((model) => model.traverse(disposeObject));\n this.models.forEach((model) => model.removeFromParent());\n this.models = [];\n\n this.scene.clear();\n\n this.loaders.forEach((loader) => loader.dispose());\n this.loaders = [];\n\n this.syncOptions();\n this.syncOverlay();\n this.update(true);\n\n this.emitEvent({ type: \"clear\" });\n\n return this;\n }\n\n syncOverlay(): void {\n if (!this.renderer) return;\n\n this._markup.syncOverlay();\n this.update();\n }\n\n clearOverlay(): void {\n if (!this.renderer) return;\n\n this._markup.clearOverlay();\n this.update();\n }\n\n clearSlices(): void {\n if (!this.renderer) return;\n\n this.renderer.clippingPlanes = [];\n this.update();\n }\n\n getSelected(): string[] {\n return this.executeCommand(\"getSelected\");\n }\n\n setSelected(handles?: string[]): void {\n this.executeCommand(\"setSelected\", handles);\n }\n\n clearSelected(): void {\n this.executeCommand(\"clearSelected\");\n }\n\n hideSelected(): void {\n this.executeCommand(\"hideSelected\");\n }\n\n isolateSelected(): void {\n this.executeCommand(\"isolateSelected\");\n }\n\n showAll(): void {\n this.executeCommand(\"showAll\");\n }\n\n explode(index = 0): void {\n this.executeCommand(\"explode\", index);\n }\n\n collect(): void {\n this.executeCommand(\"collect\");\n }\n\n activeDragger(): IDragger | null {\n return this._activeDragger;\n }\n\n setActiveDragger(name = \"\"): IDragger | null {\n if (!this._activeDragger || this._activeDragger.name !== name) {\n const oldDragger = this._activeDragger;\n let newDragger = null;\n\n if (this._activeDragger) {\n this._activeDragger.dispose();\n this._activeDragger = null;\n }\n if (this.isInitialized()) {\n newDragger = draggers.createDragger(name, this);\n if (newDragger) {\n this._activeDragger = newDragger;\n this._activeDragger.initialize?.();\n }\n }\n\n const canvas = this.canvas;\n if (canvas) {\n if (oldDragger) canvas.classList.remove(`oda-cursor-${oldDragger.name.toLowerCase()}`);\n if (newDragger) canvas.classList.add(`oda-cursor-${newDragger.name.toLowerCase()}`);\n }\n\n this.emitEvent({ type: \"changeactivedragger\", data: name });\n this.update();\n }\n return this._activeDragger;\n }\n\n resetActiveDragger(): void {\n const dragger = this._activeDragger;\n if (dragger) {\n this.setActiveDragger();\n this.setActiveDragger(dragger.name);\n }\n }\n\n getComponent(name: string): IComponent {\n return this._components.find((component) => component.name === name);\n }\n\n is3D(): boolean {\n return true;\n }\n\n screenToWorld(position: { x: number; y: number }): { x: number; y: number; z: number } {\n if (!this.renderer) return { x: position.x, y: position.y, z: 0 };\n\n const rect = this.canvas.getBoundingClientRect();\n const x = position.x / (rect.width / 2) - 1;\n const y = -position.y / (rect.height / 2) + 1;\n\n const point = new Vector3(x, y, -1);\n point.unproject(this.camera);\n\n return { x: point.x, y: point.y, z: point.z };\n }\n\n worldToScreen(position: { x: number; y: number; z: number }): { x: number; y: number } {\n if (!this.renderer) return { x: position.x, y: position.y };\n\n const point = new Vector3(position.x, position.y, position.z);\n point.project(this.camera);\n\n const rect = this.canvas.getBoundingClientRect();\n const x = (point.x + 1) * (rect.width / 2);\n const y = (-point.y + 1) * (rect.height / 2);\n\n return { x, y };\n }\n\n getScale(): { x: number; y: number; z: number } {\n return { x: 1, y: 1, z: 1 };\n }\n\n executeCommand(id: string, ...args: any[]): any {\n return commands.executeCommand(id, this, ...args);\n }\n\n drawViewpoint(viewpoint: IViewpoint): void {\n if (!this.renderer) return;\n\n const getVector3FromPoint3d = ({ x, y, z }): Vector3 => new Vector3(x, y, z);\n\n const setOrthogonalCamera = (orthogonal_camera: IOrthogonalCamera) => {\n if (orthogonal_camera) {\n const extentsSize = this.extents.getBoundingSphere(new Sphere()).radius * 2;\n const rendererSize = this.renderer.getSize(new Vector2());\n const aspect = rendererSize.x / rendererSize.y;\n\n this.camera = new OrthographicCamera();\n this.camera.top = orthogonal_camera.field_height / 2;\n this.camera.bottom = -orthogonal_camera.field_height / 2;\n this.camera.left = this.camera.bottom * aspect;\n this.camera.right = this.camera.top * aspect;\n this.camera.near = 0;\n this.camera.far = extentsSize * 100;\n this.camera.zoom = orthogonal_camera.view_to_world_scale;\n this.camera.updateProjectionMatrix();\n\n this.camera.up.copy(getVector3FromPoint3d(orthogonal_camera.up_vector));\n this.camera.position.copy(getVector3FromPoint3d(orthogonal_camera.view_point));\n this.camera.lookAt(getVector3FromPoint3d(orthogonal_camera.direction).add(this.camera.position));\n this.camera.updateMatrixWorld();\n }\n };\n\n const setPerspectiveCamera = (perspective_camera: IPerspectiveCamera) => {\n if (perspective_camera) {\n const extentsSize = this.extents.getBoundingSphere(new Sphere()).radius * 2;\n const rendererSize = this.renderer.getSize(new Vector2());\n const aspect = rendererSize.x / rendererSize.y;\n\n this.camera = new PerspectiveCamera();\n this.camera.fov = perspective_camera.field_of_view;\n this.camera.aspect = aspect;\n this.camera.near = extentsSize / 100;\n this.camera.far = extentsSize * 100;\n this.camera.updateProjectionMatrix();\n\n this.camera.up.copy(getVector3FromPoint3d(perspective_camera.up_vector));\n this.camera.position.copy(getVector3FromPoint3d(perspective_camera.view_point));\n this.camera.lookAt(getVector3FromPoint3d(perspective_camera.direction).add(this.camera.position));\n this.camera.updateMatrixWorld();\n }\n };\n\n const setClippingPlanes = (clipping_planes: IClippingPlane[]) => {\n clipping_planes?.forEach((clipping_plane) => {\n const plane = new Plane();\n plane.setFromNormalAndCoplanarPoint(\n getVector3FromPoint3d(clipping_plane.direction),\n getVector3FromPoint3d(clipping_plane.location)\n );\n\n this.renderer.clippingPlanes.push(plane);\n });\n };\n\n const setSelection = (selection: IEntity[]) => {\n if (selection) this.setSelected(selection.map((component) => component.handle));\n };\n\n const draggerName = this._activeDragger?.name;\n\n this.setActiveDragger();\n this.clearSlices();\n this.clearOverlay();\n\n this.clearSelected();\n this.showAll();\n this.explode();\n\n setOrthogonalCamera(viewpoint.orthogonal_camera);\n setPerspectiveCamera(viewpoint.perspective_camera);\n setClippingPlanes(viewpoint.clipping_planes);\n setSelection(viewpoint.selection);\n this._markup.setViewpoint(viewpoint);\n\n this.target = getVector3FromPoint3d(viewpoint.custom_fields?.camera_target ?? this.target);\n\n this.setActiveDragger(draggerName);\n this.emitEvent({ type: \"drawviewpoint\", data: viewpoint });\n this.update();\n }\n\n createViewpoint(): IViewpoint {\n if (!this.renderer) return {};\n\n const getPoint3dFromVector3 = ({ x, y, z }): IPoint => ({ x, y, z });\n\n const getOrthogonalCamera = (): IOrthogonalCamera => {\n if (this.camera[\"isOrthographicCamera\"])\n return {\n view_point: getPoint3dFromVector3(this.camera.position),\n direction: getPoint3dFromVector3(this.camera.getWorldDirection(new Vector3())),\n up_vector: getPoint3dFromVector3(this.camera.up),\n field_width: this.camera[\"right\"] - this.camera[\"left\"],\n field_height: this.camera[\"top\"] - this.camera[\"bottom\"],\n view_to_world_scale: this.camera.zoom,\n };\n else return undefined;\n };\n\n const getPerspectiveCamera = (): IPerspectiveCamera => {\n if (this.camera[\"isPerspectiveCamera\"])\n return {\n view_point: getPoint3dFromVector3(this.camera.position),\n direction: getPoint3dFromVector3(this.camera.getWorldDirection(new Vector3())),\n up_vector: getPoint3dFromVector3(this.camera.up),\n field_of_view: this.camera[\"fov\"],\n };\n else return undefined;\n };\n\n const getClippingPlanes = (): IClippingPlane[] => {\n const clipping_planes = [];\n this.renderer.clippingPlanes.forEach((plane: Plane) => {\n const clipping_plane = {\n location: getPoint3dFromVector3(plane.coplanarPoint(new Vector3())),\n direction: getPoint3dFromVector3(plane.normal),\n };\n clipping_planes.push(clipping_plane);\n });\n return clipping_planes;\n };\n\n const getSelection = (): IEntity[] => {\n return this.getSelected().map((handle) => ({ handle }));\n };\n\n const viewpoint: IViewpoint = { custom_fields: {} };\n\n viewpoint.orthogonal_camera = getOrthogonalCamera();\n viewpoint.perspective_camera = getPerspectiveCamera();\n viewpoint.clipping_planes = getClippingPlanes();\n viewpoint.selection = getSelection();\n viewpoint.description = new Date().toDateString();\n this._markup.getViewpoint(viewpoint);\n\n viewpoint.custom_fields.camera_target = getPoint3dFromVector3(this.target);\n\n this.emitEvent({ type: \"createviewpoint\", data: viewpoint });\n\n return viewpoint;\n }\n}\n"],"names":["PlaneHelper","Line","constructor","plane","size","color","offset","Vector3","positions","geometry","BufferGeometry","setAttribute","Float32BufferAttribute","computeBoundingSphere","super","LineBasicMaterial","toneMapped","this","type","positions2","geometry2","helper","Mesh","MeshBasicMaterial","opacity","transparent","depthWrite","side","DoubleSide","add","dispose","material","children","updateMatrixWorld","force","position","set","lookAt","normal","copy","translateZ","dot","constant","scale","_changeEvent","_startEvent","_endEvent","STATE","NONE","ROTATE","DOLLY","PAN","TOUCH_ROTATE","TOUCH_PAN","TOUCH_DOLLY_PAN","TOUCH_DOLLY_ROTATE","OrbitControls","EventDispatcher","object","domElement","style","touchAction","enabled","target","minDistance","maxDistance","Infinity","minZoom","maxZoom","minPolarAngle","maxPolarAngle","Math","PI","minAzimuthAngle","maxAzimuthAngle","enableDamping","dampingFactor","enableZoom","zoomSpeed","enableRotate","rotateSpeed","enablePan","panSpeed","screenSpacePanning","keyPanSpeed","autoRotate","autoRotateSpeed","keys","LEFT","UP","RIGHT","BOTTOM","mouseButtons","MOUSE","MIDDLE","touches","ONE","TOUCH","TWO","DOLLY_PAN","target0","clone","position0","zoom0","zoom","_domElementKeyEvents","getPolarAngle","spherical","phi","getAzimuthalAngle","theta","getDistance","distanceTo","listenToKeyEvents","addEventListener","onKeyDown","stopListenToKeyEvents","removeEventListener","saveState","scope","reset","updateProjectionMatrix","dispatchEvent","update","state","quat","Quaternion","setFromUnitVectors","up","quatInverse","invert","lastPosition","lastQuaternion","lastTargetPosition","twoPI","sub","applyQuaternion","setFromVector3","rotateLeft","getAutoRotationAngle","sphericalDelta","min","max","isFinite","makeSafe","radius","addScaledVector","panOffset","setFromSpherical","multiplyScalar","zoomChanged","distanceToSquared","EPS","quaternion","onContextMenu","onPointerDown","onPointerUp","onMouseWheel","onPointerMove","Spherical","rotateStart","Vector2","rotateEnd","rotateDelta","panStart","panEnd","panDelta","dollyStart","dollyEnd","dollyDelta","dollyScale","pointers","pointerPositions","getZoomScale","pow","angle","rotateUp","panLeft","v","distance","objectMatrix","setFromMatrixColumn","panUp","crossVectors","pan","deltaX","deltaY","element","isPerspectiveCamera","targetDistance","length","tan","fov","clientHeight","matrix","isOrthographicCamera","right","left","clientWidth","top","bottom","console","warn","dollyOut","dollyIn","handleMouseDownRotate","event","clientX","clientY","handleMouseDownDolly","handleMouseDownPan","handleMouseMoveRotate","subVectors","x","y","handleMouseMoveDolly","handleMouseMovePan","handleMouseWheel","handleKeyDown","needsUpdate","code","ctrlKey","metaKey","shiftKey","preventDefault","handleTouchStartRotate","pageX","pageY","handleTouchStartPan","handleTouchStartDolly","dx","dy","sqrt","handleTouchStartDollyPan","handleTouchStartDollyRotate","handleTouchMoveRotate","getSecondPointerPosition","handleTouchMovePan","handleTouchMoveDolly","handleTouchMoveDollyPan","handleTouchMoveDollyRotate","setPointerCapture","pointerId","addPointer","pointerType","onTouchStart","onMouseDown","onTouchMove","onMouseMove","removePointer","releasePointerCapture","mouseAction","button","trackPointer","DOLLY_ROTATE","push","i","splice","undefined","pointer","passive","OrbitDragger","viewer","updateControls","orbit","camera","far","near","controlsStart","changed","controlsChange","emitEvent","dX","dY","data","stopContextMenu","stopPropagation","canvas","on","initialize","off","CuttingPlaneDragger","transformChange","planeCenter","transformDrag","value","viewerExplode","planeHelper","extents","getSize","onDoubleClick","negate","center","getCenter","Plane","renderer","clippingPlanes","helpers","Object3D","transform","TransformControls","showX","showY","showZ","z","attach","getHelper","removeFromParent","detach","CuttingPlaneXAxisDragger","CuttingPlaneYAxisDragger","CuttingPlaneZAxisDragger","PRECISION","MeasureLineDragger","line","startPoint","snapper","getSnapPoint","render","endPoint","MeasureLine","overlay","addLine","onPointerCancel","PointerEvent","onPointerLeave","renderOverlay","updateSnapper","scene","MeasureOverlay","MeasureSnapper","objects","raycaster","Raycaster","mouse","rect","getBoundingClientRect","width","height","coords","setFromCamera","params","threshold","Line2","LOD","Points","Sprite","intersects","intersectObjects","point","traverseVisible","child","lines","projector","MeasureProjector","container","document","createElement","id","background","outline","pointerEvents","overflow","parentElement","appendChild","clear","remove","forEach","removeLine","filter","_middlePoint","Date","now","unit","lineWidth","border","boxShadow","font","elementStartPoint","elementEndPoint","elementLine","elementLabel","visible","projectPoint","display","point1","point2","projectLine","lerpVectors","innerHTML","toFixed","zIndex","borderRadius","transformOrigin","padding","paddingInline","_widthHalf","_heightHalf","_viewMatrix","Matrix4","_viewProjectionMatrix","_vector","_vector1","Vector4","_vector2","matrixWorldInverse","multiplyMatrices","projectionMatrix","p","applyMatrix4","p1","p2","bc1near","w","bc2near","bc1far","bc2far","alpha1","alpha2","lerp","PanDragger","WalkControls","Controls","movementSpeed","lookSpeed","multiplier","moveWheel","mouseDragOn","downPosition","movePosition","rotateCamera","onWheel","moveKeys","onKeyUp","delete","Set","moveClock","Clock","window","timeDelta","getDelta","moveDelta","has","translateX","translateY","lookDelta","sign","stop","autoStart","delta","rotateX","rotateY","xRotation","setFromAxisAngle","yRotation","premultiply","multiply","normalize","setRotationFromQuaternion","WalkDragger","controls","walkspeedChange","viewerRender","viewerZoom","ZoomDragger","draggers","draggersRegistry","registerDragger","applyModelTransform","model","clearMarkup","clearOverlay","clearSelected","selection","getComponent","clearSelection","handles","clearSlices","createPreview","encoderOptions","toDataURL","calcExplodeDepth","depth","res","objectDepth","originalPosition","originalCenter","Box3","setFromObject","isExplodeLocked","explodeModel","coeff","explodeDepth","maxDepth","scaledExplodeDepth","currentSegmentFraction","explodeObject","objectScale","parentCenter","parent","objectCenter","objectOffset","explode","index","models","collect","zoomTo","box","isEmpty","sphere","getBoundingSphere","Sphere","rendererSize","aspect","MathUtils","DEG2RAD","defaultViewPositions","front","back","sw","se","ne","nw","setDefaultViewPosition","direction","emit","getDefaultViewPositions","Object","getModels","map","_a","userData","handle","getSelected","selected","SelectionComponent","isPrimary","getMousePosition","upPosition","getPointerIntersects","select","executeCommand","initHighlighter","highlighter","isSelected","highlight","unhighlight","hideSelected","isolateSelected","visibleSet","traverseAncestors","object2","traverse","regenerateAll","resetView","selectModel","setActiveDragger","dragger","setMarkupColor","r","g","b","markup","setSelected","handleSet","showAll","zoomToExtents","zoomToObjects","reduce","result","expandByObject","zoomToSelected","commands","commandsRegistry","registerCommand","registerCommandAlias","BackgroundComponent","syncOptions","backgroundColor","setHex","Color","setClearColor","CameraComponent","geometryEnd","extentsCenter","extentsSize","sceneCamera","isCamera","ExtentsComponent","syncExtents","LightComponent","ambientLight","directionalLight","frontLight","hemisphereLight","AmbientLight","DirectionalLight","HemisphereLight","RenderLoopComponent","animate","time","requestId","requestAnimationFrame","cancelAnimationFrame","ResizeCanvasComponent","resizeViewer","entries","contentRect","setSize","resizeObserver","ResizeObserver","observe","disconnect","HighlighterUtils","isBreak","isNaN","fromIndexedLine","indices","lineGeometry","LineSegmentsGeometry","segments","idx1","idx2","setPositions","fromNonIndexedLine","isLineSegments","lastValidIndex","HighlighterComponent","facesColor","facesTransparancy","edgesColor","options","highlightMaterial","depthTest","outlineMaterial","LineMaterial","linewidth","resolution","innerWidth","innerHeight","highlightLineMaterial","highlightLineGlowMaterial","optionsChange","setRGB","viewerResize","isHighlighted","isLine","attributes","array","wireframe","Wireframe","rotation","highlightwireframe","originalMaterial","isMesh","edgesGeometry","EdgesGeometry","fromEdgesGeometry","WCSHelper","orthoCamera","OrthographicCamera","matRed","matGreen","matBlue","spriteRed","getSpriteMaterial","spriteGreen","spriteBlue","CylinderGeometry","translate","arrowGeometry","axesMap","X","Y","Z","key","name","text","context","getContext","clearRect","textAlign","fillStyle","getStyle","fillText","texture","CanvasTexture","colorSpace","SRGBColorSpace","SpriteMaterial","viewport","getViewport","setViewport","clearDepth","WCSHelperComponent","wcsHelper","showWCS","components","componentsRegistry","registerComponent","GLTFLoadingManager","LoadingManager","file","path","resourcePath","fileURL","dataURLs","Map","externalFiles","LoaderUtils","extractUrlBase","dataURL","URL","createObjectURL","Blob","setURLModifier","url","decodeURI","replace","get","revokeObjectURL","GLTFFileLoader","Loader","isSupport","format","globalThis","File","ArrayBuffer","test","load","manager","loader","GLTFLoader","setPath","setCrossOrigin","crossOrigin","setWithCredentials","withCredentials","progress","lengthComputable","loaded","total","gltf","loadAsync","syncOverlay","GLTFCloudModelLoader","database","downloadResource","httpClient","serverUrl","setRequestHeader","headers","loaders","loadersRegistry","registerLoader","Viewer","EventEmitter2","client","_options","Options","canvasEvents","CANVAS_EVENTS","canvaseventlistener","_activeDragger","_components","renderTime","bind","_markup","Markup","getDraggers","getComponents","onProgress","Scene","PerspectiveCamera","WebGLRenderer","antialias","preserveDrawingBuffer","setPixelRatio","devicePixelRatio","toneMapping","LinearToneMapping","createComponent","performance","ProgressEvent","Promise","resolve","cancel","removeAllListeners","component","isInitialized","renderNeeded","offsetWidth","offsetHeight","autoClear","_b","updatePreview","deltaTime","loadReferences","open","mode","find","default","Error","split","pop","createLoader","error","openGltfFile","loadGltfFile","disposeMaterial","materials","Array","isArray","disposeObject","activeDragger","oldDragger","newDragger","createDragger","classList","toLowerCase","resetActiveDragger","is3D","screenToWorld","unproject","worldToScreen","project","getScale","args","drawViewpoint","viewpoint","getVector3FromPoint3d","setOrthogonalCamera","orthogonal_camera","field_height","view_to_world_scale","up_vector","view_point","setPerspectiveCamera","perspective_camera","field_of_view","setClippingPlanes","clipping_planes","clipping_plane","setFromNormalAndCoplanarPoint","location","setSelection","draggerName","setViewpoint","custom_fields","camera_target","_c","createViewpoint","getPoint3dFromVector3","getOrthogonalCamera","getWorldDirection","field_width","getPerspectiveCamera","getClippingPlanes","coplanarPoint","getSelection","description","toDateString","getViewpoint"],"mappings":"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"}
1
+ {"version":3,"file":"viewer-three.module.js","sources":["../src/Viewer/helpers/PlaneHelper.ts","../src/Viewer/controls/OrbitControls.js","../src/Viewer/draggers/OrbitDragger.ts","../src/Viewer/draggers/CuttingPlaneDragger.ts","../src/Viewer/draggers/CuttingPlaneXAxis.ts","../src/Viewer/draggers/CuttingPlaneYAxis.ts","../src/Viewer/draggers/CuttingPlaneZAxis.ts","../src/Viewer/draggers/MeasureLineDragger.ts","../src/Viewer/draggers/PanDragger.ts","../src/Viewer/controls/WalkControls.ts","../src/Viewer/draggers/WalkDragger.ts","../src/Viewer/draggers/ZoomDragger.ts","../src/Viewer/draggers/index.ts","../src/Viewer/commands/ApplyModelTransform.ts","../src/Viewer/commands/ClearMarkup.ts","../src/Viewer/commands/ClearSelected.ts","../src/Viewer/commands/ClearSlices.ts","../src/Viewer/commands/CreatePreview.ts","../src/Viewer/commands/Explode.ts","../src/Viewer/commands/ZoomTo.ts","../src/Viewer/commands/SetDefaultViewPosition.ts","../src/Viewer/commands/GetDefaultViewPositions.ts","../src/Viewer/commands/GetModels.ts","../src/Viewer/commands/GetSelected.ts","../src/Viewer/commands/HideSelected.ts","../src/Viewer/commands/IsolateSelected.ts","../src/Viewer/commands/RegenerateAll.ts","../src/Viewer/commands/ResetView.ts","../src/Viewer/commands/SelectModel.ts","../src/Viewer/commands/SetActiveDragger.ts","../src/Viewer/commands/SetMarkupColor.ts","../src/Viewer/commands/SetSelected.ts","../src/Viewer/commands/ShowAll.ts","../src/Viewer/commands/ZoomToExtents.ts","../src/Viewer/commands/ZoomToObjects.ts","../src/Viewer/commands/ZoomToSelected.ts","../src/Viewer/commands/index.ts","../src/Viewer/components/BackgroundComponent.ts","../src/Viewer/components/CameraComponent.ts","../src/Viewer/components/ExtentsComponent.ts","../src/Viewer/components/LightComponent.ts","../src/Viewer/components/RenderLoopComponent.ts","../src/Viewer/components/ResizeCanvasComponent.ts","../src/Viewer/components/HighlighterUtils.ts","../src/Viewer/components/HighlighterComponent.ts","../src/Viewer/components/SelectionComponent.ts","../src/Viewer/helpers/WCSHelper.ts","../src/Viewer/components/WCSHelperComponent.ts","../src/Viewer/components/index.ts","../src/Viewer/loaders/GLTFLoadingManager.ts","../src/Viewer/model/ModelImpl.ts","../src/Viewer/loaders/GLTFFileLoader.ts","../src/Viewer/loaders/DynamicGltfLoader/DynamicModelImpl.ts","../src/Viewer/loaders/DynamicGltfLoader/GltfStructure.js","../../../node_modules/three/examples/jsm/utils/BufferGeometryUtils.js","../src/Viewer/loaders/DynamicGltfLoader/DynamicGltfLoader.js","../src/Viewer/loaders/GLTFCloudDynamicLoader.ts","../src/Viewer/loaders/index.ts","../src/Viewer/Viewer.ts"],"sourcesContent":["///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport {\n BufferGeometry,\n DoubleSide,\n Float32BufferAttribute,\n Line,\n LineBasicMaterial,\n Mesh,\n MeshBasicMaterial,\n Object3D,\n Plane,\n Vector3,\n} from \"three\";\n\nclass PlaneHelper extends Line {\n public plane: Plane;\n public size: number;\n public offset: Vector3;\n public helper: Object3D;\n\n constructor(plane: Plane, size = 1, color = 0xffff00, offset: Vector3 = new Vector3()) {\n // const positions = [1, -1, 0, -1, 1, 0, -1, -1, 0, 1, 1, 0, -1, 1, 0, -1, -1, 0, 1, -1, 0, 1, 1, 0];\n const positions = [1, 1, 0, -1, 1, 0, -1, -1, 0, 1, -1, 0, 1, 1, 0];\n\n const geometry = new BufferGeometry();\n geometry.setAttribute(\"position\", new Float32BufferAttribute(positions, 3));\n geometry.computeBoundingSphere();\n\n super(geometry, new LineBasicMaterial({ color, toneMapped: false }));\n\n (this as any).type = \"PlaneHelper\";\n\n this.plane = plane;\n this.size = size;\n this.offset = offset;\n\n const positions2 = [1, 1, 0, -1, 1, 0, -1, -1, 0, 1, 1, 0, -1, -1, 0, 1, -1, 0];\n\n const geometry2 = new BufferGeometry();\n geometry2.setAttribute(\"position\", new Float32BufferAttribute(positions2, 3));\n geometry2.computeBoundingSphere();\n\n this.helper = new Mesh(\n geometry2,\n new MeshBasicMaterial({\n color,\n opacity: 0.2,\n transparent: true,\n depthWrite: false,\n toneMapped: false,\n side: DoubleSide,\n })\n );\n this.add(this.helper);\n }\n\n dispose() {\n this.geometry.dispose();\n (this.material as any).dispose();\n (this.children[0] as any).geometry.dispose();\n (this.children[0] as any).material.dispose();\n }\n\n override updateMatrixWorld(force: boolean) {\n this.position.set(0, 0, 0);\n this.lookAt(this.plane.normal);\n\n this.position.copy(this.offset);\n this.translateZ(-(this.offset.dot(this.plane.normal) + this.plane.constant));\n\n this.scale.set(0.5 * this.size, 0.5 * this.size, 1);\n\n super.updateMatrixWorld(force);\n }\n}\n\nexport { PlaneHelper };\n","import { EventDispatcher, MOUSE, Quaternion, Spherical, TOUCH, Vector2, Vector3 } from \"three\";\n\n// OrbitControls performs orbiting, dollying (zooming), and panning.\n// Unlike TrackballControls, it maintains the \"up\" direction object.up (+Y by default).\n//\n// Orbit - left mouse / touch: one-finger move\n// Zoom - middle mouse, or mousewheel / touch: two-finger spread or squish\n// Pan - right mouse, or left mouse + ctrl/meta/shiftKey, or arrow keys / touch: two-finger move\n\nconst _changeEvent = { type: \"change\" };\nconst _startEvent = { type: \"start\" };\nconst _endEvent = { type: \"end\" };\n\nconst STATE = {\n NONE: -1,\n ROTATE: 0,\n DOLLY: 1,\n PAN: 2,\n TOUCH_ROTATE: 3,\n TOUCH_PAN: 4,\n TOUCH_DOLLY_PAN: 5,\n TOUCH_DOLLY_ROTATE: 6,\n};\n\nclass OrbitControls extends EventDispatcher {\n constructor(object, domElement) {\n super();\n\n this.object = object;\n this.domElement = domElement;\n this.domElement.style.touchAction = \"none\"; // disable touch scroll\n\n // Set to false to disable this control\n this.enabled = true;\n\n // \"target\" sets the location of focus, where the object orbits around\n this.target = new Vector3();\n\n // How far you can dolly in and out ( PerspectiveCamera only )\n this.minDistance = 0;\n this.maxDistance = Infinity;\n\n // How far you can zoom in and out ( OrthographicCamera only )\n this.minZoom = 0;\n this.maxZoom = Infinity;\n\n // How far you can orbit vertically, upper and lower limits.\n // Range is 0 to Math.PI radians.\n this.minPolarAngle = 0; // radians\n this.maxPolarAngle = Math.PI; // radians\n\n // How far you can orbit horizontally, upper and lower limits.\n // If set, the interval [ min, max ] must be a sub-interval of [ - 2 PI, 2 PI ], with ( max - min < 2 PI )\n this.minAzimuthAngle = -Infinity; // radians\n this.maxAzimuthAngle = Infinity; // radians\n\n // Set to true to enable damping (inertia)\n // If damping is enabled, you must call controls.update() in your animation loop\n this.enableDamping = false;\n this.dampingFactor = 0.05;\n\n // This option actually enables dollying in and out; left as \"zoom\" for backwards compatibility.\n // Set to false to disable zooming\n this.enableZoom = true;\n this.zoomSpeed = 1.0;\n\n // Set to false to disable rotating\n this.enableRotate = true;\n this.rotateSpeed = 1.0;\n\n // Set to false to disable panning\n this.enablePan = true;\n this.panSpeed = 1.0;\n this.screenSpacePanning = true; // if false, pan orthogonal to world-space direction camera.up\n this.keyPanSpeed = 7.0; // pixels moved per arrow key push\n\n // Set to true to automatically rotate around the target\n // If auto-rotate is enabled, you must call controls.update() in your animation loop\n this.autoRotate = false;\n this.autoRotateSpeed = 2.0; // 30 seconds per orbit when fps is 60\n\n // The four arrow keys\n this.keys = { LEFT: \"ArrowLeft\", UP: \"ArrowUp\", RIGHT: \"ArrowRight\", BOTTOM: \"ArrowDown\" };\n\n // Mouse buttons\n this.mouseButtons = { LEFT: MOUSE.ROTATE, MIDDLE: MOUSE.DOLLY, RIGHT: MOUSE.PAN };\n\n // Touch fingers\n this.touches = { ONE: TOUCH.ROTATE, TWO: TOUCH.DOLLY_PAN };\n\n // for reset\n this.target0 = this.target.clone();\n this.position0 = this.object.position.clone();\n this.zoom0 = this.object.zoom;\n\n // the target DOM element for key events\n this._domElementKeyEvents = null;\n\n //\n // public methods\n //\n\n this.getPolarAngle = function () {\n return spherical.phi;\n };\n\n this.getAzimuthalAngle = function () {\n return spherical.theta;\n };\n\n this.getDistance = function () {\n return this.object.position.distanceTo(this.target);\n };\n\n this.listenToKeyEvents = function (domElement) {\n domElement.addEventListener(\"keydown\", onKeyDown);\n this._domElementKeyEvents = domElement;\n };\n\n this.stopListenToKeyEvents = function () {\n this._domElementKeyEvents.removeEventListener(\"keydown\", onKeyDown);\n this._domElementKeyEvents = null;\n };\n\n this.saveState = function () {\n scope.target0.copy(scope.target);\n scope.position0.copy(scope.object.position);\n scope.zoom0 = scope.object.zoom;\n };\n\n this.reset = function () {\n scope.target.copy(scope.target0);\n scope.object.position.copy(scope.position0);\n scope.object.zoom = scope.zoom0;\n\n scope.object.updateProjectionMatrix();\n scope.dispatchEvent(_changeEvent);\n\n scope.update();\n\n scope.state = STATE.NONE;\n };\n\n // this method is exposed, but perhaps it would be better if we can make it private...\n this.update = (function () {\n const offset = new Vector3();\n\n // so camera.up is the orbit axis\n const quat = new Quaternion().setFromUnitVectors(object.up, new Vector3(0, 1, 0));\n const quatInverse = quat.clone().invert();\n\n const lastPosition = new Vector3();\n const lastQuaternion = new Quaternion();\n const lastTargetPosition = new Vector3();\n\n const twoPI = 2 * Math.PI;\n\n return function update() {\n const position = scope.object.position;\n\n offset.copy(position).sub(scope.target);\n\n // rotate offset to \"y-axis-is-up\" space\n offset.applyQuaternion(quat);\n\n // angle from z-axis around y-axis\n spherical.setFromVector3(offset);\n\n if (scope.autoRotate && scope.state === STATE.NONE) {\n rotateLeft(getAutoRotationAngle());\n }\n\n if (scope.enableDamping) {\n spherical.theta += sphericalDelta.theta * scope.dampingFactor;\n spherical.phi += sphericalDelta.phi * scope.dampingFactor;\n } else {\n spherical.theta += sphericalDelta.theta;\n spherical.phi += sphericalDelta.phi;\n }\n\n // restrict theta to be between desired limits\n\n let min = scope.minAzimuthAngle;\n let max = scope.maxAzimuthAngle;\n\n if (isFinite(min) && isFinite(max)) {\n if (min < -Math.PI) min += twoPI;\n else if (min > Math.PI) min -= twoPI;\n\n if (max < -Math.PI) max += twoPI;\n else if (max > Math.PI) max -= twoPI;\n\n if (min <= max) {\n spherical.theta = Math.max(min, Math.min(max, spherical.theta));\n } else {\n spherical.theta =\n spherical.theta > (min + max) / 2 ? Math.max(min, spherical.theta) : Math.min(max, spherical.theta);\n }\n }\n\n // restrict phi to be between desired limits\n spherical.phi = Math.max(scope.minPolarAngle, Math.min(scope.maxPolarAngle, spherical.phi));\n\n spherical.makeSafe();\n\n spherical.radius *= scope.scale;\n\n // restrict radius to be between desired limits\n spherical.radius = Math.max(scope.minDistance, Math.min(scope.maxDistance, spherical.radius));\n\n // move target to panned location\n\n if (scope.enableDamping === true) {\n scope.target.addScaledVector(scope.panOffset, scope.dampingFactor);\n } else {\n scope.target.add(scope.panOffset);\n }\n\n offset.setFromSpherical(spherical);\n\n // rotate offset back to \"camera-up-vector-is-up\" space\n offset.applyQuaternion(quatInverse);\n\n position.copy(scope.target).add(offset);\n\n scope.object.lookAt(scope.target);\n\n if (scope.enableDamping === true) {\n sphericalDelta.theta *= 1 - scope.dampingFactor;\n sphericalDelta.phi *= 1 - scope.dampingFactor;\n\n scope.panOffset.multiplyScalar(1 - scope.dampingFactor);\n } else {\n sphericalDelta.set(0, 0, 0);\n\n scope.panOffset.set(0, 0, 0);\n }\n\n scope.scale = 1;\n\n // update condition is:\n // min(camera displacement, camera rotation in radians)^2 > EPS\n // using small-angle approximation cos(x/2) = 1 - x^2 / 8\n\n if (\n scope.zoomChanged ||\n lastPosition.distanceToSquared(scope.object.position) > EPS ||\n 8 * (1 - lastQuaternion.dot(scope.object.quaternion)) > EPS ||\n lastTargetPosition.distanceToSquared(scope.target) > 0\n ) {\n scope.dispatchEvent(_changeEvent);\n\n lastPosition.copy(scope.object.position);\n lastQuaternion.copy(scope.object.quaternion);\n lastTargetPosition.copy(scope.target);\n\n scope.zoomChanged = false;\n\n return true;\n }\n\n return false;\n };\n })();\n\n this.dispose = function () {\n scope.domElement.removeEventListener(\"contextmenu\", onContextMenu);\n\n scope.domElement.removeEventListener(\"pointerdown\", onPointerDown);\n scope.domElement.removeEventListener(\"pointercancel\", onPointerUp);\n scope.domElement.removeEventListener(\"wheel\", onMouseWheel);\n\n scope.domElement.removeEventListener(\"pointermove\", onPointerMove);\n scope.domElement.removeEventListener(\"pointerup\", onPointerUp);\n\n if (scope._domElementKeyEvents !== null) {\n scope._domElementKeyEvents.removeEventListener(\"keydown\", onKeyDown);\n scope._domElementKeyEvents = null;\n }\n\n //scope.dispatchEvent( { type: 'dispose' } ); // should this be added here?\n };\n\n //\n // internals\n //\n\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n const scope = this;\n\n scope.state = STATE.NONE;\n\n const EPS = 0.000001;\n\n // current position in spherical coordinates\n const spherical = new Spherical();\n const sphericalDelta = new Spherical();\n\n scope.scale = 1;\n scope.panOffset = new Vector3();\n scope.zoomChanged = false;\n\n scope.rotateStart = new Vector2();\n scope.rotateEnd = new Vector2();\n scope.rotateDelta = new Vector2();\n\n scope.panStart = new Vector2();\n scope.panEnd = new Vector2();\n scope.panDelta = new Vector2();\n\n scope.dollyStart = new Vector2();\n scope.dollyEnd = new Vector2();\n scope.dollyDelta = new Vector2();\n scope.dollyScale = 0;\n\n scope.pointers = [];\n scope.pointerPositions = {};\n\n function getAutoRotationAngle() {\n return ((2 * Math.PI) / 60 / 60) * scope.autoRotateSpeed;\n }\n\n function getZoomScale() {\n return Math.pow(0.95, scope.zoomSpeed);\n }\n\n function rotateLeft(angle) {\n sphericalDelta.theta -= angle;\n }\n\n function rotateUp(angle) {\n sphericalDelta.phi -= angle;\n }\n\n const panLeft = (function () {\n const v = new Vector3();\n\n return function panLeft(distance, objectMatrix) {\n v.setFromMatrixColumn(objectMatrix, 0); // get X column of objectMatrix\n v.multiplyScalar(-distance);\n\n scope.panOffset.add(v);\n };\n })();\n\n const panUp = (function () {\n const v = new Vector3();\n\n return function panUp(distance, objectMatrix) {\n if (scope.screenSpacePanning === true) {\n v.setFromMatrixColumn(objectMatrix, 1);\n } else {\n v.setFromMatrixColumn(objectMatrix, 0);\n v.crossVectors(scope.object.up, v);\n }\n\n v.multiplyScalar(distance);\n\n scope.panOffset.add(v);\n };\n })();\n\n // deltaX and deltaY are in pixels; right and down are positive\n const pan = (function () {\n const offset = new Vector3();\n\n return function pan(deltaX, deltaY) {\n const element = scope.domElement;\n\n if (scope.object.isPerspectiveCamera) {\n // perspective\n const position = scope.object.position;\n offset.copy(position).sub(scope.target);\n let targetDistance = offset.length();\n\n // half of the fov is center to top of screen\n targetDistance *= Math.tan(((scope.object.fov / 2) * Math.PI) / 180.0);\n\n // we use only clientHeight here so aspect ratio does not distort speed\n panLeft((2 * deltaX * targetDistance) / element.clientHeight, scope.object.matrix);\n panUp((2 * deltaY * targetDistance) / element.clientHeight, scope.object.matrix);\n } else if (scope.object.isOrthographicCamera) {\n // orthographic\n panLeft(\n (deltaX * (scope.object.right - scope.object.left)) / scope.object.zoom / element.clientWidth,\n scope.object.matrix\n );\n panUp(\n (deltaY * (scope.object.top - scope.object.bottom)) / scope.object.zoom / element.clientHeight,\n scope.object.matrix\n );\n } else {\n // camera neither orthographic nor perspective\n console.warn(\"WARNING: OrbitControls.js encountered an unknown camera type - pan disabled.\");\n scope.enablePan = false;\n }\n };\n })();\n\n function dollyOut(dollyScale) {\n if (scope.object.isPerspectiveCamera) {\n scope.scale /= dollyScale;\n } else if (scope.object.isOrthographicCamera) {\n scope.object.zoom = Math.max(scope.minZoom, Math.min(scope.maxZoom, scope.object.zoom * dollyScale));\n scope.object.updateProjectionMatrix();\n scope.zoomChanged = true;\n } else {\n console.warn(\"WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled.\");\n scope.enableZoom = false;\n }\n }\n\n function dollyIn(dollyScale) {\n if (scope.object.isPerspectiveCamera) {\n scope.scale *= dollyScale;\n } else if (scope.object.isOrthographicCamera) {\n scope.object.zoom = Math.max(scope.minZoom, Math.min(scope.maxZoom, scope.object.zoom / dollyScale));\n scope.object.updateProjectionMatrix();\n scope.zoomChanged = true;\n } else {\n console.warn(\"WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled.\");\n scope.enableZoom = false;\n }\n }\n\n //\n // event callbacks - update the object state\n //\n\n function handleMouseDownRotate(event) {\n scope.rotateStart.set(event.clientX, event.clientY);\n }\n\n function handleMouseDownDolly(event) {\n scope.dollyStart.set(event.clientX, event.clientY);\n }\n\n function handleMouseDownPan(event) {\n scope.panStart.set(event.clientX, event.clientY);\n }\n\n function handleMouseMoveRotate(event) {\n scope.rotateEnd.set(event.clientX, event.clientY);\n\n scope.rotateDelta.subVectors(scope.rotateEnd, scope.rotateStart).multiplyScalar(scope.rotateSpeed);\n\n const element = scope.domElement;\n\n rotateLeft((2 * Math.PI * scope.rotateDelta.x) / element.clientHeight); // yes, height\n\n rotateUp((2 * Math.PI * scope.rotateDelta.y) / element.clientHeight);\n\n scope.rotateStart.copy(scope.rotateEnd);\n\n scope.update();\n }\n\n function handleMouseMoveDolly(event) {\n scope.dollyEnd.set(event.clientX, event.clientY);\n\n scope.dollyDelta.subVectors(scope.dollyEnd, scope.dollyStart);\n\n if (scope.dollyDelta.y < 0) {\n scope.dollyScale = 1 / getZoomScale();\n dollyOut(getZoomScale());\n } else if (scope.dollyDelta.y > 0) {\n scope.dollyScale = getZoomScale();\n dollyIn(getZoomScale());\n }\n\n scope.dollyStart.copy(scope.dollyEnd);\n\n scope.update();\n }\n\n function handleMouseMovePan(event) {\n scope.panEnd.set(event.clientX, event.clientY);\n\n scope.panDelta.subVectors(scope.panEnd, scope.panStart).multiplyScalar(scope.panSpeed);\n\n pan(scope.panDelta.x, scope.panDelta.y);\n\n scope.panStart.copy(scope.panEnd);\n\n scope.update();\n }\n\n function handleMouseWheel(event) {\n scope.dollyEnd.set(scope.domElement.clientWidth / 2, scope.domElement.clientHeight / 2);\n\n scope.dollyDelta.set(event.deltaX, event.deltaY);\n\n if (event.deltaY < 0) {\n scope.dollyScale = 1 / getZoomScale();\n dollyIn(getZoomScale());\n } else if (event.deltaY > 0) {\n scope.dollyScale = getZoomScale();\n dollyOut(getZoomScale());\n }\n\n scope.dollyStart.copy(scope.dollyEnd);\n\n scope.update();\n\n if (event.deltaY !== 0) {\n scope.state = STATE.DOLLY;\n scope.dispatchEvent(_changeEvent);\n scope.state = STATE.NONE;\n }\n }\n\n function handleKeyDown(event) {\n let needsUpdate = false;\n\n switch (event.code) {\n case scope.keys.UP:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n rotateUp((2 * Math.PI * scope.rotateSpeed) / scope.domElement.clientHeight);\n } else {\n pan(0, scope.keyPanSpeed);\n }\n\n needsUpdate = true;\n break;\n\n case scope.keys.BOTTOM:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n rotateUp((-2 * Math.PI * scope.rotateSpeed) / scope.domElement.clientHeight);\n } else {\n pan(0, -scope.keyPanSpeed);\n }\n\n needsUpdate = true;\n break;\n\n case scope.keys.LEFT:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n rotateLeft((2 * Math.PI * scope.rotateSpeed) / scope.domElement.clientHeight);\n } else {\n pan(scope.keyPanSpeed, 0);\n }\n\n needsUpdate = true;\n break;\n\n case scope.keys.RIGHT:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n rotateLeft((-2 * Math.PI * scope.rotateSpeed) / scope.domElement.clientHeight);\n } else {\n pan(-scope.keyPanSpeed, 0);\n }\n\n needsUpdate = true;\n break;\n }\n\n if (needsUpdate) {\n // prevent the browser from scrolling on cursor keys\n event.preventDefault();\n\n scope.update();\n }\n }\n\n function handleTouchStartRotate() {\n if (scope.pointers.length === 1) {\n scope.rotateStart.set(scope.pointers[0].pageX, scope.pointers[0].pageY);\n } else {\n const x = 0.5 * (scope.pointers[0].pageX + scope.pointers[1].pageX);\n const y = 0.5 * (scope.pointers[0].pageY + scope.pointers[1].pageY);\n\n scope.rotateStart.set(x, y);\n }\n }\n\n function handleTouchStartPan() {\n if (scope.pointers.length === 1) {\n scope.panStart.set(scope.pointers[0].pageX, scope.pointers[0].pageY);\n } else {\n const x = 0.5 * (scope.pointers[0].pageX + scope.pointers[1].pageX);\n const y = 0.5 * (scope.pointers[0].pageY + scope.pointers[1].pageY);\n\n scope.panStart.set(x, y);\n }\n }\n\n function handleTouchStartDolly() {\n const dx = scope.pointers[0].pageX - scope.pointers[1].pageX;\n const dy = scope.pointers[0].pageY - scope.pointers[1].pageY;\n\n const distance = Math.sqrt(dx * dx + dy * dy);\n\n scope.dollyStart.set(0, distance);\n }\n\n function handleTouchStartDollyPan() {\n if (scope.enableZoom) handleTouchStartDolly();\n\n if (scope.enablePan) handleTouchStartPan();\n }\n\n function handleTouchStartDollyRotate() {\n if (scope.enableZoom) handleTouchStartDolly();\n\n if (scope.enableRotate) handleTouchStartRotate();\n }\n\n function handleTouchMoveRotate(event) {\n if (scope.pointers.length == 1) {\n scope.rotateEnd.set(event.pageX, event.pageY);\n } else {\n const position = getSecondPointerPosition(event);\n\n const x = 0.5 * (event.pageX + position.x);\n const y = 0.5 * (event.pageY + position.y);\n\n scope.rotateEnd.set(x, y);\n }\n\n scope.rotateDelta.subVectors(scope.rotateEnd, scope.rotateStart).multiplyScalar(scope.rotateSpeed);\n\n const element = scope.domElement;\n\n rotateLeft((2 * Math.PI * scope.rotateDelta.x) / element.clientHeight); // yes, height\n\n rotateUp((2 * Math.PI * scope.rotateDelta.y) / element.clientHeight);\n\n scope.rotateStart.copy(scope.rotateEnd);\n }\n\n function handleTouchMovePan(event) {\n if (scope.pointers.length === 1) {\n scope.panEnd.set(event.pageX, event.pageY);\n } else {\n const position = getSecondPointerPosition(event);\n\n const x = 0.5 * (event.pageX + position.x);\n const y = 0.5 * (event.pageY + position.y);\n\n scope.panEnd.set(x, y);\n }\n\n scope.panDelta.subVectors(scope.panEnd, scope.panStart).multiplyScalar(scope.panSpeed);\n\n pan(scope.panDelta.x, scope.panDelta.y);\n\n scope.panStart.copy(scope.panEnd);\n }\n\n function handleTouchMoveDolly(event) {\n const position = getSecondPointerPosition(event);\n\n const dx = event.pageX - position.x;\n const dy = event.pageY - position.y;\n\n const distance = Math.sqrt(dx * dx + dy * dy);\n\n scope.dollyEnd.set(0, distance);\n\n scope.dollyDelta.set(0, Math.pow(scope.dollyEnd.y / scope.dollyStart.y, scope.zoomSpeed));\n\n dollyOut(scope.dollyDelta.y);\n\n scope.dollyStart.copy(scope.dollyEnd);\n }\n\n function handleTouchMoveDollyPan(event) {\n if (scope.enableZoom) handleTouchMoveDolly(event);\n\n if (scope.enablePan) handleTouchMovePan(event);\n }\n\n function handleTouchMoveDollyRotate(event) {\n if (scope.enableZoom) handleTouchMoveDolly(event);\n\n if (scope.enableRotate) handleTouchMoveRotate(event);\n }\n\n //\n // event handlers - FSM: listen for events and reset state\n //\n\n function onPointerDown(event) {\n if (scope.enabled === false) return;\n\n if (scope.pointers.length === 0) {\n scope.domElement.setPointerCapture(event.pointerId);\n\n scope.domElement.addEventListener(\"pointermove\", onPointerMove);\n scope.domElement.addEventListener(\"pointerup\", onPointerUp);\n }\n\n //\n\n addPointer(event);\n\n if (event.pointerType === \"touch\") {\n onTouchStart(event);\n } else {\n onMouseDown(event);\n }\n }\n\n function onPointerMove(event) {\n if (scope.enabled === false) return;\n\n if (event.pointerType === \"touch\") {\n onTouchMove(event);\n } else {\n onMouseMove(event);\n }\n }\n\n function onPointerUp(event) {\n removePointer(event);\n\n if (scope.pointers.length === 0) {\n scope.domElement.releasePointerCapture(event.pointerId);\n\n scope.domElement.removeEventListener(\"pointermove\", onPointerMove);\n scope.domElement.removeEventListener(\"pointerup\", onPointerUp);\n }\n\n scope.dispatchEvent(_endEvent);\n\n scope.state = STATE.NONE;\n }\n\n function onMouseDown(event) {\n let mouseAction;\n\n switch (event.button) {\n case 0:\n mouseAction = scope.mouseButtons.LEFT;\n break;\n\n case 1:\n mouseAction = scope.mouseButtons.MIDDLE;\n break;\n\n case 2:\n mouseAction = scope.mouseButtons.RIGHT;\n break;\n\n default:\n mouseAction = -1;\n }\n\n switch (mouseAction) {\n case MOUSE.DOLLY:\n if (scope.enableZoom === false) return;\n\n handleMouseDownDolly(event);\n\n scope.state = STATE.DOLLY;\n\n break;\n\n case MOUSE.ROTATE:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n if (scope.enablePan === false) return;\n\n handleMouseDownPan(event);\n\n scope.state = STATE.PAN;\n } else {\n if (scope.enableRotate === false) return;\n\n handleMouseDownRotate(event);\n\n scope.state = STATE.ROTATE;\n }\n\n break;\n\n case MOUSE.PAN:\n if (event.ctrlKey || event.metaKey || event.shiftKey) {\n if (scope.enableRotate === false) return;\n\n handleMouseDownRotate(event);\n\n scope.state = STATE.ROTATE;\n } else {\n if (scope.enablePan === false) return;\n\n handleMouseDownPan(event);\n\n scope.state = STATE.PAN;\n }\n\n break;\n\n default:\n scope.state = STATE.NONE;\n }\n\n if (scope.state !== STATE.NONE) {\n scope.dispatchEvent(_startEvent);\n }\n }\n\n function onMouseMove(event) {\n switch (scope.state) {\n case STATE.ROTATE:\n if (scope.enableRotate === false) return;\n\n handleMouseMoveRotate(event);\n\n break;\n\n case STATE.DOLLY:\n if (scope.enableZoom === false) return;\n\n handleMouseMoveDolly(event);\n\n break;\n\n case STATE.PAN:\n if (scope.enablePan === false) return;\n\n handleMouseMovePan(event);\n\n break;\n }\n }\n\n function onMouseWheel(event) {\n if (scope.enabled === false || scope.enableZoom === false || scope.state !== STATE.NONE) return;\n\n event.preventDefault();\n\n scope.dispatchEvent(_startEvent);\n\n handleMouseWheel(event);\n\n scope.dispatchEvent(_endEvent);\n }\n\n function onKeyDown(event) {\n if (scope.enabled === false || scope.enablePan === false) return;\n\n handleKeyDown(event);\n }\n\n function onTouchStart(event) {\n trackPointer(event);\n\n switch (scope.pointers.length) {\n case 1:\n switch (scope.touches.ONE) {\n case TOUCH.ROTATE:\n if (scope.enableRotate === false) return;\n\n handleTouchStartRotate();\n\n scope.state = STATE.TOUCH_ROTATE;\n\n break;\n\n case TOUCH.PAN:\n if (scope.enablePan === false) return;\n\n handleTouchStartPan();\n\n scope.state = STATE.TOUCH_PAN;\n\n break;\n\n default:\n scope.state = STATE.NONE;\n }\n\n break;\n\n case 2:\n switch (scope.touches.TWO) {\n case TOUCH.DOLLY_PAN:\n if (scope.enableZoom === false && scope.enablePan === false) return;\n\n handleTouchStartDollyPan();\n\n scope.state = STATE.TOUCH_DOLLY_PAN;\n\n break;\n\n case TOUCH.DOLLY_ROTATE:\n if (scope.enableZoom === false && scope.enableRotate === false) return;\n\n handleTouchStartDollyRotate();\n\n scope.state = STATE.TOUCH_DOLLY_ROTATE;\n\n break;\n\n default:\n scope.state = STATE.NONE;\n }\n\n break;\n\n default:\n scope.state = STATE.NONE;\n }\n\n if (scope.state !== STATE.NONE) {\n scope.dispatchEvent(_startEvent);\n }\n }\n\n function onTouchMove(event) {\n trackPointer(event);\n\n switch (scope.state) {\n case STATE.TOUCH_ROTATE:\n if (scope.enableRotate === false) return;\n\n handleTouchMoveRotate(event);\n\n scope.update();\n\n break;\n\n case STATE.TOUCH_PAN:\n if (scope.enablePan === false) return;\n\n handleTouchMovePan(event);\n\n scope.update();\n\n break;\n\n case STATE.TOUCH_DOLLY_PAN:\n if (scope.enableZoom === false && scope.enablePan === false) return;\n\n handleTouchMoveDollyPan(event);\n\n scope.update();\n\n break;\n\n case STATE.TOUCH_DOLLY_ROTATE:\n if (scope.enableZoom === false && scope.enableRotate === false) return;\n\n handleTouchMoveDollyRotate(event);\n\n scope.update();\n\n break;\n\n default:\n scope.state = STATE.NONE;\n }\n }\n\n function onContextMenu(event) {\n if (scope.enabled === false) return;\n\n event.preventDefault();\n }\n\n function addPointer(event) {\n scope.pointers.push(event);\n }\n\n function removePointer(event) {\n delete scope.pointerPositions[event.pointerId];\n\n for (let i = 0; i < scope.pointers.length; i++) {\n if (scope.pointers[i].pointerId == event.pointerId) {\n scope.pointers.splice(i, 1);\n return;\n }\n }\n }\n\n function trackPointer(event) {\n let position = scope.pointerPositions[event.pointerId];\n\n if (position === undefined) {\n position = new Vector2();\n scope.pointerPositions[event.pointerId] = position;\n }\n\n position.set(event.pageX, event.pageY);\n }\n\n function getSecondPointerPosition(event) {\n const pointer = event.pointerId === scope.pointers[0].pointerId ? scope.pointers[1] : scope.pointers[0];\n\n return scope.pointerPositions[pointer.pointerId];\n }\n\n //\n\n scope.domElement.addEventListener(\"contextmenu\", onContextMenu);\n\n scope.domElement.addEventListener(\"pointerdown\", onPointerDown);\n scope.domElement.addEventListener(\"pointercancel\", onPointerUp);\n scope.domElement.addEventListener(\"wheel\", onMouseWheel, { passive: false });\n\n // force an update at start\n\n this.update();\n }\n}\n\nexport { OrbitControls, STATE };\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { MOUSE, TOUCH } from \"three\";\nimport { type IDragger } from \"@inweb/viewer-core\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { OrbitControls, STATE } from \"../controls/OrbitControls.js\";\n\nexport class OrbitDragger implements IDragger {\n protected viewer: Viewer;\n protected orbit: OrbitControls;\n protected changed: boolean;\n\n constructor(viewer: Viewer) {\n this.orbit = new OrbitControls(viewer.camera, viewer.canvas);\n this.orbit.mouseButtons = { LEFT: MOUSE.ROTATE, MIDDLE: MOUSE.PAN, RIGHT: MOUSE.PAN };\n this.orbit.touches = { ONE: TOUCH.ROTATE, TWO: TOUCH.DOLLY_PAN };\n this.orbit.screenSpacePanning = true;\n this.orbit.rotateSpeed = 0.33;\n this.orbit.addEventListener(\"start\", this.controlsStart);\n this.orbit.addEventListener(\"change\", this.controlsChange);\n this.changed = false;\n this.viewer = viewer;\n this.viewer.addEventListener(\"databasechunk\", this.updateControls);\n this.viewer.on(\"viewposition\", this.updateControls);\n this.viewer.addEventListener(\"zoom\", this.updateControls);\n this.viewer.addEventListener(\"drawviewpoint\", this.updateControls);\n this.viewer.addEventListener(\"contextmenu\", this.stopContextMenu);\n this.updateControls();\n }\n\n initialize() {}\n\n dispose(): void {\n this.viewer.removeEventListener(\"databasechunk\", this.updateControls);\n this.viewer.off(\"viewposition\", this.updateControls);\n this.viewer.removeEventListener(\"zoom\", this.updateControls);\n this.viewer.removeEventListener(\"drawviewpoint\", this.updateControls);\n this.viewer.removeEventListener(\"contextmenu\", this.stopContextMenu);\n\n this.orbit.removeEventListener(\"start\", this.controlsStart);\n this.orbit.removeEventListener(\"change\", this.controlsChange);\n this.orbit.dispose();\n }\n\n updateControls = () => {\n this.orbit.maxDistance = this.viewer.camera.far;\n this.orbit.minDistance = this.viewer.camera.near;\n this.orbit.object = this.viewer.camera;\n this.orbit.target.copy(this.viewer.target);\n this.orbit.update();\n };\n\n controlsStart = () => {\n this.changed = false;\n };\n\n controlsChange = () => {\n this.viewer.target.copy(this.orbit.target);\n this.viewer.update();\n\n switch (this.orbit.state) {\n case STATE.PAN:\n case STATE.TOUCH_PAN:\n this.viewer.emitEvent({\n type: \"pan\",\n x: this.orbit.panEnd.x,\n y: this.orbit.panEnd.y,\n dX: this.orbit.panDelta.x,\n dY: this.orbit.panDelta.y,\n });\n break;\n\n case STATE.DOLLY:\n this.viewer.emitEvent({\n type: \"zoomat\",\n data: this.orbit.dollyScale,\n x: this.orbit.dollyEnd.x,\n y: this.orbit.dollyEnd.y,\n });\n break;\n }\n\n this.changed = true;\n };\n\n stopContextMenu = (event: PointerEvent) => {\n if (this.changed) {\n event.preventDefault();\n event.stopPropagation();\n }\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Object3D, Plane, Vector3 } from \"three\";\nimport { TransformControls } from \"three/examples/jsm/controls/TransformControls.js\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { PlaneHelper } from \"../helpers/PlaneHelper\";\nimport { OrbitDragger } from \"./OrbitDragger\";\n\nexport class CuttingPlaneDragger extends OrbitDragger {\n protected plane: Plane;\n protected planeCenter: Object3D;\n protected planeHelper: PlaneHelper;\n protected transform: TransformControls;\n\n constructor(viewer: Viewer, normal: Vector3, color: number) {\n super(viewer);\n\n const size = viewer.extents.getSize(new Vector3()).length();\n const center = viewer.extents.getCenter(new Vector3());\n const constant = -center.dot(normal);\n\n this.plane = new Plane(normal, constant);\n\n if (!viewer.renderer.clippingPlanes) viewer.renderer.clippingPlanes = [];\n viewer.renderer.clippingPlanes.push(this.plane);\n\n this.planeHelper = new PlaneHelper(this.plane, size, color, center);\n this.viewer.helpers.add(this.planeHelper);\n\n this.planeCenter = new Object3D();\n this.planeCenter.position.copy(viewer.extents.getCenter(new Vector3()));\n this.viewer.helpers.add(this.planeCenter);\n\n this.transform = new TransformControls(viewer.camera, viewer.canvas);\n this.transform.showX = !!normal.x;\n this.transform.showY = !!normal.y;\n this.transform.showZ = !!normal.z;\n this.transform.attach(this.planeCenter);\n this.transform.addEventListener(\"change\", this.transformChange);\n this.transform.addEventListener(\"dragging-changed\", this.transformDrag);\n this.viewer.helpers.add(this.transform.getHelper());\n\n this.viewer.on(\"explode\", this.updatePlaneSize);\n this.viewer.on(\"show\", this.updatePlaneSize);\n this.viewer.on(\"showall\", this.updatePlaneSize);\n this.viewer.canvas.addEventListener(\"dblclick\", this.onDoubleClick, true);\n this.viewer.update();\n }\n\n override dispose() {\n this.viewer.off(\"explode\", this.updatePlaneSize);\n this.viewer.off(\"show\", this.updatePlaneSize);\n this.viewer.off(\"showAll\", this.updatePlaneSize);\n this.viewer.canvas.removeEventListener(\"dblclick\", this.onDoubleClick, true);\n\n this.transform.removeEventListener(\"change\", this.transformChange);\n this.transform.removeEventListener(\"dragging-changed\", this.transformDrag);\n this.transform.getHelper().removeFromParent();\n this.transform.detach();\n this.transform.dispose();\n\n this.planeHelper.removeFromParent();\n this.planeHelper.dispose();\n\n this.planeCenter.removeFromParent();\n\n // this.viewer.renderer.clippingPlanes = this.viewer.renderer.clippingPlanes.filter((plane) => plane !== this.plane);\n // this.viewer.update();\n\n super.dispose();\n }\n\n transformChange = () => {\n this.plane.constant = -this.planeCenter.position.dot(this.plane.normal);\n this.viewer.update();\n };\n\n transformDrag = (event) => {\n this.orbit.enabled = !event.value;\n };\n\n updatePlaneSize = () => {\n this.planeHelper.size = this.viewer.extents.getSize(new Vector3()).length();\n this.viewer.update();\n };\n\n onDoubleClick = (event: PointerEvent) => {\n event.stopPropagation();\n\n this.plane.negate();\n this.viewer.update();\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Vector3 } from \"three\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { CuttingPlaneDragger } from \"./CuttingPlaneDragger\";\n\nexport class CuttingPlaneXAxisDragger extends CuttingPlaneDragger {\n constructor(viewer: Viewer) {\n super(viewer, new Vector3(1, 0, 0), 0xff0000);\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Vector3 } from \"three\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { CuttingPlaneDragger } from \"./CuttingPlaneDragger\";\n\nexport class CuttingPlaneYAxisDragger extends CuttingPlaneDragger {\n constructor(viewer: Viewer) {\n super(viewer, new Vector3(0, 1, 0), 0x00ff00);\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Vector3 } from \"three\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { CuttingPlaneDragger } from \"./CuttingPlaneDragger\";\n\nexport class CuttingPlaneZAxisDragger extends CuttingPlaneDragger {\n constructor(viewer: Viewer) {\n super(viewer, new Vector3(0, 0, 1), 0x0000ff);\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Camera, Matrix4, Object3D, Scene, Raycaster, Vector2, Vector3, Vector4 } from \"three\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { OrbitDragger } from \"./OrbitDragger\";\n\nconst PRECISION = 0.01;\n\nexport class MeasureLineDragger extends OrbitDragger {\n private overlay: MeasureOverlay;\n private line: MeasureLine;\n private snapper: MeasureSnapper;\n\n constructor(viewer: Viewer) {\n super(viewer);\n\n this.overlay = new MeasureOverlay(viewer.camera, viewer.canvas);\n this.overlay.attach();\n\n this.line = new MeasureLine(this.overlay);\n this.overlay.addLine(this.line);\n\n this.snapper = new MeasureSnapper(viewer.camera, viewer.canvas);\n this.snapper.update(viewer.scene);\n\n this.viewer.canvas.addEventListener(\"pointerdown\", this.onPointerDown);\n this.viewer.canvas.addEventListener(\"pointermove\", this.onPointerMove);\n this.viewer.canvas.addEventListener(\"pointerup\", this.onPointerUp);\n this.viewer.canvas.addEventListener(\"pointercancel\", this.onPointerCancel);\n this.viewer.canvas.addEventListener(\"pointerleave\", this.onPointerLeave);\n\n this.viewer.addEventListener(\"render\", this.renderOverlay);\n this.viewer.addEventListener(\"hide\", this.updateSnapper);\n this.viewer.addEventListener(\"isolate\", this.updateSnapper);\n this.viewer.addEventListener(\"show\", this.updateSnapper);\n this.viewer.addEventListener(\"showall\", this.updateSnapper);\n }\n\n override dispose() {\n this.viewer.canvas.removeEventListener(\"pointerdown\", this.onPointerDown);\n this.viewer.canvas.removeEventListener(\"pointermove\", this.onPointerMove);\n this.viewer.canvas.removeEventListener(\"pointerup\", this.onPointerUp);\n this.viewer.canvas.removeEventListener(\"pointercancel\", this.onPointerCancel);\n this.viewer.canvas.removeEventListener(\"pointerleave\", this.onPointerLeave);\n\n this.viewer.removeEventListener(\"render\", this.renderOverlay);\n this.viewer.removeEventListener(\"hide\", this.updateSnapper);\n this.viewer.removeEventListener(\"isolate\", this.updateSnapper);\n this.viewer.removeEventListener(\"show\", this.updateSnapper);\n this.viewer.removeEventListener(\"showall\", this.updateSnapper);\n\n this.overlay.detach();\n this.overlay.dispose();\n\n super.dispose();\n }\n\n onPointerDown = (event: PointerEvent) => {\n if (event.button !== 0) return;\n\n this.line.startPoint = this.snapper.getSnapPoint(event);\n this.line.render();\n\n this.viewer.canvas.setPointerCapture(event.pointerId);\n this.orbit.enabled = !this.line.startPoint;\n };\n\n onPointerMove = (event: PointerEvent) => {\n if (this.orbit.enabled && this.orbit.state !== -1) return;\n\n this.line.endPoint = this.snapper.getSnapPoint(event);\n this.line.render();\n\n if (this.line.startPoint) this.changed = true; // <- to prevent context menu\n };\n\n onPointerUp = (event: PointerEvent) => {\n if (this.line.startPoint && this.line.endPoint && this.line.getDistance() >= PRECISION) {\n this.line = new MeasureLine(this.overlay);\n this.overlay.addLine(this.line);\n } else {\n this.line.startPoint = undefined;\n this.line.endPoint = undefined;\n this.line.render();\n }\n\n this.viewer.canvas.releasePointerCapture(event.pointerId);\n this.orbit.enabled = true;\n };\n\n onPointerCancel = (event: PointerEvent) => {\n this.viewer.canvas.dispatchEvent(new PointerEvent(\"pointerup\", event));\n };\n\n onPointerLeave = () => {\n this.line.endPoint = undefined;\n this.line.render();\n };\n\n renderOverlay = () => {\n this.overlay.render();\n };\n\n updateSnapper = () => {\n this.snapper.update(this.viewer.scene);\n };\n}\n\nclass MeasureSnapper {\n private camera: Camera;\n private canvas: HTMLCanvasElement;\n private objects: Object3D[] = [];\n private raycaster: Raycaster;\n\n constructor(camera: Camera, canvas: HTMLCanvasElement) {\n this.camera = camera;\n this.canvas = canvas;\n this.raycaster = new Raycaster();\n }\n\n getSnapPoint(event: PointerEvent): Vector3 | undefined {\n const mouse = new Vector2(event.clientX, event.clientY);\n\n const rect = this.canvas.getBoundingClientRect();\n const x = ((mouse.x - rect.left) / rect.width) * 2 - 1;\n const y = (-(mouse.y - rect.top) / rect.height) * 2 + 1;\n\n const coords = new Vector2(x, y);\n this.raycaster.setFromCamera(coords, this.camera);\n\n this.raycaster.params = {\n Mesh: {},\n Line: { threshold: 0.25 },\n Line2: { threshold: 0.25 },\n LOD: {},\n Points: { threshold: 0.1 },\n Sprite: {},\n };\n\n const intersects = this.raycaster.intersectObjects(this.objects, false);\n if (intersects.length === 0) return undefined;\n\n return intersects[0].point;\n }\n\n update(scene: Scene) {\n this.objects = [];\n scene.traverseVisible((child) => this.objects.push(child));\n }\n}\n\nclass MeasureOverlay {\n public camera: Camera;\n public canvas: HTMLCanvasElement;\n public container: HTMLElement;\n public lines: MeasureLine[] = [];\n public projector: MeasureProjector;\n\n constructor(camera: Camera, canvas: HTMLCanvasElement) {\n this.camera = camera;\n this.canvas = canvas;\n this.projector = new MeasureProjector(camera, canvas);\n }\n\n attach() {\n this.container = document.createElement(\"div\");\n this.container.id = \"measure-container\";\n this.container.style.background = \"rgba(0,0,0,0)\";\n this.container.style.position = \"absolute\";\n this.container.style.top = \"0px\";\n this.container.style.left = \"0px\";\n this.container.style.width = \"100%\";\n this.container.style.height = \"100%\";\n this.container.style.outline = \"none\";\n this.container.style.pointerEvents = \"none\";\n this.container.style.overflow = \"hidden\";\n\n this.canvas.parentElement.appendChild(this.container);\n }\n\n dispose() {\n this.clear();\n }\n\n detach() {\n this.container.remove();\n this.container = undefined;\n }\n\n clear() {\n this.lines.forEach((line) => line.dispose());\n this.lines = [];\n }\n\n render() {\n this.projector.updateProjectionMatrix();\n this.lines.forEach((line) => line.render());\n }\n\n update() {\n this.lines.forEach((line) => line.update());\n }\n\n addLine(line: MeasureLine) {\n this.lines.push(line);\n }\n\n removeLine(line: MeasureLine) {\n this.lines = this.lines.filter((x) => x !== line);\n }\n}\n\nconst _middlePoint = new Vector3();\n\nclass MeasureLine {\n private overlay: MeasureOverlay;\n\n private elementStartPoint: HTMLElement;\n private elementEndPoint: HTMLElement;\n private elementLine: HTMLElement;\n private elementLabel: HTMLElement;\n\n public startPoint: Vector3;\n public endPoint: Vector3;\n\n public id = Date.now();\n public unit = \"\";\n public scale = 1.0;\n public size = 10.0;\n public lineWidth = 2;\n\n public style = {\n border: \"2px solid #FFFFFF\",\n background: \"#009bff\",\n boxShadow: \"0 0 10px rgba(0,0,0,0.5)\",\n color: \"white\",\n font: \"1rem system-ui\",\n };\n\n constructor(overlay: MeasureOverlay) {\n this.overlay = overlay;\n\n this.elementStartPoint = overlay.container.appendChild(document.createElement(\"div\"));\n this.elementEndPoint = overlay.container.appendChild(document.createElement(\"div\"));\n this.elementLine = overlay.container.appendChild(document.createElement(\"div\"));\n this.elementLabel = overlay.container.appendChild(document.createElement(\"div\"));\n\n this.update();\n }\n\n dispose() {\n this.elementStartPoint.remove();\n this.elementEndPoint.remove();\n this.elementLine.remove();\n this.elementLabel.remove();\n }\n\n render() {\n const projector = this.overlay.projector;\n\n if (this.startPoint) {\n const { point, visible } = projector.projectPoint(this.startPoint);\n\n this.elementStartPoint.style.display = visible ? \"block\" : \"none\";\n this.elementStartPoint.style.left = `${point.x}px`;\n this.elementStartPoint.style.top = `${point.y}px`;\n } else {\n this.elementStartPoint.style.display = \"none\";\n }\n\n if (this.endPoint) {\n const { point, visible } = projector.projectPoint(this.endPoint);\n\n this.elementEndPoint.style.display = visible ? \"block\" : \"none\";\n this.elementEndPoint.style.left = `${point.x}px`;\n this.elementEndPoint.style.top = `${point.y}px`;\n } else {\n this.elementEndPoint.style.display = \"none\";\n }\n\n if (this.startPoint && this.endPoint) {\n const { point1, point2, visible } = projector.projectLine(this.startPoint, this.endPoint);\n\n point2.sub(point1);\n const angle = point2.angle();\n const width = point2.length();\n\n this.elementLine.style.display = visible ? \"block\" : \"none\";\n this.elementLine.style.left = `${point1.x}px`;\n this.elementLine.style.top = `${point1.y}px`;\n this.elementLine.style.width = `${width}px`;\n this.elementLine.style.transform = `translate(0px, ${-this.lineWidth / 2}px) rotate(${angle}rad)`;\n } else {\n this.elementLine.style.display = \"none\";\n }\n\n if (this.startPoint && this.endPoint) {\n _middlePoint.lerpVectors(this.startPoint, this.endPoint, 0.5);\n const { point, visible } = projector.projectPoint(_middlePoint);\n\n const distance = this.getDistance();\n\n this.elementLabel.style.display = visible && distance >= PRECISION ? \"block\" : \"none\";\n this.elementLabel.style.left = `${point.x}px`;\n this.elementLabel.style.top = `${point.y}px`;\n this.elementLabel.innerHTML = `${distance.toFixed(2)} ${this.unit}`;\n } else {\n this.elementLabel.style.display = \"none\";\n }\n }\n\n update() {\n this.elementStartPoint.id = `markup-dot-start-${this.id}`;\n this.elementStartPoint.style.position = \"absolute\";\n this.elementStartPoint.style.zIndex = \"2\";\n this.elementStartPoint.style.width = `${this.size}px`;\n this.elementStartPoint.style.height = `${this.size}px`;\n this.elementStartPoint.style.border = this.style.border;\n this.elementStartPoint.style.borderRadius = `${this.size}px`;\n this.elementStartPoint.style.background = this.style.background;\n this.elementStartPoint.style.boxShadow = this.style.boxShadow;\n this.elementStartPoint.style.transform = \"translate(-50%, -50%)\";\n\n this.elementEndPoint.id = `markup-dot-end-${this.id}`;\n this.elementEndPoint.style.position = \"absolute\";\n this.elementEndPoint.style.zIndex = \"2\";\n this.elementEndPoint.style.width = `${this.size}px`;\n this.elementEndPoint.style.height = `${this.size}px`;\n this.elementEndPoint.style.border = this.style.border;\n this.elementEndPoint.style.borderRadius = `${this.size}px`;\n this.elementEndPoint.style.background = this.style.background;\n this.elementEndPoint.style.boxShadow = this.style.boxShadow;\n this.elementEndPoint.style.transform = \"translate(-50%, -50%)\";\n\n this.elementLine.id = `markup-line-${this.id}`;\n this.elementLine.style.position = \"absolute\";\n this.elementLine.style.zIndex = \"1\";\n this.elementLine.style.height = `${this.lineWidth}px`;\n this.elementLine.style.background = this.style.background;\n this.elementLine.style.boxShadow = this.style.boxShadow;\n this.elementLine.style.transformOrigin = `0px ${this.lineWidth / 2}px`;\n\n this.elementLabel.id = `markup-label-${this.id}`;\n this.elementLabel.style.position = \"absolute\";\n this.elementLabel.style.zIndex = \"3\";\n this.elementLabel.style.padding = \"2px\";\n this.elementLabel.style.paddingInline = \"5px\";\n this.elementLabel.style.borderRadius = \"5px\";\n this.elementLabel.style.background = this.style.background;\n this.elementLabel.style.boxShadow = this.style.boxShadow;\n this.elementLabel.style.color = this.style.color;\n this.elementLabel.style.font = this.style.font;\n this.elementLabel.style.transform = \"translate(-50%, -50%)\";\n }\n\n getDistance(): number {\n return this.startPoint.distanceTo(this.endPoint) / this.scale;\n }\n}\n\nlet _widthHalf: number;\nlet _heightHalf: number;\nconst _viewMatrix = new Matrix4();\nconst _viewProjectionMatrix = new Matrix4();\nconst _vector = new Vector3();\nconst _vector1 = new Vector4();\nconst _vector2 = new Vector4();\nconst point = new Vector2();\nconst point1 = new Vector2();\nconst point2 = new Vector2();\n\nclass MeasureProjector {\n private camera: Camera;\n private canvas: HTMLElement;\n\n constructor(camera: Camera, canvas: HTMLCanvasElement) {\n this.camera = camera;\n this.canvas = canvas;\n }\n\n updateProjectionMatrix() {\n const rect = this.canvas.getBoundingClientRect();\n _widthHalf = rect.width / 2;\n _heightHalf = rect.height / 2;\n\n _viewMatrix.copy(this.camera.matrixWorldInverse);\n _viewProjectionMatrix.multiplyMatrices(this.camera.projectionMatrix, _viewMatrix);\n }\n\n projectPoint(p: Vector3) {\n _vector.copy(p).applyMatrix4(_viewProjectionMatrix);\n const visible = _vector.z >= -1 && _vector.z <= 1;\n\n point.x = (_vector.x + 1) * _widthHalf;\n point.y = (-_vector.y + 1) * _heightHalf;\n\n return { point, visible };\n }\n\n projectLine(p1: Vector3, p2: Vector3) {\n let visible: boolean;\n\n _vector1.copy(p1 as any).applyMatrix4(_viewProjectionMatrix);\n _vector2.copy(p2 as any).applyMatrix4(_viewProjectionMatrix);\n\n // see three/examples/jsm/renderers/Projector.js/clipLine for more details\n\n const bc1near = _vector1.z + _vector1.w;\n const bc2near = _vector2.z + _vector2.w;\n const bc1far = -_vector1.z + _vector1.w;\n const bc2far = -_vector2.z + _vector2.w;\n\n if (bc1near >= 0 && bc2near >= 0 && bc1far >= 0 && bc2far >= 0) visible = true;\n else if ((bc1near < 0 && bc2near < 0) || (bc1far < 0 && bc2far < 0)) visible = false;\n else {\n let alpha1 = 0;\n let alpha2 = 1;\n\n if (bc1near < 0) alpha1 = Math.max(alpha1, bc1near / (bc1near - bc2near));\n else if (bc2near < 0) alpha2 = Math.min(alpha2, bc1near / (bc1near - bc2near));\n\n if (bc1far < 0) alpha1 = Math.max(alpha1, bc1far / (bc1far - bc2far));\n else if (bc2far < 0) alpha2 = Math.min(alpha2, bc1far / (bc1far - bc2far));\n\n visible = alpha2 >= alpha1;\n\n if (visible) {\n _vector1.lerp(_vector2, alpha1);\n _vector2.lerp(_vector1, 1 - alpha2);\n }\n }\n\n _vector1.multiplyScalar(1 / _vector1.w);\n _vector2.multiplyScalar(1 / _vector2.w);\n\n point1.x = (_vector1.x + 1) * _widthHalf;\n point1.y = (-_vector1.y + 1) * _heightHalf;\n\n point2.x = (_vector2.x + 1) * _widthHalf;\n point2.y = (-_vector2.y + 1) * _heightHalf;\n\n return { point1, point2, visible };\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { MOUSE } from \"three\";\n\nimport { OrbitDragger } from \"./OrbitDragger\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class PanDragger extends OrbitDragger {\n constructor(viewer: Viewer) {\n super(viewer);\n this.orbit.mouseButtons = { LEFT: MOUSE.PAN, MIDDLE: MOUSE.PAN, RIGHT: MOUSE.PAN };\n // this.controls.touches = { ONE: TOUCH.PAN, TWO: TOUCH.DOLLY_ROTATE };\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Clock, Camera, Controls, Quaternion, Vector2, Vector3 } from \"three\";\n\ninterface WalkControlsEventMap {\n change: { type: \"change\" };\n walkspeedchange: { type: \"walkspeedchange\"; data: number };\n}\n\nexport class WalkControls extends Controls<WalkControlsEventMap> {\n public movementSpeed = 0.2;\n public lookSpeed = 5;\n public multiplier = 5;\n\n private moveKeys: Set<string>;\n private moveWheel = 0;\n private moveClock: Clock;\n\n private quaternion: Quaternion;\n private downPosition: Vector2;\n private mouseDragOn = false;\n public rotateDelta: Vector2;\n\n constructor(camera: Camera, canvas: HTMLElement) {\n super(camera, canvas);\n\n this.moveKeys = new Set();\n this.moveClock = new Clock();\n\n this.quaternion = camera.quaternion.clone();\n this.downPosition = new Vector2(0, 0);\n this.rotateDelta = new Vector2(0, 0);\n\n this.domElement.addEventListener(\"pointerdown\", this.onPointerDown);\n this.domElement.addEventListener(\"pointermove\", this.onPointerMove);\n this.domElement.addEventListener(\"pointerup\", this.onPointerUp);\n this.domElement.addEventListener(\"pointercancel\", this.onPointerCancel);\n this.domElement.addEventListener(\"wheel\", this.onWheel);\n\n window.addEventListener(\"keydown\", this.onKeyDown);\n window.addEventListener(\"keyup\", this.onKeyUp);\n }\n\n override dispose() {\n this.domElement.removeEventListener(\"pointerdown\", this.onPointerDown);\n this.domElement.removeEventListener(\"pointermove\", this.onPointerMove);\n this.domElement.removeEventListener(\"pointerup\", this.onPointerUp);\n this.domElement.removeEventListener(\"pointercancel\", this.onPointerCancel);\n this.domElement.removeEventListener(\"wheel\", this.onWheel);\n\n window.removeEventListener(\"keydown\", this.onKeyDown);\n window.removeEventListener(\"keyup\", this.onKeyUp);\n\n super.dispose();\n }\n\n onPointerDown = (event: PointerEvent) => {\n if (event.button !== 0) return;\n\n this.domElement.setPointerCapture(event.pointerId);\n this.downPosition.set(event.clientX, event.clientY);\n this.quaternion.copy(this.object.quaternion);\n this.mouseDragOn = true;\n };\n\n onPointerMove = (event: PointerEvent) => {\n if (!this.mouseDragOn) return;\n\n const movePosition = new Vector2(event.clientX, event.clientY);\n if (this.downPosition.distanceTo(movePosition) === 0) return;\n\n this.rotateDelta.copy(this.downPosition).sub(movePosition);\n this.rotateCamera(this.rotateDelta);\n this.dispatchEvent({ type: \"change\" });\n };\n\n onPointerUp = (event: PointerEvent) => {\n this.domElement.releasePointerCapture(event.pointerId);\n this.mouseDragOn = false;\n };\n\n onPointerCancel = (event: PointerEvent) => {\n this.domElement.dispatchEvent(new PointerEvent(\"pointerup\", event));\n };\n\n onWheel = (event: WheelEvent) => {\n this.moveWheel = event.deltaY;\n this.update();\n };\n\n onKeyDown = (event: KeyboardEvent) => {\n switch (event.code) {\n case \"NumpadSubtract\":\n case \"Minus\":\n if (this.multiplier > 1) {\n this.multiplier = this.multiplier - 1;\n this.dispatchEvent({ type: \"walkspeedchange\", data: this.multiplier });\n }\n break;\n\n case \"NumpadAdd\":\n case \"Equal\":\n if (this.multiplier < 10) {\n this.multiplier = this.multiplier + 1;\n this.dispatchEvent({ type: \"walkspeedchange\", data: this.multiplier });\n }\n break;\n\n case \"ArrowLeft\":\n case \"ArrowRight\":\n case \"ArrowUp\":\n case \"ArrowDown\":\n case \"KeyW\":\n case \"KeyS\":\n case \"KeyA\":\n case \"KeyD\":\n case \"KeyQ\":\n case \"KeyE\":\n this.moveKeys.add(event.code);\n this.update();\n break;\n }\n };\n\n onKeyUp = (event: KeyboardEvent) => {\n if (this.moveKeys.delete(event.code)) this.update();\n };\n\n override update() {\n if (this.moveKeys.size > 0) {\n const timeDelta = this.moveClock.getDelta();\n const moveDelta = timeDelta * this.movementSpeed * this.multiplier;\n\n if (this.moveKeys.has(\"KeyW\")) this.object.translateZ(-moveDelta);\n if (this.moveKeys.has(\"KeyS\")) this.object.translateZ(moveDelta);\n\n if (this.moveKeys.has(\"KeyA\")) this.object.translateX(-moveDelta);\n if (this.moveKeys.has(\"KeyD\")) this.object.translateX(moveDelta);\n\n if (this.moveKeys.has(\"KeyQ\")) this.object.translateY(moveDelta);\n if (this.moveKeys.has(\"KeyE\")) this.object.translateY(-moveDelta);\n\n const lookDelta = this.lookSpeed + (this.multiplier - 1);\n\n if (this.moveKeys.has(\"ArrowUp\")) this.rotateCamera(this.rotateDelta.add(new Vector2(0, -lookDelta / 2)));\n if (this.moveKeys.has(\"ArrowDown\")) this.rotateCamera(this.rotateDelta.add(new Vector2(0, lookDelta / 2)));\n\n if (this.moveKeys.has(\"ArrowLeft\")) this.rotateCamera(this.rotateDelta.add(new Vector2(lookDelta, 0)));\n if (this.moveKeys.has(\"ArrowRight\")) this.rotateCamera(this.rotateDelta.add(new Vector2(-lookDelta, 0)));\n\n this.moveWheel = 0;\n this.dispatchEvent({ type: \"change\" });\n }\n\n if (this.moveWheel !== 0) {\n const moveDelta = this.moveWheel * 0.0001 * this.movementSpeed * this.multiplier;\n\n this.object.translateZ(-moveDelta);\n this.moveWheel += -1 * Math.sign(this.moveWheel);\n this.dispatchEvent({ type: \"change\" });\n }\n\n if (this.moveKeys.size === 0 && this.moveWheel === 0) {\n this.moveClock.stop();\n this.moveClock.autoStart = true;\n }\n }\n\n rotateCamera(delta: Vector2) {\n const rotateX = (Math.PI * delta.x) / this.domElement.clientWidth;\n const rotateY = (Math.PI * delta.y) / this.domElement.clientHeight;\n\n const xRotation = new Quaternion();\n xRotation.setFromAxisAngle(this.object.up, rotateX);\n\n const yRotation = new Quaternion();\n yRotation.setFromAxisAngle(new Vector3(1, 0, 0), rotateY);\n\n const quaternion = this.quaternion.clone();\n quaternion.premultiply(xRotation).multiply(yRotation).normalize();\n\n this.object.setRotationFromQuaternion(quaternion);\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Vector3 } from \"three\";\nimport { type IDragger } from \"@inweb/viewer-core\";\n\nimport type { Viewer } from \"../Viewer\";\nimport { WalkControls } from \"../controls/WalkControls\";\n\nexport class WalkDragger implements IDragger {\n protected viewer: Viewer;\n public controls: WalkControls;\n\n constructor(viewer: Viewer) {\n this.controls = new WalkControls(viewer.camera, viewer.canvas);\n this.controls.addEventListener(\"change\", this.controlsChange);\n this.controls.addEventListener(\"walkspeedchange\", this.walkspeedChange);\n this.viewer = viewer;\n this.viewer.on(\"render\", this.viewerRender);\n this.viewer.on(\"zoom\", this.viewerZoom);\n this.updateControls();\n }\n\n dispose() {\n this.viewer.off(\"render\", this.viewerRender);\n this.viewer.off(\"zoom\", this.viewerZoom);\n this.controls.removeEventListener(\"walkspeedchange\", this.walkspeedChange);\n this.controls.removeEventListener(\"change\", this.controlsChange);\n this.controls.dispose();\n }\n\n updateControls = () => {\n const size = this.viewer.extents.getSize(new Vector3());\n this.controls.movementSpeed = Math.min(size.x, size.y, size.z) / 2;\n };\n\n controlsChange = () => {\n this.viewer.update();\n };\n\n walkspeedChange = (event: any) => {\n this.viewer.emitEvent(event);\n };\n\n viewerRender = () => {\n this.controls.update();\n };\n\n viewerZoom = () => {\n this.controls.rotateDelta.set(0, 0);\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { MOUSE } from \"three\";\n\nimport { OrbitDragger } from \"./OrbitDragger\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class ZoomDragger extends OrbitDragger {\n constructor(viewer: Viewer) {\n super(viewer);\n this.orbit.mouseButtons = { LEFT: MOUSE.DOLLY, MIDDLE: MOUSE.PAN, RIGHT: MOUSE.PAN };\n // this.controls.touches = { ONE: TOUCH.DOLLY_PAN, TWO: TOUCH.DOLLY_PAN };\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { IDraggersRegistry, draggersRegistry } from \"@inweb/viewer-core\";\n\nimport { CuttingPlaneXAxisDragger } from \"./CuttingPlaneXAxis\";\nimport { CuttingPlaneYAxisDragger } from \"./CuttingPlaneYAxis\";\nimport { CuttingPlaneZAxisDragger } from \"./CuttingPlaneZAxis\";\nimport { MeasureLineDragger } from \"./MeasureLineDragger\";\nimport { OrbitDragger } from \"./OrbitDragger\";\nimport { PanDragger } from \"./PanDragger\";\nimport { WalkDragger } from \"./WalkDragger\";\nimport { ZoomDragger } from \"./ZoomDragger\";\n\n/**\n * Viewer draggers registry. Use this registry to register custom draggers.\n *\n * To implement custom dragger:\n *\n * 1. Define a dragger class implements {@link IDragger}.\n * 2. Define a constructor with a `viewer` parameter and add mouse event listeners for the specified viewer.\n * 3. Define the dragger logic in the event listeners. For example, listen for the `mousemove` event and\n * zoom in/out when the left mouse button is pressed.\n * 4. Override {@link IDragger.dispose} and remove mouse event listeners from the viewer.\n * 5. Register dragger provider in the draggers registry by calling the {@link draggers.registerDragger}.\n *\n * @example Implementing a custom dragger.\n *\n * ```javascript\n * import { IDragger, draggers, Viewer } from \"@inweb/viewer-three\";\n *\n * class MyDragger implements IDragger {\n * protected viewer: Viewer;\n *\n * constructor(viewer: Viewer) {\n * this.viewer = viewer;\n * this.viewer.addEventListener(\"pointermove\", this.onPointerMove);\n * }\n *\n * override dispose() {\n * this.viewer.removeEventListener(\"pointermove\", this.onPointerMove);\n * }\n *\n * onPointerMove = (event: PointerEvent) => {\n * // place custom logic here\n * };\n * }\n *\n * draggers.registerDragger(\"MyDragger\", (viewer): IDragger => new MyDragger(viewer));\n * ```\n *\n * @example Activating a custom dragger.\n *\n * ```javascript\n * viewer.setActiveDragger(\"MyDragger\");\n * ```\n */\nexport const draggers: IDraggersRegistry = draggersRegistry(\"threejs\");\n\n// build-in draggers\n\ndraggers.registerDragger(\"Pan\", (viewer) => new PanDragger(viewer));\ndraggers.registerDragger(\"Orbit\", (viewer) => new OrbitDragger(viewer));\ndraggers.registerDragger(\"Zoom\", (viewer) => new ZoomDragger(viewer));\ndraggers.registerDragger(\"MeasureLine\", (viewer) => new MeasureLineDragger(viewer));\ndraggers.registerDragger(\"CuttingPlaneXAxis\", (viewer) => new CuttingPlaneXAxisDragger(viewer));\ndraggers.registerDragger(\"CuttingPlaneYAxis\", (viewer) => new CuttingPlaneYAxisDragger(viewer));\ndraggers.registerDragger(\"CuttingPlaneZAxis\", (viewer) => new CuttingPlaneZAxisDragger(viewer));\ndraggers.registerDragger(\"Walk\", (viewer) => new WalkDragger(viewer));\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Model, File, Assembly } from \"@inweb/client\";\nimport type { Viewer } from \"../Viewer\";\n\nexport function applyModelTransform(viewer: Viewer, model: Model | File | Assembly) {\n console.warn(\"applyModelTransform not implemented\");\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function clearMarkup(viewer: Viewer) {\n viewer.clearOverlay();\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\nimport type { SelectionComponent } from \"../components/SelectionComponent\";\n\nexport function clearSelected(viewer: Viewer): void {\n const selection = viewer.getComponent(\"SelectionComponent\") as SelectionComponent;\n selection.clearSelection();\n\n viewer.update();\n viewer.emitEvent({ type: \"select\", data: undefined, handles: [] });\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function clearSlices(viewer: Viewer) {\n viewer.clearSlices();\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function createPreview(viewer: Viewer, type = \"image/jpeg\", encoderOptions = 0.25): string {\n viewer.update(true);\n return viewer.canvas.toDataURL(type, encoderOptions);\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function explode(viewer: Viewer, index = 0): void {\n viewer.models.forEach((model) => model.explode(index));\n\n viewer.update();\n viewer.emitEvent({ type: \"explode\", data: index });\n}\n\nexport function collect(viewer: Viewer) {\n explode(viewer, 0);\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Box3, MathUtils, Sphere, Vector2, Vector3 } from \"three\";\nimport type { Viewer } from \"../Viewer\";\n\nexport function zoomTo(viewer: Viewer, box: Box3): void {\n if (box.isEmpty()) return;\n\n const center = box.getCenter(new Vector3());\n const sphere = box.getBoundingSphere(new Sphere());\n\n const rendererSize = viewer.renderer.getSize(new Vector2());\n const aspect = rendererSize.x / rendererSize.y;\n\n const camera = viewer.camera as any;\n\n if (camera.isPerspectiveCamera) {\n const offset = new Vector3(0, 0, 1);\n offset.applyQuaternion(camera.quaternion);\n offset.multiplyScalar(sphere.radius / Math.tan(MathUtils.DEG2RAD * camera.fov * 0.5));\n\n camera.position.copy(center).add(offset);\n camera.updateMatrixWorld();\n }\n if (camera.isOrthographicCamera) {\n camera.top = sphere.radius;\n camera.bottom = -sphere.radius;\n camera.left = camera.bottom * aspect;\n camera.right = camera.top * aspect;\n camera.zoom = 1;\n camera.updateProjectionMatrix();\n\n const offset = new Vector3(0, 0, 1);\n offset.applyQuaternion(camera.quaternion);\n offset.multiplyScalar(viewer.extents.getBoundingSphere(new Sphere()).radius * 3);\n\n camera.position.copy(center).add(offset);\n camera.updateMatrixWorld();\n }\n\n viewer.target.copy(center);\n\n viewer.update();\n viewer.emitEvent({ type: \"zoom\" });\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Sphere, Vector3 } from \"three\";\nimport type { Viewer } from \"../Viewer\";\nimport { zoomTo } from \"./ZoomTo\";\n\nexport const defaultViewPositions = {\n top: new Vector3(0, 0, 1),\n bottom: new Vector3(0, 0, -1),\n left: new Vector3(-1, 0, 0),\n right: new Vector3(1, 0, 0),\n front: new Vector3(0, -1, 0),\n back: new Vector3(0, 1, 0),\n sw: new Vector3(-0.5, -0.5, 1.0).normalize(),\n se: new Vector3(0.5, -0.5, 1.0).normalize(),\n ne: new Vector3(0.5, 0.5, 1.0).normalize(),\n nw: new Vector3(-0.5, 0.5, 1.0).normalize(),\n};\n\nexport function setDefaultViewPosition(viewer: Viewer, position: string): void {\n const direction = defaultViewPositions[position] || defaultViewPositions[\"sw\"];\n\n const center = viewer.extents.getCenter(new Vector3());\n const sphere = viewer.extents.getBoundingSphere(new Sphere());\n const offset = direction.clone().multiplyScalar(sphere.radius);\n\n const camera = viewer.camera;\n camera.position.copy(center).add(offset);\n camera.lookAt(center);\n camera.updateMatrixWorld();\n\n viewer.target.copy(center);\n\n viewer.update();\n viewer.emit({ type: \"viewposition\", data: position });\n\n zoomTo(viewer, viewer.extents);\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { defaultViewPositions } from \"./SetDefaultViewPosition\";\n\nexport function getDefaultViewPositions(): string[] {\n return Object.keys(defaultViewPositions);\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function getModels(viewer: Viewer): string[] {\n return viewer.models.map((model) => model.handle);\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function getSelected(viewer: Viewer): string[] {\n const handles = [];\n viewer.models.forEach((model) => handles.push(...model.getHandlesByObjects(viewer.selected)));\n return handles;\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\nimport type { SelectionComponent } from \"../components/SelectionComponent\";\n\nexport function hideSelected(viewer: Viewer): void {\n viewer.models.forEach((model) => model.hideObjects(viewer.selected));\n\n const selection = viewer.getComponent(\"SelectionComponent\") as SelectionComponent;\n selection.clearSelection();\n\n viewer.update();\n viewer.emitEvent({ type: \"hide\" });\n viewer.emitEvent({ type: \"select\", data: undefined, handles: [] });\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function isolateSelected(viewer: Viewer): void {\n viewer.models.forEach((model) => model.isolateObjects(viewer.selected));\n\n viewer.update();\n viewer.emitEvent({ type: \"isolate\" });\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function regenerateAll(viewer: Viewer): void {\n viewer.emit({ type: \"regenerateall\" });\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function resetView(viewer: Viewer): void {\n viewer.executeCommand(\"setActiveDragger\");\n viewer.executeCommand(\"clearSlices\");\n viewer.executeCommand(\"clearOverlay\");\n viewer.executeCommand(\"setMarkupColor\");\n viewer.executeCommand(\"clearSelected\");\n viewer.executeCommand(\"showAll\");\n viewer.executeCommand(\"explode\", 0);\n viewer.executeCommand(\"zoomToExtents\", true);\n viewer.executeCommand(\"k3DViewSW\");\n\n viewer.emit({ type: \"resetview\" });\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\nimport type { SelectionComponent } from \"../components/SelectionComponent\";\n\nexport function selectModel(viewer: Viewer, handle: string): void {\n const selection = viewer.getComponent(\"SelectionComponent\") as SelectionComponent;\n selection.clearSelection();\n\n viewer.models\n .filter((model) => model.handle === handle)\n .forEach((model) => selection.select(model.getObjects(), model));\n\n viewer.update();\n viewer.emit({ type: \"select\", data: [] });\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function setActiveDragger(viewer: Viewer, dragger = \"\") {\n viewer.setActiveDragger(dragger);\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function setMarkupColor(viewer: Viewer, r = 255, g = 0, b = 0) {\n viewer.markup.setMarkupColor(r, g, b);\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\nimport type { SelectionComponent } from \"../components/SelectionComponent\";\n\nexport function setSelected(viewer: Viewer, handles: string[] = []): void {\n const selection = viewer.getComponent(\"SelectionComponent\") as SelectionComponent;\n selection.clearSelection();\n\n viewer.models.forEach((model) => {\n const objects = model.getObjectsByHandles(handles);\n selection.select(objects, model);\n });\n\n viewer.update();\n viewer.emitEvent({ type: \"show\" });\n viewer.emitEvent({ type: \"select\", data: undefined, handles });\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\n\nexport function showAll(viewer: Viewer): void {\n viewer.models.forEach((model) => model.showAllObjects());\n\n viewer.update();\n viewer.emitEvent({ type: \"showall\" });\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport type { Viewer } from \"../Viewer\";\nimport { zoomTo } from \"./ZoomTo\";\n\nexport function zoomToExtents(viewer: Viewer): void {\n zoomTo(viewer, viewer.extents);\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Box3 } from \"three\";\nimport type { Viewer } from \"../Viewer\";\nimport { zoomTo } from \"./ZoomTo\";\n\nexport function zoomToObjects(viewer: Viewer, handles: string[] = []): void {\n const handleSet = new Set(handles);\n const objects = [];\n viewer.scene.traverseVisible((child) => {\n if (handleSet.has(child.userData?.handle)) objects.push(child);\n });\n\n const extents = objects.reduce((result: Box3, object) => result.expandByObject(object), new Box3());\n if (extents.isEmpty()) extents.copy(viewer.extents);\n\n zoomTo(viewer, extents);\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Box3 } from \"three\";\nimport type { Viewer } from \"../Viewer\";\nimport { zoomTo } from \"./ZoomTo\";\n\nexport function zoomToSelected(viewer: Viewer): void {\n const extents = viewer.selected.reduce((result: Box3, object) => result.expandByObject(object), new Box3());\n if (extents.isEmpty()) extents.copy(viewer.extents);\n\n zoomTo(viewer, extents);\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { ICommandsRegistry, commandsRegistry } from \"@inweb/viewer-core\";\n\nimport { applyModelTransform } from \"./ApplyModelTransform\";\nimport { clearMarkup } from \"./ClearMarkup\";\nimport { clearSelected } from \"./ClearSelected\";\nimport { clearSlices } from \"./ClearSlices\";\nimport { createPreview } from \"./CreatePreview\";\nimport { explode, collect } from \"./Explode\";\nimport { getDefaultViewPositions } from \"./GetDefaultViewPositions\";\nimport { getModels } from \"./GetModels\";\nimport { getSelected } from \"./GetSelected\";\nimport { hideSelected } from \"./HideSelected\";\nimport { isolateSelected } from \"./IsolateSelected\";\nimport { regenerateAll } from \"./RegenerateAll\";\nimport { resetView } from \"./ResetView\";\nimport { selectModel } from \"./SelectModel\";\nimport { setActiveDragger } from \"./SetActiveDragger\";\nimport { setDefaultViewPosition } from \"./SetDefaultViewPosition\";\nimport { setMarkupColor } from \"./SetMarkupColor\";\nimport { setSelected } from \"./SetSelected\";\nimport { showAll } from \"./ShowAll\";\nimport { zoomToExtents } from \"./ZoomToExtents\";\nimport { zoomToObjects } from \"./ZoomToObjects\";\nimport { zoomToSelected } from \"./ZoomToSelected\";\n\n/**\n * Viewer commands registry. Use this registry to register custom commands.\n *\n * To implement custom command:\n *\n * 1. Define a command handler with a first `viewer` parameter.\n * 2. Register command handler in the commands registry by calling the {@link commands.registerCommand}.\n *\n * @example Implementing a custom command.\n *\n * ```javascript\n * import { commands, Viewer } from \"@inweb/viewer-three\";\n *\n * function commandHandler(viewer: Viewer, name = \"world\"): void {\n * console.log(`Hello ${name}!!!`);\n * }\n *\n * commands.registerCommand(\"sayHello\", commandHandler);\n * ```\n *\n * @example Calling a custom command.\n *\n * ```javascript\n * viewer.executeCommand(\"sayHello\", \"user\");\n * ```\n */\nexport const commands: ICommandsRegistry = commandsRegistry(\"threejs\");\n\n// build-in commands\n\ncommands.registerCommand(\"applyModelTransform\", applyModelTransform);\ncommands.registerCommand(\"clearMarkup\", clearMarkup);\ncommands.registerCommand(\"clearSelected\", clearSelected);\ncommands.registerCommand(\"clearSlices\", clearSlices);\ncommands.registerCommand(\"createPreview\", createPreview);\ncommands.registerCommand(\"explode\", explode);\ncommands.registerCommand(\"collect\", collect);\ncommands.registerCommand(\"getDefaultViewPositions\", getDefaultViewPositions);\ncommands.registerCommand(\"getModels\", getModels);\ncommands.registerCommand(\"getSelected\", getSelected);\ncommands.registerCommand(\"hideSelected\", hideSelected);\ncommands.registerCommand(\"isolateSelected\", isolateSelected);\ncommands.registerCommand(\"regenerateAll\", regenerateAll);\ncommands.registerCommand(\"resetView\", resetView);\ncommands.registerCommand(\"selectModel\", selectModel);\ncommands.registerCommand(\"setActiveDragger\", setActiveDragger);\ncommands.registerCommand(\"setDefaultViewPosition\", setDefaultViewPosition);\ncommands.registerCommand(\"setMarkupColor\", setMarkupColor);\ncommands.registerCommand(\"setSelected\", setSelected);\ncommands.registerCommand(\"showAll\", showAll);\ncommands.registerCommand(\"zoomToExtents\", zoomToExtents);\ncommands.registerCommand(\"zoomToObjects\", zoomToObjects);\ncommands.registerCommand(\"zoomToSelected\", zoomToSelected);\n\ncommands.registerCommand(\"top\", (viewer) => setDefaultViewPosition(viewer, \"top\"));\ncommands.registerCommand(\"bottom\", (viewer) => setDefaultViewPosition(viewer, \"bottom\"));\ncommands.registerCommand(\"left\", (viewer) => setDefaultViewPosition(viewer, \"left\"));\ncommands.registerCommand(\"right\", (viewer) => setDefaultViewPosition(viewer, \"right\"));\ncommands.registerCommand(\"front\", (viewer) => setDefaultViewPosition(viewer, \"front\"));\ncommands.registerCommand(\"back\", (viewer) => setDefaultViewPosition(viewer, \"back\"));\ncommands.registerCommand(\"sw\", (viewer) => setDefaultViewPosition(viewer, \"sw\"));\ncommands.registerCommand(\"se\", (viewer) => setDefaultViewPosition(viewer, \"se\"));\ncommands.registerCommand(\"ne\", (viewer) => setDefaultViewPosition(viewer, \"ne\"));\ncommands.registerCommand(\"nw\", (viewer) => setDefaultViewPosition(viewer, \"nw\"));\n\ncommands.registerCommandAlias(\"clearMarkup\", \"clearOverlay\");\ncommands.registerCommandAlias(\"clearSelected\", \"unselect\");\ncommands.registerCommandAlias(\"zoomToExtents\", \"zoomExtents\");\n\ncommands.registerCommandAlias(\"top\", \"k3DViewTop\");\ncommands.registerCommandAlias(\"bottom\", \"k3DViewBottom\");\ncommands.registerCommandAlias(\"left\", \"k3DViewLeft\");\ncommands.registerCommandAlias(\"right\", \"k3DViewRight\");\ncommands.registerCommandAlias(\"front\", \"k3DViewFront\");\ncommands.registerCommandAlias(\"back\", \"k3DViewBack\");\ncommands.registerCommandAlias(\"se\", \"k3DViewSE\");\ncommands.registerCommandAlias(\"sw\", \"k3DViewSW\");\ncommands.registerCommandAlias(\"ne\", \"k3DViewNE\");\ncommands.registerCommandAlias(\"nw\", \"k3DViewNW\");\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Color } from \"three\";\n\nimport { IComponent } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class BackgroundComponent implements IComponent {\n protected viewer: Viewer;\n protected backgroundColor: Color;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n\n this.backgroundColor = new Color(0xffffff);\n\n this.viewer.renderer.setClearColor(this.backgroundColor);\n this.viewer.scene.background = this.backgroundColor;\n this.viewer.addEventListener(\"optionschange\", this.syncOptions);\n }\n\n dispose() {\n this.viewer.removeEventListener(\"optionschange\", this.syncOptions);\n this.viewer.scene.background = undefined;\n }\n\n syncOptions = () => {\n this.backgroundColor.setHex(0xffffff);\n this.viewer.renderer.setClearColor(this.backgroundColor);\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Sphere, Vector2, Vector3 } from \"three\";\n\nimport { IComponent } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class CameraComponent implements IComponent {\n protected viewer: Viewer;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n this.viewer.addEventListener(\"databasechunk\", this.geometryEnd);\n }\n\n dispose() {\n this.viewer.removeEventListener(\"databasechunk\", this.geometryEnd);\n }\n\n geometryEnd = () => {\n const extentsCenter = this.viewer.extents.getCenter(new Vector3());\n const extentsSize = this.viewer.extents.getBoundingSphere(new Sphere()).radius * 2;\n const rendererSize = this.viewer.renderer.getSize(new Vector2());\n const aspect = rendererSize.x / rendererSize.y;\n\n // TODO: do not change the camera and target after opening the second model in \"append\" mode\n let sceneCamera: any;\n this.viewer.scene.traverse((object: any) => {\n if (object.isCamera)\n if (!sceneCamera) sceneCamera = object;\n else if (object.isPerspectiveCamera && sceneCamera.isOrthographicCamera) sceneCamera = object;\n });\n if (sceneCamera) {\n this.viewer.camera = sceneCamera.clone();\n this.viewer.camera.up.set(0, 0, 1);\n this.viewer.camera.scale.set(1, 1, 1); // <- visualize fix\n }\n\n const camera = this.viewer.camera as any;\n\n if (camera.isPerspectiveCamera) {\n camera.aspect = aspect;\n camera.near = extentsSize / 100;\n camera.far = extentsSize * 100;\n camera.updateProjectionMatrix();\n }\n if (camera.isOrthographicCamera) {\n camera.left = camera.bottom * aspect;\n camera.right = camera.top * aspect;\n camera.near = 0;\n camera.far = extentsSize * 100;\n camera.updateProjectionMatrix();\n }\n\n this.viewer.target.copy(extentsCenter);\n\n if (!sceneCamera) {\n this.viewer.executeCommand(\"setDefaultViewPosition\");\n }\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Box3 } from \"three\";\n\nimport { IComponent } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class ExtentsComponent implements IComponent {\n private viewer: Viewer;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n this.viewer.addEventListener(\"databasechunk\", this.syncExtents);\n this.viewer.addEventListener(\"clear\", this.syncExtents);\n this.viewer.on(\"explode\", this.syncExtents);\n this.viewer.on(\"hide\", this.syncExtents);\n this.viewer.on(\"isolate\", this.syncExtents);\n this.viewer.on(\"show\", this.syncExtents);\n this.viewer.on(\"showall\", this.syncExtents);\n }\n\n dispose() {\n this.viewer.removeEventListener(\"databasechunk\", this.syncExtents);\n this.viewer.removeEventListener(\"clear\", this.syncExtents);\n this.viewer.off(\"explode\", this.syncExtents);\n this.viewer.off(\"hide\", this.syncExtents);\n this.viewer.off(\"isolate\", this.syncExtents);\n this.viewer.off(\"show\", this.syncExtents);\n this.viewer.off(\"showall\", this.syncExtents);\n }\n\n syncExtents = () => {\n const extents = new Box3();\n this.viewer.models.forEach((model) => model.getExtents(extents));\n\n this.viewer.extents.copy(extents);\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { AmbientLight, DirectionalLight, HemisphereLight, Sphere, Vector3 } from \"three\";\n\nimport { IComponent } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class LightComponent implements IComponent {\n protected viewer: Viewer;\n protected ambientLight: AmbientLight;\n protected directionalLight: DirectionalLight;\n protected frontLight: DirectionalLight;\n protected hemisphereLight: HemisphereLight;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n\n this.ambientLight = new AmbientLight(0xffffff, 1);\n this.viewer.scene.add(this.ambientLight);\n\n this.directionalLight = new DirectionalLight(0xffffff, 1);\n this.directionalLight.position.set(0.5, 0, 0.866); // ~60º\n this.viewer.scene.add(this.directionalLight);\n\n this.frontLight = new DirectionalLight(0xffffff, 1.25);\n this.frontLight.position.set(0, 1, 0);\n this.viewer.scene.add(this.frontLight);\n\n this.hemisphereLight = new HemisphereLight(0xffffff, 0x444444, 1.25);\n this.hemisphereLight.position.set(0, 0, 1);\n this.viewer.scene.add(this.hemisphereLight);\n\n this.viewer.addEventListener(\"databasechunk\", this.geometryEnd);\n this.viewer.addEventListener(\"clear\", this.geometryEnd);\n }\n\n dispose(): void {\n this.ambientLight.removeFromParent();\n this.ambientLight.dispose();\n\n this.directionalLight.removeFromParent();\n this.directionalLight.dispose();\n\n this.frontLight.removeFromParent();\n this.frontLight.dispose();\n\n this.hemisphereLight.removeFromParent();\n this.hemisphereLight.dispose();\n\n this.viewer.removeEventListener(\"databasechunk\", this.geometryEnd);\n this.viewer.removeEventListener(\"clear\", this.geometryEnd);\n }\n\n geometryEnd = () => {\n this.ambientLight.removeFromParent();\n this.directionalLight.removeFromParent();\n this.frontLight.removeFromParent();\n this.hemisphereLight.removeFromParent();\n\n if (this.viewer.extents.isEmpty()) return;\n\n const extentsCenter = this.viewer.extents.getCenter(new Vector3());\n const extentsSize = this.viewer.extents.getBoundingSphere(new Sphere()).radius;\n\n this.directionalLight.position\n .set(0.5, 0, 0.866)\n .multiplyScalar(extentsSize * 2)\n .add(extentsCenter);\n this.directionalLight.target.position.copy(extentsCenter);\n\n this.frontLight.position.set(0, extentsSize * 2, 0).add(extentsCenter);\n this.frontLight.target.position.copy(extentsCenter);\n\n this.hemisphereLight.position.set(0, extentsSize * 3, 0).add(extentsCenter);\n\n this.viewer.scene.add(this.ambientLight);\n this.viewer.scene.add(this.directionalLight);\n this.viewer.scene.add(this.frontLight);\n this.viewer.scene.add(this.hemisphereLight);\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { IComponent } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class RenderLoopComponent implements IComponent {\n protected viewer: Viewer;\n protected requestId: number;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n this.animate();\n }\n\n dispose() {\n cancelAnimationFrame(this.requestId);\n }\n\n animate = (time = 0) => {\n this.requestId = requestAnimationFrame(this.animate);\n\n this.viewer.render(time);\n this.viewer.emitEvent({ type: \"animate\", time });\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { IComponent } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\n\nexport class ResizeCanvasComponent implements IComponent {\n protected viewer: Viewer;\n protected resizeObserver: ResizeObserver;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n this.resizeObserver = new ResizeObserver(this.resizeViewer);\n this.resizeObserver.observe(viewer.canvas.parentElement);\n }\n\n dispose() {\n this.resizeObserver.disconnect();\n }\n\n resizeViewer = (entries: ResizeObserverEntry[]) => {\n const { width, height } = entries[0].contentRect;\n\n if (!width || !height) return; // <- invisible viewer, or viewer with parent removed\n\n const camera = this.viewer.camera as any;\n const aspect = width / height;\n\n if (camera.isPerspectiveCamera) {\n camera.aspect = aspect;\n camera.updateProjectionMatrix();\n }\n if (camera.isOrthographicCamera) {\n camera.left = camera.bottom * aspect;\n camera.right = camera.top * aspect;\n camera.updateProjectionMatrix();\n }\n\n this.viewer.renderer.setSize(width, height, true);\n\n this.viewer.update(true);\n this.viewer.emitEvent({ type: \"resize\", width, height });\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { LineSegmentsGeometry } from \"three/examples/jsm/lines/LineSegmentsGeometry.js\";\n\nexport class HighlighterUtils {\n static isBreak(positions: Float32Array, i: number) {\n return (\n isNaN(positions[i]) ||\n isNaN(positions[i + 1]) ||\n isNaN(positions[i + 2]) ||\n positions[i] === Infinity ||\n positions[i] === -Infinity ||\n positions[i + 1] === Infinity ||\n positions[i + 1] === -Infinity ||\n positions[i + 2] === Infinity ||\n positions[i + 2] === -Infinity\n );\n }\n\n static fromIndexedLine(positions: Float32Array, indices: number[]) {\n const lineGeometry = new LineSegmentsGeometry();\n const segments = [];\n\n for (let i = 0; i < indices.length; i += 2) {\n const idx1 = indices[i] * 3;\n const idx2 = indices[i + 1] * 3;\n\n if (indices[i] === -1 || indices[i + 1] === -1) {\n continue;\n }\n\n segments.push(\n positions[idx1],\n positions[idx1 + 1],\n positions[idx1 + 2],\n positions[idx2],\n positions[idx2 + 1],\n positions[idx2 + 2]\n );\n }\n\n if (segments.length === 0) return null;\n\n lineGeometry.setPositions(segments);\n return lineGeometry;\n }\n\n static fromNonIndexedLine(positions: Float32Array, isLineSegments: boolean) {\n const lineGeometry = new LineSegmentsGeometry();\n const segments = [];\n\n if (isLineSegments) {\n for (let i = 0; i < positions.length; i += 6) {\n if (i + 5 >= positions.length) break;\n\n if (HighlighterUtils.isBreak(positions, i) || HighlighterUtils.isBreak(positions, i + 3)) continue;\n\n segments.push(\n positions[i],\n positions[i + 1],\n positions[i + 2],\n positions[i + 3],\n positions[i + 4],\n positions[i + 5]\n );\n }\n } else {\n let lastValidIndex = -1;\n\n for (let i = 0; i < positions.length; i += 3) {\n if (HighlighterUtils.isBreak(positions, i)) {\n lastValidIndex = -1;\n continue;\n }\n\n if (lastValidIndex !== -1) {\n segments.push(\n positions[lastValidIndex],\n positions[lastValidIndex + 1],\n positions[lastValidIndex + 2],\n positions[i],\n positions[i + 1],\n positions[i + 2]\n );\n }\n lastValidIndex = i;\n }\n }\n\n if (segments.length === 0) return null;\n\n lineGeometry.setPositions(segments);\n return lineGeometry;\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport {\n Color,\n EdgesGeometry,\n LineBasicMaterial,\n MeshBasicMaterial,\n Object3D,\n RGBAFormat,\n UnsignedByteType,\n Vector2,\n WebGLRenderTarget,\n} from \"three\";\nimport { LineSegmentsGeometry } from \"three/examples/jsm/lines/LineSegmentsGeometry.js\";\nimport { Wireframe } from \"three/examples/jsm/lines/Wireframe.js\";\nimport { LineMaterial } from \"three/examples/jsm/lines/LineMaterial.js\";\n\nimport { IComponent, ResizeEvent } from \"@inweb/viewer-core\";\nimport { Viewer } from \"../Viewer\";\nimport { HighlighterUtils } from \"./HighlighterUtils\";\n\nexport class HighlighterComponent implements IComponent {\n protected viewer: Viewer;\n public renderTarget: WebGLRenderTarget;\n public highlightMaterial: MeshBasicMaterial;\n public outlineMaterial: LineMaterial;\n public highlightLineMaterial: LineBasicMaterial;\n public highlightLineGlowMaterial: LineMaterial;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n\n const gl2 = viewer.canvas.getContext(\"webgl2\");\n if (gl2) {\n const size = viewer.renderer.getSize(new Vector2());\n this.renderTarget = new WebGLRenderTarget(size.x, size.y, {\n format: RGBAFormat,\n stencilBuffer: false,\n samples: 4,\n type: UnsignedByteType,\n });\n }\n\n this.viewer.addEventListener(\"databasechunk\", this.geometryEnd);\n this.viewer.addEventListener(\"optionschange\", this.optionsChange);\n this.viewer.addEventListener(\"resize\", this.viewerResize);\n\n this.geometryEnd();\n }\n\n dispose() {\n this.viewer.removeEventListener(\"databasechunk\", this.geometryEnd);\n this.viewer.removeEventListener(\"optionschange\", this.optionsChange);\n this.viewer.removeEventListener(\"resize\", this.viewerResize);\n }\n\n highlight(objects: Object3D | Object3D[]) {\n if (!Array.isArray(objects)) objects = [objects];\n if (!objects.length) return;\n\n objects.forEach((object: any) => {\n if (object.isHighlighted) return;\n\n if (object.isLine || object.isLineSegments) {\n const positions = object.geometry.attributes.position.array;\n const indices = object.geometry.index ? object.geometry.index.array : null;\n const lineGeometry = indices\n ? HighlighterUtils.fromIndexedLine(positions, indices)\n : HighlighterUtils.fromNonIndexedLine(positions, object.isLineSegments);\n\n const wireframe = new Wireframe(lineGeometry, this.highlightLineGlowMaterial);\n wireframe.position.copy(object.position);\n wireframe.rotation.copy(object.rotation);\n wireframe.scale.copy(object.scale);\n\n object.parent.add(wireframe);\n\n object.userData.highlightwireframe = wireframe;\n object.userData.originalMaterial = object.material;\n object.material = this.highlightLineMaterial;\n object.isHighlighted = true;\n } else if (object.isMesh) {\n const edgesGeometry = new EdgesGeometry(object.geometry, 30);\n const lineGeometry = new LineSegmentsGeometry().fromEdgesGeometry(edgesGeometry);\n\n const wireframe = new Wireframe(lineGeometry, this.outlineMaterial);\n wireframe.position.copy(object.position);\n wireframe.rotation.copy(object.rotation);\n wireframe.scale.copy(object.scale);\n\n object.parent.add(wireframe);\n\n object.userData.highlightwireframe = wireframe;\n object.userData.originalMaterial = object.material;\n object.material = this.highlightMaterial;\n object.isHighlighted = true;\n }\n });\n }\n\n unhighlight(objects: Object3D | Object3D[]) {\n if (!Array.isArray(objects)) objects = [objects];\n if (!objects.length) return;\n\n objects.forEach((object: any) => {\n if (!object.isHighlighted) return;\n\n object.isHighlighted = false;\n object.material = object.userData.originalMaterial;\n object.userData.highlightwireframe.removeFromParent();\n\n delete object.userData.originalMaterial;\n delete object.userData.highlightwireframe;\n });\n }\n\n geometryEnd = () => {\n const { facesColor, facesTransparancy, edgesColor } = this.viewer.options;\n\n this.highlightMaterial = new MeshBasicMaterial({\n color: new Color(facesColor.r / 255, facesColor.g / 255, facesColor.b / 255),\n transparent: true,\n opacity: (255 - facesTransparancy) / 255,\n depthTest: false,\n depthWrite: false,\n });\n\n this.outlineMaterial = new LineMaterial({\n color: new Color(edgesColor.r / 255, edgesColor.g / 255, edgesColor.b / 255),\n linewidth: 1.5,\n depthTest: false,\n depthWrite: false,\n resolution: new Vector2(window.innerWidth, window.innerHeight),\n });\n\n this.highlightLineMaterial = new LineBasicMaterial({\n color: new Color(facesColor.r / 255, facesColor.g / 255, facesColor.b / 255),\n depthTest: false,\n depthWrite: false,\n });\n\n this.highlightLineGlowMaterial = new LineMaterial({\n color: new Color(facesColor.r / 255, facesColor.g / 255, facesColor.b / 255),\n linewidth: 5,\n transparent: true,\n opacity: 0.8,\n depthTest: true,\n depthWrite: true,\n resolution: new Vector2(window.innerWidth, window.innerHeight),\n });\n };\n\n optionsChange = () => {\n const { facesColor, facesTransparancy, edgesColor } = this.viewer.options;\n\n this.highlightMaterial.color.setRGB(facesColor.r / 255, facesColor.g / 255, facesColor.b / 255);\n this.highlightMaterial.opacity = (255 - facesTransparancy) / 255;\n this.outlineMaterial.color.setRGB(edgesColor.r / 255, edgesColor.g / 255, edgesColor.b / 255);\n this.highlightLineMaterial.color.setRGB(facesColor.r / 255, facesColor.g / 255, facesColor.b / 255);\n this.highlightLineGlowMaterial.color.setRGB(facesColor.r / 255, facesColor.g / 255, facesColor.b / 255);\n\n this.viewer.update();\n };\n\n viewerResize(event: ResizeEvent) {\n this.renderTarget?.setSize(event.width, event.height);\n this.outlineMaterial?.resolution.set(event.width, event.height);\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Intersection, Object3D, Raycaster, Vector2 } from \"three\";\n\nimport type { IComponent } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\nimport type { IModelImpl } from \"../model\";\nimport type { HighlighterComponent } from \"./HighlighterComponent\";\n\nexport class SelectionComponent implements IComponent {\n protected viewer: Viewer;\n protected raycaster: Raycaster;\n protected downPosition: Vector2;\n protected highlighter: HighlighterComponent;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n this.raycaster = new Raycaster();\n this.downPosition = new Vector2();\n\n this.viewer.addEventListener(\"pointerdown\", this.onPointerDown);\n this.viewer.addEventListener(\"pointerup\", this.onPointerUp);\n this.viewer.addEventListener(\"dblclick\", this.onDoubleClick);\n this.viewer.addEventListener(\"initialize\", this.initHighlighter);\n }\n\n dispose() {\n this.viewer.removeEventListener(\"pointerdown\", this.onPointerDown);\n this.viewer.removeEventListener(\"pointerup\", this.onPointerUp);\n this.viewer.removeEventListener(\"dblclick\", this.onDoubleClick);\n this.viewer.removeEventListener(\"initialize\", this.initHighlighter);\n }\n\n onPointerDown = (event: PointerEvent) => {\n if (!event.isPrimary || event.button !== 0) return;\n\n this.getMousePosition(event, this.downPosition);\n };\n\n onPointerUp = (event: PointerEvent) => {\n if (!event.isPrimary) return;\n\n const upPosition = this.getMousePosition(event, new Vector2());\n if (upPosition.distanceTo(this.downPosition) !== 0) return;\n\n let intersections = [];\n this.viewer.models.forEach((model) => {\n const objects = model.getVisibleObjects();\n const intersects = this.getPointerIntersects(upPosition, objects);\n intersections.push(...intersects.map((x) => ({ ...x, model })));\n });\n intersections = intersections.sort((a, b) => a.distance - b.distance);\n\n if (!event.shiftKey) this.clearSelection();\n\n if (intersections.length > 0) {\n const model = intersections[0].model;\n const handles = model.getHandlesByObjects(intersections[0].object);\n const objects = model.getObjectsByHandles(handles);\n\n if (!event.shiftKey) this.select(objects, model);\n else this.toggleSelection(objects, model);\n }\n\n this.viewer.update();\n this.viewer.emitEvent({ type: \"select\", data: undefined, handles: this.viewer.getSelected() });\n };\n\n onDoubleClick = (event: MouseEvent) => {\n if (event.button !== 0) return;\n\n this.viewer.executeCommand(\"zoomToSelected\");\n };\n\n getMousePosition(event: MouseEvent, target: Vector2): Vector2 {\n return target.set(event.clientX, event.clientY);\n }\n\n getPointerIntersects(mouse: Vector2, objects: Object3D[]): Array<Intersection<Object3D>> {\n const rect = this.viewer.canvas.getBoundingClientRect();\n const x = ((mouse.x - rect.left) / rect.width) * 2 - 1;\n const y = (-(mouse.y - rect.top) / rect.height) * 2 + 1;\n\n const coords = new Vector2(x, y);\n this.raycaster.setFromCamera(coords, this.viewer.camera);\n\n this.raycaster.params = this.raycaster.params = {\n Mesh: {},\n Line: { threshold: 0.25 },\n Line2: { threshold: 0.25 },\n LOD: {},\n Points: { threshold: 0.1 },\n Sprite: {},\n };\n\n return this.raycaster.intersectObjects(objects, false);\n }\n\n select(objects: Object3D | Object3D[], model?: IModelImpl) {\n if (!model) {\n this.viewer.models.forEach((model) => this.select(objects, model));\n return;\n }\n\n if (!Array.isArray(objects)) objects = [objects];\n if (!objects.length) return;\n\n model.showObjects(objects);\n model.showOriginalObjects(objects);\n this.highlighter.highlight(objects);\n\n objects.forEach((object: any) => this.viewer.selected.push(object));\n objects.forEach((object: any) => (object.isSelected = true));\n }\n\n deselect(objects: Object3D | Object3D[], model?: IModelImpl) {\n if (!model) {\n this.viewer.models.forEach((model) => this.select(objects, model));\n return;\n }\n\n if (!Array.isArray(objects)) objects = [objects];\n if (!objects.length) return;\n\n this.highlighter.unhighlight(objects);\n model.hideOriginalObjects(objects);\n\n this.viewer.selected = this.viewer.selected.filter((x) => !objects.includes(x));\n objects.forEach((object: any) => (object.isSelected = false));\n }\n\n toggleSelection(objects: Object3D | Object3D[], model?: IModelImpl) {\n if (!Array.isArray(objects)) objects = [objects];\n if (!objects.length) return;\n\n if ((objects[0] as any).isSelected) this.deselect(objects, model);\n else this.select(objects, model);\n }\n\n clearSelection() {\n if (!this.viewer.selected.length) return;\n\n this.highlighter.unhighlight(this.viewer.selected);\n this.viewer.models.forEach((model) => model.hideOriginalObjects(this.viewer.selected));\n\n this.viewer.selected.forEach((object: any) => (object.isSelected = false));\n this.viewer.selected.length = 0;\n }\n\n initHighlighter = () => {\n this.highlighter = this.viewer.getComponent(\"HighlighterComponent\") as HighlighterComponent;\n };\n}\n","import {\n Camera,\n CylinderGeometry,\n CanvasTexture,\n Color,\n Mesh,\n MeshBasicMaterial,\n Object3D,\n OrthographicCamera,\n Sprite,\n SpriteMaterial,\n SRGBColorSpace,\n Vector4,\n WebGLRenderer,\n} from \"three\";\n\nexport class WCSHelper extends Object3D {\n private camera: Camera;\n private orthoCamera: OrthographicCamera;\n public size: number;\n\n constructor(camera: Camera) {\n super();\n\n this.camera = camera;\n this.size = 160;\n\n this.orthoCamera = new OrthographicCamera(-2, 2, 2, -2, 0, 4);\n this.orthoCamera.position.set(0, 0, 2);\n\n const matRed = new MeshBasicMaterial({ toneMapped: false, color: \"#aa0000\" });\n const matGreen = new MeshBasicMaterial({ toneMapped: false, color: \"#00aa00\" });\n const matBlue = new MeshBasicMaterial({ toneMapped: false, color: \"#0000aa\" });\n\n const spriteRed = this.getSpriteMaterial(matRed.color, \"X\");\n const spriteGreen = this.getSpriteMaterial(matGreen.color, \"Y\");\n const spriteBlue = this.getSpriteMaterial(matBlue.color, \"Z\");\n\n const lineGeometry = new CylinderGeometry(0.01, 0.01, 1, 3);\n lineGeometry.translate(0, 0.5, 0);\n\n const arrowGeometry = new CylinderGeometry(0, 0.1, 0.25, 12);\n arrowGeometry.translate(0, 0.625, 0);\n\n const axesMap = {\n X: [\n [new Mesh(arrowGeometry, matRed), [0.5, 0, 0], [0, 0, -Math.PI / 2]],\n [new Mesh(lineGeometry, matRed), [0, 0, 0], [0, 0, -Math.PI / 2]],\n [new Sprite(spriteRed), [1.55, 0, 0]],\n ],\n Y: [\n [new Mesh(arrowGeometry, matGreen), [0, 0.5, 0], null],\n [new Mesh(lineGeometry, matGreen), null, null],\n [new Sprite(spriteGreen), [0, 1.55, 0]],\n ],\n Z: [\n [new Mesh(arrowGeometry, matBlue), [0, 0, 0.5], [Math.PI / 2, 0, 0]],\n [new Mesh(lineGeometry, matBlue), null, [Math.PI / 2, 0, 0]],\n [new Sprite(spriteBlue), [0, 0, 1.55]],\n ],\n };\n\n Object.keys(axesMap).forEach((key) => {\n axesMap[key].forEach((objects: any) => {\n const object = objects[0];\n const position = objects[1];\n const rotation = objects[2];\n\n object.name = key;\n if (position) object.position.set(position[0], position[1], position[2]);\n if (rotation) object.rotation.set(rotation[0], rotation[1], rotation[2]);\n object.updateMatrixWorld();\n\n this.add(object);\n });\n });\n }\n\n dispose() {\n this.traverse((object: any) => {\n if (object.geometry) object.geometry.dispose();\n if (object.material) object.material.dispose();\n });\n }\n\n getSpriteMaterial(color: Color, text: string) {\n const canvas = document.createElement(\"canvas\");\n canvas.width = 64;\n canvas.height = 64;\n\n const context = canvas.getContext(\"2d\");\n context.clearRect(0, 0, 64, 64);\n context.font = \"24px Arial\";\n context.textAlign = \"center\";\n context.fillStyle = color.getStyle();\n context.fillText(text, 32, 41);\n\n const texture = new CanvasTexture(canvas);\n texture.colorSpace = SRGBColorSpace;\n\n return new SpriteMaterial({ map: texture, toneMapped: false });\n }\n\n render(renderer: WebGLRenderer) {\n this.quaternion.copy(this.camera.quaternion).invert();\n this.updateMatrixWorld();\n\n const clippingPlanes = renderer.clippingPlanes;\n const viewport = renderer.getViewport(new Vector4());\n\n renderer.setViewport(this.position.x, this.position.y, this.size, this.size);\n renderer.clippingPlanes = [];\n renderer.clearDepth();\n renderer.render(this, this.orthoCamera);\n\n renderer.setViewport(viewport);\n renderer.clippingPlanes = clippingPlanes;\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { IComponent } from \"@inweb/viewer-core\";\nimport type { Viewer } from \"../Viewer\";\nimport { WCSHelper } from \"../helpers/WCSHelper\";\n\nexport class WCSHelperComponent implements IComponent {\n private wcsHelper: WCSHelper;\n private viewer: Viewer;\n\n constructor(viewer: Viewer) {\n this.wcsHelper = new WCSHelper(viewer.camera);\n this.viewer = viewer;\n this.viewer.addEventListener(\"databasechunk\", this.geometryEnd);\n this.viewer.addEventListener(\"drawviewpoint\", this.geometryEnd);\n this.viewer.addEventListener(\"render\", this.viewerRender);\n }\n\n dispose() {\n this.viewer.removeEventListener(\"databasechunk\", this.geometryEnd);\n this.viewer.removeEventListener(\"drawviewpoint\", this.geometryEnd);\n this.viewer.removeEventListener(\"render\", this.viewerRender);\n this.wcsHelper.dispose();\n }\n\n geometryEnd = () => {\n this.wcsHelper.dispose();\n this.wcsHelper = new WCSHelper(this.viewer.camera);\n };\n\n viewerRender = () => {\n if (!this.viewer.options.showWCS) return;\n\n this.wcsHelper.render(this.viewer.renderer);\n };\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { IComponentsRegistry, componentsRegistry } from \"@inweb/viewer-core\";\n\nimport { BackgroundComponent } from \"./BackgroundComponent\";\nimport { CameraComponent } from \"./CameraComponent\";\nimport { ExtentsComponent } from \"./ExtentsComponent\";\nimport { LightComponent } from \"./LightComponent\";\nimport { RenderLoopComponent } from \"./RenderLoopComponent\";\nimport { ResizeCanvasComponent } from \"./ResizeCanvasComponent\";\nimport { HighlighterComponent } from \"./HighlighterComponent\";\nimport { SelectionComponent } from \"./SelectionComponent\";\nimport { WCSHelperComponent } from \"./WCSHelperComponent\";\n\n/**\n * Viewer components registry. Use this registry to register custom components.\n *\n * To implement custom component:\n *\n * 1. Define a component class implements {@link IComponent}.\n * 2. Define a constructor with a `viewer` parameter and add mouse event listeners for the specified viewer.\n * 3. Define the component logic in the event listeners. For example, listen for the `mousedown` event and\n * select objects when the left mouse button is pressed.\n * 4. Override {@link IComponent.dispose} and remove mouse event listeners from the viewer.\n * 5. Register component provider in the components registry by calling the\n * {@link components.registerComponent}.\n *\n * @example Implementing a custom component.\n *\n * ```javascript\n * import { IComponent, components, Viewer } from \"@inweb/viewer-three\";\n *\n * class MyComponent implements IComponent {\n * protected viewer: Viewer;\n *\n * constructor(viewer: Viewer) {\n * this.viewer = viewer;\n * this.viewer.addEventListener(\"mousedown\", this.onMouseDown);\n * }\n *\n * override dispose() {\n * this.viewer.removeEventListener(\"mousedown\", this.onMouseDown);\n * }\n *\n * onMouseDown = (event: PointerEvent) => {\n * // place custom logic here\n * };\n * }\n *\n * components.registerComponent(\"MyComponent\", (viewer): IComponent => new MyComponent(viewer));\n * ```\n */\nexport const components: IComponentsRegistry = componentsRegistry(\"threejs\");\n\n// build-in components\n\ncomponents.registerComponent(\"ExtentsComponent\", (viewer) => new ExtentsComponent(viewer));\ncomponents.registerComponent(\"CameraComponent\", (viewer) => new CameraComponent(viewer));\ncomponents.registerComponent(\"BackgroundComponent\", (viewer) => new BackgroundComponent(viewer));\ncomponents.registerComponent(\"LightComponent\", (viewer) => new LightComponent(viewer));\ncomponents.registerComponent(\"ResizeCanvasComponent\", (viewer) => new ResizeCanvasComponent(viewer));\ncomponents.registerComponent(\"RenderLoopComponent\", (viewer) => new RenderLoopComponent(viewer));\ncomponents.registerComponent(\"HighlighterComponent\", (viewer) => new HighlighterComponent(viewer));\ncomponents.registerComponent(\"SelectionComponent\", (viewer) => new SelectionComponent(viewer));\ncomponents.registerComponent(\"WCSHelperComponent\", (viewer) => new WCSHelperComponent(viewer));\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { LoadingManager, LoaderUtils } from \"three\";\n\nexport type GLTFFileSource = string | globalThis.File | ArrayBuffer | Blob;\n\nexport type GLTFLoadParams = {\n path?: string;\n externalFiles?: Map<string, GLTFFileSource>;\n requestHeader?: HeadersInit;\n crossOrigin?: string;\n withCredentials?: boolean;\n};\n\nexport class GLTFLoadingManager extends LoadingManager {\n public path = \"\";\n public resourcePath = \"\";\n public fileURL = \"\";\n public dataURLs = new Map();\n\n constructor(file: GLTFFileSource, params: GLTFLoadParams = {}) {\n super();\n\n this.path = params.path || \"\";\n\n const externalFiles = params.externalFiles || new Map();\n\n if (typeof file === \"string\") {\n this.fileURL = file;\n this.resourcePath = LoaderUtils.extractUrlBase(file);\n } else {\n externalFiles.forEach((value, key) => (this.fileURL = value === file ? key : this.fileURL));\n externalFiles.set(this.fileURL, file);\n }\n\n externalFiles.forEach((value, key) => {\n let dataURL: string;\n if (typeof value === \"string\") dataURL = value;\n else dataURL = URL.createObjectURL(new Blob([value]));\n this.dataURLs.set(key, dataURL);\n });\n\n this.setURLModifier((url: string) => {\n const key = decodeURI(url)\n .replace(this.path, \"\")\n .replace(this.resourcePath, \"\")\n .replace(/^(\\.?\\/)/, \"\");\n const dataURL = this.dataURLs.get(key);\n return dataURL ?? url;\n });\n }\n\n dispose() {\n this.dataURLs.forEach(URL.revokeObjectURL);\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Box3, Object3D, Vector3 } from \"three\";\nimport { ILoader } from \"@inweb/viewer-core\";\n\nimport { IModelImpl } from \"./IModelImpl\";\nimport { Viewer } from \"../Viewer\";\n\n/**\n * Basic model implementation.\n */\nexport class ModelImpl implements IModelImpl {\n public handle: string;\n public scene: Object3D;\n public loader: ILoader;\n public viewer: Viewer;\n\n constructor(scene: Object3D) {\n this.handle = \"1\";\n this.scene = scene;\n }\n\n dispose() {\n function disposeMaterial(material: any) {\n // if (material.alphaMap) material.alphaMap.dispose();\n // if (material.anisotropyMap) material.anisotropyMap.dispose();\n // if (material.aoMap) material.aoMap.dispose();\n // if (material.bumpMap) material.bumpMap.dispose();\n // if (material.clearcoatMap) material.clearcoatMap.dispose();\n // if (material.clearcoatNormalMap) material.clearcoatNormalMap.dispose();\n // if (material.clearcoatRoughnessMap) material.clearcoatRoughnessMap.dispose();\n // if (material.displacementMap) material.displacementMap.dispose();\n // if (material.emissiveMap) material.emissiveMap.dispose();\n // if (material.gradientMap) material.gradientMap.dispose();\n // if (material.envMap) material.envMap.dispose();\n // if (material.iridescenceMap) material.iridescenceMap.dispose();\n // if (material.lightMap) material.lightMap.dispose();\n // if (material.map) material.map.dispose();\n // if (material.metalnessMap) material.metalnessMap.dispose();\n // if (material.normalMap) material.normalMap.dispose();\n // if (material.roughnessMap) material.roughnessMap.dispose();\n // if (material.sheenColorMap) material.sheenColorMap.dispose();\n // if (material.sheenRoughnessMap) material.sheenRoughnessMap.dispose();\n // if (material.specularMap) material.specularMap.dispose();\n // if (material.thicknessMap) material.thicknessMap.dispose();\n // if (material.transmissionMap) material.transmissionMap.dispose();\n material.dispose();\n }\n\n function disposeMaterials(material: any) {\n const materials = Array.isArray(material) ? material : [material];\n materials.forEach((material: any) => disposeMaterial(material));\n }\n\n function disposeObject(object: any) {\n if (object.geometry) object.geometry.dispose();\n if (object.material) disposeMaterials(object.material);\n }\n\n this.scene.traverse(disposeObject);\n this.scene.clear();\n }\n\n getExtents(target: Box3): Box3 {\n this.scene.traverseVisible((object) => !object.children.length && target.expandByObject(object));\n return target;\n }\n\n getObjects(): Object3D[] {\n const objects = [];\n this.scene.traverse((object) => objects.push(object));\n return objects;\n }\n\n getVisibleObjects(): Object3D[] {\n const objects = [];\n this.scene.traverseVisible((object) => objects.push(object));\n return objects;\n }\n\n hasObject(object: Object3D): boolean {\n while (object) {\n if (object === this.scene) return true;\n object = object.parent;\n }\n return false;\n }\n\n getOwnObjects(objects: Object3D | Object3D[]): Object3D[] {\n if (!Array.isArray(objects)) objects = [objects];\n return objects.filter((object) => this.hasObject(object));\n }\n\n getObjectsByHandles(handles: string | string[]): Object3D[] {\n const handleSet = new Set(handles);\n const objects = [];\n this.scene.traverse((object) => handleSet.has(object.userData.handle) && objects.push(object));\n return objects;\n }\n\n getHandlesByObjects(objects: Object3D | Object3D[]): string[] {\n if (!Array.isArray(objects)) objects = [objects];\n const handlesSet = new Set<string>();\n this.getOwnObjects(objects).forEach((object) => handlesSet.add(object.userData.handle));\n return Array.from(handlesSet);\n }\n\n hideObjects(objects: Object3D | Object3D[]): this {\n if (!Array.isArray(objects)) objects = [objects];\n this.getOwnObjects(objects).forEach((object) => (object.visible = false));\n return this;\n }\n\n hideAllObjects(): this {\n return this.isolateObjects([]);\n }\n\n isolateObjects(objects: Object3D | Object3D[]): this {\n if (!Array.isArray(objects)) objects = [objects];\n const visibleSet = new Set(objects);\n this.getOwnObjects(objects).forEach((object) => object.traverseAncestors((parent) => visibleSet.add(parent)));\n this.scene.traverse((object) => (object.visible = visibleSet.has(object)));\n return this;\n }\n\n showObjects(objects: Object3D | Object3D[]): this {\n if (!Array.isArray(objects)) objects = [objects];\n this.getOwnObjects(objects).forEach((object) => {\n object.visible = true;\n object.traverseAncestors((parent) => (parent.visible = true));\n });\n return this;\n }\n\n showAllObjects(): this {\n this.scene.traverse((object) => (object.visible = true));\n return this;\n }\n\n showOriginalObjects(objects: Object3D | Object3D[]): this {\n return this;\n }\n\n hideOriginalObjects(objects: Object3D | Object3D[]): this {\n return this;\n }\n\n explode(scale = 0, coeff = 4): this {\n function calcExplodeDepth(object: Object3D, depth: number): number {\n let res = depth;\n object.children.forEach((x: Object3D) => {\n const objectDepth = calcExplodeDepth(x, depth + 1);\n if (res < objectDepth) res = objectDepth;\n });\n\n object.userData.originalPosition = object.position.clone();\n object.userData.originalCenter = new Box3().setFromObject(object).getCenter(new Vector3());\n object.userData.isExplodeLocked = depth > 2 && object.children.length === 0;\n\n return res;\n }\n\n scale /= 100;\n\n if (!this.scene.userData.explodeDepth) this.scene.userData.explodeDepth = calcExplodeDepth(this.scene, 1);\n const maxDepth = this.scene.userData.explodeDepth;\n\n const scaledExplodeDepth = scale * maxDepth + 1;\n const explodeDepth = 0 | scaledExplodeDepth;\n const currentSegmentFraction = scaledExplodeDepth - explodeDepth;\n\n function explodeObject(object: Object3D, depth: number) {\n object.position.copy(object.userData.originalPosition);\n\n if (depth > 0 && depth <= explodeDepth && !object.userData.isExplodeLocked) {\n let objectScale = scale * coeff;\n if (depth === explodeDepth) objectScale *= currentSegmentFraction;\n\n const parentCenter = object.parent.userData.originalCenter;\n const objectCenter = object.userData.originalCenter;\n const objectOffset = objectCenter.clone().sub(parentCenter).multiplyScalar(objectScale);\n\n object.position.add(objectOffset);\n }\n\n object.children.forEach((x) => explodeObject(x, depth + 1));\n }\n\n explodeObject(this.scene, 0);\n this.scene.updateMatrixWorld();\n\n return this;\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { GLTFLoader } from \"three/examples/jsm/loaders/GLTFLoader.js\";\nimport { Loader } from \"@inweb/viewer-core\";\n\nimport { Viewer } from \"../Viewer\";\nimport { GLTFLoadingManager, GLTFLoadParams } from \"./GLTFLoadingManager\";\nimport { ModelImpl } from \"../model/ModelImpl\";\n\nexport class GLTFFileLoader extends Loader {\n public viewer: Viewer;\n\n constructor(viewer: Viewer) {\n super();\n this.viewer = viewer;\n }\n\n override isSupport(file: any, format?: string): boolean {\n return (\n (typeof file === \"string\" || file instanceof globalThis.File || file instanceof ArrayBuffer) &&\n /(gltf|glb)$/i.test(format)\n );\n }\n\n override async load(file: any, format?: string, params?: GLTFLoadParams): Promise<this> {\n const manager = new GLTFLoadingManager(file, params);\n\n const loader = new GLTFLoader(manager);\n loader.setPath(manager.path);\n loader.setCrossOrigin(params.crossOrigin || loader.crossOrigin);\n loader.setWithCredentials(params.withCredentials || loader.withCredentials);\n\n const progress = (event: ProgressEvent) => {\n const { lengthComputable, loaded, total } = event;\n const progress = lengthComputable ? loaded / total : 1;\n this.viewer.emitEvent({ type: \"geometryprogress\", data: progress, file });\n };\n\n const gltf = await loader.loadAsync(manager.fileURL, progress);\n if (!this.viewer.scene) return this;\n\n const modelImpl = new ModelImpl(gltf.scene);\n modelImpl.loader = this;\n modelImpl.viewer = this.viewer;\n\n this.viewer.scene.add(modelImpl.scene);\n this.viewer.models.push(modelImpl);\n\n this.viewer.syncOptions();\n this.viewer.syncOverlay();\n this.viewer.update();\n\n this.viewer.emitEvent({ type: \"databasechunk\", data: gltf.scene, file });\n\n return this;\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Box3, Object3D } from \"three\";\n\nimport { ModelImpl } from \"../../model\";\nimport { DynamicGltfLoader } from \"./DynamicGltfLoader.js\";\n\n/**\n * Dynamic model implementation.\n */\nexport class DynamicModelImpl extends ModelImpl {\n public gltfLoader: DynamicGltfLoader;\n\n override getExtents(target: Box3): Box3 {\n return target.union(this.gltfLoader.getTotalGeometryExtent());\n }\n\n override getObjects(): Object3D[] {\n const objects = [];\n this.gltfLoader.originalObjects.forEach((object: Object3D) => {\n objects.push(object);\n });\n return objects;\n }\n\n override getVisibleObjects(): Object3D[] {\n return this.gltfLoader.getOriginalObjectForSelect();\n }\n\n override hasObject(object: any): boolean {\n return this.gltfLoader.originalObjects.has(object);\n }\n\n override getObjectsByHandles(handles: string | string[]): Object3D[] {\n const handlesSet = new Set(handles);\n const objects = [];\n handlesSet.forEach((handle) => {\n const handles = this.gltfLoader.handleToObjects.get(handle) || [];\n objects.push(...Array.from(handles));\n });\n return objects;\n }\n\n override hideObjects(objects: Object3D | Object3D[]): this {\n this.getOwnObjects(objects)\n .map((object) => object.userData.handle)\n .forEach((handle) => this.gltfLoader.hiddenHandles.add(handle));\n this.gltfLoader.syncHiddenObjects();\n return this;\n }\n\n override isolateObjects(objects: Object3D | Object3D[]): this {\n const handles = this.getHandlesByObjects(objects);\n this.gltfLoader.isolateObjects(new Set(handles));\n return this;\n }\n\n override showObjects(objects: Object3D | Object3D[]): this {\n this.getOwnObjects(objects)\n .map((object) => object.userData.handle)\n .forEach((handle) => this.gltfLoader.hiddenHandles.delete(handle));\n this.gltfLoader.syncHiddenObjects();\n return this;\n }\n\n override showAllObjects(): this {\n this.gltfLoader.hiddenHandles.clear();\n this.gltfLoader.syncHiddenObjects();\n return this;\n }\n\n override showOriginalObjects(objects: Object3D | Object3D[]): this {\n this.getOwnObjects(objects).forEach((object) => (object.visible = true));\n return this;\n }\n\n override hideOriginalObjects(objects: Object3D | Object3D[]): this {\n this.getOwnObjects(objects).forEach((object) => (object.visible = false));\n return this;\n }\n}\n","import { TextureLoader, BufferAttribute, MeshStandardMaterial, DoubleSide, FrontSide } from \"three\";\n\nexport const GL_COMPONENT_TYPES = {\n 5120: Int8Array,\n 5121: Uint8Array,\n 5122: Int16Array,\n 5123: Uint16Array,\n 5125: Uint32Array,\n 5126: Float32Array,\n};\n\nexport const GL_CONSTANTS = {\n FLOAT: 5126,\n //FLOAT_MAT2: 35674,\n FLOAT_MAT3: 35675,\n FLOAT_MAT4: 35676,\n FLOAT_VEC2: 35664,\n FLOAT_VEC3: 35665,\n FLOAT_VEC4: 35666,\n LINEAR: 9729,\n REPEAT: 10497,\n SAMPLER_2D: 35678,\n POINTS: 0,\n LINES: 1,\n LINE_LOOP: 2,\n LINE_STRIP: 3,\n TRIANGLES: 4,\n TRIANGLE_STRIP: 5,\n TRIANGLE_FAN: 6,\n UNSIGNED_BYTE: 5121,\n UNSIGNED_SHORT: 5123,\n};\n\nexport class GltfStructure {\n constructor(id) {\n this.id = `${id}`;\n this.json = null;\n this.baseUrl = \"\";\n\n // Binary manager properties\n this.loadController = null;\n // Request batching parameters\n this.batchDelay = 10;\n this.maxBatchSize = 5 * 1024 * 1024;\n this.maxRangesPerRequest = 512;\n\n // Request queue\n this.pendingRequests = [];\n this.batchTimeout = null;\n\n // Material and texture properties\n this.textureLoader = new TextureLoader();\n this.materials = new Map();\n this.textureCache = new Map();\n }\n\n async initialize(loadController) {\n this.json = await loadController.loadJson();\n this.baseUrl = await loadController.baseUrl();\n this.loadController = loadController;\n }\n\n clear() {\n this.json = null;\n this.baseUrl = \"\";\n this.loadController = null;\n this.pendingRequests = [];\n if (this.batchTimeout) {\n clearTimeout(this.batchTimeout);\n this.batchTimeout = null;\n }\n\n // Clear materials and textures\n this.disposeMaterials();\n this.textureCache.clear();\n this.materials.clear();\n }\n\n getJson() {\n return this.json;\n }\n\n // Schedule a request for processing\n scheduleRequest(request) {\n this.pendingRequests.push(request);\n\n // Clear existing timeout\n if (this.batchTimeout) {\n clearTimeout(this.batchTimeout);\n }\n\n // Set new timeout for batch processing\n this.batchTimeout = setTimeout(() => this.processBatch(), this.batchDelay);\n\n // Return a promise that will resolve when the data is available\n return new Promise((resolve, reject) => {\n request.resolve = resolve;\n request.reject = reject;\n });\n }\n\n async processBatch() {\n if (this.pendingRequests.length === 0) return;\n\n // Take current batch of requests and clear timeout\n const currentBatch = [...this.pendingRequests];\n this.pendingRequests = [];\n\n if (this.batchTimeout) {\n clearTimeout(this.batchTimeout);\n this.batchTimeout = null;\n }\n try {\n // Split requests into smaller groups\n for (let i = 0; i < currentBatch.length; i += this.maxRangesPerRequest) {\n const batchRequests = currentBatch.slice(i, i + this.maxRangesPerRequest);\n const buffer = await this.loadController.loadBinaryData(batchRequests);\n\n let currentOffset = 0;\n batchRequests.forEach((request) => {\n const view = this.createTypedArray(buffer, currentOffset, request.length, request.componentType);\n request.resolve(view);\n currentOffset += request.length;\n });\n }\n } catch (error) {\n console.error(\"Error processing batch:\", error);\n currentBatch.forEach((request) => request.reject(error));\n }\n\n if (this.pendingRequests.length > 0) {\n this.batchTimeout = setTimeout(() => this.processBatch(), this.batchDelay);\n }\n }\n\n getBufferView(byteOffset, byteLength, componentType) {\n return this.scheduleRequest({\n offset: byteOffset,\n length: byteLength,\n componentType,\n });\n }\n\n createTypedArray(buffer, offset, length, componentType) {\n try {\n // Validate parameters\n if (!buffer || !(buffer instanceof ArrayBuffer)) {\n throw new Error(\"Invalid buffer\");\n }\n\n // Calculate element size for given type\n let elementSize;\n switch (componentType) {\n case 5120:\n case 5121:\n elementSize = 1;\n break; // BYTE, UNSIGNED_BYTE\n case 5122:\n case 5123:\n elementSize = 2;\n break; // SHORT, UNSIGNED_SHORT\n case 5125:\n case 5126:\n elementSize = 4;\n break; // UNSIGNED_INT, FLOAT\n default:\n throw new Error(`Unsupported component type: ${componentType}`);\n }\n\n // Check if requested length is correct\n const numElements = length / elementSize;\n if (!Number.isInteger(numElements)) {\n throw new Error(`Invalid length ${length} for component type ${componentType}`);\n }\n\n // Check if buffer is large enough\n if (length > buffer.byteLength) {\n throw new Error(`Buffer too small: need ${length} bytes, but buffer is ${buffer.byteLength} bytes`);\n }\n\n // Create appropriate typed array\n const ArrayType = GL_COMPONENT_TYPES[componentType];\n return new ArrayType(buffer, offset, numElements);\n } catch (error) {\n if (error.name !== \"AbortError\") {\n console.error(\"Error creating typed array:\", {\n bufferSize: buffer?.byteLength,\n offset,\n length,\n componentType,\n error,\n });\n }\n throw error;\n }\n }\n\n async createBufferAttribute(accessorIndex) {\n if (!this.json) {\n throw new Error(\"No GLTF structure loaded\");\n }\n\n const gltf = this.json;\n const accessor = gltf.accessors[accessorIndex];\n const bufferView = gltf.bufferViews[accessor.bufferView];\n\n try {\n const byteOffset = (bufferView.byteOffset || 0) + (accessor.byteOffset || 0);\n const components = this.getNumComponents(accessor.type);\n const count = accessor.count;\n const byteLength = count * components * this.getComponentSize(accessor.componentType);\n\n const array = await this.getBufferView(byteOffset, byteLength, accessor.componentType);\n\n const attribute = new BufferAttribute(array, components);\n\n if (accessor.min !== undefined) attribute.min = accessor.min;\n if (accessor.max !== undefined) attribute.max = accessor.max;\n\n return attribute;\n } catch (error) {\n if (error.name !== \"AbortError\") {\n console.error(\"Error creating buffer attribute:\", {\n error,\n accessor,\n bufferView,\n });\n }\n\n throw error;\n }\n }\n\n getComponentSize(componentType) {\n switch (componentType) {\n case 5120: // BYTE\n case 5121: // UNSIGNED_BYTE\n return 1;\n case 5122: // SHORT\n case 5123: // UNSIGNED_SHORT\n return 2;\n case 5125: // UNSIGNED_INT\n case 5126: // FLOAT\n return 4;\n default:\n throw new Error(`Unknown component type: ${componentType}`);\n }\n }\n\n getNumComponents(type) {\n switch (type) {\n case \"SCALAR\":\n return 1;\n case \"VEC2\":\n return 2;\n case \"VEC3\":\n return 3;\n case \"VEC4\":\n return 4;\n case \"MAT2\":\n return 4;\n case \"MAT3\":\n return 9;\n case \"MAT4\":\n return 16;\n default:\n throw new Error(`Unknown type: ${type}`);\n }\n }\n\n async loadTextures() {\n if (!this.json.textures) return;\n\n const loadTexture = async (imageIndex) => {\n const image = this.json.images[imageIndex];\n\n if (image.uri) {\n // Handle base64 or URL\n if (image.uri.startsWith(\"data:\")) {\n return await this.textureLoader.loadAsync(image.uri);\n } else {\n const fullUrl = this.baseUrl + image.uri;\n return await this.textureLoader.loadAsync(fullUrl);\n }\n } else if (image.bufferView !== undefined) {\n // Handle embedded binary data\n const bufferView = this.json.bufferViews[image.bufferView];\n const array = await this.getBufferView(\n bufferView.byteOffset || 0,\n bufferView.byteLength,\n 5121 // UNSIGNED_BYTE\n );\n const blob = new Blob([array], { type: image.mimeType });\n const url = URL.createObjectURL(blob);\n const texture = await this.textureLoader.loadAsync(url);\n URL.revokeObjectURL(url);\n texture.flipY = false; // GLTF standard\n return texture;\n }\n };\n\n // Load all textures\n const texturePromises = [];\n for (let i = 0; i < this.json.textures.length; i++) {\n texturePromises.push(\n loadTexture(this.json.textures[i].source).then((texture) => this.textureCache.set(i, texture))\n );\n }\n await Promise.all(texturePromises);\n }\n\n loadMaterials() {\n if (!this.json.materials) return this.materials;\n\n for (let i = 0; i < this.json.materials.length; i++) {\n const materialDef = this.json.materials[i];\n const material = this.createMaterial(materialDef);\n this.materials.set(i, material);\n }\n return this.materials;\n }\n\n createMaterial(materialDef) {\n const material = new MeshStandardMaterial();\n\n // Base color\n if (materialDef.pbrMetallicRoughness) {\n const pbr = materialDef.pbrMetallicRoughness;\n\n if (pbr.baseColorFactor) {\n material.color.fromArray(pbr.baseColorFactor);\n material.opacity = pbr.baseColorFactor[3];\n }\n\n if (pbr.baseColorTexture) {\n material.map = this.textureCache.get(pbr.baseColorTexture.index);\n }\n\n // Metallic and roughness\n if (pbr.metallicFactor !== undefined) {\n material.metalness = pbr.metallicFactor;\n }\n if (pbr.roughnessFactor !== undefined) {\n material.roughness = pbr.roughnessFactor;\n }\n if (pbr.metallicRoughnessTexture) {\n material.metalnessMap = this.textureCache.get(pbr.metallicRoughnessTexture.index);\n material.roughnessMap = material.metalnessMap;\n }\n }\n\n // Normal map\n if (materialDef.normalTexture) {\n material.normalMap = this.textureCache.get(materialDef.normalTexture.index);\n if (materialDef.normalTexture.scale !== undefined) {\n material.normalScale.set(materialDef.normalTexture.scale, materialDef.normalTexture.scale);\n }\n }\n\n // Emissive\n if (materialDef.emissiveFactor) {\n material.emissive.fromArray(materialDef.emissiveFactor);\n }\n if (materialDef.emissiveTexture) {\n material.emissiveMap = this.textureCache.get(materialDef.emissiveTexture.index);\n }\n\n // Occlusion\n if (materialDef.occlusionTexture) {\n material.aoMap = this.textureCache.get(materialDef.occlusionTexture.index);\n if (materialDef.occlusionTexture.strength !== undefined) {\n material.aoMapIntensity = materialDef.occlusionTexture.strength;\n }\n }\n\n // Alpha mode\n if (materialDef.alphaMode === \"BLEND\") {\n material.transparent = true;\n } else if (materialDef.alphaMode === \"MASK\") {\n material.alphaTest = materialDef.alphaCutoff !== undefined ? materialDef.alphaCutoff : 0.5;\n }\n\n // Double sided\n material.side = materialDef.doubleSided ? DoubleSide : FrontSide;\n\n material.name = materialDef.name;\n\n return material;\n }\n\n disposeMaterials() {\n // Dispose all textures\n this.textureCache.forEach((texture) => texture.dispose());\n this.textureCache.clear();\n\n // Dispose all materials\n this.materials.forEach((material) => {\n if (material.map) material.map.dispose();\n if (material.lightMap) material.lightMap.dispose();\n if (material.bumpMap) material.bumpMap.dispose();\n if (material.normalMap) material.normalMap.dispose();\n if (material.specularMap) material.specularMap.dispose();\n if (material.envMap) material.envMap.dispose();\n if (material.aoMap) material.aoMap.dispose();\n if (material.metalnessMap) material.metalnessMap.dispose();\n if (material.roughnessMap) material.roughnessMap.dispose();\n if (material.emissiveMap) material.emissiveMap.dispose();\n material.dispose();\n });\n this.materials.clear();\n }\n\n estimateNodeSize(meshIndex) {\n if (!this.json.meshes) return 0;\n\n const meshDef = this.json.meshes[meshIndex];\n if (!meshDef || !meshDef.primitives) return 0;\n\n let totalSize = 0;\n\n // Estimate size for each primitive\n for (const primitive of meshDef.primitives) {\n // Check for attributes\n if (primitive.attributes) {\n // Calculate attributes size\n for (const [, accessorIndex] of Object.entries(primitive.attributes)) {\n if (accessorIndex === undefined) continue;\n\n const accessor = this.json.accessors[accessorIndex];\n if (!accessor) continue;\n\n const numComponents = this.getNumComponents(accessor.type);\n const bytesPerComponent = this.getComponentSize(accessor.componentType);\n totalSize += accessor.count * numComponents * bytesPerComponent;\n }\n }\n\n // Calculate indices size if present\n if (primitive.indices !== undefined) {\n const accessor = this.json.accessors[primitive.indices];\n if (accessor) {\n const bytesPerComponent = this.getComponentSize(accessor.componentType);\n totalSize += accessor.count * bytesPerComponent;\n }\n }\n }\n\n return totalSize;\n }\n}\n","import {\n\tBufferAttribute,\n\tBufferGeometry,\n\tFloat32BufferAttribute,\n\tInstancedBufferAttribute,\n\tInterleavedBuffer,\n\tInterleavedBufferAttribute,\n\tTriangleFanDrawMode,\n\tTriangleStripDrawMode,\n\tTrianglesDrawMode,\n\tVector3,\n} from 'three';\n\nfunction computeMikkTSpaceTangents( geometry, MikkTSpace, negateSign = true ) {\n\n\tif ( ! MikkTSpace || ! MikkTSpace.isReady ) {\n\n\t\tthrow new Error( 'BufferGeometryUtils: Initialized MikkTSpace library required.' );\n\n\t}\n\n\tif ( ! geometry.hasAttribute( 'position' ) || ! geometry.hasAttribute( 'normal' ) || ! geometry.hasAttribute( 'uv' ) ) {\n\n\t\tthrow new Error( 'BufferGeometryUtils: Tangents require \"position\", \"normal\", and \"uv\" attributes.' );\n\n\t}\n\n\tfunction getAttributeArray( attribute ) {\n\n\t\tif ( attribute.normalized || attribute.isInterleavedBufferAttribute ) {\n\n\t\t\tconst dstArray = new Float32Array( attribute.count * attribute.itemSize );\n\n\t\t\tfor ( let i = 0, j = 0; i < attribute.count; i ++ ) {\n\n\t\t\t\tdstArray[ j ++ ] = attribute.getX( i );\n\t\t\t\tdstArray[ j ++ ] = attribute.getY( i );\n\n\t\t\t\tif ( attribute.itemSize > 2 ) {\n\n\t\t\t\t\tdstArray[ j ++ ] = attribute.getZ( i );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\treturn dstArray;\n\n\t\t}\n\n\t\tif ( attribute.array instanceof Float32Array ) {\n\n\t\t\treturn attribute.array;\n\n\t\t}\n\n\t\treturn new Float32Array( attribute.array );\n\n\t}\n\n\t// MikkTSpace algorithm requires non-indexed input.\n\n\tconst _geometry = geometry.index ? geometry.toNonIndexed() : geometry;\n\n\t// Compute vertex tangents.\n\n\tconst tangents = MikkTSpace.generateTangents(\n\n\t\tgetAttributeArray( _geometry.attributes.position ),\n\t\tgetAttributeArray( _geometry.attributes.normal ),\n\t\tgetAttributeArray( _geometry.attributes.uv )\n\n\t);\n\n\t// Texture coordinate convention of glTF differs from the apparent\n\t// default of the MikkTSpace library; .w component must be flipped.\n\n\tif ( negateSign ) {\n\n\t\tfor ( let i = 3; i < tangents.length; i += 4 ) {\n\n\t\t\ttangents[ i ] *= - 1;\n\n\t\t}\n\n\t}\n\n\t//\n\n\t_geometry.setAttribute( 'tangent', new BufferAttribute( tangents, 4 ) );\n\n\tif ( geometry !== _geometry ) {\n\n\t\tgeometry.copy( _geometry );\n\n\t}\n\n\treturn geometry;\n\n}\n\n/**\n * @param {Array<BufferGeometry>} geometries\n * @param {Boolean} useGroups\n * @return {BufferGeometry}\n */\nfunction mergeGeometries( geometries, useGroups = false ) {\n\n\tconst isIndexed = geometries[ 0 ].index !== null;\n\n\tconst attributesUsed = new Set( Object.keys( geometries[ 0 ].attributes ) );\n\tconst morphAttributesUsed = new Set( Object.keys( geometries[ 0 ].morphAttributes ) );\n\n\tconst attributes = {};\n\tconst morphAttributes = {};\n\n\tconst morphTargetsRelative = geometries[ 0 ].morphTargetsRelative;\n\n\tconst mergedGeometry = new BufferGeometry();\n\n\tlet offset = 0;\n\n\tfor ( let i = 0; i < geometries.length; ++ i ) {\n\n\t\tconst geometry = geometries[ i ];\n\t\tlet attributesCount = 0;\n\n\t\t// ensure that all geometries are indexed, or none\n\n\t\tif ( isIndexed !== ( geometry.index !== null ) ) {\n\n\t\t\tconsole.error( 'THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index ' + i + '. All geometries must have compatible attributes; make sure index attribute exists among all geometries, or in none of them.' );\n\t\t\treturn null;\n\n\t\t}\n\n\t\t// gather attributes, exit early if they're different\n\n\t\tfor ( const name in geometry.attributes ) {\n\n\t\t\tif ( ! attributesUsed.has( name ) ) {\n\n\t\t\t\tconsole.error( 'THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index ' + i + '. All geometries must have compatible attributes; make sure \"' + name + '\" attribute exists among all geometries, or in none of them.' );\n\t\t\t\treturn null;\n\n\t\t\t}\n\n\t\t\tif ( attributes[ name ] === undefined ) attributes[ name ] = [];\n\n\t\t\tattributes[ name ].push( geometry.attributes[ name ] );\n\n\t\t\tattributesCount ++;\n\n\t\t}\n\n\t\t// ensure geometries have the same number of attributes\n\n\t\tif ( attributesCount !== attributesUsed.size ) {\n\n\t\t\tconsole.error( 'THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index ' + i + '. Make sure all geometries have the same number of attributes.' );\n\t\t\treturn null;\n\n\t\t}\n\n\t\t// gather morph attributes, exit early if they're different\n\n\t\tif ( morphTargetsRelative !== geometry.morphTargetsRelative ) {\n\n\t\t\tconsole.error( 'THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index ' + i + '. .morphTargetsRelative must be consistent throughout all geometries.' );\n\t\t\treturn null;\n\n\t\t}\n\n\t\tfor ( const name in geometry.morphAttributes ) {\n\n\t\t\tif ( ! morphAttributesUsed.has( name ) ) {\n\n\t\t\t\tconsole.error( 'THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index ' + i + '. .morphAttributes must be consistent throughout all geometries.' );\n\t\t\t\treturn null;\n\n\t\t\t}\n\n\t\t\tif ( morphAttributes[ name ] === undefined ) morphAttributes[ name ] = [];\n\n\t\t\tmorphAttributes[ name ].push( geometry.morphAttributes[ name ] );\n\n\t\t}\n\n\t\tif ( useGroups ) {\n\n\t\t\tlet count;\n\n\t\t\tif ( isIndexed ) {\n\n\t\t\t\tcount = geometry.index.count;\n\n\t\t\t} else if ( geometry.attributes.position !== undefined ) {\n\n\t\t\t\tcount = geometry.attributes.position.count;\n\n\t\t\t} else {\n\n\t\t\t\tconsole.error( 'THREE.BufferGeometryUtils: .mergeGeometries() failed with geometry at index ' + i + '. The geometry must have either an index or a position attribute' );\n\t\t\t\treturn null;\n\n\t\t\t}\n\n\t\t\tmergedGeometry.addGroup( offset, count, i );\n\n\t\t\toffset += count;\n\n\t\t}\n\n\t}\n\n\t// merge indices\n\n\tif ( isIndexed ) {\n\n\t\tlet indexOffset = 0;\n\t\tconst mergedIndex = [];\n\n\t\tfor ( let i = 0; i < geometries.length; ++ i ) {\n\n\t\t\tconst index = geometries[ i ].index;\n\n\t\t\tfor ( let j = 0; j < index.count; ++ j ) {\n\n\t\t\t\tmergedIndex.push( index.getX( j ) + indexOffset );\n\n\t\t\t}\n\n\t\t\tindexOffset += geometries[ i ].attributes.position.count;\n\n\t\t}\n\n\t\tmergedGeometry.setIndex( mergedIndex );\n\n\t}\n\n\t// merge attributes\n\n\tfor ( const name in attributes ) {\n\n\t\tconst mergedAttribute = mergeAttributes( attributes[ name ] );\n\n\t\tif ( ! mergedAttribute ) {\n\n\t\t\tconsole.error( 'THREE.BufferGeometryUtils: .mergeGeometries() failed while trying to merge the ' + name + ' attribute.' );\n\t\t\treturn null;\n\n\t\t}\n\n\t\tmergedGeometry.setAttribute( name, mergedAttribute );\n\n\t}\n\n\t// merge morph attributes\n\n\tfor ( const name in morphAttributes ) {\n\n\t\tconst numMorphTargets = morphAttributes[ name ][ 0 ].length;\n\n\t\tif ( numMorphTargets === 0 ) break;\n\n\t\tmergedGeometry.morphAttributes = mergedGeometry.morphAttributes || {};\n\t\tmergedGeometry.morphAttributes[ name ] = [];\n\n\t\tfor ( let i = 0; i < numMorphTargets; ++ i ) {\n\n\t\t\tconst morphAttributesToMerge = [];\n\n\t\t\tfor ( let j = 0; j < morphAttributes[ name ].length; ++ j ) {\n\n\t\t\t\tmorphAttributesToMerge.push( morphAttributes[ name ][ j ][ i ] );\n\n\t\t\t}\n\n\t\t\tconst mergedMorphAttribute = mergeAttributes( morphAttributesToMerge );\n\n\t\t\tif ( ! mergedMorphAttribute ) {\n\n\t\t\t\tconsole.error( 'THREE.BufferGeometryUtils: .mergeGeometries() failed while trying to merge the ' + name + ' morphAttribute.' );\n\t\t\t\treturn null;\n\n\t\t\t}\n\n\t\t\tmergedGeometry.morphAttributes[ name ].push( mergedMorphAttribute );\n\n\t\t}\n\n\t}\n\n\treturn mergedGeometry;\n\n}\n\n/**\n * @param {Array<BufferAttribute>} attributes\n * @return {BufferAttribute}\n */\nfunction mergeAttributes( attributes ) {\n\n\tlet TypedArray;\n\tlet itemSize;\n\tlet normalized;\n\tlet gpuType = - 1;\n\tlet arrayLength = 0;\n\n\tfor ( let i = 0; i < attributes.length; ++ i ) {\n\n\t\tconst attribute = attributes[ i ];\n\n\t\tif ( TypedArray === undefined ) TypedArray = attribute.array.constructor;\n\t\tif ( TypedArray !== attribute.array.constructor ) {\n\n\t\t\tconsole.error( 'THREE.BufferGeometryUtils: .mergeAttributes() failed. BufferAttribute.array must be of consistent array types across matching attributes.' );\n\t\t\treturn null;\n\n\t\t}\n\n\t\tif ( itemSize === undefined ) itemSize = attribute.itemSize;\n\t\tif ( itemSize !== attribute.itemSize ) {\n\n\t\t\tconsole.error( 'THREE.BufferGeometryUtils: .mergeAttributes() failed. BufferAttribute.itemSize must be consistent across matching attributes.' );\n\t\t\treturn null;\n\n\t\t}\n\n\t\tif ( normalized === undefined ) normalized = attribute.normalized;\n\t\tif ( normalized !== attribute.normalized ) {\n\n\t\t\tconsole.error( 'THREE.BufferGeometryUtils: .mergeAttributes() failed. BufferAttribute.normalized must be consistent across matching attributes.' );\n\t\t\treturn null;\n\n\t\t}\n\n\t\tif ( gpuType === - 1 ) gpuType = attribute.gpuType;\n\t\tif ( gpuType !== attribute.gpuType ) {\n\n\t\t\tconsole.error( 'THREE.BufferGeometryUtils: .mergeAttributes() failed. BufferAttribute.gpuType must be consistent across matching attributes.' );\n\t\t\treturn null;\n\n\t\t}\n\n\t\tarrayLength += attribute.count * itemSize;\n\n\t}\n\n\tconst array = new TypedArray( arrayLength );\n\tconst result = new BufferAttribute( array, itemSize, normalized );\n\tlet offset = 0;\n\n\tfor ( let i = 0; i < attributes.length; ++ i ) {\n\n\t\tconst attribute = attributes[ i ];\n\t\tif ( attribute.isInterleavedBufferAttribute ) {\n\n\t\t\tconst tupleOffset = offset / itemSize;\n\t\t\tfor ( let j = 0, l = attribute.count; j < l; j ++ ) {\n\n\t\t\t\tfor ( let c = 0; c < itemSize; c ++ ) {\n\n\t\t\t\t\tconst value = attribute.getComponent( j, c );\n\t\t\t\t\tresult.setComponent( j + tupleOffset, c, value );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tarray.set( attribute.array, offset );\n\n\t\t}\n\n\t\toffset += attribute.count * itemSize;\n\n\t}\n\n\tif ( gpuType !== undefined ) {\n\n\t\tresult.gpuType = gpuType;\n\n\t}\n\n\treturn result;\n\n}\n\n/**\n * @param {BufferAttribute} attribute\n * @return {BufferAttribute}\n */\nexport function deepCloneAttribute( attribute ) {\n\n\tif ( attribute.isInstancedInterleavedBufferAttribute || attribute.isInterleavedBufferAttribute ) {\n\n\t\treturn deinterleaveAttribute( attribute );\n\n\t}\n\n\tif ( attribute.isInstancedBufferAttribute ) {\n\n\t\treturn new InstancedBufferAttribute().copy( attribute );\n\n\t}\n\n\treturn new BufferAttribute().copy( attribute );\n\n}\n\n/**\n * @param {Array<BufferAttribute>} attributes\n * @return {Array<InterleavedBufferAttribute>}\n */\nfunction interleaveAttributes( attributes ) {\n\n\t// Interleaves the provided attributes into an InterleavedBuffer and returns\n\t// a set of InterleavedBufferAttributes for each attribute\n\tlet TypedArray;\n\tlet arrayLength = 0;\n\tlet stride = 0;\n\n\t// calculate the length and type of the interleavedBuffer\n\tfor ( let i = 0, l = attributes.length; i < l; ++ i ) {\n\n\t\tconst attribute = attributes[ i ];\n\n\t\tif ( TypedArray === undefined ) TypedArray = attribute.array.constructor;\n\t\tif ( TypedArray !== attribute.array.constructor ) {\n\n\t\t\tconsole.error( 'AttributeBuffers of different types cannot be interleaved' );\n\t\t\treturn null;\n\n\t\t}\n\n\t\tarrayLength += attribute.array.length;\n\t\tstride += attribute.itemSize;\n\n\t}\n\n\t// Create the set of buffer attributes\n\tconst interleavedBuffer = new InterleavedBuffer( new TypedArray( arrayLength ), stride );\n\tlet offset = 0;\n\tconst res = [];\n\tconst getters = [ 'getX', 'getY', 'getZ', 'getW' ];\n\tconst setters = [ 'setX', 'setY', 'setZ', 'setW' ];\n\n\tfor ( let j = 0, l = attributes.length; j < l; j ++ ) {\n\n\t\tconst attribute = attributes[ j ];\n\t\tconst itemSize = attribute.itemSize;\n\t\tconst count = attribute.count;\n\t\tconst iba = new InterleavedBufferAttribute( interleavedBuffer, itemSize, offset, attribute.normalized );\n\t\tres.push( iba );\n\n\t\toffset += itemSize;\n\n\t\t// Move the data for each attribute into the new interleavedBuffer\n\t\t// at the appropriate offset\n\t\tfor ( let c = 0; c < count; c ++ ) {\n\n\t\t\tfor ( let k = 0; k < itemSize; k ++ ) {\n\n\t\t\t\tiba[ setters[ k ] ]( c, attribute[ getters[ k ] ]( c ) );\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\treturn res;\n\n}\n\n// returns a new, non-interleaved version of the provided attribute\nexport function deinterleaveAttribute( attribute ) {\n\n\tconst cons = attribute.data.array.constructor;\n\tconst count = attribute.count;\n\tconst itemSize = attribute.itemSize;\n\tconst normalized = attribute.normalized;\n\n\tconst array = new cons( count * itemSize );\n\tlet newAttribute;\n\tif ( attribute.isInstancedInterleavedBufferAttribute ) {\n\n\t\tnewAttribute = new InstancedBufferAttribute( array, itemSize, normalized, attribute.meshPerAttribute );\n\n\t} else {\n\n\t\tnewAttribute = new BufferAttribute( array, itemSize, normalized );\n\n\t}\n\n\tfor ( let i = 0; i < count; i ++ ) {\n\n\t\tnewAttribute.setX( i, attribute.getX( i ) );\n\n\t\tif ( itemSize >= 2 ) {\n\n\t\t\tnewAttribute.setY( i, attribute.getY( i ) );\n\n\t\t}\n\n\t\tif ( itemSize >= 3 ) {\n\n\t\t\tnewAttribute.setZ( i, attribute.getZ( i ) );\n\n\t\t}\n\n\t\tif ( itemSize >= 4 ) {\n\n\t\t\tnewAttribute.setW( i, attribute.getW( i ) );\n\n\t\t}\n\n\t}\n\n\treturn newAttribute;\n\n}\n\n// deinterleaves all attributes on the geometry\nexport function deinterleaveGeometry( geometry ) {\n\n\tconst attributes = geometry.attributes;\n\tconst morphTargets = geometry.morphTargets;\n\tconst attrMap = new Map();\n\n\tfor ( const key in attributes ) {\n\n\t\tconst attr = attributes[ key ];\n\t\tif ( attr.isInterleavedBufferAttribute ) {\n\n\t\t\tif ( ! attrMap.has( attr ) ) {\n\n\t\t\t\tattrMap.set( attr, deinterleaveAttribute( attr ) );\n\n\t\t\t}\n\n\t\t\tattributes[ key ] = attrMap.get( attr );\n\n\t\t}\n\n\t}\n\n\tfor ( const key in morphTargets ) {\n\n\t\tconst attr = morphTargets[ key ];\n\t\tif ( attr.isInterleavedBufferAttribute ) {\n\n\t\t\tif ( ! attrMap.has( attr ) ) {\n\n\t\t\t\tattrMap.set( attr, deinterleaveAttribute( attr ) );\n\n\t\t\t}\n\n\t\t\tmorphTargets[ key ] = attrMap.get( attr );\n\n\t\t}\n\n\t}\n\n}\n\n/**\n * @param {BufferGeometry} geometry\n * @return {number}\n */\nfunction estimateBytesUsed( geometry ) {\n\n\t// Return the estimated memory used by this geometry in bytes\n\t// Calculate using itemSize, count, and BYTES_PER_ELEMENT to account\n\t// for InterleavedBufferAttributes.\n\tlet mem = 0;\n\tfor ( const name in geometry.attributes ) {\n\n\t\tconst attr = geometry.getAttribute( name );\n\t\tmem += attr.count * attr.itemSize * attr.array.BYTES_PER_ELEMENT;\n\n\t}\n\n\tconst indices = geometry.getIndex();\n\tmem += indices ? indices.count * indices.itemSize * indices.array.BYTES_PER_ELEMENT : 0;\n\treturn mem;\n\n}\n\n/**\n * @param {BufferGeometry} geometry\n * @param {number} tolerance\n * @return {BufferGeometry}\n */\nfunction mergeVertices( geometry, tolerance = 1e-4 ) {\n\n\ttolerance = Math.max( tolerance, Number.EPSILON );\n\n\t// Generate an index buffer if the geometry doesn't have one, or optimize it\n\t// if it's already available.\n\tconst hashToIndex = {};\n\tconst indices = geometry.getIndex();\n\tconst positions = geometry.getAttribute( 'position' );\n\tconst vertexCount = indices ? indices.count : positions.count;\n\n\t// next value for triangle indices\n\tlet nextIndex = 0;\n\n\t// attributes and new attribute arrays\n\tconst attributeNames = Object.keys( geometry.attributes );\n\tconst tmpAttributes = {};\n\tconst tmpMorphAttributes = {};\n\tconst newIndices = [];\n\tconst getters = [ 'getX', 'getY', 'getZ', 'getW' ];\n\tconst setters = [ 'setX', 'setY', 'setZ', 'setW' ];\n\n\t// Initialize the arrays, allocating space conservatively. Extra\n\t// space will be trimmed in the last step.\n\tfor ( let i = 0, l = attributeNames.length; i < l; i ++ ) {\n\n\t\tconst name = attributeNames[ i ];\n\t\tconst attr = geometry.attributes[ name ];\n\n\t\ttmpAttributes[ name ] = new attr.constructor(\n\t\t\tnew attr.array.constructor( attr.count * attr.itemSize ),\n\t\t\tattr.itemSize,\n\t\t\tattr.normalized\n\t\t);\n\n\t\tconst morphAttributes = geometry.morphAttributes[ name ];\n\t\tif ( morphAttributes ) {\n\n\t\t\tif ( ! tmpMorphAttributes[ name ] ) tmpMorphAttributes[ name ] = [];\n\t\t\tmorphAttributes.forEach( ( morphAttr, i ) => {\n\n\t\t\t\tconst array = new morphAttr.array.constructor( morphAttr.count * morphAttr.itemSize );\n\t\t\t\ttmpMorphAttributes[ name ][ i ] = new morphAttr.constructor( array, morphAttr.itemSize, morphAttr.normalized );\n\n\t\t\t} );\n\n\t\t}\n\n\t}\n\n\t// convert the error tolerance to an amount of decimal places to truncate to\n\tconst halfTolerance = tolerance * 0.5;\n\tconst exponent = Math.log10( 1 / tolerance );\n\tconst hashMultiplier = Math.pow( 10, exponent );\n\tconst hashAdditive = halfTolerance * hashMultiplier;\n\tfor ( let i = 0; i < vertexCount; i ++ ) {\n\n\t\tconst index = indices ? indices.getX( i ) : i;\n\n\t\t// Generate a hash for the vertex attributes at the current index 'i'\n\t\tlet hash = '';\n\t\tfor ( let j = 0, l = attributeNames.length; j < l; j ++ ) {\n\n\t\t\tconst name = attributeNames[ j ];\n\t\t\tconst attribute = geometry.getAttribute( name );\n\t\t\tconst itemSize = attribute.itemSize;\n\n\t\t\tfor ( let k = 0; k < itemSize; k ++ ) {\n\n\t\t\t\t// double tilde truncates the decimal value\n\t\t\t\thash += `${ ~ ~ ( attribute[ getters[ k ] ]( index ) * hashMultiplier + hashAdditive ) },`;\n\n\t\t\t}\n\n\t\t}\n\n\t\t// Add another reference to the vertex if it's already\n\t\t// used by another index\n\t\tif ( hash in hashToIndex ) {\n\n\t\t\tnewIndices.push( hashToIndex[ hash ] );\n\n\t\t} else {\n\n\t\t\t// copy data to the new index in the temporary attributes\n\t\t\tfor ( let j = 0, l = attributeNames.length; j < l; j ++ ) {\n\n\t\t\t\tconst name = attributeNames[ j ];\n\t\t\t\tconst attribute = geometry.getAttribute( name );\n\t\t\t\tconst morphAttributes = geometry.morphAttributes[ name ];\n\t\t\t\tconst itemSize = attribute.itemSize;\n\t\t\t\tconst newArray = tmpAttributes[ name ];\n\t\t\t\tconst newMorphArrays = tmpMorphAttributes[ name ];\n\n\t\t\t\tfor ( let k = 0; k < itemSize; k ++ ) {\n\n\t\t\t\t\tconst getterFunc = getters[ k ];\n\t\t\t\t\tconst setterFunc = setters[ k ];\n\t\t\t\t\tnewArray[ setterFunc ]( nextIndex, attribute[ getterFunc ]( index ) );\n\n\t\t\t\t\tif ( morphAttributes ) {\n\n\t\t\t\t\t\tfor ( let m = 0, ml = morphAttributes.length; m < ml; m ++ ) {\n\n\t\t\t\t\t\t\tnewMorphArrays[ m ][ setterFunc ]( nextIndex, morphAttributes[ m ][ getterFunc ]( index ) );\n\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\thashToIndex[ hash ] = nextIndex;\n\t\t\tnewIndices.push( nextIndex );\n\t\t\tnextIndex ++;\n\n\t\t}\n\n\t}\n\n\t// generate result BufferGeometry\n\tconst result = geometry.clone();\n\tfor ( const name in geometry.attributes ) {\n\n\t\tconst tmpAttribute = tmpAttributes[ name ];\n\n\t\tresult.setAttribute( name, new tmpAttribute.constructor(\n\t\t\ttmpAttribute.array.slice( 0, nextIndex * tmpAttribute.itemSize ),\n\t\t\ttmpAttribute.itemSize,\n\t\t\ttmpAttribute.normalized,\n\t\t) );\n\n\t\tif ( ! ( name in tmpMorphAttributes ) ) continue;\n\n\t\tfor ( let j = 0; j < tmpMorphAttributes[ name ].length; j ++ ) {\n\n\t\t\tconst tmpMorphAttribute = tmpMorphAttributes[ name ][ j ];\n\n\t\t\tresult.morphAttributes[ name ][ j ] = new tmpMorphAttribute.constructor(\n\t\t\t\ttmpMorphAttribute.array.slice( 0, nextIndex * tmpMorphAttribute.itemSize ),\n\t\t\t\ttmpMorphAttribute.itemSize,\n\t\t\t\ttmpMorphAttribute.normalized,\n\t\t\t);\n\n\t\t}\n\n\t}\n\n\t// indices\n\n\tresult.setIndex( newIndices );\n\n\treturn result;\n\n}\n\n/**\n * @param {BufferGeometry} geometry\n * @param {number} drawMode\n * @return {BufferGeometry}\n */\nfunction toTrianglesDrawMode( geometry, drawMode ) {\n\n\tif ( drawMode === TrianglesDrawMode ) {\n\n\t\tconsole.warn( 'THREE.BufferGeometryUtils.toTrianglesDrawMode(): Geometry already defined as triangles.' );\n\t\treturn geometry;\n\n\t}\n\n\tif ( drawMode === TriangleFanDrawMode || drawMode === TriangleStripDrawMode ) {\n\n\t\tlet index = geometry.getIndex();\n\n\t\t// generate index if not present\n\n\t\tif ( index === null ) {\n\n\t\t\tconst indices = [];\n\n\t\t\tconst position = geometry.getAttribute( 'position' );\n\n\t\t\tif ( position !== undefined ) {\n\n\t\t\t\tfor ( let i = 0; i < position.count; i ++ ) {\n\n\t\t\t\t\tindices.push( i );\n\n\t\t\t\t}\n\n\t\t\t\tgeometry.setIndex( indices );\n\t\t\t\tindex = geometry.getIndex();\n\n\t\t\t} else {\n\n\t\t\t\tconsole.error( 'THREE.BufferGeometryUtils.toTrianglesDrawMode(): Undefined position attribute. Processing not possible.' );\n\t\t\t\treturn geometry;\n\n\t\t\t}\n\n\t\t}\n\n\t\t//\n\n\t\tconst numberOfTriangles = index.count - 2;\n\t\tconst newIndices = [];\n\n\t\tif ( drawMode === TriangleFanDrawMode ) {\n\n\t\t\t// gl.TRIANGLE_FAN\n\n\t\t\tfor ( let i = 1; i <= numberOfTriangles; i ++ ) {\n\n\t\t\t\tnewIndices.push( index.getX( 0 ) );\n\t\t\t\tnewIndices.push( index.getX( i ) );\n\t\t\t\tnewIndices.push( index.getX( i + 1 ) );\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\t// gl.TRIANGLE_STRIP\n\n\t\t\tfor ( let i = 0; i < numberOfTriangles; i ++ ) {\n\n\t\t\t\tif ( i % 2 === 0 ) {\n\n\t\t\t\t\tnewIndices.push( index.getX( i ) );\n\t\t\t\t\tnewIndices.push( index.getX( i + 1 ) );\n\t\t\t\t\tnewIndices.push( index.getX( i + 2 ) );\n\n\t\t\t\t} else {\n\n\t\t\t\t\tnewIndices.push( index.getX( i + 2 ) );\n\t\t\t\t\tnewIndices.push( index.getX( i + 1 ) );\n\t\t\t\t\tnewIndices.push( index.getX( i ) );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t}\n\n\t\tif ( ( newIndices.length / 3 ) !== numberOfTriangles ) {\n\n\t\t\tconsole.error( 'THREE.BufferGeometryUtils.toTrianglesDrawMode(): Unable to generate correct amount of triangles.' );\n\n\t\t}\n\n\t\t// build final geometry\n\n\t\tconst newGeometry = geometry.clone();\n\t\tnewGeometry.setIndex( newIndices );\n\t\tnewGeometry.clearGroups();\n\n\t\treturn newGeometry;\n\n\t} else {\n\n\t\tconsole.error( 'THREE.BufferGeometryUtils.toTrianglesDrawMode(): Unknown draw mode:', drawMode );\n\t\treturn geometry;\n\n\t}\n\n}\n\n/**\n * Calculates the morphed attributes of a morphed/skinned BufferGeometry.\n * Helpful for Raytracing or Decals.\n * @param {Mesh | Line | Points} object An instance of Mesh, Line or Points.\n * @return {Object} An Object with original position/normal attributes and morphed ones.\n */\nfunction computeMorphedAttributes( object ) {\n\n\tconst _vA = new Vector3();\n\tconst _vB = new Vector3();\n\tconst _vC = new Vector3();\n\n\tconst _tempA = new Vector3();\n\tconst _tempB = new Vector3();\n\tconst _tempC = new Vector3();\n\n\tconst _morphA = new Vector3();\n\tconst _morphB = new Vector3();\n\tconst _morphC = new Vector3();\n\n\tfunction _calculateMorphedAttributeData(\n\t\tobject,\n\t\tattribute,\n\t\tmorphAttribute,\n\t\tmorphTargetsRelative,\n\t\ta,\n\t\tb,\n\t\tc,\n\t\tmodifiedAttributeArray\n\t) {\n\n\t\t_vA.fromBufferAttribute( attribute, a );\n\t\t_vB.fromBufferAttribute( attribute, b );\n\t\t_vC.fromBufferAttribute( attribute, c );\n\n\t\tconst morphInfluences = object.morphTargetInfluences;\n\n\t\tif ( morphAttribute && morphInfluences ) {\n\n\t\t\t_morphA.set( 0, 0, 0 );\n\t\t\t_morphB.set( 0, 0, 0 );\n\t\t\t_morphC.set( 0, 0, 0 );\n\n\t\t\tfor ( let i = 0, il = morphAttribute.length; i < il; i ++ ) {\n\n\t\t\t\tconst influence = morphInfluences[ i ];\n\t\t\t\tconst morph = morphAttribute[ i ];\n\n\t\t\t\tif ( influence === 0 ) continue;\n\n\t\t\t\t_tempA.fromBufferAttribute( morph, a );\n\t\t\t\t_tempB.fromBufferAttribute( morph, b );\n\t\t\t\t_tempC.fromBufferAttribute( morph, c );\n\n\t\t\t\tif ( morphTargetsRelative ) {\n\n\t\t\t\t\t_morphA.addScaledVector( _tempA, influence );\n\t\t\t\t\t_morphB.addScaledVector( _tempB, influence );\n\t\t\t\t\t_morphC.addScaledVector( _tempC, influence );\n\n\t\t\t\t} else {\n\n\t\t\t\t\t_morphA.addScaledVector( _tempA.sub( _vA ), influence );\n\t\t\t\t\t_morphB.addScaledVector( _tempB.sub( _vB ), influence );\n\t\t\t\t\t_morphC.addScaledVector( _tempC.sub( _vC ), influence );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\t_vA.add( _morphA );\n\t\t\t_vB.add( _morphB );\n\t\t\t_vC.add( _morphC );\n\n\t\t}\n\n\t\tif ( object.isSkinnedMesh ) {\n\n\t\t\tobject.applyBoneTransform( a, _vA );\n\t\t\tobject.applyBoneTransform( b, _vB );\n\t\t\tobject.applyBoneTransform( c, _vC );\n\n\t\t}\n\n\t\tmodifiedAttributeArray[ a * 3 + 0 ] = _vA.x;\n\t\tmodifiedAttributeArray[ a * 3 + 1 ] = _vA.y;\n\t\tmodifiedAttributeArray[ a * 3 + 2 ] = _vA.z;\n\t\tmodifiedAttributeArray[ b * 3 + 0 ] = _vB.x;\n\t\tmodifiedAttributeArray[ b * 3 + 1 ] = _vB.y;\n\t\tmodifiedAttributeArray[ b * 3 + 2 ] = _vB.z;\n\t\tmodifiedAttributeArray[ c * 3 + 0 ] = _vC.x;\n\t\tmodifiedAttributeArray[ c * 3 + 1 ] = _vC.y;\n\t\tmodifiedAttributeArray[ c * 3 + 2 ] = _vC.z;\n\n\t}\n\n\tconst geometry = object.geometry;\n\tconst material = object.material;\n\n\tlet a, b, c;\n\tconst index = geometry.index;\n\tconst positionAttribute = geometry.attributes.position;\n\tconst morphPosition = geometry.morphAttributes.position;\n\tconst morphTargetsRelative = geometry.morphTargetsRelative;\n\tconst normalAttribute = geometry.attributes.normal;\n\tconst morphNormal = geometry.morphAttributes.position;\n\n\tconst groups = geometry.groups;\n\tconst drawRange = geometry.drawRange;\n\tlet i, j, il, jl;\n\tlet group;\n\tlet start, end;\n\n\tconst modifiedPosition = new Float32Array( positionAttribute.count * positionAttribute.itemSize );\n\tconst modifiedNormal = new Float32Array( normalAttribute.count * normalAttribute.itemSize );\n\n\tif ( index !== null ) {\n\n\t\t// indexed buffer geometry\n\n\t\tif ( Array.isArray( material ) ) {\n\n\t\t\tfor ( i = 0, il = groups.length; i < il; i ++ ) {\n\n\t\t\t\tgroup = groups[ i ];\n\n\t\t\t\tstart = Math.max( group.start, drawRange.start );\n\t\t\t\tend = Math.min( ( group.start + group.count ), ( drawRange.start + drawRange.count ) );\n\n\t\t\t\tfor ( j = start, jl = end; j < jl; j += 3 ) {\n\n\t\t\t\t\ta = index.getX( j );\n\t\t\t\t\tb = index.getX( j + 1 );\n\t\t\t\t\tc = index.getX( j + 2 );\n\n\t\t\t\t\t_calculateMorphedAttributeData(\n\t\t\t\t\t\tobject,\n\t\t\t\t\t\tpositionAttribute,\n\t\t\t\t\t\tmorphPosition,\n\t\t\t\t\t\tmorphTargetsRelative,\n\t\t\t\t\t\ta, b, c,\n\t\t\t\t\t\tmodifiedPosition\n\t\t\t\t\t);\n\n\t\t\t\t\t_calculateMorphedAttributeData(\n\t\t\t\t\t\tobject,\n\t\t\t\t\t\tnormalAttribute,\n\t\t\t\t\t\tmorphNormal,\n\t\t\t\t\t\tmorphTargetsRelative,\n\t\t\t\t\t\ta, b, c,\n\t\t\t\t\t\tmodifiedNormal\n\t\t\t\t\t);\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tstart = Math.max( 0, drawRange.start );\n\t\t\tend = Math.min( index.count, ( drawRange.start + drawRange.count ) );\n\n\t\t\tfor ( i = start, il = end; i < il; i += 3 ) {\n\n\t\t\t\ta = index.getX( i );\n\t\t\t\tb = index.getX( i + 1 );\n\t\t\t\tc = index.getX( i + 2 );\n\n\t\t\t\t_calculateMorphedAttributeData(\n\t\t\t\t\tobject,\n\t\t\t\t\tpositionAttribute,\n\t\t\t\t\tmorphPosition,\n\t\t\t\t\tmorphTargetsRelative,\n\t\t\t\t\ta, b, c,\n\t\t\t\t\tmodifiedPosition\n\t\t\t\t);\n\n\t\t\t\t_calculateMorphedAttributeData(\n\t\t\t\t\tobject,\n\t\t\t\t\tnormalAttribute,\n\t\t\t\t\tmorphNormal,\n\t\t\t\t\tmorphTargetsRelative,\n\t\t\t\t\ta, b, c,\n\t\t\t\t\tmodifiedNormal\n\t\t\t\t);\n\n\t\t\t}\n\n\t\t}\n\n\t} else {\n\n\t\t// non-indexed buffer geometry\n\n\t\tif ( Array.isArray( material ) ) {\n\n\t\t\tfor ( i = 0, il = groups.length; i < il; i ++ ) {\n\n\t\t\t\tgroup = groups[ i ];\n\n\t\t\t\tstart = Math.max( group.start, drawRange.start );\n\t\t\t\tend = Math.min( ( group.start + group.count ), ( drawRange.start + drawRange.count ) );\n\n\t\t\t\tfor ( j = start, jl = end; j < jl; j += 3 ) {\n\n\t\t\t\t\ta = j;\n\t\t\t\t\tb = j + 1;\n\t\t\t\t\tc = j + 2;\n\n\t\t\t\t\t_calculateMorphedAttributeData(\n\t\t\t\t\t\tobject,\n\t\t\t\t\t\tpositionAttribute,\n\t\t\t\t\t\tmorphPosition,\n\t\t\t\t\t\tmorphTargetsRelative,\n\t\t\t\t\t\ta, b, c,\n\t\t\t\t\t\tmodifiedPosition\n\t\t\t\t\t);\n\n\t\t\t\t\t_calculateMorphedAttributeData(\n\t\t\t\t\t\tobject,\n\t\t\t\t\t\tnormalAttribute,\n\t\t\t\t\t\tmorphNormal,\n\t\t\t\t\t\tmorphTargetsRelative,\n\t\t\t\t\t\ta, b, c,\n\t\t\t\t\t\tmodifiedNormal\n\t\t\t\t\t);\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t} else {\n\n\t\t\tstart = Math.max( 0, drawRange.start );\n\t\t\tend = Math.min( positionAttribute.count, ( drawRange.start + drawRange.count ) );\n\n\t\t\tfor ( i = start, il = end; i < il; i += 3 ) {\n\n\t\t\t\ta = i;\n\t\t\t\tb = i + 1;\n\t\t\t\tc = i + 2;\n\n\t\t\t\t_calculateMorphedAttributeData(\n\t\t\t\t\tobject,\n\t\t\t\t\tpositionAttribute,\n\t\t\t\t\tmorphPosition,\n\t\t\t\t\tmorphTargetsRelative,\n\t\t\t\t\ta, b, c,\n\t\t\t\t\tmodifiedPosition\n\t\t\t\t);\n\n\t\t\t\t_calculateMorphedAttributeData(\n\t\t\t\t\tobject,\n\t\t\t\t\tnormalAttribute,\n\t\t\t\t\tmorphNormal,\n\t\t\t\t\tmorphTargetsRelative,\n\t\t\t\t\ta, b, c,\n\t\t\t\t\tmodifiedNormal\n\t\t\t\t);\n\n\t\t\t}\n\n\t\t}\n\n\t}\n\n\tconst morphedPositionAttribute = new Float32BufferAttribute( modifiedPosition, 3 );\n\tconst morphedNormalAttribute = new Float32BufferAttribute( modifiedNormal, 3 );\n\n\treturn {\n\n\t\tpositionAttribute: positionAttribute,\n\t\tnormalAttribute: normalAttribute,\n\t\tmorphedPositionAttribute: morphedPositionAttribute,\n\t\tmorphedNormalAttribute: morphedNormalAttribute\n\n\t};\n\n}\n\nfunction mergeGroups( geometry ) {\n\n\tif ( geometry.groups.length === 0 ) {\n\n\t\tconsole.warn( 'THREE.BufferGeometryUtils.mergeGroups(): No groups are defined. Nothing to merge.' );\n\t\treturn geometry;\n\n\t}\n\n\tlet groups = geometry.groups;\n\n\t// sort groups by material index\n\n\tgroups = groups.sort( ( a, b ) => {\n\n\t\tif ( a.materialIndex !== b.materialIndex ) return a.materialIndex - b.materialIndex;\n\n\t\treturn a.start - b.start;\n\n\t} );\n\n\t// create index for non-indexed geometries\n\n\tif ( geometry.getIndex() === null ) {\n\n\t\tconst positionAttribute = geometry.getAttribute( 'position' );\n\t\tconst indices = [];\n\n\t\tfor ( let i = 0; i < positionAttribute.count; i += 3 ) {\n\n\t\t\tindices.push( i, i + 1, i + 2 );\n\n\t\t}\n\n\t\tgeometry.setIndex( indices );\n\n\t}\n\n\t// sort index\n\n\tconst index = geometry.getIndex();\n\n\tconst newIndices = [];\n\n\tfor ( let i = 0; i < groups.length; i ++ ) {\n\n\t\tconst group = groups[ i ];\n\n\t\tconst groupStart = group.start;\n\t\tconst groupLength = groupStart + group.count;\n\n\t\tfor ( let j = groupStart; j < groupLength; j ++ ) {\n\n\t\t\tnewIndices.push( index.getX( j ) );\n\n\t\t}\n\n\t}\n\n\tgeometry.dispose(); // Required to force buffer recreation\n\tgeometry.setIndex( newIndices );\n\n\t// update groups indices\n\n\tlet start = 0;\n\n\tfor ( let i = 0; i < groups.length; i ++ ) {\n\n\t\tconst group = groups[ i ];\n\n\t\tgroup.start = start;\n\t\tstart += group.count;\n\n\t}\n\n\t// merge groups\n\n\tlet currentGroup = groups[ 0 ];\n\n\tgeometry.groups = [ currentGroup ];\n\n\tfor ( let i = 1; i < groups.length; i ++ ) {\n\n\t\tconst group = groups[ i ];\n\n\t\tif ( currentGroup.materialIndex === group.materialIndex ) {\n\n\t\t\tcurrentGroup.count += group.count;\n\n\t\t} else {\n\n\t\t\tcurrentGroup = group;\n\t\t\tgeometry.groups.push( currentGroup );\n\n\t\t}\n\n\t}\n\n\treturn geometry;\n\n}\n\n\n/**\n * Modifies the supplied geometry if it is non-indexed, otherwise creates a new,\n * non-indexed geometry. Returns the geometry with smooth normals everywhere except\n * faces that meet at an angle greater than the crease angle.\n *\n * @param {BufferGeometry} geometry\n * @param {number} [creaseAngle]\n * @return {BufferGeometry}\n */\nfunction toCreasedNormals( geometry, creaseAngle = Math.PI / 3 /* 60 degrees */ ) {\n\n\tconst creaseDot = Math.cos( creaseAngle );\n\tconst hashMultiplier = ( 1 + 1e-10 ) * 1e2;\n\n\t// reusable vectors\n\tconst verts = [ new Vector3(), new Vector3(), new Vector3() ];\n\tconst tempVec1 = new Vector3();\n\tconst tempVec2 = new Vector3();\n\tconst tempNorm = new Vector3();\n\tconst tempNorm2 = new Vector3();\n\n\t// hashes a vector\n\tfunction hashVertex( v ) {\n\n\t\tconst x = ~ ~ ( v.x * hashMultiplier );\n\t\tconst y = ~ ~ ( v.y * hashMultiplier );\n\t\tconst z = ~ ~ ( v.z * hashMultiplier );\n\t\treturn `${x},${y},${z}`;\n\n\t}\n\n\t// BufferGeometry.toNonIndexed() warns if the geometry is non-indexed\n\t// and returns the original geometry\n\tconst resultGeometry = geometry.index ? geometry.toNonIndexed() : geometry;\n\tconst posAttr = resultGeometry.attributes.position;\n\tconst vertexMap = {};\n\n\t// find all the normals shared by commonly located vertices\n\tfor ( let i = 0, l = posAttr.count / 3; i < l; i ++ ) {\n\n\t\tconst i3 = 3 * i;\n\t\tconst a = verts[ 0 ].fromBufferAttribute( posAttr, i3 + 0 );\n\t\tconst b = verts[ 1 ].fromBufferAttribute( posAttr, i3 + 1 );\n\t\tconst c = verts[ 2 ].fromBufferAttribute( posAttr, i3 + 2 );\n\n\t\ttempVec1.subVectors( c, b );\n\t\ttempVec2.subVectors( a, b );\n\n\t\t// add the normal to the map for all vertices\n\t\tconst normal = new Vector3().crossVectors( tempVec1, tempVec2 ).normalize();\n\t\tfor ( let n = 0; n < 3; n ++ ) {\n\n\t\t\tconst vert = verts[ n ];\n\t\t\tconst hash = hashVertex( vert );\n\t\t\tif ( ! ( hash in vertexMap ) ) {\n\n\t\t\t\tvertexMap[ hash ] = [];\n\n\t\t\t}\n\n\t\t\tvertexMap[ hash ].push( normal );\n\n\t\t}\n\n\t}\n\n\t// average normals from all vertices that share a common location if they are within the\n\t// provided crease threshold\n\tconst normalArray = new Float32Array( posAttr.count * 3 );\n\tconst normAttr = new BufferAttribute( normalArray, 3, false );\n\tfor ( let i = 0, l = posAttr.count / 3; i < l; i ++ ) {\n\n\t\t// get the face normal for this vertex\n\t\tconst i3 = 3 * i;\n\t\tconst a = verts[ 0 ].fromBufferAttribute( posAttr, i3 + 0 );\n\t\tconst b = verts[ 1 ].fromBufferAttribute( posAttr, i3 + 1 );\n\t\tconst c = verts[ 2 ].fromBufferAttribute( posAttr, i3 + 2 );\n\n\t\ttempVec1.subVectors( c, b );\n\t\ttempVec2.subVectors( a, b );\n\n\t\ttempNorm.crossVectors( tempVec1, tempVec2 ).normalize();\n\n\t\t// average all normals that meet the threshold and set the normal value\n\t\tfor ( let n = 0; n < 3; n ++ ) {\n\n\t\t\tconst vert = verts[ n ];\n\t\t\tconst hash = hashVertex( vert );\n\t\t\tconst otherNormals = vertexMap[ hash ];\n\t\t\ttempNorm2.set( 0, 0, 0 );\n\n\t\t\tfor ( let k = 0, lk = otherNormals.length; k < lk; k ++ ) {\n\n\t\t\t\tconst otherNorm = otherNormals[ k ];\n\t\t\t\tif ( tempNorm.dot( otherNorm ) > creaseDot ) {\n\n\t\t\t\t\ttempNorm2.add( otherNorm );\n\n\t\t\t\t}\n\n\t\t\t}\n\n\t\t\ttempNorm2.normalize();\n\t\t\tnormAttr.setXYZ( i3 + n, tempNorm2.x, tempNorm2.y, tempNorm2.z );\n\n\t\t}\n\n\t}\n\n\tresultGeometry.setAttribute( 'normal', normAttr );\n\treturn resultGeometry;\n\n}\n\nexport {\n\tcomputeMikkTSpaceTangents,\n\tmergeGeometries,\n\tmergeAttributes,\n\tinterleaveAttributes,\n\testimateBytesUsed,\n\tmergeVertices,\n\ttoTrianglesDrawMode,\n\tcomputeMorphedAttributes,\n\tmergeGroups,\n\ttoCreasedNormals\n};\n","import {\n BufferGeometry,\n PointsMaterial,\n Material,\n Points,\n Mesh,\n TriangleStripDrawMode,\n TriangleFanDrawMode,\n LineSegments,\n Line,\n LineLoop,\n Group,\n Vector3,\n Quaternion,\n Matrix4,\n Box3,\n MeshStandardMaterial,\n Color,\n MathUtils,\n PerspectiveCamera,\n OrthographicCamera,\n DoubleSide,\n NormalBlending,\n BufferAttribute,\n LineBasicMaterial,\n} from \"three\";\nimport { GltfStructure, GL_CONSTANTS } from \"./GltfStructure.js\";\nimport { mergeGeometries } from \"three/examples/jsm/utils/BufferGeometryUtils.js\";\n\nexport class DynamicGltfLoader {\n constructor(camera, scene, renderer) {\n this.camera = camera;\n this.scene = scene;\n this.renderer = renderer;\n\n this.eventHandlers = {\n geometryprogress: [],\n databasechunk: [],\n geometryend: [],\n geometryerror: [],\n update: [],\n geometrymemory: [],\n };\n\n this.loadDistance = 100;\n this.unloadDistance = 150;\n this.checkInterval = 1000;\n\n this.nodes = new Map();\n this.loadedMeshes = new Map();\n this.nodesToLoad = [];\n this.edgeNodes = [];\n this.structures = [];\n this.structureRoots = new Map();\n\n this.memoryLimit = this.getAvailableMemory();\n this.loadedGeometrySize = 0;\n this.geometryCache = new Map();\n this.materialCache = new Map();\n this.textureCache = new Map();\n this.currentMemoryUsage = 0;\n\n this.updateMemoryIndicator();\n\n this.loadedMaterials = new Map();\n this.abortController = new AbortController();\n\n this.batchSize = 10000;\n this.frameDelay = 0;\n\n this.graphicsObjectLimit = 10000;\n this.totalLoadedObjects = 0;\n\n this.lastUpdateTime = 0;\n this.updateInterval = 1000;\n\n this.handleToObjects = new Map();\n\n this.originalObjects = new Set();\n this.originalObjectsToSelection = new Set();\n\n this.optimizedOriginalMap = new Map();\n this.mergedMesh = new Set();\n this.mergedLines = new Set();\n this.mergedLineSegments = new Set();\n this.mergedPoints = new Set();\n\n this.isolatedObjects = [];\n this.useVAO = !!window.WebGL2RenderingContext && this.renderer.getContext() instanceof WebGL2RenderingContext;\n\n this.handleToOptimizedObjects = new Map();\n\n this.hiddenHandles = new Set();\n this.newOptimizedObjects = new Set();\n this.oldOptimizeObjects = new Set();\n }\n\n getAvailableMemory() {\n let memoryLimit = 6 * 1024 * 1024 * 1024;\n try {\n if (navigator.deviceMemory) {\n memoryLimit = navigator.deviceMemory * 1024 * 1024 * 1024;\n } else if (performance.memory) {\n const jsHeapSizeLimit = performance.memory.jsHeapSizeLimit;\n if (jsHeapSizeLimit) {\n memoryLimit = Math.min(memoryLimit, jsHeapSizeLimit);\n }\n }\n\n memoryLimit = Math.min(memoryLimit, 16 * 1024 * 1024 * 1024);\n memoryLimit = Math.max(memoryLimit, 2 * 1024 * 1024 * 1024);\n\n console.log(`Available memory set to ${Math.round(memoryLimit / (1024 * 1024 * 1024))}GB`);\n } catch (error) {\n console.warn(\"Error detecting available memory:\", error);\n }\n\n return memoryLimit;\n }\n\n getAbortController() {\n return this.abortController;\n }\n\n abortLoading() {\n this.abortController.abort();\n }\n\n updateMemoryIndicator() {\n this.dispatchEvent(\"geometrymemory\", {\n currentUsage: this.currentMemoryUsage,\n limit: this.memoryLimit,\n });\n }\n\n setMemoryLimit(bytesLimit) {\n // this.memoryLimit = bytesLimit;\n //this.updateMemoryIndicator();\n // console.log(`Memory limit set to ${Math.round(bytesLimit / (1024 * 1024))}MB`);\n }\n\n estimateGeometrySize(nodeGroup) {\n let totalSize = 0;\n nodeGroup.traverse((child) => {\n if (child.geometry) {\n if (this.abortController.signal.aborted) {\n throw new DOMException(\"Loading aborted\", \"AbortError\");\n }\n const geometry = child.geometry;\n\n if (geometry.attributes) {\n Object.values(geometry.attributes).forEach((attribute) => {\n if (attribute && attribute.array) {\n totalSize += attribute.array.byteLength;\n }\n });\n }\n\n if (geometry.index && geometry.index.array) {\n totalSize += geometry.index.array.byteLength;\n }\n }\n });\n\n return totalSize;\n }\n\n recalculateScene() {\n const geometries = [];\n this.scene.traverse((object) => {\n if (this.abortController.signal.aborted) {\n throw new DOMException(\"Loading aborted\", \"AbortError\");\n }\n\n if (object.geometry && !this.geometryCache.has(object.geometry.uuid)) {\n const size = this.estimateGeometrySize(object);\n this.geometryCache.set(object.geometry.uuid, size);\n geometries.push({\n object,\n size,\n distance: object.position.distanceTo(this.camera.position),\n });\n }\n });\n\n if (this.abortController.signal.aborted) {\n throw new DOMException(\"Loading aborted\", \"AbortError\");\n }\n\n geometries.sort((a, b) => b.distance - a.distance);\n\n let currentMemoryUsage = 0;\n for (const geo of geometries) {\n currentMemoryUsage += geo.size;\n }\n\n if (currentMemoryUsage > this.memoryLimit) {\n console.log(`Memory usage (${Math.round(currentMemoryUsage / (1024 * 1024))}MB) exceeds limit`);\n\n for (const geo of geometries) {\n if (currentMemoryUsage <= this.memoryLimit) break;\n\n if (this.abortController.signal.aborted) {\n throw new DOMException(\"Loading aborted\", \"AbortError\");\n }\n\n const object = geo.object;\n if (object.geometry) {\n currentMemoryUsage -= geo.size;\n this.geometryCache.delete(object.geometry.uuid);\n object.geometry.dispose();\n object.visible = false;\n }\n }\n }\n\n this.currentMemoryUsage = currentMemoryUsage;\n this.updateMemoryIndicator();\n\n console.log(`Final memory usage: ${Math.round(currentMemoryUsage / (1024 * 1024))}MB`);\n }\n\n async loadNode(nodeId) {\n const node = this.nodes.get(nodeId);\n if (!node || node.loaded || node.loading) return;\n\n node.loading = true;\n const meshDef = node.structure.getJson().meshes[node.meshIndex];\n\n try {\n for (const primitive of meshDef.primitives) {\n const positionAccessor = primitive.attributes.POSITION;\n const geometry = new BufferGeometry();\n const attributes = new Map();\n\n attributes.set(\"position\", node.structure.createBufferAttribute(positionAccessor));\n\n if (primitive.attributes.NORMAL !== undefined) {\n attributes.set(\"normal\", node.structure.createBufferAttribute(primitive.attributes.NORMAL));\n }\n\n if (primitive.attributes.TEXCOORD_0 !== undefined) {\n attributes.set(\"uv\", node.structure.createBufferAttribute(primitive.attributes.TEXCOORD_0));\n }\n\n const loadedAttributes = await Promise.all(\n [...attributes.entries()].map(async ([name, promise]) => {\n const attribute = await promise;\n return [name, attribute];\n })\n );\n\n loadedAttributes.forEach(([name, attribute]) => {\n geometry.setAttribute(name, attribute);\n });\n\n if (primitive.indices !== undefined) {\n const indexAttribute = await node.structure.createBufferAttribute(primitive.indices);\n geometry.setIndex(indexAttribute);\n }\n\n this.currentPrimitiveMode = primitive.mode;\n\n let material;\n if (primitive.material !== undefined) {\n material = node.structure.materials.get(primitive.material) || this.createDefaultMaterial();\n } else {\n material = this.createDefaultMaterial();\n }\n\n let mesh;\n if (primitive.mode === GL_CONSTANTS.POINTS) {\n const pointsMaterial = new PointsMaterial();\n Material.prototype.copy.call(pointsMaterial, material);\n pointsMaterial.color.copy(material.color);\n pointsMaterial.map = material.map;\n pointsMaterial.sizeAttenuation = false; // glTF spec says points should be 1px\n\n mesh = new Points(geometry, pointsMaterial);\n } else if (\n primitive.mode === GL_CONSTANTS.TRIANGLES ||\n primitive.mode === GL_CONSTANTS.TRIANGLE_STRIP ||\n primitive.mode === GL_CONSTANTS.TRIANGLE_FAN ||\n primitive.mode === undefined\n ) {\n mesh = new Mesh(geometry, material);\n\n if (primitive.mode === GL_CONSTANTS.TRIANGLE_STRIP) {\n mesh.drawMode = TriangleStripDrawMode;\n } else if (primitive.mode === GL_CONSTANTS.TRIANGLE_FAN) {\n mesh.drawMode = TriangleFanDrawMode;\n }\n } else if (primitive.mode === GL_CONSTANTS.LINES) {\n mesh = new LineSegments(geometry, material);\n } else if (primitive.mode === GL_CONSTANTS.LINE_STRIP) {\n mesh = new Line(geometry, material);\n } else if (primitive.mode === GL_CONSTANTS.LINE_LOOP) {\n mesh = new LineLoop(geometry, material);\n }\n\n if (node.extras) {\n mesh.userData = { ...mesh.userData, ...node.extras };\n }\n\n if (meshDef.extras) {\n mesh.userData = { ...mesh.userData, ...meshDef.extras };\n }\n\n if (primitive.extras) {\n mesh.userData = { ...mesh.userData, ...primitive.extras };\n }\n\n if (node.handle) {\n mesh.userData.handle = node.handle;\n } else {\n mesh.userData.handle = `${node.structure.id}_${mesh.userData.handle}`;\n }\n\n if (mesh.material.name === \"edges\") {\n mesh.userData.isEdge = true;\n } else {\n mesh.userData.isEdge = false;\n }\n\n this.registerObjectWithHandle(mesh, mesh.userData.handle);\n\n mesh.position.copy(node.position);\n\n if (!geometry.attributes.normal) {\n geometry.computeVertexNormals();\n }\n\n if (material.aoMap && geometry.attributes.uv) {\n geometry.setAttribute(\"uv2\", geometry.attributes.uv);\n }\n if (node.group) {\n node.group.add(mesh);\n } else {\n this.scene.add(mesh);\n }\n node.object = mesh;\n\n this.totalLoadedObjects++;\n mesh.visible = this.totalLoadedObjects < this.graphicsObjectLimit;\n }\n\n node.loaded = true;\n node.loading = false;\n\n const geometrySize = this.estimateGeometrySize(node.object);\n this.geometryCache.set(node.object.uuid, geometrySize);\n this.currentMemoryUsage += geometrySize;\n } catch (error) {\n if (error.name !== \"AbortError\") {\n console.error(`Error loading node ${nodeId}:`, error);\n }\n node.loading = false;\n }\n }\n\n unloadNode(nodeId) {\n const node = this.nodes.get(nodeId);\n if (!node || !node.loaded) return;\n\n if (node.object) {\n if (node.object.parent) {\n node.object.parent.remove(node.object);\n } else {\n this.scene.remove(node.object);\n }\n\n node.object.traverse((child) => {\n if (child.geometry) {\n const geometrySize = this.geometryCache.get(child.geometry.uuid) || 0;\n this.currentMemoryUsage -= geometrySize;\n this.geometryCache.delete(child.geometry.uuid);\n child.geometry.dispose();\n }\n });\n\n node.object = null;\n node.loaded = false;\n this.updateMemoryIndicator();\n console.log(`Unloaded node: ${nodeId}`);\n }\n }\n\n checkDistances() {\n const cameraPosition = this.camera.position;\n\n this.nodes.forEach((node, nodeId) => {\n const distance = cameraPosition.distanceTo(node.position);\n\n if (node.loaded) {\n if (distance > this.unloadDistance) {\n this.unloadNode(nodeId);\n }\n } else if (!node.loading) {\n if (distance < this.loadDistance) {\n this.loadNode(nodeId);\n }\n }\n });\n }\n\n async loadStructure(structures) {\n this.clear();\n\n const structureArray = Array.isArray(structures) ? structures : [structures];\n\n for (const structure of structureArray) {\n this.structures.push(structure);\n }\n\n for (const structure of this.structures) {\n try {\n await structure.loadTextures();\n await structure.loadMaterials();\n } catch (error) {\n console.error(\"Error loading materials:\", error);\n throw error;\n }\n }\n\n await this.processSceneHierarchy();\n }\n\n async processSceneHierarchy() {\n if (this.structures.length === 0) {\n throw new Error(\"No GLTF structures loaded\");\n }\n\n this.nodesToLoad = [];\n\n let estimatedSize = 0;\n\n for (const structure of this.structures) {\n const gltf = structure.getJson();\n\n if (!gltf.scenes || !gltf.scenes.length) {\n console.warn(\"No scenes found in GLTF structure\");\n continue;\n }\n\n estimatedSize += gltf.buffers[0].byteLength;\n\n const rootGroup = new Group();\n rootGroup.name = `structure_${structure.id}_root`;\n this.scene.add(rootGroup);\n this.structureRoots.set(structure.id, rootGroup);\n\n const scene = gltf.scenes[gltf.scene || 0];\n\n for (const nodeIndex of scene.nodes) {\n await this.processNodeHierarchy(structure, nodeIndex, rootGroup);\n }\n }\n\n const ignoreEdges = estimatedSize * 2 > this.memoryLimit;\n\n this.nodesToLoad.sort((a, b) => {\n const nodeA = this.nodes.get(a);\n const nodeB = this.nodes.get(b);\n\n if (!nodeA?.geometryExtents || !nodeB?.geometryExtents) {\n return 0;\n }\n\n const sizeA = nodeA.geometryExtents.getSize(new Vector3());\n const sizeB = nodeB.geometryExtents.getSize(new Vector3());\n const volumeA = sizeA.x * sizeA.y * sizeA.z;\n const volumeB = sizeB.x * sizeB.y * sizeB.z;\n\n return volumeB - volumeA;\n });\n\n if (!ignoreEdges) {\n this.nodesToLoad.push(...this.edgeNodes);\n }\n\n this.dispatchEvent(\"databasechunk\", {\n totalNodes: this.nodesToLoad.length,\n structures: this.structures.map((s) => ({\n id: s.id,\n nodeCount: this.nodesToLoad.filter((nodeId) => nodeId.startsWith(s.id)).length,\n })),\n });\n }\n\n async processNodeHierarchy(structure, nodeId, parentGroup) {\n const nodeDef = structure.json.nodes[nodeId];\n let nodeGroup = null;\n\n let handle = null;\n if (nodeDef.extras?.handle) {\n handle = `${structure.id}_${nodeDef.extras.handle}`;\n }\n\n if (nodeDef.camera !== undefined) {\n const camera = this.loadCamera(structure, nodeDef.camera, nodeDef);\n if (nodeDef.extras) {\n camera.userData = { ...camera.userData, ...nodeDef.extras };\n }\n this.scene.add(camera);\n return;\n }\n\n const needsGroup = this.needsGroupForNode(structure, nodeDef);\n\n if (needsGroup) {\n nodeGroup = new Group();\n nodeGroup.name = nodeDef.name || `node_${nodeId}`;\n\n if (nodeDef.extras) {\n nodeGroup.userData = { ...nodeDef.extras };\n if (nodeGroup.userData.handle) {\n nodeGroup.userData.handle = `${structure.id}_${nodeGroup.userData.handle}`;\n }\n }\n\n if (nodeDef.matrix) {\n nodeGroup.matrix.fromArray(nodeDef.matrix);\n nodeGroup.matrixAutoUpdate = false;\n } else if (nodeDef.translation || nodeDef.rotation || nodeDef.scale) {\n const position = nodeDef.translation ? new Vector3().fromArray(nodeDef.translation) : new Vector3();\n const quaternion = nodeDef.rotation ? new Quaternion().fromArray(nodeDef.rotation) : new Quaternion();\n const scale = nodeDef.scale ? new Vector3().fromArray(nodeDef.scale) : new Vector3(1, 1, 1);\n nodeGroup.matrix.compose(position, quaternion, scale);\n nodeGroup.matrixAutoUpdate = false;\n }\n\n if (parentGroup) {\n parentGroup.add(nodeGroup);\n }\n }\n\n if (nodeDef.mesh !== undefined) {\n const nodeMatrix = new Matrix4();\n const uniqueNodeId = `${structure.id}_${nodeId}`;\n const meshDef = structure.json.meshes[nodeDef.mesh];\n const geometryExtents = new Box3();\n\n for (const primitive of meshDef.primitives) {\n const positionAccessor = structure.json.accessors[primitive.attributes.POSITION];\n if (positionAccessor && positionAccessor.min && positionAccessor.max) {\n const primitiveBox = new Box3(\n new Vector3().fromArray(positionAccessor.min),\n new Vector3().fromArray(positionAccessor.max)\n );\n geometryExtents.union(primitiveBox);\n }\n }\n\n let isEdge = false;\n if (meshDef.primitives[0].material !== undefined) {\n const material = structure.json.materials[meshDef.primitives[0].material];\n if (material?.name === \"edges\") {\n isEdge = true;\n }\n }\n\n if (!isEdge) {\n this.nodesToLoad.push(uniqueNodeId);\n } else {\n this.edgeNodes.push(uniqueNodeId);\n }\n\n this.nodes.set(uniqueNodeId, {\n position: nodeGroup ? nodeGroup.position.clone() : new Vector3().setFromMatrixPosition(nodeMatrix),\n nodeIndex: nodeId,\n meshIndex: nodeDef.mesh,\n loaded: false,\n loading: false,\n object: null,\n group: nodeGroup || parentGroup,\n structure,\n extras: nodeDef.extras,\n geometryExtents,\n handle,\n });\n }\n\n if (nodeDef.children) {\n for (const childId of nodeDef.children) {\n await this.processNodeHierarchy(structure, childId, nodeGroup || parentGroup);\n }\n }\n\n return nodeGroup;\n }\n\n needsGroupForNode(structure, nodeDef) {\n const hasTransforms = nodeDef.matrix || nodeDef.translation || nodeDef.rotation || nodeDef.scale;\n\n const hasMultiplePrimitives =\n nodeDef.mesh !== undefined && structure.json.meshes[nodeDef.mesh].primitives.length > 1;\n\n return hasTransforms !== undefined || hasMultiplePrimitives;\n }\n\n async processNodes() {\n const nodesToLoad = this.nodesToLoad;\n let loadedCount = 0;\n const totalNodes = nodesToLoad.length;\n\n try {\n while (loadedCount < totalNodes) {\n const batch = nodesToLoad.slice(loadedCount, loadedCount + this.batchSize);\n const batchPromises = [];\n\n for (const nodeId of batch) {\n if (this.abortController.signal.aborted) {\n throw new DOMException(\"Loading aborted\", \"AbortError\");\n }\n\n const estimatedSize = await this.estimateNodeSize(nodeId);\n\n if (this.currentMemoryUsage + estimatedSize > this.memoryLimit) {\n console.log(`Memory limit reached after loading ${loadedCount} nodes`);\n this.dispatchEvent(\"geometryerror\", { message: \"Memory limit reached\" });\n this.dispatchEvent(\"update\");\n return loadedCount;\n }\n\n batchPromises.push(this.loadNode(nodeId));\n }\n\n await Promise.all(batchPromises);\n loadedCount += batch.length;\n\n this.updateMemoryIndicator();\n this.dispatchEvent(\"geometryprogress\", {\n percentage: Math.round((loadedCount / totalNodes) * 100),\n loaded: loadedCount,\n total: totalNodes,\n });\n\n const currentTime = Date.now();\n if (currentTime - this.lastUpdateTime >= this.updateInterval) {\n this.dispatchEvent(\"update\");\n this.lastUpdateTime = currentTime;\n }\n\n await new Promise((resolve) => {\n setTimeout(resolve, 0);\n });\n }\n\n this.dispatchEvent(\"geometryend\", {\n totalLoaded: loadedCount,\n totalNodes,\n });\n\n return loadedCount;\n } catch (error) {\n this.dispatchEvent(\"geometryerror\", { error });\n throw error;\n }\n }\n\n async loadNodes() {\n console.time(\"process nodes\");\n await this.processNodes();\n console.timeEnd(\"process nodes\");\n\n console.time(\"optimize scene\");\n await this.optimizeScene();\n console.timeEnd(\"optimize scene\");\n }\n\n cleanupPartialLoad() {\n this.nodesToLoad.forEach((nodeId) => {\n const node = this.nodes.get(nodeId);\n if (node && node.loading) {\n this.unloadNode(nodeId);\n }\n });\n }\n\n createDefaultMaterial() {\n if (this.currentPrimitiveMode === GL_CONSTANTS.POINTS) {\n return new PointsMaterial({\n color: new Color(0x808080),\n size: 0.05,\n sizeAttenuation: true,\n alphaTest: 0.5,\n transparent: true,\n vertexColors: false,\n blending: NormalBlending,\n depthWrite: false,\n depthTest: true,\n });\n } else {\n return new MeshStandardMaterial({\n color: 0x808080,\n metalness: 0.0,\n roughness: 1.0,\n side: DoubleSide,\n });\n }\n }\n\n async estimateNodeSize(nodeId) {\n const node = this.nodes.get(nodeId);\n if (!node) return 0;\n return await node.structure.estimateNodeSize(node.meshIndex);\n }\n\n getTotalGeometryExtent() {\n const totalExtent = new Box3();\n\n for (const node of this.nodes.values()) {\n if (!node.geometryExtents) continue;\n\n if (node.object && this.hiddenHandles.has(node.object.userData.handle)) continue;\n\n const transformedBox = node.geometryExtents.clone();\n\n if (node.group && node.group.matrix) {\n transformedBox.applyMatrix4(node.group.matrix);\n\n if (node.group.parent && node.group.parent.matrix) {\n transformedBox.applyMatrix4(node.group.parent.matrix);\n }\n }\n totalExtent.union(transformedBox);\n }\n\n return totalExtent;\n }\n\n loadCamera(structure, cameraIndex, nodeDef) {\n const cameraDef = structure.getJson().cameras[cameraIndex];\n const params = cameraDef[cameraDef.type];\n\n let camera;\n if (cameraDef.type === \"perspective\") {\n camera = new PerspectiveCamera(\n MathUtils.radToDeg(params.yfov),\n params.aspectRatio || 1,\n params.znear || 1,\n params.zfar || 2e6\n );\n } else if (cameraDef.type === \"orthographic\") {\n camera = new OrthographicCamera(\n params.xmag / -2,\n params.xmag / 2,\n params.ymag / 2,\n params.ymag / -2,\n params.znear,\n params.zfar\n );\n }\n\n if (nodeDef.matrix) {\n camera.matrix.fromArray(nodeDef.matrix);\n camera.matrix.decompose(camera.position, camera.quaternion, camera.scale);\n } else {\n if (nodeDef.translation) {\n camera.position.fromArray(nodeDef.translation);\n }\n if (nodeDef.rotation) {\n camera.quaternion.fromArray(nodeDef.rotation);\n }\n if (nodeDef.scale) {\n camera.scale.fromArray(nodeDef.scale);\n }\n }\n\n return camera;\n }\n\n clearNodesToLoad() {\n this.nodesToLoad = [];\n }\n\n async addStructure(loadController) {\n const structure = new GltfStructure();\n await structure.initialize(loadController);\n this.structures.push(structure);\n return structure;\n }\n\n removeOptimization() {\n this.originalObjects.forEach((obj) => (obj.visible = true));\n\n const disposeMerged = (obj) => {\n if (obj.parent) {\n obj.parent.remove(obj);\n }\n if (obj.geometry) {\n obj.geometry.dispose();\n }\n };\n\n if (this.structureGroups) {\n for (const group of this.structureGroups.values()) {\n group.meshes.forEach(disposeMerged);\n group.lines.forEach(disposeMerged);\n group.lineSegments.forEach(disposeMerged);\n group.meshes.clear();\n group.lines.clear();\n group.lineSegments.clear();\n }\n }\n this.optimizedOriginalMap.clear();\n this.mergedMesh.clear();\n this.mergedLines.clear();\n this.mergedLineSegments.clear();\n this.originalObjects.clear();\n this.originalObjectsToSelection.clear();\n }\n\n clear() {\n // Clear all structures\n this.structures.forEach((structure) => {\n if (structure) {\n structure.clear();\n }\n });\n this.structures = [];\n\n // Clear all nodes and unload their objects\n this.nodes.forEach((node) => {\n if (node.object) {\n if (node.object.parent) {\n node.object.parent.remove(node.object);\n }\n if (node.object.geometry) {\n node.object.geometry.dispose();\n }\n if (node.object.material) {\n if (Array.isArray(node.object.material)) {\n node.object.material.forEach((material) => material.dispose());\n } else {\n node.object.material.dispose();\n }\n }\n }\n });\n this.nodes.clear();\n\n // Clear all loaded meshes\n this.loadedMeshes.forEach((mesh) => {\n if (mesh.geometry) mesh.geometry.dispose();\n if (mesh.material) {\n if (Array.isArray(mesh.material)) {\n mesh.material.forEach((material) => material.dispose());\n } else {\n mesh.material.dispose();\n }\n }\n });\n this.loadedMeshes.clear();\n\n // Clear all structure roots and their children\n this.structureRoots.forEach((rootGroup) => {\n if (rootGroup) {\n rootGroup.traverse((child) => {\n if (child.geometry) child.geometry.dispose();\n if (child.material) {\n if (Array.isArray(child.material)) {\n child.material.forEach((material) => material.dispose());\n } else {\n child.material.dispose();\n }\n }\n });\n if (rootGroup.parent) {\n rootGroup.parent.remove(rootGroup);\n }\n }\n });\n this.structureRoots.clear();\n\n // Clear all optimized objects\n this.mergedMesh.forEach((mesh) => {\n if (mesh.geometry) mesh.geometry.dispose();\n if (mesh.material) {\n if (Array.isArray(mesh.material)) {\n mesh.material.forEach((material) => material.dispose());\n } else {\n mesh.material.dispose();\n }\n }\n if (mesh.parent) mesh.parent.remove(mesh);\n });\n this.mergedMesh.clear();\n\n this.mergedLines.forEach((line) => {\n if (line.geometry) line.geometry.dispose();\n if (line.material) line.material.dispose();\n if (line.parent) line.parent.remove(line);\n });\n this.mergedLines.clear();\n\n this.mergedLineSegments.forEach((lineSegment) => {\n if (lineSegment.geometry) lineSegment.geometry.dispose();\n if (lineSegment.material) lineSegment.material.dispose();\n if (lineSegment.parent) lineSegment.parent.remove(lineSegment);\n });\n this.mergedLineSegments.clear();\n\n this.mergedPoints.forEach((points) => {\n if (points.geometry) points.geometry.dispose();\n if (points.material) points.material.dispose();\n if (points.parent) points.parent.remove(points);\n });\n this.mergedPoints.clear();\n\n // Clear all caches\n this.geometryCache.clear();\n this.materialCache.clear();\n this.textureCache.clear();\n this.loadedMaterials.clear();\n\n // Clear all maps and sets\n this.nodesToLoad = [];\n this.handleToObjects.clear();\n this.originalObjects.clear();\n this.originalObjectsToSelection.clear();\n this.optimizedOriginalMap.clear();\n this.handleToOptimizedObjects.clear();\n this.hiddenHandles.clear();\n this.newOptimizedObjects.clear();\n this.oldOptimizeObjects.clear();\n this.isolatedObjects = [];\n\n // Reset counters and state\n this.totalLoadedObjects = 0;\n this.lastUpdateTime = 0;\n this.currentMemoryUsage = 0;\n this.loadedGeometrySize = 0;\n\n this.abortController = new AbortController();\n this.updateMemoryIndicator();\n }\n\n setStructureTransform(structureId, matrix) {\n const rootGroup = this.structureRoots.get(structureId);\n if (rootGroup) {\n rootGroup.matrix.copy(matrix);\n rootGroup.matrix.decompose(rootGroup.position, rootGroup.quaternion, rootGroup.scale);\n return true;\n }\n return false;\n }\n\n getStructureRootGroup(structureId) {\n return this.structureRoots.get(structureId);\n }\n\n addEventListener(event, handler) {\n if (this.eventHandlers[event]) {\n this.eventHandlers[event].push(handler);\n }\n }\n\n removeEventListener(event, handler) {\n if (this.eventHandlers[event]) {\n this.eventHandlers[event] = this.eventHandlers[event].filter((h) => h !== handler);\n }\n }\n\n dispatchEvent(event, data) {\n if (this.eventHandlers[event]) {\n this.eventHandlers[event].forEach((handler) => handler(data));\n }\n }\n\n registerObjectWithHandle(object, handle) {\n if (!handle) return;\n\n const fullHandle = object.userData.handle;\n if (!this.handleToObjects.has(fullHandle)) {\n this.handleToObjects.set(fullHandle, new Set());\n }\n this.handleToObjects.get(fullHandle).add(object);\n\n object.userData.structureId = object.userData.handle.split(\"_\")[0];\n }\n\n getObjectsByHandle(handle) {\n if (!handle) return [];\n return Array.from(this.handleToObjects.get(handle) || []);\n }\n\n getHandlesByObjects(objects) {\n if (!objects.length) return [];\n const handles = new Set();\n objects.forEach((obj) => {\n if (this.originalObjects.has(obj)) handles.add(obj.userData.handle);\n });\n return Array.from(handles);\n }\n\n getMaterialId(material, index) {\n const props = {\n type: material.type,\n color: material.color?.getHex(),\n map: material.map?.uuid,\n transparent: material.transparent,\n opacity: material.opacity,\n side: material.side,\n index: index ? 1 : 0,\n };\n return JSON.stringify(props);\n }\n\n addToMaterialGroup(object, groupsMap, optimizeGroupList) {\n const VERTEX_LIMIT = 100_000;\n const INDEX_LIMIT = 100_000;\n\n const objectGeometryVertexCount = object.geometry.attributes.position.count;\n const objectGeometryIndexCount = object.geometry.index ? object.geometry.index.count : 0;\n\n const material = object.material;\n let materialId = this.getMaterialId(material, object.geometry.index !== null);\n\n let group;\n if (!groupsMap.has(materialId)) {\n group = {\n material,\n objects: [object],\n totalVertices: objectGeometryVertexCount,\n totalIndices: objectGeometryIndexCount,\n };\n groupsMap.set(materialId, group);\n optimizeGroupList.push(group);\n } else {\n group = groupsMap.get(materialId);\n if (\n group.totalVertices + objectGeometryVertexCount > VERTEX_LIMIT ||\n group.totalIndices + objectGeometryIndexCount > INDEX_LIMIT\n ) {\n const newGroup = {\n material,\n objects: [object],\n totalVertices: objectGeometryVertexCount,\n totalIndices: objectGeometryIndexCount,\n };\n materialId = this.getMaterialId(material, object.geometry.index !== null);\n groupsMap.set(materialId, newGroup);\n optimizeGroupList.push(newGroup);\n } else {\n group.objects.push(object);\n group.totalVertices += objectGeometryVertexCount;\n group.totalIndices += objectGeometryIndexCount;\n }\n }\n\n this.originalObjects.add(object);\n }\n\n optimizeScene() {\n this.originalObjects.clear();\n this.originalObjectsToSelection.clear();\n const structureGroups = new Map();\n\n this.scene.traverse((object) => {\n if (object.userData.structureId) {\n const structureId = object.userData.structureId;\n if (!structureGroups.has(structureId)) {\n structureGroups.set(structureId, {\n mapMeshes: new Map(),\n mapLines: new Map(),\n mapLineSegments: new Map(),\n mapPoints: new Map(),\n\n meshes: [],\n lines: [],\n lineSegments: [],\n points: [],\n rootGroup: this.structureRoots.get(structureId),\n });\n }\n\n const group = structureGroups.get(structureId);\n\n if (object instanceof Mesh) {\n this.addToMaterialGroup(object, group.mapMeshes, group.meshes);\n } else if (object instanceof LineSegments) {\n this.addToMaterialGroup(object, group.mapLineSegments, group.lineSegments);\n } else if (object instanceof Line) {\n this.addToMaterialGroup(object, group.mapLines, group.lines);\n } else if (object instanceof Points) {\n this.addToMaterialGroup(object, group.mapPoints, group.points);\n }\n }\n });\n\n for (const group of structureGroups.values()) {\n group.mapMeshes.clear();\n group.mapLines.clear();\n group.mapLineSegments.clear();\n group.mapPoints.clear();\n\n this.mergeMeshGroups(group.meshes, group.rootGroup);\n this.mergeLineGroups(group.lines, group.rootGroup);\n this.mergeLineSegmentGroups(group.lineSegments, group.rootGroup);\n this.mergePointsGroups(group.points, group.rootGroup);\n }\n\n this.originalObjects.forEach((obj) => {\n obj.visible = false;\n if (!(obj instanceof Points) && !obj.userData.isEdge) {\n this.originalObjectsToSelection.add(obj);\n }\n });\n\n this.dispatchEvent(\"update\");\n }\n\n mergeMeshGroups(materialGroups, rootGroup) {\n for (const group of materialGroups) {\n try {\n const geometries = [];\n const handles = new Set();\n const optimizedObjects = [];\n\n for (const mesh of group.objects) {\n const geometry = mesh.geometry.clone();\n mesh.updateWorldMatrix(true, false);\n geometry.applyMatrix4(mesh.matrixWorld);\n geometries.push(geometry);\n\n optimizedObjects.push(mesh);\n handles.add(mesh.userData.handle);\n }\n\n const mergedObjects = [];\n\n if (geometries.length > 0) {\n const mergedGeometry = mergeGeometries(geometries);\n if (this.useVAO) {\n this.createVAO(mergedGeometry);\n }\n\n const mergedMesh = new Mesh(mergedGeometry, group.material);\n rootGroup.add(mergedMesh);\n\n this.mergedMesh.add(mergedMesh);\n this.optimizedOriginalMap.set(mergedMesh, optimizedObjects);\n\n mergedObjects.push(mergedMesh);\n\n geometries.forEach((geometry) => {\n geometry.dispose();\n });\n }\n\n handles.forEach((handle) => {\n if (this.handleToOptimizedObjects.has(handle)) {\n const existingObjects = this.handleToOptimizedObjects.get(handle);\n existingObjects.push(...mergedObjects);\n this.handleToOptimizedObjects.set(handle, existingObjects);\n } else {\n this.handleToOptimizedObjects.set(handle, mergedObjects);\n }\n });\n } catch (error) {\n console.error(\"Failed to merge meshes for material:\", error);\n group.objects.forEach((mesh) => {\n mesh.visible = true;\n });\n }\n }\n }\n\n mergeLineGroups(materialGroups, rootGroup) {\n for (const group of materialGroups) {\n if (group.objects.length === 0) continue;\n\n const handles = new Set();\n let totalVertices = 0;\n group.objects.map((line) => {\n handles.add(line.userData.handle);\n totalVertices += line.geometry.attributes.position.count;\n });\n\n const positions = new Float32Array(totalVertices * 3);\n let posOffset = 0;\n\n const indices = [];\n let vertexOffset = 0;\n\n group.objects.forEach((line) => {\n const geometry = line.geometry;\n const positionAttr = geometry.attributes.position;\n const vertexCount = positionAttr.count;\n\n line.updateWorldMatrix(true, false);\n const matrix = line.matrixWorld;\n const vector = new Vector3();\n\n for (let i = 0; i < vertexCount; i++) {\n vector.fromBufferAttribute(positionAttr, i);\n vector.applyMatrix4(matrix);\n positions[posOffset++] = vector.x;\n positions[posOffset++] = vector.y;\n positions[posOffset++] = vector.z;\n }\n\n for (let i = 0; i < vertexCount - 1; i++) {\n indices.push(vertexOffset + i, vertexOffset + i + 1);\n }\n\n vertexOffset += vertexCount;\n });\n\n const geometry = new BufferGeometry();\n geometry.setAttribute(\"position\", new BufferAttribute(positions, 3));\n geometry.setIndex(indices);\n geometry.computeBoundingSphere();\n geometry.computeBoundingBox();\n\n const mergedLine = new LineSegments(geometry, group.material);\n const mergedObjects = [mergedLine];\n if (this.useVAO) {\n this.createVAO(mergedLine);\n }\n rootGroup.add(mergedLine);\n this.mergedLines.add(mergedLine);\n this.optimizedOriginalMap.set(mergedLine, group.objects);\n\n handles.forEach((handle) => {\n if (this.handleToOptimizedObjects.has(handle)) {\n const existingObjects = this.handleToOptimizedObjects.get(handle);\n existingObjects.push(...mergedObjects);\n this.handleToOptimizedObjects.set(handle, existingObjects);\n } else {\n this.handleToOptimizedObjects.set(handle, mergedObjects);\n }\n });\n }\n }\n\n mergeLineSegmentGroups(materialGroups, rootGroup) {\n for (const group of materialGroups) {\n try {\n const geometries = [];\n const optimizedObjects = [];\n const handles = new Set();\n\n for (const line of group.objects) {\n const geometry = line.geometry.clone();\n line.updateWorldMatrix(true, false);\n geometry.applyMatrix4(line.matrixWorld);\n geometries.push(geometry);\n optimizedObjects.push(line);\n handles.add(line.userData.handle);\n }\n\n const mergedObjects = [];\n\n if (geometries.length > 0) {\n const mergedGeometry = mergeGeometries(geometries, false);\n const mergedLine = new LineSegments(mergedGeometry, group.material);\n\n if (this.useVAO) {\n this.createVAO(mergedLine);\n }\n\n rootGroup.add(mergedLine);\n this.mergedLineSegments.add(mergedLine);\n this.optimizedOriginalMap.set(mergedLine, optimizedObjects);\n mergedObjects.push(mergedLine);\n\n geometries.forEach((geometry) => {\n geometry.dispose();\n });\n }\n\n handles.forEach((handle) => {\n if (this.handleToOptimizedObjects.has(handle)) {\n const existingObjects = this.handleToOptimizedObjects.get(handle);\n existingObjects.push(...mergedObjects);\n this.handleToOptimizedObjects.set(handle, existingObjects);\n } else {\n this.handleToOptimizedObjects.set(handle, mergedObjects);\n }\n });\n } catch (error) {\n console.warn(\"Failed to merge line segments for material:\", error);\n group.objects.forEach((line) => {\n line.visible = true;\n });\n }\n }\n }\n\n mergePointsGroups(materialGroups, rootGroup) {\n for (const group of materialGroups) {\n try {\n const geometries = [];\n const optimizedObjects = [];\n const handles = new Set();\n\n for (const points of group.objects) {\n const geometry = points.geometry.clone();\n points.updateWorldMatrix(true, false);\n geometry.applyMatrix4(points.matrixWorld);\n geometries.push(geometry);\n optimizedObjects.push(points);\n handles.add(points.userData.handle);\n }\n\n const mergedObjects = [];\n\n if (geometries.length > 0) {\n const mergedGeometry = mergeGeometries(geometries, false);\n const mergedPoints = new Points(mergedGeometry, group.material);\n\n if (this.useVAO) {\n this.createVAO(mergedPoints);\n }\n\n rootGroup.add(mergedPoints);\n\n this.mergedPoints.add(mergedPoints);\n this.optimizedOriginalMap.set(mergedPoints, optimizedObjects);\n mergedObjects.push(mergedPoints);\n\n geometries.forEach((geometry) => {\n geometry.dispose();\n });\n }\n\n handles.forEach((handle) => {\n if (this.handleToOptimizedObjects.has(handle)) {\n const existingObjects = this.handleToOptimizedObjects.get(handle);\n existingObjects.push(...mergedObjects);\n this.handleToOptimizedObjects.set(handle, existingObjects);\n } else {\n this.handleToOptimizedObjects.set(handle, mergedObjects);\n }\n });\n } catch (error) {\n console.warn(\"Failed to merge points for material:\", error);\n group.objects.forEach((points) => {\n points.visible = true;\n });\n }\n }\n }\n\n mergeInSingleSegment(structureId, rootGroup) {\n const lineSegmentsArray = [...this.mergedLineSegments, ...this.mergedLines].filter(\n (obj) => obj.userData.structureId === structureId\n );\n\n if (lineSegmentsArray.length === 0) return;\n\n try {\n const geometriesWithIndex = [];\n const hasNormals = lineSegmentsArray.some((segment) => segment.geometry.attributes.normal !== undefined);\n\n lineSegmentsArray.forEach((segment) => {\n const clonedGeometry = segment.geometry.clone();\n segment.updateWorldMatrix(true, false);\n clonedGeometry.applyMatrix4(segment.matrixWorld);\n\n if (hasNormals && !clonedGeometry.attributes.normal) {\n clonedGeometry.computeVertexNormals();\n }\n if (!hasNormals && clonedGeometry.attributes.normal) {\n clonedGeometry.deleteAttribute(\"normal\");\n }\n\n const colorArray = new Float32Array(clonedGeometry.attributes.position.count * 3);\n for (let i = 0; i < colorArray.length; i += 3) {\n colorArray[i] = segment.material.color.r;\n colorArray[i + 1] = segment.material.color.g;\n colorArray[i + 2] = segment.material.color.b;\n }\n clonedGeometry.setAttribute(\"color\", new BufferAttribute(colorArray, 3));\n\n if (!clonedGeometry.index) {\n const indices = [];\n const posCount = clonedGeometry.attributes.position.count;\n for (let i = 0; i < posCount - 1; i += 2) {\n indices.push(i, i + 1);\n }\n clonedGeometry.setIndex(indices);\n }\n\n geometriesWithIndex.push(clonedGeometry);\n });\n\n const finalGeometry = mergeGeometries(geometriesWithIndex, false);\n const material = new LineBasicMaterial({\n vertexColors: true,\n });\n\n if (this.useVAO) {\n this.createVAO(finalGeometry);\n }\n\n const mergedLine = new LineSegments(finalGeometry, material);\n mergedLine.userData.structureId = structureId;\n rootGroup.add(mergedLine);\n this.mergedLineSegments.add(mergedLine);\n\n lineSegmentsArray.forEach((obj) => {\n if (obj.parent) {\n obj.parent.remove(obj);\n }\n obj.geometry.dispose();\n });\n } catch (error) {\n console.error(\"Failed to merge geometries:\", error);\n lineSegmentsArray.forEach((obj) => {\n obj.visible = true;\n rootGroup.add(obj);\n });\n }\n }\n\n showOriginalObjects(objects) {\n objects.forEach((obj) => {\n if (this.originalObjects.has(obj)) {\n obj.visible = true;\n }\n });\n }\n\n hideOriginalObjects(objects) {\n objects.forEach((obj) => {\n if (this.originalObjects.has(obj)) {\n obj.visible = false;\n }\n });\n }\n\n createVAO(geometry) {\n if (!this.useVAO) {\n return;\n }\n\n if (geometry.attributes?.position?.count < 1000) {\n return;\n }\n\n const gl = this.renderer.getContext();\n const vao = gl.createVertexArray();\n gl.bindVertexArray(vao);\n\n for (const name in geometry.attributes) {\n const attribute = geometry.attributes[name];\n const buffer = this.renderer.properties.get(attribute).buffer;\n\n gl.bindBuffer(gl.ARRAY_BUFFER, buffer);\n gl.enableVertexAttribArray(attribute.itemSize);\n gl.vertexAttribPointer(attribute.itemSize, attribute.itemSize, gl.FLOAT, false, 0, 0);\n }\n\n if (geometry.index) {\n const indexBuffer = this.renderer.properties.get(geometry.index).buffer;\n gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, indexBuffer);\n }\n\n gl.bindVertexArray(null);\n gl.bindBuffer(gl.ARRAY_BUFFER, null);\n gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, null);\n\n geometry.vao = vao;\n }\n\n getOriginalObjectForSelect() {\n const optimizedOriginals = [];\n\n for (const obj of this.originalObjectsToSelection) {\n if (this.hiddenHandles.has(obj.userData.handle)) {\n continue;\n }\n\n optimizedOriginals.push(obj);\n }\n\n return optimizedOriginals;\n }\n\n isolateObjects(handles) {\n if (this.hiddenHandles.size !== 0) {\n this.hiddenHandles.clear();\n this.syncHiddenObjects();\n }\n\n for (const handle of this.handleToOptimizedObjects.keys()) {\n if (!handles.has(handle)) {\n this.hiddenHandles.add(handle);\n }\n }\n\n this.syncHiddenObjects();\n }\n\n showAllHiddenObjects() {\n this.hiddenHandles.clear();\n this.syncHiddenObjects();\n }\n\n hideObjects(handles) {\n handles.forEach((handle) => {\n this.hiddenHandles.add(handle);\n });\n this.syncHiddenObjects();\n }\n\n showObjects(handles) {\n handles.forEach((handle) => {\n this.hiddenHandles.delete(handle);\n });\n this.syncHiddenObjects();\n }\n\n syncHiddenObjects() {\n if (this.oldOptimizeObjects.size !== 0) {\n for (const obj of this.oldOptimizeObjects) {\n obj.visible = true;\n }\n this.oldOptimizeObjects.clear();\n }\n\n if (this.newOptimizedObjects.size !== 0) {\n for (const obj of this.newOptimizedObjects) {\n obj.visible = false;\n obj.geometry.dispose();\n obj.parent.remove(obj);\n }\n this.newOptimizedObjects.clear();\n }\n\n if (this.hiddenHandles.size === 0) {\n return;\n }\n\n this.hiddenHandles.forEach((handle) => {\n const objects = this.handleToOptimizedObjects.get(handle);\n if (objects) {\n objects.forEach((x) => this.oldOptimizeObjects.add(x));\n }\n });\n\n this.oldOptimizeObjects.forEach((optimizedObject) => {\n optimizedObject.visible = false;\n\n const originObjects = this.optimizedOriginalMap.get(optimizedObject);\n const updateListToOptimize = [];\n originObjects.forEach((obj) => {\n if (!this.hiddenHandles.has(obj.userData.handle)) {\n updateListToOptimize.push(obj);\n }\n });\n\n const firstObject = updateListToOptimize[0];\n\n if (firstObject instanceof Mesh || firstObject instanceof LineSegments) {\n const geometries = updateListToOptimize.map((obj) => {\n const geometry = obj.geometry.clone();\n obj.updateWorldMatrix(true, false);\n geometry.applyMatrix4(obj.matrixWorld);\n return geometry;\n });\n\n const newMergedGeometry = mergeGeometries(geometries);\n const mergedObject =\n firstObject instanceof Mesh\n ? new Mesh(newMergedGeometry, optimizedObject.material)\n : new LineSegments(newMergedGeometry, optimizedObject.material);\n\n mergedObject.visible = true;\n optimizedObject.parent.add(mergedObject);\n this.newOptimizedObjects.add(mergedObject);\n\n geometries.forEach((geometry) => {\n geometry.dispose();\n });\n } else if (firstObject instanceof Line) {\n let totalVertices = 0;\n updateListToOptimize.map((line) => {\n totalVertices += line.geometry.attributes.position.count;\n });\n\n const positions = new Float32Array(totalVertices * 3);\n let posOffset = 0;\n\n const indices = [];\n let vertexOffset = 0;\n\n updateListToOptimize.forEach((line) => {\n const geometry = line.geometry;\n const positionAttr = geometry.attributes.position;\n const vertexCount = positionAttr.count;\n\n line.updateWorldMatrix(true, false);\n const matrix = line.matrixWorld;\n const vector = new Vector3();\n\n for (let i = 0; i < vertexCount; i++) {\n vector.fromBufferAttribute(positionAttr, i);\n vector.applyMatrix4(matrix);\n positions[posOffset++] = vector.x;\n positions[posOffset++] = vector.y;\n positions[posOffset++] = vector.z;\n }\n\n for (let i = 0; i < vertexCount - 1; i++) {\n indices.push(vertexOffset + i, vertexOffset + i + 1);\n }\n\n vertexOffset += vertexCount;\n });\n\n const geometry = new BufferGeometry();\n geometry.setAttribute(\"position\", new BufferAttribute(positions, 3));\n geometry.setIndex(indices);\n geometry.computeBoundingSphere();\n geometry.computeBoundingBox();\n\n const mergedLine = new LineSegments(geometry, optimizedObject.material);\n mergedLine.visible = true;\n optimizedObject.parent.add(mergedLine);\n this.newOptimizedObjects.add(mergedLine);\n }\n });\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { Group } from \"three\";\nimport { ILoader, LoadParams } from \"@inweb/viewer-core\";\n\nimport { Viewer } from \"../Viewer\";\nimport { DynamicModelImpl } from \"./DynamicGltfLoader/DynamicModelImpl\";\nimport { DynamicGltfLoader } from \"./DynamicGltfLoader/DynamicGltfLoader.js\";\nimport { GltfStructure } from \"./DynamicGltfLoader/GltfStructure.js\";\n\nexport class GLTFCloudDynamicLoader implements ILoader {\n public viewer: Viewer;\n public scene: Group;\n public gltfLoader: DynamicGltfLoader;\n public requestId = 0;\n\n constructor(viewer: Viewer) {\n this.viewer = viewer;\n this.scene = new Group();\n }\n\n dispose() {\n if (this.gltfLoader) this.gltfLoader.clear();\n }\n\n isSupport(file: any): boolean {\n return (\n typeof file === \"object\" &&\n typeof file.database === \"string\" &&\n typeof file.downloadResource === \"function\" &&\n typeof file.downloadResourceRange === \"function\" &&\n /.gltf$/i.test(file.database)\n );\n }\n\n async load(model: any, format?: string, params?: LoadParams): Promise<this> {\n this.gltfLoader = new DynamicGltfLoader(this.viewer.camera, this.viewer.scene, this.viewer.renderer);\n this.gltfLoader.memoryLimit = this.viewer.options.memoryLimit;\n\n this.gltfLoader.addEventListener(\"databasechunk\", (data) => {\n const modelImpl = new DynamicModelImpl(this.scene);\n modelImpl.loader = this;\n modelImpl.gltfLoader = this.gltfLoader;\n modelImpl.viewer = this.viewer;\n\n this.viewer.scene.add(this.scene);\n this.viewer.models.push(modelImpl);\n\n this.viewer.syncOptions();\n this.viewer.syncOverlay();\n this.viewer.update();\n\n this.viewer.emitEvent({ type: \"databasechunk\", data, file: model.file, model });\n });\n\n this.gltfLoader.addEventListener(\"geometryprogress\", (data) => {\n const progress = data.loaded / data.total;\n this.viewer.emitEvent({ type: \"geometryprogress\", data: progress, file: model.file, model });\n });\n\n this.gltfLoader.addEventListener(\"geometrymemory\", (data) => {\n this.viewer.emit({ type: \"geometryprogress\", data });\n });\n\n this.gltfLoader.addEventListener(\"geometryerror\", (data) => {\n this.viewer.emitEvent({ type: \"geometryerror\", data, file: model.file, model });\n });\n\n this.gltfLoader.addEventListener(\"update\", (data) => {\n this.viewer.update();\n });\n\n const loadController = {\n loadJson: async () => {\n const progress = (progress: number) => {\n this.viewer.emitEvent({ type: \"geometryprogress\", data: progress, file: model });\n };\n\n const arrayBuffer = await model.downloadResource(\n model.database,\n progress,\n this.gltfLoader.getAbortController().signal\n );\n\n const text = new TextDecoder().decode(arrayBuffer);\n const json = JSON.parse(text);\n\n return json;\n },\n\n loadBinaryData: (requests) => {\n const ranges = requests.map((request) => ({\n begin: request.offset,\n end: request.offset + request.length - 1,\n requestId: this.requestId++,\n }));\n\n return model.downloadResourceRange(\n model.geometry[0],\n undefined,\n ranges,\n undefined,\n this.gltfLoader.getAbortController().signal\n );\n },\n\n baseUrl: () => Promise.resolve(`${model.httpClient.serverUrl}${model.path}/`),\n };\n\n const structure = new GltfStructure(1);\n await structure.initialize(loadController);\n\n await this.gltfLoader.loadStructure(structure);\n await this.gltfLoader.loadNodes();\n\n return this;\n }\n\n cancel() {\n if (this.gltfLoader) {\n this.gltfLoader.abortLoading();\n }\n }\n}\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport { ILoadersRegistry, loadersRegistry } from \"@inweb/viewer-core\";\n\nimport { GLTFFileLoader } from \"./GLTFFileLoader\";\nimport { GLTFCloudDynamicLoader } from \"./GLTFCloudDynamicLoader\";\n\n/**\n * Viewer loaders registry. Use this registry to register custom loaders.\n *\n * To implement custom loader:\n *\n * 1. Define a loader class implements {@link ILoader}.\n * 2. Define a constructor with a `viewer` parameter.\n * 3. Override {@link ILoader.isSupport} and сheck if the loader can load the specified file.\n * 4. Override {@link ILoader.load} and define the logic for loading the model from the file.\n *\n * The loader should do:\n *\n * - Load model from file. The model must be a Three.js object of type `Object3D` or a descendant of it.\n * - Add model to the viewer `scene` and `models` list.\n * - Synchronize viewer options and overlay.\n * - Update the viewer.\n *\n * The loader must emit events:\n *\n * - `geometryprogress` - during loading. If progress is not supported, emit it once with a value of 100%\n * after the load is complete.\n * - `databasechunk` - when model is loaded and ready to render.\n * 5. Override {@link ILoader.dispose} and release loader resources, if required.\n * 6. Register loader provider in the loaders registry by calling the {@link loaders.registerLoader}.\n *\n * @example Implementing a custom loader.\n *\n * ```javascript\n * import { Loader } from \"@inweb/viewer-core\";\n * import { loaders, Viewer } from \"@inweb/viewer-three\";\n *\n * class MyLoader extends Loader {\n * public viewer: Viewer;\n *\n * constructor(viewer: Viewer) {\n * super();\n * this.viewer = viewer;\n * }\n *\n * override isSupport(file, format): Boolean {\n * // place custom logic here\n * return ...;\n * }\n *\n * override load(file, format, params): Promise<this> {\n *\n * // place custom loading logic here\n * const model = ...;\n *\n * this.viewer.scene.add(model);\n * this.viewer.models.push(model);\n *\n * this.viewer.syncOptions();\n * this.viewer.syncOverlay();\n * this.viewer.update();\n *\n * this.viewer.emitEvent({ type: \"databasechunk\", data: model, file });\n *\n * return Promise.resove(this);\n * };\n * }\n *\n * loaders.registerLoader(\"MyLoader\", (viewer) => new MyLoader(viewer));\n * ```\n */\nexport const loaders: ILoadersRegistry = loadersRegistry(\"threejs\");\n\n// build-in loaders\n\nloaders.registerLoader(\"gltf-file\", (viewer: any) => new GLTFFileLoader(viewer));\nloaders.registerLoader(\"gltf-cloud\", (viewer: any) => new GLTFCloudDynamicLoader(viewer));\n","///////////////////////////////////////////////////////////////////////////////\n// Copyright (C) 2002-2025, Open Design Alliance (the \"Alliance\").\n// All rights reserved.\n//\n// This software and its documentation and related materials are owned by\n// the Alliance. The software may only be incorporated into application\n// programs owned by members of the Alliance, subject to a signed\n// Membership Agreement and Supplemental Software License Agreement with the\n// Alliance. The structure and organization of this software are the valuable\n// trade secrets of the Alliance and its suppliers. The software is also\n// protected by copyright law and international treaty provisions. Application\n// programs incorporating this software must include the following statement\n// with their copyright notices:\n//\n// This application incorporates Open Design Alliance software pursuant to a\n// license agreement with Open Design Alliance.\n// Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance.\n// All rights reserved.\n//\n// By use of this software, its documentation or related materials, you\n// acknowledge and accept the above terms.\n///////////////////////////////////////////////////////////////////////////////\n\nimport {\n Box3,\n LinearToneMapping,\n Object3D,\n OrthographicCamera,\n PerspectiveCamera,\n Plane,\n Scene,\n Sphere,\n Vector2,\n Vector3,\n WebGLRenderer,\n} from \"three\";\n\nimport { EventEmitter2 } from \"@inweb/eventemitter2\";\nimport { Assembly, Client, Model, File } from \"@inweb/client\";\nimport {\n CANVAS_EVENTS,\n CanvasEventMap,\n FileSource,\n IClippingPlane,\n IComponent,\n IEntity,\n IDragger,\n ILoader,\n IOptions,\n IOrthogonalCamera,\n IPerspectiveCamera,\n IPoint,\n IViewer,\n IViewpoint,\n Options,\n OptionsEventMap,\n ViewerEventMap,\n} from \"@inweb/viewer-core\";\nimport { IMarkup, IWorldTransform, Markup } from \"@inweb/markup\";\n\nimport { draggers } from \"./draggers\";\nimport { commands } from \"./commands\";\nimport { components } from \"./components\";\nimport { loaders } from \"./loaders\";\nimport { IModelImpl } from \"./model\";\n\n/**\n * 3D viewer powered by {@link https://threejs.org/ | Three.js}.\n */\nexport class Viewer\n extends EventEmitter2<ViewerEventMap & CanvasEventMap & OptionsEventMap>\n implements IViewer, IWorldTransform\n{\n public client: Client | undefined;\n protected _options: Options;\n\n private canvaseventlistener: (event: any) => void;\n\n public canvas: HTMLCanvasElement | undefined;\n public canvasEvents: string[];\n\n public scene: Scene | undefined;\n public helpers: Scene | undefined;\n public camera: PerspectiveCamera | OrthographicCamera | undefined;\n public renderer: WebGLRenderer | undefined;\n public loaders: ILoader[];\n public models: IModelImpl[];\n public selected: Object3D[];\n public extents: Box3;\n public target: Vector3;\n\n private _activeDragger: IDragger | null;\n private _components: IComponent[];\n\n private renderNeeded: boolean;\n private renderTime: DOMHighResTimeStamp;\n\n private _markup: IMarkup;\n\n /**\n * @param client - The `Client` instance that is used to load model reference files from the Open Cloud\n * Server. Do not specify `Client` if you need a standalone viewer instance to view `glTF` files from\n * the web or from local computer.\n */\n constructor(client?: Client) {\n super();\n this._options = new Options(this);\n\n this.client = client;\n\n this.canvasEvents = CANVAS_EVENTS;\n this.canvaseventlistener = (event: Event) => this.emit(event);\n\n this.loaders = [];\n this.models = [];\n this.selected = [];\n this.extents = new Box3();\n this.target = new Vector3();\n\n this._activeDragger = null;\n this._components = [];\n\n this.renderTime = 0;\n\n this.render = this.render.bind(this);\n this.update = this.update.bind(this);\n\n this._markup = new Markup();\n }\n\n get options(): IOptions {\n return this._options;\n }\n\n get draggers(): string[] {\n return [...draggers.getDraggers().keys()];\n }\n\n get components(): string[] {\n return [...components.getComponents().keys()];\n }\n\n /**\n * 2D markup core instance used to create markups.\n *\n * @readonly\n */\n get markup(): IMarkup {\n return this._markup;\n }\n\n initialize(canvas: HTMLCanvasElement, onProgress?: (event: ProgressEvent<EventTarget>) => void): Promise<this> {\n this.addEventListener(\"optionschange\", (event) => this.syncOptions(event.data));\n\n this.scene = new Scene();\n this.helpers = new Scene();\n\n const pixelRatio = window.devicePixelRatio;\n const rect = canvas.parentElement.getBoundingClientRect();\n const width = rect.width || 1;\n const height = rect.height || 1;\n const aspect = width / height;\n this.camera = new PerspectiveCamera(45, aspect, 0.01, 1000);\n this.camera.up.set(0, 0, 1);\n\n this.renderer = new WebGLRenderer({\n canvas,\n antialias: true,\n alpha: true,\n preserveDrawingBuffer: true,\n powerPreference: \"high-performance\",\n logarithmicDepthBuffer: false,\n });\n this.renderer.setPixelRatio(pixelRatio);\n this.renderer.setSize(width, height);\n this.renderer.toneMapping = LinearToneMapping;\n\n this.canvas = canvas;\n this.canvasEvents.forEach((x) => canvas.addEventListener(x, this.canvaseventlistener));\n\n this._markup.initialize(this.canvas, this.canvasEvents, this, this);\n\n for (const name of components.getComponents().keys()) {\n this._components.push(components.createComponent(name, this));\n }\n\n this.syncOptions();\n this.syncOverlay();\n\n this.renderTime = performance.now();\n this.render(this.renderTime);\n\n if (typeof onProgress === \"function\")\n onProgress(new ProgressEvent(\"progress\", { lengthComputable: true, loaded: 1, total: 1 }));\n\n this.emitEvent({ type: \"initializeprogress\", data: 1, loaded: 1, total: 1 });\n this.emitEvent({ type: \"initialize\" });\n\n return Promise.resolve(this);\n }\n\n dispose(): this {\n this.cancel();\n this.clear();\n\n this.emitEvent({ type: \"dispose\" });\n this.removeAllListeners();\n\n this.setActiveDragger();\n\n this._components.forEach((component: IComponent) => component.dispose());\n this._components = [];\n\n this._markup.dispose();\n\n if (this.canvas) {\n this.canvasEvents.forEach((x) => this.canvas.removeEventListener(x, this.canvaseventlistener));\n this.canvas = undefined;\n }\n\n if (this.renderer) this.renderer.dispose();\n\n this.helpers = undefined;\n this.scene = undefined;\n this.renderer = undefined;\n this.camera = undefined;\n\n return this;\n }\n\n isInitialized(): boolean {\n return !!this.renderer;\n }\n\n update(force = false): void {\n this.renderNeeded = true;\n if (force) this.render(performance.now());\n this.emitEvent({ type: \"update\", data: force });\n }\n\n render(time: DOMHighResTimeStamp): void {\n if (!this.renderNeeded) return;\n if (!this.renderer) return;\n\n this.renderNeeded = false;\n\n this.renderer.setViewport(0, 0, this.canvas.offsetWidth, this.canvas.offsetHeight);\n this.renderer.autoClear = true;\n this.renderer.render(this.scene, this.camera);\n\n const clippingPlanes = this.renderer.clippingPlanes;\n this.renderer.clippingPlanes = [];\n this.renderer.autoClear = false;\n this.renderer.render(this.helpers, this.camera);\n this.renderer.clippingPlanes = clippingPlanes;\n\n this._activeDragger?.updatePreview?.();\n\n const deltaTime = (time - this.renderTime) / 1000;\n this.renderTime = time;\n this.emitEvent({ type: \"render\", time, deltaTime });\n }\n\n loadReferences(model: Model | File | Assembly): Promise<this> {\n // todo: load reference as text fonts\n return Promise.resolve(this);\n }\n\n /**\n * Loads a file into the viewer.\n *\n * The viewer must be {@link initialize | initialized} before opening the file. Otherwise, `open()` does\n * nothing.\n *\n * This method requires a `Client` instance to be specified to load file from the Open Cloud Server.\n * The file geometry data on the Open Cloud Server must be converted into a format siutable for the\n * viewer, otherwise an exception will be thrown.\n *\n * For files from Open Cloud Server, the default model will be loaded. If there is no default model,\n * first availiable model will be loaded. If no models are found in the file, an exception will be\n * thrown.\n *\n * The file extension is used to determine the file format. For a `ArrayBuffer`, `Blob` and `Data URL`,\n * a file format must be specified using `params.format` parameter (see below). If no appropriate\n * loader is found for the specified format, an exception will be thrown.\n *\n * If there was an active dragger before opening the file, it will be deactivated. After opening the\n * file, you must manually activate the required dragger.\n *\n * To open a large files, enable {@link IOptions.enablePartialMode | partial streaming} mode before\n * opening. For example:\n *\n * ```javascript\n * viewer.options.enableStreamingMode = true;\n * viewer.options.enablePartialMode = true;\n * await viewer.open(file);\n * ```\n *\n * Fires:\n *\n * - {@link OpenEvent | open}\n * - {@link GeometryStartEvent | geometrystart}\n * - {@link GeometryProgressEvent | geometryprogress}\n * - {@link DatabaseChunkEvent | databasechunk}\n * - {@link GeometryChunkEvent | geometrychunk}\n * - {@link GeometryEndEvent | geometryend}\n * - {@link GeometryErrorEvent | geometryerror}\n *\n * @param file - File to load.\n * @param params - Loading parameters.\n * @param params.format - File format string. Required when loading a file as `ArrayBuffer`, `Blob` or\n * `Data URL`.\n * @param params.mode - File opening mode. Can be one of:\n *\n * - `open` - Unloads an open file and opens a new one. This is default mode.\n * - `append` - Appends a file to an already open file.\n *\n * @param params.externalFiles - External resource map such as binary data buffers or textures. Each\n * resource should be represented by a `uri` and a corresponding resource URL, or\n * {@link https://developer.mozilla.org/docs/Web/API/File | Web API File} object, or\n * {@link https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/ArrayBuffer | ArrayBuffer},\n * or {@link https://developer.mozilla.org/docs/Web/API/Blob/Blob | Blob}, or\n * {@link https://developer.mozilla.org/docs/Web/HTTP/Basics_of_HTTP/Data_URIs | Data URL} string,\n * @param params.path - The base path from which additional resources will be loaded. If not defined,\n * the base path of the file URL will be used.\n * @param params.requestHeader - The\n * {@link https://developer.mozilla.org/docs/Glossary/Request_header | request header} used in HTTP\n * request.\n * @param params.crossOrigin - The crossOrigin string to implement CORS for loading the url from a\n * different domain that allows CORS. Default is `anonymous`.\n * @param params.withCredentials - Whether the XMLHttpRequest uses credentials such as cookies,\n * authorization headers or TLS client certificates. See\n * {@link https://developer.mozilla.org/docs/Web/API/XMLHttpRequest/withCredentials | XMLHttpRequest.withCredentials}.\n */\n async open(\n file: FileSource,\n params: {\n format?: string;\n mode?: string;\n path?: string;\n externalFiles?: Map<string, string | globalThis.File | ArrayBuffer | Blob>;\n requestHeader?: HeadersInit;\n crossOrigin?: string;\n withCredentials?: boolean;\n } = {}\n ): Promise<this> {\n if (!this.renderer) return this;\n\n if (params.mode !== \"a\" && params.mode !== \"append\") {\n this.cancel();\n this.clear();\n }\n\n this.emitEvent({ type: \"open\", file });\n\n let model: any = file;\n if (model && typeof model.getModels === \"function\") {\n const models = await model.getModels();\n model = models.find((model: Model) => model.default) || models[0] || file;\n }\n if (!model) throw new Error(`Format not supported`);\n\n let format = params.format;\n if (!format && typeof model.type === \"string\") format = model.type.split(\".\").pop();\n if (!format && typeof file === \"string\") format = file.split(\".\").pop();\n if (!format && file instanceof globalThis.File) format = file.name.split(\".\").pop();\n\n const loader: ILoader = loaders.createLoader(this, model, format);\n if (!loader) throw new Error(`Format not supported`);\n this.loaders.push(loader);\n\n this.emitEvent({ type: \"geometrystart\", file, model });\n try {\n await this.loadReferences(model);\n await loader.load(model, format, params);\n } catch (error: any) {\n this.emitEvent({ type: \"geometryerror\", data: error, file, model });\n throw error;\n }\n this.emitEvent({ type: \"geometryend\", file, model });\n\n return this;\n }\n\n /**\n * Deprecated since `26.4`. Use {@link open | open()} instead.\n *\n * @deprecated\n */\n openGltfFile(file, externalFiles, params: any = {}): Promise<this> {\n return this.open(file, { ...params, format: \"gltf\", externalFiles });\n }\n\n /**\n * Deprecated since `26.4`. Use {@link open | open()} instead.\n *\n * @deprecated\n */\n loadGltfFile(file, externalFiles, params: any = {}): Promise<this> {\n return this.open(file, { ...params, format: \"gltf\", externalFiles, mode: \"append\" });\n }\n\n cancel(): this {\n this.loaders.forEach((loader) => loader.cancel());\n\n this.emitEvent({ type: \"cancel\" });\n return this;\n }\n\n clear(): this {\n if (!this.renderer) return this;\n\n this.setActiveDragger();\n this.clearSlices();\n this.clearOverlay();\n this.clearSelected();\n\n this.loaders.forEach((loader) => loader.dispose());\n this.loaders = [];\n\n this.models.forEach((model) => model.dispose());\n this.models = [];\n\n this.helpers.clear();\n this.scene.clear();\n\n this.syncOptions();\n this.syncOverlay();\n this.update(true);\n\n this.emitEvent({ type: \"clear\" });\n\n return this;\n }\n\n syncOptions(options: IOptions = this.options): void {\n // this.update();\n }\n\n syncOverlay(): void {\n if (!this.renderer) return;\n\n this._markup.syncOverlay();\n this.update();\n }\n\n clearOverlay(): void {\n if (!this.renderer) return;\n\n this._markup.clearOverlay();\n this.update();\n }\n\n clearSlices(): void {\n if (!this.renderer) return;\n\n this.renderer.clippingPlanes = [];\n this.update();\n }\n\n getSelected(): string[] {\n return this.executeCommand(\"getSelected\");\n }\n\n setSelected(handles?: string[]): void {\n this.executeCommand(\"setSelected\", handles);\n }\n\n clearSelected(): void {\n this.executeCommand(\"clearSelected\");\n }\n\n hideSelected(): void {\n this.executeCommand(\"hideSelected\");\n }\n\n isolateSelected(): void {\n this.executeCommand(\"isolateSelected\");\n }\n\n showAll(): void {\n this.executeCommand(\"showAll\");\n }\n\n explode(index = 0): void {\n this.executeCommand(\"explode\", index);\n }\n\n collect(): void {\n this.executeCommand(\"collect\");\n }\n\n activeDragger(): IDragger | null {\n return this._activeDragger;\n }\n\n setActiveDragger(name = \"\"): IDragger | null {\n if (!this._activeDragger || this._activeDragger.name !== name) {\n const oldDragger = this._activeDragger;\n let newDragger = null;\n\n if (this._activeDragger) {\n this._activeDragger.dispose();\n this._activeDragger = null;\n }\n if (this.isInitialized()) {\n newDragger = draggers.createDragger(name, this);\n if (newDragger) {\n this._activeDragger = newDragger;\n this._activeDragger.initialize?.();\n }\n }\n\n const canvas = this.canvas;\n if (canvas) {\n if (oldDragger) canvas.classList.remove(`oda-cursor-${oldDragger.name.toLowerCase()}`);\n if (newDragger) canvas.classList.add(`oda-cursor-${newDragger.name.toLowerCase()}`);\n }\n\n this.emitEvent({ type: \"changeactivedragger\", data: name });\n this.update();\n }\n return this._activeDragger;\n }\n\n resetActiveDragger(): void {\n const dragger = this._activeDragger;\n if (dragger) {\n this.setActiveDragger();\n this.setActiveDragger(dragger.name);\n }\n }\n\n getComponent(name: string): IComponent {\n return this._components.find((component) => component.name === name);\n }\n\n is3D(): boolean {\n return true;\n }\n\n screenToWorld(position: { x: number; y: number }): { x: number; y: number; z: number } {\n if (!this.renderer) return { x: position.x, y: position.y, z: 0 };\n\n const rect = this.canvas.getBoundingClientRect();\n const x = position.x / (rect.width / 2) - 1;\n const y = -position.y / (rect.height / 2) + 1;\n\n const point = new Vector3(x, y, -1);\n point.unproject(this.camera);\n\n return { x: point.x, y: point.y, z: point.z };\n }\n\n worldToScreen(position: { x: number; y: number; z: number }): { x: number; y: number } {\n if (!this.renderer) return { x: position.x, y: position.y };\n\n const point = new Vector3(position.x, position.y, position.z);\n point.project(this.camera);\n\n const rect = this.canvas.getBoundingClientRect();\n const x = (point.x + 1) * (rect.width / 2);\n const y = (-point.y + 1) * (rect.height / 2);\n\n return { x, y };\n }\n\n getScale(): { x: number; y: number; z: number } {\n return { x: 1, y: 1, z: 1 };\n }\n\n executeCommand(id: string, ...args: any[]): any {\n return commands.executeCommand(id, this, ...args);\n }\n\n drawViewpoint(viewpoint: IViewpoint): void {\n if (!this.renderer) return;\n\n const getVector3FromPoint3d = ({ x, y, z }): Vector3 => new Vector3(x, y, z);\n\n const setOrthogonalCamera = (orthogonal_camera: IOrthogonalCamera) => {\n if (orthogonal_camera) {\n const extentsSize = this.extents.getBoundingSphere(new Sphere()).radius * 2;\n const rendererSize = this.renderer.getSize(new Vector2());\n const aspect = rendererSize.x / rendererSize.y;\n\n this.camera = new OrthographicCamera();\n this.camera.top = orthogonal_camera.field_height / 2;\n this.camera.bottom = -orthogonal_camera.field_height / 2;\n this.camera.left = this.camera.bottom * aspect;\n this.camera.right = this.camera.top * aspect;\n this.camera.near = 0;\n this.camera.far = extentsSize * 100;\n this.camera.zoom = orthogonal_camera.view_to_world_scale;\n this.camera.updateProjectionMatrix();\n\n this.camera.up.copy(getVector3FromPoint3d(orthogonal_camera.up_vector));\n this.camera.position.copy(getVector3FromPoint3d(orthogonal_camera.view_point));\n this.camera.lookAt(getVector3FromPoint3d(orthogonal_camera.direction).add(this.camera.position));\n this.camera.updateMatrixWorld();\n }\n };\n\n const setPerspectiveCamera = (perspective_camera: IPerspectiveCamera) => {\n if (perspective_camera) {\n const extentsSize = this.extents.getBoundingSphere(new Sphere()).radius * 2;\n const rendererSize = this.renderer.getSize(new Vector2());\n const aspect = rendererSize.x / rendererSize.y;\n\n this.camera = new PerspectiveCamera();\n this.camera.fov = perspective_camera.field_of_view;\n this.camera.aspect = aspect;\n this.camera.near = extentsSize / 100;\n this.camera.far = extentsSize * 100;\n this.camera.updateProjectionMatrix();\n\n this.camera.up.copy(getVector3FromPoint3d(perspective_camera.up_vector));\n this.camera.position.copy(getVector3FromPoint3d(perspective_camera.view_point));\n this.camera.lookAt(getVector3FromPoint3d(perspective_camera.direction).add(this.camera.position));\n this.camera.updateMatrixWorld();\n }\n };\n\n const setClippingPlanes = (clipping_planes: IClippingPlane[]) => {\n clipping_planes?.forEach((clipping_plane) => {\n const plane = new Plane();\n plane.setFromNormalAndCoplanarPoint(\n getVector3FromPoint3d(clipping_plane.direction),\n getVector3FromPoint3d(clipping_plane.location)\n );\n\n this.renderer.clippingPlanes.push(plane);\n });\n };\n\n const setSelection = (selection: IEntity[]) => {\n if (selection) this.setSelected(selection.map((component) => component.handle));\n };\n\n const draggerName = this._activeDragger?.name;\n\n this.setActiveDragger();\n this.clearSlices();\n this.clearOverlay();\n\n this.clearSelected();\n this.showAll();\n this.explode();\n\n setOrthogonalCamera(viewpoint.orthogonal_camera);\n setPerspectiveCamera(viewpoint.perspective_camera);\n setClippingPlanes(viewpoint.clipping_planes);\n setSelection(viewpoint.selection);\n this._markup.setViewpoint(viewpoint);\n\n this.target = getVector3FromPoint3d(viewpoint.custom_fields?.camera_target ?? this.target);\n\n this.setActiveDragger(draggerName);\n this.emitEvent({ type: \"drawviewpoint\", data: viewpoint });\n this.update();\n }\n\n createViewpoint(): IViewpoint {\n if (!this.renderer) return {};\n\n const getPoint3dFromVector3 = ({ x, y, z }): IPoint => ({ x, y, z });\n\n const getOrthogonalCamera = (): IOrthogonalCamera => {\n if (this.camera[\"isOrthographicCamera\"])\n return {\n view_point: getPoint3dFromVector3(this.camera.position),\n direction: getPoint3dFromVector3(this.camera.getWorldDirection(new Vector3())),\n up_vector: getPoint3dFromVector3(this.camera.up),\n field_width: this.camera[\"right\"] - this.camera[\"left\"],\n field_height: this.camera[\"top\"] - this.camera[\"bottom\"],\n view_to_world_scale: this.camera.zoom,\n };\n else return undefined;\n };\n\n const getPerspectiveCamera = (): IPerspectiveCamera => {\n if (this.camera[\"isPerspectiveCamera\"])\n return {\n view_point: getPoint3dFromVector3(this.camera.position),\n direction: getPoint3dFromVector3(this.camera.getWorldDirection(new Vector3())),\n up_vector: getPoint3dFromVector3(this.camera.up),\n field_of_view: this.camera[\"fov\"],\n };\n else return undefined;\n };\n\n const getClippingPlanes = (): IClippingPlane[] => {\n const clipping_planes = [];\n this.renderer.clippingPlanes.forEach((plane: Plane) => {\n const clipping_plane = {\n location: getPoint3dFromVector3(plane.coplanarPoint(new Vector3())),\n direction: getPoint3dFromVector3(plane.normal),\n };\n clipping_planes.push(clipping_plane);\n });\n return clipping_planes;\n };\n\n const getSelection = (): IEntity[] => {\n return this.getSelected().map((handle) => ({ handle }));\n };\n\n const viewpoint: IViewpoint = { custom_fields: {} };\n\n viewpoint.orthogonal_camera = getOrthogonalCamera();\n viewpoint.perspective_camera = getPerspectiveCamera();\n viewpoint.clipping_planes = getClippingPlanes();\n viewpoint.selection = getSelection();\n viewpoint.description = new Date().toDateString();\n this._markup.getViewpoint(viewpoint);\n\n viewpoint.custom_fields.camera_target = getPoint3dFromVector3(this.target);\n\n this.emitEvent({ type: \"createviewpoint\", data: viewpoint });\n\n return viewpoint;\n }\n}\n"],"names":["PlaneHelper","Line","constructor","plane","size","color","offset","Vector3","positions","geometry","BufferGeometry","setAttribute","Float32BufferAttribute","computeBoundingSphere","super","LineBasicMaterial","toneMapped","this","type","positions2","geometry2","helper","Mesh","MeshBasicMaterial","opacity","transparent","depthWrite","side","DoubleSide","add","dispose","material","children","updateMatrixWorld","force","position","set","lookAt","normal","copy","translateZ","dot","constant","scale","_changeEvent","_startEvent","_endEvent","STATE","NONE","ROTATE","DOLLY","PAN","TOUCH_ROTATE","TOUCH_PAN","TOUCH_DOLLY_PAN","TOUCH_DOLLY_ROTATE","OrbitControls","EventDispatcher","object","domElement","style","touchAction","enabled","target","minDistance","maxDistance","Infinity","minZoom","maxZoom","minPolarAngle","maxPolarAngle","Math","PI","minAzimuthAngle","maxAzimuthAngle","enableDamping","dampingFactor","enableZoom","zoomSpeed","enableRotate","rotateSpeed","enablePan","panSpeed","screenSpacePanning","keyPanSpeed","autoRotate","autoRotateSpeed","keys","LEFT","UP","RIGHT","BOTTOM","mouseButtons","MOUSE","MIDDLE","touches","ONE","TOUCH","TWO","DOLLY_PAN","target0","clone","position0","zoom0","zoom","_domElementKeyEvents","getPolarAngle","spherical","phi","getAzimuthalAngle","theta","getDistance","distanceTo","listenToKeyEvents","addEventListener","onKeyDown","stopListenToKeyEvents","removeEventListener","saveState","scope","reset","updateProjectionMatrix","dispatchEvent","update","state","quat","Quaternion","setFromUnitVectors","up","quatInverse","invert","lastPosition","lastQuaternion","lastTargetPosition","twoPI","sub","applyQuaternion","setFromVector3","rotateLeft","getAutoRotationAngle","sphericalDelta","min","max","isFinite","makeSafe","radius","addScaledVector","panOffset","setFromSpherical","multiplyScalar","zoomChanged","distanceToSquared","EPS","quaternion","onContextMenu","onPointerDown","onPointerUp","onMouseWheel","onPointerMove","Spherical","rotateStart","Vector2","rotateEnd","rotateDelta","panStart","panEnd","panDelta","dollyStart","dollyEnd","dollyDelta","dollyScale","pointers","pointerPositions","getZoomScale","pow","angle","rotateUp","panLeft","v","distance","objectMatrix","setFromMatrixColumn","panUp","crossVectors","pan","deltaX","deltaY","element","isPerspectiveCamera","targetDistance","length","tan","fov","clientHeight","matrix","isOrthographicCamera","right","left","clientWidth","top","bottom","console","warn","dollyOut","dollyIn","handleMouseDownRotate","event","clientX","clientY","handleMouseDownDolly","handleMouseDownPan","handleMouseMoveRotate","subVectors","x","y","handleMouseMoveDolly","handleMouseMovePan","handleMouseWheel","handleKeyDown","needsUpdate","code","ctrlKey","metaKey","shiftKey","preventDefault","handleTouchStartRotate","pageX","pageY","handleTouchStartPan","handleTouchStartDolly","dx","dy","sqrt","handleTouchStartDollyPan","handleTouchStartDollyRotate","handleTouchMoveRotate","getSecondPointerPosition","handleTouchMovePan","handleTouchMoveDolly","handleTouchMoveDollyPan","handleTouchMoveDollyRotate","setPointerCapture","pointerId","addPointer","pointerType","onTouchStart","onMouseDown","onTouchMove","onMouseMove","removePointer","releasePointerCapture","mouseAction","button","trackPointer","DOLLY_ROTATE","push","i","splice","undefined","pointer","passive","OrbitDragger","viewer","updateControls","orbit","camera","far","near","controlsStart","changed","controlsChange","emitEvent","dX","dY","data","stopContextMenu","stopPropagation","canvas","on","initialize","off","CuttingPlaneDragger","transformChange","planeCenter","transformDrag","value","updatePlaneSize","planeHelper","extents","getSize","onDoubleClick","negate","center","getCenter","Plane","renderer","clippingPlanes","helpers","Object3D","transform","TransformControls","showX","showY","showZ","z","attach","getHelper","removeFromParent","detach","CuttingPlaneXAxisDragger","CuttingPlaneYAxisDragger","CuttingPlaneZAxisDragger","PRECISION","MeasureLineDragger","line","startPoint","snapper","getSnapPoint","render","endPoint","MeasureLine","overlay","addLine","onPointerCancel","PointerEvent","onPointerLeave","renderOverlay","updateSnapper","scene","MeasureOverlay","MeasureSnapper","objects","raycaster","Raycaster","mouse","rect","getBoundingClientRect","width","height","coords","setFromCamera","params","threshold","Line2","LOD","Points","Sprite","intersects","intersectObjects","point","traverseVisible","child","lines","projector","MeasureProjector","container","document","createElement","id","background","outline","pointerEvents","overflow","parentElement","appendChild","clear","remove","forEach","removeLine","filter","_middlePoint","Date","now","unit","lineWidth","border","boxShadow","font","elementStartPoint","elementEndPoint","elementLine","elementLabel","visible","projectPoint","display","point1","point2","projectLine","lerpVectors","innerHTML","toFixed","zIndex","borderRadius","transformOrigin","padding","paddingInline","_widthHalf","_heightHalf","_viewMatrix","Matrix4","_viewProjectionMatrix","_vector","_vector1","Vector4","_vector2","matrixWorldInverse","multiplyMatrices","projectionMatrix","p","applyMatrix4","p1","p2","bc1near","w","bc2near","bc1far","bc2far","alpha1","alpha2","lerp","PanDragger","WalkControls","Controls","movementSpeed","lookSpeed","multiplier","moveWheel","mouseDragOn","downPosition","movePosition","rotateCamera","onWheel","moveKeys","onKeyUp","delete","Set","moveClock","Clock","window","timeDelta","getDelta","moveDelta","has","translateX","translateY","lookDelta","sign","stop","autoStart","delta","rotateX","rotateY","xRotation","setFromAxisAngle","yRotation","premultiply","multiply","normalize","setRotationFromQuaternion","WalkDragger","controls","walkspeedChange","viewerRender","viewerZoom","ZoomDragger","draggers","draggersRegistry","registerDragger","applyModelTransform","model","clearMarkup","clearOverlay","clearSelected","selection","getComponent","clearSelection","handles","clearSlices","createPreview","encoderOptions","toDataURL","explode","index","models","collect","zoomTo","box","isEmpty","sphere","getBoundingSphere","Sphere","rendererSize","aspect","MathUtils","DEG2RAD","defaultViewPositions","front","back","sw","se","ne","nw","setDefaultViewPosition","direction","emit","getDefaultViewPositions","Object","getModels","map","handle","getSelected","getHandlesByObjects","selected","hideSelected","hideObjects","isolateSelected","isolateObjects","regenerateAll","resetView","executeCommand","selectModel","select","getObjects","setActiveDragger","dragger","setMarkupColor","r","g","b","markup","setSelected","getObjectsByHandles","showAll","showAllObjects","zoomToExtents","zoomToObjects","handleSet","_a","userData","reduce","result","expandByObject","Box3","zoomToSelected","commands","commandsRegistry","registerCommand","registerCommandAlias","BackgroundComponent","syncOptions","backgroundColor","setHex","setClearColor","Color","CameraComponent","geometryEnd","extentsCenter","extentsSize","sceneCamera","traverse","isCamera","ExtentsComponent","syncExtents","getExtents","LightComponent","ambientLight","directionalLight","frontLight","hemisphereLight","AmbientLight","DirectionalLight","HemisphereLight","RenderLoopComponent","animate","time","requestId","requestAnimationFrame","cancelAnimationFrame","ResizeCanvasComponent","resizeViewer","entries","contentRect","setSize","resizeObserver","ResizeObserver","observe","disconnect","HighlighterUtils","isBreak","isNaN","fromIndexedLine","indices","lineGeometry","LineSegmentsGeometry","segments","idx1","idx2","setPositions","fromNonIndexedLine","isLineSegments","lastValidIndex","HighlighterComponent","facesColor","facesTransparancy","edgesColor","options","highlightMaterial","depthTest","outlineMaterial","LineMaterial","linewidth","resolution","innerWidth","innerHeight","highlightLineMaterial","highlightLineGlowMaterial","optionsChange","setRGB","gl2","getContext","renderTarget","WebGLRenderTarget","format","RGBAFormat","stencilBuffer","samples","UnsignedByteType","viewerResize","highlight","Array","isArray","isHighlighted","isLine","attributes","array","wireframe","Wireframe","rotation","parent","highlightwireframe","originalMaterial","isMesh","edgesGeometry","EdgesGeometry","fromEdgesGeometry","unhighlight","_b","SelectionComponent","isPrimary","getMousePosition","upPosition","intersections","getVisibleObjects","getPointerIntersects","sort","a","toggleSelection","initHighlighter","highlighter","showObjects","showOriginalObjects","isSelected","deselect","hideOriginalObjects","includes","WCSHelper","orthoCamera","OrthographicCamera","matRed","matGreen","matBlue","spriteRed","getSpriteMaterial","spriteGreen","spriteBlue","CylinderGeometry","translate","arrowGeometry","axesMap","X","Y","Z","key","name","text","context","clearRect","textAlign","fillStyle","getStyle","fillText","texture","CanvasTexture","colorSpace","SRGBColorSpace","SpriteMaterial","viewport","getViewport","setViewport","clearDepth","WCSHelperComponent","wcsHelper","showWCS","components","componentsRegistry","registerComponent","GLTFLoadingManager","LoadingManager","file","path","resourcePath","fileURL","dataURLs","Map","externalFiles","LoaderUtils","extractUrlBase","dataURL","URL","createObjectURL","Blob","setURLModifier","url","decodeURI","replace","get","revokeObjectURL","ModelImpl","disposeMaterial","disposeMaterials","materials","disposeObject","hasObject","getOwnObjects","handlesSet","from","hideAllObjects","visibleSet","traverseAncestors","coeff","calcExplodeDepth","depth","res","objectDepth","originalPosition","originalCenter","setFromObject","isExplodeLocked","explodeDepth","maxDepth","scaledExplodeDepth","currentSegmentFraction","explodeObject","objectScale","parentCenter","objectCenter","objectOffset","GLTFFileLoader","Loader","isSupport","globalThis","File","ArrayBuffer","test","load","manager","loader","GLTFLoader","setPath","setCrossOrigin","crossOrigin","setWithCredentials","withCredentials","progress","lengthComputable","loaded","total","gltf","loadAsync","modelImpl","syncOverlay","DynamicModelImpl","union","gltfLoader","getTotalGeometryExtent","originalObjects","getOriginalObjectForSelect","handleToObjects","hiddenHandles","syncHiddenObjects","GL_COMPONENT_TYPES","Int8Array","Uint8Array","Int16Array","Uint16Array","Uint32Array","Float32Array","GL_CONSTANTS","POINTS","LINES","LINE_LOOP","LINE_STRIP","TRIANGLES","TRIANGLE_STRIP","TRIANGLE_FAN","GltfStructure","json","baseUrl","loadController","batchDelay","maxBatchSize","maxRangesPerRequest","pendingRequests","batchTimeout","textureLoader","TextureLoader","textureCache","loadJson","clearTimeout","getJson","scheduleRequest","request","setTimeout","processBatch","Promise","resolve","reject","currentBatch","batchRequests","slice","buffer","loadBinaryData","currentOffset","view","createTypedArray","componentType","error","getBufferView","byteOffset","byteLength","Error","elementSize","numElements","Number","isInteger","ArrayType","bufferSize","createBufferAttribute","accessorIndex","accessor","accessors","bufferView","bufferViews","getNumComponents","count","getComponentSize","attribute","BufferAttribute","loadTextures","textures","loadTexture","async","imageIndex","image","images","uri","startsWith","fullUrl","blob","mimeType","flipY","texturePromises","source","then","all","loadMaterials","materialDef","createMaterial","MeshStandardMaterial","pbrMetallicRoughness","pbr","baseColorFactor","fromArray","baseColorTexture","metallicFactor","metalness","roughnessFactor","roughness","metallicRoughnessTexture","metalnessMap","roughnessMap","normalTexture","normalMap","normalScale","emissiveFactor","emissive","emissiveTexture","emissiveMap","occlusionTexture","aoMap","strength","aoMapIntensity","alphaMode","alphaTest","alphaCutoff","doubleSided","FrontSide","lightMap","bumpMap","specularMap","envMap","estimateNodeSize","meshIndex","meshes","meshDef","primitives","totalSize","primitive","numComponents","bytesPerComponent","mergeGeometries","geometries","useGroups","isIndexed","attributesUsed","morphAttributesUsed","morphAttributes","morphTargetsRelative","mergedGeometry","attributesCount","addGroup","indexOffset","mergedIndex","j","getX","setIndex","mergedAttribute","mergeAttributes","numMorphTargets","morphAttributesToMerge","mergedMorphAttribute","TypedArray","itemSize","normalized","gpuType","arrayLength","isInterleavedBufferAttribute","tupleOffset","l","c","setComponent","DynamicGltfLoader","eventHandlers","geometryprogress","databasechunk","geometryend","geometryerror","geometrymemory","loadDistance","unloadDistance","checkInterval","nodes","loadedMeshes","nodesToLoad","edgeNodes","structures","structureRoots","memoryLimit","getAvailableMemory","loadedGeometrySize","geometryCache","materialCache","currentMemoryUsage","updateMemoryIndicator","loadedMaterials","abortController","AbortController","batchSize","frameDelay","graphicsObjectLimit","totalLoadedObjects","lastUpdateTime","updateInterval","originalObjectsToSelection","optimizedOriginalMap","mergedMesh","mergedLines","mergedLineSegments","mergedPoints","isolatedObjects","useVAO","WebGL2RenderingContext","handleToOptimizedObjects","newOptimizedObjects","oldOptimizeObjects","navigator","deviceMemory","performance","memory","jsHeapSizeLimit","log","round","getAbortController","abortLoading","abort","currentUsage","limit","setMemoryLimit","bytesLimit","estimateGeometrySize","nodeGroup","signal","aborted","DOMException","values","recalculateScene","uuid","geo","loadNode","nodeId","node","loading","structure","positionAccessor","POSITION","NORMAL","TEXCOORD_0","loadedAttributes","promise","indexAttribute","currentPrimitiveMode","mode","createDefaultMaterial","mesh","pointsMaterial","PointsMaterial","Material","prototype","call","sizeAttenuation","drawMode","TriangleStripDrawMode","TriangleFanDrawMode","LineSegments","LineLoop","extras","isEdge","registerObjectWithHandle","computeVertexNormals","uv","group","geometrySize","unloadNode","checkDistances","cameraPosition","loadStructure","structureArray","processSceneHierarchy","estimatedSize","scenes","buffers","rootGroup","Group","nodeIndex","processNodeHierarchy","ignoreEdges","nodeA","nodeB","geometryExtents","sizeA","sizeB","volumeA","volumeB","totalNodes","s","nodeCount","parentGroup","nodeDef","loadCamera","needsGroup","needsGroupForNode","matrixAutoUpdate","translation","compose","nodeMatrix","uniqueNodeId","primitiveBox","setFromMatrixPosition","childId","hasTransforms","hasMultiplePrimitives","processNodes","loadedCount","batch","batchPromises","message","percentage","currentTime","totalLoaded","loadNodes","timeEnd","optimizeScene","cleanupPartialLoad","vertexColors","blending","NormalBlending","totalExtent","transformedBox","cameraIndex","cameraDef","cameras","PerspectiveCamera","radToDeg","yfov","aspectRatio","znear","zfar","xmag","ymag","decompose","clearNodesToLoad","addStructure","removeOptimization","obj","disposeMerged","structureGroups","lineSegments","lineSegment","points","setStructureTransform","structureId","getStructureRootGroup","handler","h","fullHandle","split","getObjectsByHandle","getMaterialId","props","getHex","JSON","stringify","addToMaterialGroup","groupsMap","optimizeGroupList","VERTEX_LIMIT","INDEX_LIMIT","objectGeometryVertexCount","objectGeometryIndexCount","materialId","totalVertices","totalIndices","newGroup","mapMeshes","mapLines","mapLineSegments","mapPoints","mergeMeshGroups","mergeLineGroups","mergeLineSegmentGroups","mergePointsGroups","materialGroups","optimizedObjects","updateWorldMatrix","matrixWorld","mergedObjects","createVAO","existingObjects","posOffset","vertexOffset","positionAttr","vertexCount","vector","fromBufferAttribute","computeBoundingBox","mergedLine","mergeInSingleSegment","lineSegmentsArray","geometriesWithIndex","hasNormals","some","segment","clonedGeometry","deleteAttribute","colorArray","posCount","finalGeometry","gl","vao","createVertexArray","bindVertexArray","properties","bindBuffer","ARRAY_BUFFER","enableVertexAttribArray","vertexAttribPointer","FLOAT","indexBuffer","ELEMENT_ARRAY_BUFFER","optimizedOriginals","showAllHiddenObjects","optimizedObject","originObjects","updateListToOptimize","firstObject","newMergedGeometry","mergedObject","GLTFCloudDynamicLoader","database","downloadResource","downloadResourceRange","arrayBuffer","TextDecoder","decode","parse","requests","ranges","begin","end","httpClient","serverUrl","cancel","loaders","loadersRegistry","registerLoader","Viewer","EventEmitter2","client","_options","Options","canvasEvents","CANVAS_EVENTS","canvaseventlistener","_activeDragger","_components","renderTime","bind","_markup","Markup","getDraggers","getComponents","onProgress","Scene","pixelRatio","devicePixelRatio","WebGLRenderer","antialias","alpha","preserveDrawingBuffer","powerPreference","logarithmicDepthBuffer","setPixelRatio","toneMapping","LinearToneMapping","createComponent","ProgressEvent","removeAllListeners","component","isInitialized","renderNeeded","offsetWidth","offsetHeight","autoClear","updatePreview","deltaTime","loadReferences","open","find","default","pop","createLoader","openGltfFile","loadGltfFile","activeDragger","oldDragger","newDragger","createDragger","classList","toLowerCase","resetActiveDragger","is3D","screenToWorld","unproject","worldToScreen","project","getScale","args","drawViewpoint","viewpoint","getVector3FromPoint3d","setOrthogonalCamera","orthogonal_camera","field_height","view_to_world_scale","up_vector","view_point","setPerspectiveCamera","perspective_camera","field_of_view","setClippingPlanes","clipping_planes","clipping_plane","setFromNormalAndCoplanarPoint","location","setSelection","draggerName","setViewpoint","custom_fields","camera_target","_c","createViewpoint","getPoint3dFromVector3","getOrthogonalCamera","getWorldDirection","field_width","getPerspectiveCamera","getClippingPlanes","coplanarPoint","getSelection","description","toDateString","getViewpoint"],"mappings":"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","x_google_ignoreList":[54]}