@cognite/reveal 3.1.0 → 3.2.1

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 (327) hide show
  1. package/README.md +10 -0
  2. package/eptBinaryDecoder.worker.map +1 -1
  3. package/extensions/datasource.d.ts +9 -9
  4. package/extensions/datasource.js +2 -26
  5. package/{core/src/public/migration/RenderController.d.ts → extensions/datasource.js.LICENSE.txt} +3 -4
  6. package/extensions/datasource.map +1 -1
  7. package/index.d.ts +13 -13
  8. package/index.js +2 -576
  9. package/index.js.LICENSE.txt +11 -0
  10. package/index.map +1 -1
  11. package/package.json +9 -6
  12. package/packages/api/index.d.ts +11 -0
  13. package/{core → packages/api}/src/public/RevealManager.d.ts +52 -52
  14. package/{core → packages/api}/src/public/createRevealManager.d.ts +24 -24
  15. package/{core → packages/api}/src/public/migration/Cognite3DViewer.d.ts +509 -498
  16. package/{core → packages/api}/src/public/migration/renderOptionsHelpers.d.ts +36 -29
  17. package/{core → packages/api}/src/public/migration/types.d.ts +184 -171
  18. package/{core → packages/api}/src/public/types.d.ts +31 -30
  19. package/{core → packages/api}/src/storage/RevealManagerHelper.d.ts +61 -60
  20. package/{core → packages/api}/src/utilities/Spinner.d.ts +27 -27
  21. package/{core → packages/api}/src/utilities/ViewStateHelper.d.ts +49 -49
  22. package/{core → packages/api}/src/utilities/reflection.d.ts +7 -7
  23. package/packages/cad-geometry-loaders/index.d.ts +10 -10
  24. package/packages/cad-geometry-loaders/src/CadLoadingHints.d.ts +11 -11
  25. package/packages/cad-geometry-loaders/src/CadManager.d.ts +46 -46
  26. package/packages/cad-geometry-loaders/src/CadModelBudget.d.ts +21 -21
  27. package/packages/cad-geometry-loaders/src/CadModelUpdateHandler.d.ts +44 -44
  28. package/packages/cad-geometry-loaders/src/InternalRevealCadOptions.d.ts +13 -13
  29. package/packages/cad-geometry-loaders/src/createCadManager.d.ts +10 -10
  30. package/packages/cad-geometry-loaders/src/sector/ModelStateHandler.d.ts +12 -12
  31. package/packages/cad-geometry-loaders/src/sector/SectorDownloadScheduler.d.ts +22 -22
  32. package/packages/cad-geometry-loaders/src/sector/SectorLoader.d.ts +32 -32
  33. package/packages/cad-geometry-loaders/src/sector/culling/ByScreenSizeSectorCuller.d.ts +23 -23
  34. package/packages/cad-geometry-loaders/src/sector/culling/ByVisibilityGpuSectorCuller.d.ts +51 -51
  35. package/packages/cad-geometry-loaders/src/sector/culling/OrderSectorsByVisibilityCoverage.d.ts +106 -106
  36. package/packages/cad-geometry-loaders/src/sector/culling/RenderAlreadyLoadedGeometryProvider.d.ts +11 -11
  37. package/packages/cad-geometry-loaders/src/sector/culling/SectorCuller.d.ts +33 -33
  38. package/packages/cad-geometry-loaders/src/sector/culling/WeightFunctionsHelper.d.ts +51 -50
  39. package/packages/cad-geometry-loaders/src/sector/culling/computeNdcAreaOfBox.d.ts +12 -12
  40. package/packages/cad-geometry-loaders/src/sector/culling/computeSectorCost.d.ts +7 -7
  41. package/packages/cad-geometry-loaders/src/sector/culling/createV8SectorCuller.d.ts +7 -7
  42. package/packages/cad-geometry-loaders/src/sector/culling/takensectors/TakenSectorMapBase.d.ts +11 -11
  43. package/packages/cad-geometry-loaders/src/sector/culling/takensectors/TakenV8SectorMap.d.ts +17 -17
  44. package/packages/cad-geometry-loaders/src/sector/culling/takensectors/TakenV8SectorTree.d.ts +24 -24
  45. package/packages/cad-geometry-loaders/src/sector/culling/takensectors/TakenV9SectorMap.d.ts +20 -20
  46. package/packages/cad-geometry-loaders/src/sector/culling/takensectors/index.d.ts +5 -5
  47. package/packages/cad-geometry-loaders/src/sector/culling/transformBoxToNDC.d.ts +5 -5
  48. package/packages/cad-geometry-loaders/src/sector/culling/types.d.ts +83 -83
  49. package/packages/cad-geometry-loaders/src/sector/rxSectorUtilities.d.ts +12 -12
  50. package/packages/cad-geometry-loaders/src/utilities/PromiseUtils.d.ts +28 -28
  51. package/packages/cad-model/index.d.ts +9 -9
  52. package/packages/cad-model/src/CadModelFactory.d.ts +17 -17
  53. package/packages/cad-model/src/batching/GeometryBatchingManager.d.ts +31 -31
  54. package/packages/cad-model/src/batching/InstancedMeshManager.d.ts +20 -20
  55. package/packages/cad-model/src/picking/PickingHandler.d.ts +36 -35
  56. package/packages/cad-model/src/picking/readPixelsFromTargetAsync.d.ts +17 -0
  57. package/packages/cad-model/src/types.d.ts +59 -59
  58. package/packages/cad-model/src/utilities/BoundingBoxClipper.d.ts +23 -23
  59. package/packages/cad-model/src/utilities/NodeIdAndTreeIndexMaps.d.ts +4 -4
  60. package/packages/cad-model/src/utilities/callActionWithIndicesAsync.d.ts +4 -4
  61. package/packages/cad-model/src/wrappers/CadNode.d.ts +54 -54
  62. package/packages/cad-model/src/wrappers/Cognite3DModel.d.ts +337 -337
  63. package/packages/cad-parsers/index.d.ts +20 -20
  64. package/packages/cad-parsers/src/cad/CadSectorParser.d.ts +15 -15
  65. package/packages/cad-parsers/src/cad/LevelOfDetail.d.ts +8 -8
  66. package/packages/cad-parsers/src/cad/filterInstanceMesh.d.ts +6 -6
  67. package/packages/cad-parsers/src/cad/filterPrimitivesCommon.d.ts +5 -5
  68. package/packages/cad-parsers/src/cad/filterPrimitivesV8.d.ts +9 -9
  69. package/packages/cad-parsers/src/cad/filterPrimitivesV9.d.ts +6 -6
  70. package/packages/cad-parsers/src/cad/primitiveGeometries.d.ts +30 -30
  71. package/packages/cad-parsers/src/cad/triangleMeshes.d.ts +6 -6
  72. package/packages/cad-parsers/src/cad/types.d.ts +56 -56
  73. package/packages/cad-parsers/src/metadata/CadMetadataParser.d.ts +7 -7
  74. package/packages/cad-parsers/src/metadata/CadModelClipper.d.ts +10 -10
  75. package/packages/cad-parsers/src/metadata/CadModelMetadata.d.ts +54 -54
  76. package/packages/cad-parsers/src/metadata/CadModelMetadataRepository.d.ts +16 -16
  77. package/packages/cad-parsers/src/metadata/parsers/CadMetadataParserGltf.d.ts +8 -8
  78. package/packages/cad-parsers/src/metadata/parsers/CadMetadataParserV8.d.ts +6 -6
  79. package/packages/cad-parsers/src/metadata/parsers/types.d.ts +62 -62
  80. package/packages/cad-parsers/src/metadata/types.d.ts +53 -53
  81. package/packages/cad-parsers/src/sector/RootSectorNode.d.ts +13 -13
  82. package/packages/cad-parsers/src/sector/SectorNode.d.ts +22 -22
  83. package/packages/cad-parsers/src/utilities/SectorScene.d.ts +23 -23
  84. package/packages/cad-parsers/src/utilities/SectorSceneFactory.d.ts +9 -9
  85. package/packages/cad-parsers/src/utilities/computeBoundingBoxFromAttributes.d.ts +10 -10
  86. package/packages/cad-parsers/src/utilities/float32BufferToMatrix.d.ts +12 -12
  87. package/packages/cad-parsers/src/utilities/types.d.ts +71 -71
  88. package/packages/cad-styling/index.d.ts +20 -20
  89. package/packages/cad-styling/src/AssetNodeCollection.d.ts +47 -47
  90. package/packages/cad-styling/src/CdfModelNodeCollectionDataProvider.d.ts +26 -26
  91. package/packages/cad-styling/src/CombineNodeCollectionBase.d.ts +34 -34
  92. package/packages/cad-styling/src/IntersectionNodeCollection.d.ts +20 -20
  93. package/packages/cad-styling/src/InvertedNodeCollection.d.ts +27 -27
  94. package/packages/cad-styling/src/NodeAppearance.d.ts +85 -85
  95. package/packages/cad-styling/src/NodeAppearanceProvider.d.ts +38 -38
  96. package/packages/cad-styling/src/NodeCollection.d.ts +31 -26
  97. package/packages/cad-styling/src/NodeCollectionDeserializer.d.ts +26 -26
  98. package/packages/cad-styling/src/PopulateIndexSetFromPagedResponseHelper.d.ts +30 -30
  99. package/packages/cad-styling/src/PropertyFilterNodeCollection.d.ts +57 -57
  100. package/packages/cad-styling/src/SerializedNodeCollection.d.ts +8 -8
  101. package/packages/cad-styling/src/SinglePropertyFilterNodeCollection.d.ts +53 -53
  102. package/packages/cad-styling/src/TreeIndexNodeCollection.d.ts +40 -40
  103. package/packages/cad-styling/src/UnionNodeCollection.d.ts +19 -19
  104. package/packages/cad-styling/src/prioritized/AreaCollection.d.ts +39 -39
  105. package/packages/cad-styling/src/prioritized/BoxClusterer.d.ts +29 -29
  106. package/packages/cad-styling/src/prioritized/ClusteredAreaCollection.d.ts +17 -17
  107. package/packages/cad-styling/src/prioritized/EmptyAreaCollection.d.ts +18 -18
  108. package/packages/cad-styling/src/prioritized/types.d.ts +7 -7
  109. package/packages/camera-manager/index.d.ts +8 -8
  110. package/packages/camera-manager/src/CameraManager.d.ts +78 -74
  111. package/packages/camera-manager/src/CameraManagerHelper.d.ts +42 -42
  112. package/packages/camera-manager/src/ComboControls.d.ts +110 -112
  113. package/packages/camera-manager/src/DefaultCameraManager.d.ts +150 -136
  114. package/packages/camera-manager/src/Keyboard.d.ts +19 -17
  115. package/packages/camera-manager/src/types.d.ts +66 -66
  116. package/packages/data-source/index.d.ts +6 -6
  117. package/packages/data-source/src/CdfDataSource.d.ts +19 -19
  118. package/packages/data-source/src/DataSource.d.ts +25 -25
  119. package/packages/data-source/src/LocalDataSource.d.ts +15 -15
  120. package/packages/logger/index.d.ts +5 -5
  121. package/packages/logger/src/Log.d.ts +5 -5
  122. package/packages/metrics/index.d.ts +4 -4
  123. package/packages/metrics/src/MetricsLogger.d.ts +34 -21
  124. package/packages/metrics/src/types.d.ts +7 -7
  125. package/packages/model-base/index.d.ts +7 -7
  126. package/packages/model-base/src/CogniteModelBase.d.ts +17 -17
  127. package/packages/model-base/src/MetadataRepository.d.ts +7 -7
  128. package/packages/model-base/src/SupportedModelTypes.d.ts +4 -4
  129. package/packages/model-base/src/types.d.ts +36 -36
  130. package/packages/modeldata-api/index.d.ts +12 -12
  131. package/packages/modeldata-api/src/CdfModelDataProvider.d.ts +16 -16
  132. package/packages/modeldata-api/src/CdfModelIdentifier.d.ts +15 -15
  133. package/packages/modeldata-api/src/CdfModelMetadataProvider.d.ts +20 -20
  134. package/packages/modeldata-api/src/LocalModelDataProvider.d.ts +8 -8
  135. package/packages/modeldata-api/src/LocalModelIdentifier.d.ts +14 -14
  136. package/packages/modeldata-api/src/LocalModelMetadataProvider.d.ts +16 -16
  137. package/packages/modeldata-api/src/ModelIdentifier.d.ts +12 -12
  138. package/packages/modeldata-api/src/ModelMetadataProvider.d.ts +18 -18
  139. package/packages/modeldata-api/src/applyDefaultModelTransformation.d.ts +6 -6
  140. package/packages/modeldata-api/src/types.d.ts +43 -43
  141. package/packages/modeldata-api/src/utilities.d.ts +7 -7
  142. package/packages/nodes-api/index.d.ts +6 -6
  143. package/packages/nodes-api/src/NodesApiClient.d.ts +50 -50
  144. package/packages/nodes-api/src/NodesCdfClient.d.ts +24 -24
  145. package/packages/nodes-api/src/NodesLocalClient.d.ts +30 -30
  146. package/packages/nodes-api/src/types.d.ts +10 -10
  147. package/packages/pointclouds/index.d.ts +15 -15
  148. package/packages/pointclouds/src/CognitePointCloudModel.d.ts +131 -131
  149. package/packages/pointclouds/src/PointCloudBudget.d.ts +14 -14
  150. package/packages/pointclouds/src/PointCloudFactory.d.ts +13 -13
  151. package/packages/pointclouds/src/PointCloudIntersection.d.ts +26 -26
  152. package/packages/pointclouds/src/PointCloudManager.d.ts +37 -37
  153. package/packages/pointclouds/src/PointCloudMetadata.d.ts +15 -14
  154. package/packages/pointclouds/src/PointCloudMetadataRepository.d.ts +14 -14
  155. package/packages/pointclouds/src/PointCloudNode.d.ts +69 -69
  156. package/packages/pointclouds/src/{picking.d.ts → PointCloudPickingHandler.d.ts} +36 -29
  157. package/packages/pointclouds/src/PotreeGroupWrapper.d.ts +46 -46
  158. package/packages/pointclouds/src/PotreeNodeWrapper.d.ts +39 -36
  159. package/packages/pointclouds/src/PotreePnextLoader.d.ts +4 -4
  160. package/packages/pointclouds/src/createPointClassKey.d.ts +5 -5
  161. package/packages/pointclouds/src/createPointCloudManager.d.ts +7 -7
  162. package/packages/pointclouds/src/potree-three-loader/Potree.d.ts +43 -46
  163. package/packages/pointclouds/src/potree-three-loader/geometry/IPointCloudTreeGeometry.d.ts +10 -10
  164. package/packages/pointclouds/src/potree-three-loader/geometry/IPointCloudTreeGeometryNode.d.ts +11 -11
  165. package/packages/pointclouds/src/potree-three-loader/geometry/PointCloudEptGeometry.d.ts +50 -50
  166. package/packages/pointclouds/src/potree-three-loader/geometry/PointCloudEptGeometryNode.d.ts +63 -63
  167. package/packages/pointclouds/src/potree-three-loader/geometry/translationUtils.d.ts +7 -7
  168. package/packages/pointclouds/src/potree-three-loader/index.d.ts +10 -10
  169. package/packages/pointclouds/src/potree-three-loader/loading/EptBinaryLoader.d.ts +12 -12
  170. package/packages/pointclouds/src/potree-three-loader/loading/EptLoader.d.ts +5 -5
  171. package/packages/pointclouds/src/potree-three-loader/loading/ILoader.d.ts +4 -4
  172. package/packages/pointclouds/src/potree-three-loader/loading/globalLoadingCounter.d.ts +5 -5
  173. package/packages/pointclouds/src/potree-three-loader/rendering/PointCloudMaterial.d.ts +204 -203
  174. package/packages/pointclouds/src/potree-three-loader/rendering/classification.d.ts +2 -2
  175. package/packages/pointclouds/src/potree-three-loader/rendering/clipping.d.ts +12 -12
  176. package/packages/pointclouds/src/potree-three-loader/rendering/constants.d.ts +15 -14
  177. package/packages/pointclouds/src/potree-three-loader/rendering/enums.d.ts +46 -46
  178. package/packages/pointclouds/src/potree-three-loader/rendering/features.d.ts +6 -6
  179. package/packages/pointclouds/src/potree-three-loader/rendering/gradients/SpectralGradient.d.ts +2 -2
  180. package/packages/pointclouds/src/potree-three-loader/rendering/index.d.ts +5 -5
  181. package/packages/pointclouds/src/potree-three-loader/rendering/texture-generation.d.ts +5 -5
  182. package/packages/pointclouds/src/potree-three-loader/rendering/types.d.ts +10 -10
  183. package/packages/pointclouds/src/potree-three-loader/tree/IPointCloudTreeNode.d.ts +7 -7
  184. package/packages/pointclouds/src/potree-three-loader/tree/IPointCloudTreeNodeBase.d.ts +18 -18
  185. package/packages/pointclouds/src/potree-three-loader/tree/PointAttributes.d.ts +52 -52
  186. package/packages/pointclouds/src/potree-three-loader/tree/PointCloudOctree.d.ts +48 -48
  187. package/packages/pointclouds/src/potree-three-loader/tree/PointCloudOctreeNode.d.ts +27 -27
  188. package/packages/pointclouds/src/potree-three-loader/tree/PointCloudOctreePicker.d.ts +14 -11
  189. package/packages/pointclouds/src/potree-three-loader/tree/PointCloudOctreePickerHelper.d.ts +57 -57
  190. package/packages/pointclouds/src/potree-three-loader/tree/PointCloudTree.d.ts +6 -6
  191. package/packages/pointclouds/src/potree-three-loader/types/IPotree.d.ts +10 -11
  192. package/packages/pointclouds/src/potree-three-loader/types/IVisibilityUpdateResult.d.ts +18 -18
  193. package/packages/pointclouds/src/potree-three-loader/types/type-predicates.d.ts +6 -6
  194. package/packages/pointclouds/src/potree-three-loader/types/types.d.ts +14 -14
  195. package/packages/pointclouds/src/potree-three-loader/utils/BinaryHeap.d.ts +11 -11
  196. package/packages/pointclouds/src/potree-three-loader/utils/WorkerPool.d.ts +31 -31
  197. package/packages/pointclouds/src/potree-three-loader/utils/async-blocking-queue.d.ts +8 -8
  198. package/packages/pointclouds/src/potree-three-loader/utils/bounds.d.ts +6 -6
  199. package/packages/pointclouds/src/potree-three-loader/utils/box3-helper.d.ts +13 -13
  200. package/packages/pointclouds/src/potree-three-loader/utils/lru.d.ts +32 -32
  201. package/packages/pointclouds/src/potree-three-loader/utils/math.d.ts +1 -1
  202. package/packages/pointclouds/src/potree-three-loader/utils/utils.d.ts +8 -8
  203. package/packages/pointclouds/src/potree-three-loader/version.d.ts +9 -9
  204. package/packages/pointclouds/src/potree-three-loader/workers/eptBinaryDecoder.worker.d.ts +18 -18
  205. package/packages/pointclouds/src/types.d.ts +84 -84
  206. package/packages/rendering/index.d.ts +18 -17
  207. package/packages/rendering/src/CadMaterialManager.d.ts +39 -39
  208. package/packages/rendering/src/RenderPass.d.ts +15 -15
  209. package/packages/rendering/src/RenderPipelineExecutor.d.ts +13 -12
  210. package/packages/rendering/src/RenderPipelineProvider.d.ts +15 -15
  211. package/packages/rendering/src/pipeline-executors/BasicPipelineExecutor.d.ts +22 -11
  212. package/packages/rendering/src/render-passes/GeometryPass.d.ts +16 -16
  213. package/packages/rendering/src/render-passes/PointCloudEffectsPass.d.ts +16 -0
  214. package/packages/rendering/src/render-passes/PostProcessingPass.d.ts +22 -24
  215. package/packages/rendering/src/render-passes/SSAOPass.d.ts +14 -14
  216. package/packages/rendering/src/render-passes/types.d.ts +67 -31
  217. package/packages/rendering/src/render-pipeline-providers/CadGeometryRenderModePipelineProvider.d.ts +23 -23
  218. package/packages/rendering/src/render-pipeline-providers/CadGeometryRenderPipelineProvider.d.ts +25 -25
  219. package/packages/rendering/src/render-pipeline-providers/DefaultRenderPipelineProvider.d.ts +37 -34
  220. package/packages/rendering/src/render-pipeline-providers/PointCloudRenderPipelineProvider.d.ts +24 -0
  221. package/packages/rendering/src/render-pipeline-providers/types.d.ts +23 -19
  222. package/packages/rendering/src/rendering/NodeAppearanceTextureBuilder.d.ts +51 -51
  223. package/packages/rendering/src/rendering/RenderMode.d.ts +15 -15
  224. package/packages/rendering/src/rendering/createSimpleGeometryMesh.d.ts +6 -6
  225. package/packages/rendering/src/rendering/matCapTextureData.d.ts +5 -5
  226. package/packages/rendering/src/rendering/materials.d.ts +23 -23
  227. package/packages/rendering/src/rendering/primitives.d.ts +12 -12
  228. package/packages/rendering/src/rendering/shaders.d.ts +100 -87
  229. package/packages/rendering/src/rendering/types.d.ts +89 -76
  230. package/packages/rendering/src/transform/NodeTransformProvider.d.ts +13 -13
  231. package/packages/rendering/src/transform/NodeTransformTextureBuilder.d.ts +24 -23
  232. package/packages/rendering/src/transform/TransformOverrideBuffer.d.ts +21 -21
  233. package/packages/rendering/src/utilities/renderUtilities.d.ts +29 -26
  234. package/packages/rendering/src/utilities/types.d.ts +26 -26
  235. package/packages/sector-loader/index.d.ts +6 -6
  236. package/packages/sector-loader/src/GltfSectorLoader.d.ts +12 -12
  237. package/packages/sector-loader/src/GltfSectorRepository.d.ts +19 -19
  238. package/packages/sector-loader/src/SectorRepository.d.ts +10 -10
  239. package/packages/sector-loader/src/V8SectorRepository.d.ts +26 -26
  240. package/packages/sector-loader/src/v8/SimpleAndDetailedToSector3D.d.ts +20 -20
  241. package/packages/sector-loader/src/v8/arrays.d.ts +5 -5
  242. package/packages/sector-loader/src/v8/groupMeshesByNumber.d.ts +8 -8
  243. package/packages/sector-loader/src/v8/sectorUtilities.d.ts +16 -16
  244. package/packages/sector-parser/index.d.ts +5 -5
  245. package/packages/sector-parser/src/DracoDecoderHelper.d.ts +32 -32
  246. package/packages/sector-parser/src/GltfSectorParser.d.ts +19 -19
  247. package/packages/sector-parser/src/constants.d.ts +6 -6
  248. package/packages/sector-parser/src/lib/draco_decoder_gltf.d.ts +5 -0
  249. package/packages/sector-parser/src/reveal-glb-parser/GlbMetadataParser.d.ts +14 -14
  250. package/packages/sector-parser/src/reveal-glb-parser/primitiveGeometries.d.ts +12 -12
  251. package/packages/sector-parser/src/types.d.ts +106 -106
  252. package/packages/tools/index.d.ts +18 -15
  253. package/packages/tools/src/AxisView/AxisViewTool.d.ts +31 -31
  254. package/packages/tools/src/AxisView/types.d.ts +98 -98
  255. package/packages/tools/src/Cognite3DViewerToolBase.d.ts +25 -25
  256. package/packages/tools/src/DebugCameraTool.d.ts +20 -20
  257. package/packages/tools/src/DebugLoadedSectorsTool.d.ts +23 -23
  258. package/packages/tools/src/ExplodedViewTool.d.ts +12 -12
  259. package/packages/tools/src/Geomap/Geomap.d.ts +17 -17
  260. package/packages/tools/src/Geomap/GeomapTool.d.ts +23 -23
  261. package/packages/tools/src/Geomap/MapConfig.d.ts +195 -195
  262. package/packages/tools/src/HtmlOverlay/BucketGrid2D.d.ts +28 -28
  263. package/packages/tools/src/HtmlOverlay/HtmlOverlayTool.d.ts +166 -160
  264. package/packages/tools/src/Measurement/MeasurementLabels.d.ts +18 -0
  265. package/packages/tools/src/Measurement/MeasurementLine.d.ts +44 -0
  266. package/packages/tools/src/Measurement/MeasurementManager.d.ts +66 -0
  267. package/packages/tools/src/Measurement/MeasurementTool.d.ts +183 -0
  268. package/packages/tools/src/Measurement/types.d.ts +38 -0
  269. package/packages/tools/src/Timeline/Keyframe.d.ts +39 -39
  270. package/packages/tools/src/Timeline/TimelineTool.d.ts +79 -79
  271. package/packages/tools/src/Timeline/types.d.ts +13 -13
  272. package/packages/tools/src/types.d.ts +4 -4
  273. package/packages/utilities/index.d.ts +36 -36
  274. package/packages/utilities/src/CameraConfiguration.d.ts +10 -10
  275. package/packages/utilities/src/DeferredPromise.d.ts +17 -17
  276. package/packages/utilities/src/IndexSet.d.ts +1 -1
  277. package/packages/utilities/src/NumericRange.d.ts +22 -22
  278. package/packages/utilities/src/RandomColors.d.ts +34 -34
  279. package/packages/utilities/src/SceneHandler.d.ts +28 -21
  280. package/packages/utilities/src/WebGLRendererStateHelper.d.ts +29 -27
  281. package/packages/utilities/src/assertNever.d.ts +7 -7
  282. package/packages/utilities/src/cache/MemoryRequestCache.d.ts +24 -24
  283. package/packages/utilities/src/cache/MostFrequentlyUsedCache.d.ts +19 -19
  284. package/packages/utilities/src/cache/RequestCache.d.ts +13 -13
  285. package/packages/utilities/src/calculateVolumeOfMesh.d.ts +4 -4
  286. package/packages/utilities/src/counterMap.d.ts +5 -5
  287. package/packages/utilities/src/datastructures/DynamicDefragmentedBuffer.d.ts +33 -33
  288. package/packages/utilities/src/determinePowerOfTwoDimensions.d.ts +11 -11
  289. package/packages/utilities/src/device.d.ts +10 -10
  290. package/packages/utilities/src/disposeAttributeArrayOnUpload.d.ts +17 -17
  291. package/packages/utilities/src/events/EventTrigger.d.ts +13 -13
  292. package/packages/utilities/src/events/InputHandler.d.ts +30 -30
  293. package/packages/utilities/src/events/clickOrTouchEventOffset.d.ts +13 -13
  294. package/packages/utilities/src/events/index.d.ts +7 -7
  295. package/packages/utilities/src/events/types.d.ts +32 -27
  296. package/packages/utilities/src/indexset/IndexSet.d.ts +26 -26
  297. package/packages/utilities/src/indexset/IntermediateIndexNode.d.ts +26 -26
  298. package/packages/utilities/src/indexset/LeafIndexNode.d.ts +16 -16
  299. package/packages/utilities/src/isMobileOrTablet.d.ts +5 -5
  300. package/packages/utilities/src/networking/isTheSameDomain.d.ts +11 -11
  301. package/packages/utilities/src/objectTraversal.d.ts +8 -8
  302. package/packages/utilities/src/revealEnv.d.ts +10 -10
  303. package/packages/utilities/src/three/AutoDisposeGroup.d.ts +17 -17
  304. package/packages/utilities/src/three/BoundingBoxLOD.d.ts +27 -27
  305. package/packages/utilities/src/three/createFullScreenTriangleGeometry.d.ts +5 -5
  306. package/packages/utilities/src/three/fitCameraToBoundingBox.d.ts +15 -0
  307. package/packages/utilities/src/three/isBox3OnPositiveSideOfPlane.d.ts +10 -10
  308. package/packages/utilities/src/three/toThreeBox3.d.ts +6 -6
  309. package/packages/utilities/src/three/unionBoxes.d.ts +5 -5
  310. package/packages/utilities/src/three/visitBox3CornerPoints.d.ts +12 -12
  311. package/packages/utilities/src/transformCameraConfiguration.d.ts +6 -6
  312. package/packages/utilities/src/types.d.ts +11 -11
  313. package/packages/utilities/src/workers/WorkerPool.d.ts +14 -14
  314. package/packages/utilities/src/worldToViewport.d.ts +30 -30
  315. package/tools.d.ts +7 -7
  316. package/tools.js +2 -280
  317. package/tools.js.LICENSE.txt +7 -0
  318. package/tools.map +1 -1
  319. package/core/cad.d.ts +0 -4
  320. package/core/index.d.ts +0 -6
  321. package/core/src/index.d.ts +0 -13
  322. package/core/src/internals.d.ts +0 -10
  323. package/core/src/public/migration/NotSupportedInMigrationWrapperError.d.ts +0 -11
  324. package/core/src/utilities/index.d.ts +0 -6
  325. package/core/utilities.d.ts +0 -4
  326. package/packages/cad-geometry-loaders/src/utilities/rxOperations.d.ts +0 -6
  327. package/packages/utilities/src/packFloat.d.ts +0 -6
@@ -1,498 +1,509 @@
1
- /*!
2
- * Copyright 2021 Cognite AS
3
- */
4
- import * as THREE from 'three';
5
- import { PointerEventDelegate, SceneRenderedDelegate, DisposedDelegate } from '../../../../packages/utilities';
6
- import { Cognite3DModel } from '../../../../packages/cad-model';
7
- import { PointCloudBudget, CognitePointCloudModel } from '../../../../packages/pointclouds';
8
- import { AddModelOptions, Cognite3DViewerOptions, Intersection, CadModelBudget } from './types';
9
- import { IntersectionFromPixelOptions } from '../..';
10
- import { ViewerState } from '../../utilities/ViewStateHelper';
11
- import { CameraManager, CameraChangeDelegate } from '../../../../packages/camera-manager';
12
- import { SupportedModelTypes, CogniteModelBase } from '../../../../packages/model-base';
13
- /**
14
- * @example
15
- * ```js
16
- * const viewer = new Cognite3DViewer({
17
- * noBackground: true,
18
- * sdk: CogniteClient({...})
19
- * });
20
- * ```
21
- * @module @cognite/reveal
22
- */
23
- export declare class Cognite3DViewer {
24
- private get canvas();
25
- /**
26
- * For now it just always returns true.
27
- * @see Https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/getContext#Browser_compatibility.
28
- */
29
- static isBrowserSupported(): true;
30
- /**
31
- * The DOM element the viewer will insert its rendering canvas into.
32
- * The DOM element can be specified in the options when the viewer is created.
33
- * If not specified, the DOM element will be created automatically.
34
- * The DOM element cannot be changed after the viewer has been created.
35
- */
36
- get domElement(): HTMLElement;
37
- /**
38
- * Returns the renderer used to produce images from 3D geometry.
39
- */
40
- get renderer(): THREE.WebGLRenderer;
41
- private readonly _cdfSdkClient;
42
- private readonly _dataSource;
43
- private readonly camera;
44
- private readonly _sceneHandler;
45
- private readonly _cameraManager;
46
- private readonly _subscription;
47
- private readonly _revealManagerHelper;
48
- private readonly _domElement;
49
- private readonly _renderer;
50
- private readonly _pickingHandler;
51
- private readonly _boundAnimate;
52
- private readonly _events;
53
- private readonly _mouseHandler;
54
- private readonly _models;
55
- private readonly _extraObjects;
56
- private isDisposed;
57
- private readonly renderController;
58
- private latestRequestId;
59
- private readonly clock;
60
- private _clippingNeedsUpdate;
61
- private readonly spinner;
62
- private get revealManager();
63
- /**
64
- * Reusable buffers used by functions in Cognite3dViewer to avoid allocations.
65
- */
66
- private readonly _updateNearAndFarPlaneBuffers;
67
- /**
68
- * Gets the current budget for downloading geometry for CAD models. Note that this
69
- * budget is shared between all added CAD models and not a per-model budget.
70
- */
71
- get cadBudget(): CadModelBudget;
72
- /**
73
- * Sets the current budget for downloading geometry for CAD models. Note that this
74
- * budget is shared between all added CAD models and not a per-model budget.
75
- */
76
- set cadBudget(budget: CadModelBudget);
77
- /**
78
- * Returns the point cloud budget. The budget is shared between all loaded
79
- * point cloud models.
80
- */
81
- get pointCloudBudget(): PointCloudBudget;
82
- /**
83
- * Sets the point cloud budget. The budget is shared between all loaded
84
- * point cloud models.
85
- */
86
- set pointCloudBudget(budget: PointCloudBudget);
87
- /**
88
- * Gets a list of models currently added to the viewer.
89
- */
90
- get models(): CogniteModelBase[];
91
- constructor(options: Cognite3DViewerOptions);
92
- /**
93
- * Returns reveal version installed.
94
- */
95
- getVersion(): string;
96
- /**
97
- * Sets the log level. Used for debugging.
98
- * Defaults to 'none' (which is identical to 'silent').
99
- * @param level
100
- */
101
- setLogLevel(level: 'trace' | 'debug' | 'info' | 'warn' | 'error' | 'silent' | 'none'): void;
102
- /**
103
- * Dispose of WebGL resources. Can be used to free up memory when the viewer is no longer in use.
104
- * @see {@link https://threejs.org/docs/#manual/en/introduction/How-to-dispose-of-objects}
105
- * ```ts
106
- * // Viewer is no longer in use, free up memory
107
- * viewer.dispose();
108
- * ```.
109
- */
110
- dispose(): void;
111
- /**
112
- * Triggered when the viewer is disposed. Listeners should clean up any
113
- * resources held and remove the reference to the viewer.
114
- */
115
- on(event: 'disposed', callback: DisposedDelegate): void;
116
- /**
117
- * @example
118
- * ```js
119
- * const onClick = (event) => { console.log(event.offsetX, event.offsetY) };
120
- * viewer.on('click', onClick);
121
- * ```
122
- */
123
- on(event: 'click' | 'hover', callback: PointerEventDelegate): void;
124
- /**
125
- * @example
126
- * ```js
127
- * viewer.on('cameraChange', (position, target) => {
128
- * console.log('Camera changed: ', position, target);
129
- * });
130
- * ```
131
- */
132
- on(event: 'cameraChange', callback: CameraChangeDelegate): void;
133
- /**
134
- * Event that is triggered immediatly after the scene has been rendered.
135
- * @param event Metadata about the rendering frame.
136
- * @param callback Callback to trigger when the event occurs.
137
- */
138
- on(event: 'sceneRendered', callback: SceneRenderedDelegate): void;
139
- /**
140
- * @example
141
- * ```js
142
- * viewer.off('click', onClick);
143
- * ```
144
- */
145
- off(event: 'click' | 'hover', callback: PointerEventDelegate): void;
146
- /**
147
- * @example
148
- * ```js
149
- * viewer.off('cameraChange', onCameraChange);
150
- * ```
151
- */
152
- off(event: 'cameraChange', callback: CameraChangeDelegate): void;
153
- /**
154
- * @example
155
- * ```js
156
- * viewer.off('sceneRendered', updateStats);
157
- * ```
158
- */
159
- off(event: 'sceneRendered', callback: SceneRenderedDelegate): void;
160
- /**
161
- * @example
162
- * ```js
163
- * viewer.off('disposed', clearAll);
164
- * ```
165
- */
166
- off(event: 'disposed', callback: DisposedDelegate): void;
167
- get cameraManager(): CameraManager;
168
- /**
169
- * Gets the current viewer state which includes the camera pose as well as applied styling.
170
- * @returns JSON object containing viewer state.
171
- */
172
- getViewState(): ViewerState;
173
- /**
174
- * Restores camera settings from the state provided, and clears all current styled
175
- * node collections and applies the `state` object.
176
- * @param state Viewer state retrieved from {@link Cognite3DViewer.getViewState}.
177
- */
178
- setViewState(state: ViewerState): Promise<void>;
179
- /**
180
- * Add a new model to the viewer.
181
- * Call {@link Cognite3DViewer.fitCameraToModel} to see the model after the model has loaded.
182
- * @param options
183
- * @example
184
- * ```js
185
- * const options = {
186
- * modelId: 'COGNITE_3D_MODEL_ID',
187
- * revisionId: 'COGNITE_3D_REVISION_ID',
188
- * };
189
- * viewer.addModel(options).then(model => {
190
- * viewer.fitCameraToModel(model, 0);
191
- * });
192
- * ```
193
- */
194
- addModel(options: AddModelOptions): Promise<Cognite3DModel | CognitePointCloudModel>;
195
- /**
196
- * Add a new CAD 3D model to the viewer.
197
- * Call {@link Cognite3DViewer.fitCameraToModel} to see the model after the model has loaded.
198
- * @param options
199
- * @example
200
- * ```js
201
- * const options = {
202
- * modelId: 'COGNITE_3D_MODEL_ID',
203
- * revisionId: 'COGNITE_3D_REVISION_ID',
204
- * };
205
- * viewer.addCadModel(options).then(model => {
206
- * viewer.fitCameraToModel(model, 0);
207
- * });
208
- * ```
209
- */
210
- addCadModel(options: AddModelOptions): Promise<Cognite3DModel>;
211
- /**
212
- * Add a new pointcloud 3D model to the viewer.
213
- * Call {@link Cognite3DViewer.fitCameraToModel} to see the model after the model has loaded.
214
- * @param options
215
- * @example
216
- * ```js
217
- * const options = {
218
- * modelId: 'COGNITE_3D_MODEL_ID',
219
- * revisionId: 'COGNITE_3D_REVISION_ID',
220
- * };
221
- * viewer.addPointCloudModel(options).then(model => {
222
- * viewer.fitCameraToModel(model, 0);
223
- * });
224
- * ```
225
- */
226
- addPointCloudModel(options: AddModelOptions): Promise<CognitePointCloudModel>;
227
- /**
228
- * Removes a model that was previously added using {@link Cognite3DViewer.addModel},
229
- * {@link Cognite3DViewer.addCadModel} or {@link Cognite3DViewer.addPointCloudModel}
230
- * .
231
- * @param model
232
- */
233
- removeModel(model: CogniteModelBase): void;
234
- /**
235
- * Use to determine of which type the model is.
236
- *
237
- * @param modelId The model's id.
238
- * @param revisionId The model's revision id.
239
- *
240
- * @returns Empty string if type is not supported.
241
- * @example
242
- * ```typescript
243
- * const viewer = new Cognite3DViewer(...);
244
- * const type = await viewer.determineModelType(options.modelId, options.revisionId)
245
- * let model: Cognite3DModel | CognitePointCloudModel
246
- * switch (type) {
247
- * case 'cad':
248
- * model = await viewer.addCadModel(options);
249
- * break;
250
- * case 'pointcloud':
251
- * model = await viewer.addPointCloudModel(options);
252
- * break;
253
- * default:
254
- * throw new Error('Model is not supported');
255
- * }
256
- * viewer.fitCameraToModel(model);
257
- * ```
258
- */
259
- determineModelType(modelId: number, revisionId: number): Promise<SupportedModelTypes | ''>;
260
- /**
261
- * Add a THREE.Object3D to the viewer.
262
- * @param object
263
- * @example
264
- * ```js
265
- * const sphere = new THREE.Mesh(
266
- * new THREE.SphereBufferGeometry(),
267
- * new THREE.MeshBasicMaterial()
268
- * );
269
- * viewer.addObject3D(sphere);
270
- * ```
271
- */
272
- addObject3D(object: THREE.Object3D): void;
273
- /**
274
- * Remove a THREE.Object3D from the viewer.
275
- * @param object
276
- * @example
277
- * ```js
278
- * const sphere = new THREE.Mesh(new THREE.SphereBufferGeometry(), new THREE.MeshBasicMaterial());
279
- * viewer.addObject3D(sphere);
280
- * viewer.removeObject3D(sphere);
281
- * ```
282
- */
283
- removeObject3D(object: THREE.Object3D): void;
284
- /**
285
- * Sets the color used as the clear color of the renderer.
286
- * @param color
287
- */
288
- setBackgroundColor(color: THREE.Color): void;
289
- /**
290
- * Sets per-pixel clipping planes. Pixels behind any of the planes will be sliced away.
291
- * @param clippingPlanes The planes to use for clipping.
292
- * @example
293
- * ```js
294
- * // Hide pixels with values less than 0 in the x direction
295
- * const plane = new THREE.Plane(new THREE.Vector3(1, 0, 0), 0);
296
- * viewer.setClippingPlanes([plane]);
297
- * ```
298
- * ```js
299
- * // Hide pixels with values greater than 20 in the x direction
300
- * const plane = new THREE.Plane(new THREE.Vector3(-1, 0, 0), 20);
301
- * viewer.setClippingPlanes([plane]);
302
- * ```
303
- * ```js
304
- * // Hide pixels with values less than 0 in the x direction or greater than 0 in the y direction
305
- * const xPlane = new THREE.Plane(new THREE.Vector3(1, 0, 0), 0);
306
- * const yPlane = new THREE.Plane(new THREE.Vector3(0, -1, 0), 0);
307
- * viewer.setClippingPlanes([xPlane, yPlane]);
308
- * ```
309
- * ```js
310
- * // Hide pixels behind an arbitrary, non axis-aligned plane
311
- * const plane = new THREE.Plane(new THREE.Vector3(1.5, 20, -19), 20);
312
- * viewer.setClippingPlanes([plane]);
313
- * ```
314
- * ```js
315
- * // Disable clipping planes
316
- * viewer.setClippingPlanes([]);
317
- * ```
318
- */
319
- setClippingPlanes(clippingPlanes: THREE.Plane[]): void;
320
- /**
321
- * Returns the current active clipping planes.
322
- */
323
- getClippingPlanes(): THREE.Plane[];
324
- /**
325
- * @obvious
326
- * @returns The THREE.Camera used for rendering.
327
- */
328
- getCamera(): THREE.PerspectiveCamera;
329
- /**
330
- * @obvious
331
- * @returns The THREE.Scene used for rendering.
332
- */
333
- getScene(): THREE.Scene;
334
- /**
335
- * Attempts to load the camera settings from the settings stored for the
336
- * provided model. See {@link https://docs.cognite.com/api/v1/#operation/get3DRevision}
337
- * and {@link https://docs.cognite.com/api/v1/#operation/update3DRevisions} for
338
- * information on how this setting is retrieved and stored. This setting can
339
- * also be changed through the 3D models management interface in Cognite Fusion.
340
- * If no camera configuration is stored in CDF, {@link Cognite3DViewer.fitCameraToModel}
341
- * is used as a fallback.
342
- * @param model The model to load camera settings from.
343
- */
344
- loadCameraFromModel(model: CogniteModelBase): void;
345
- /**
346
- * Move camera to a place where the 3D model is visible.
347
- * It uses the bounding box of the 3D model and calls {@link Cognite3DViewer.fitCameraToBoundingBox}.
348
- * @param model The 3D model.
349
- * @param duration The duration of the animation moving the camera. Set this to 0 (zero) to disable animation.
350
- * @example
351
- * ```js
352
- * // Fit camera to model
353
- * viewer.fitCameraToModel(model);
354
- * ```
355
- * ```js
356
- * // Fit camera to model over 500 milliseconds
357
- * viewer.fitCameraToModel(model, 500);
358
- * ```
359
- * ```js
360
- * // Fit camera to model instantly
361
- * viewer.fitCameraToModel(model, 0);
362
- * ```
363
- */
364
- fitCameraToModel(model: CogniteModelBase, duration?: number): void;
365
- /**
366
- * Move camera to a place where the content of a bounding box is visible to the camera.
367
- * @param box The bounding box in world space.
368
- * @param duration The duration of the animation moving the camera. Set this to 0 (zero) to disable animation.
369
- * @param radiusFactor The ratio of the distance from camera to center of box and radius of the box.
370
- * @example
371
- * ```js
372
- * // Fit camera to bounding box over 500 milliseconds
373
- * viewer.fitCameraToBoundingBox(boundingBox, 500);
374
- * ```
375
- * ```js
376
- * // Fit camera to bounding box instantaneously
377
- * viewer.fitCameraToBoundingBox(boundingBox, 0);
378
- * ```
379
- * ```js
380
- * // Place the camera closer to the bounding box
381
- * viewer.fitCameraToBoundingBox(boundingBox, 500, 2);
382
- * ```
383
- */
384
- fitCameraToBoundingBox(box: THREE.Box3, duration?: number, radiusFactor?: number): void;
385
- /**
386
- * Typically used when you perform some changes and can't see them unless you move camera.
387
- */
388
- requestRedraw(): void;
389
- /**
390
- * Convert a point in world space to its coordinates in the canvas. This can be used to place HTML objects near 3D objects on top of the 3D viewer.
391
- * @see {@link https://www.w3schools.com/graphics/canvas_coordinates.asp https://www.w3schools.com/graphics/canvas_coordinates.asp}.
392
- * @param point World space coordinate.
393
- * @param normalize Optional. If true, coordinates are normalized into [0,1]. If false, the values are in the range [0, <canvas_size>).
394
- * @returns Returns 2D coordinates if the point is visible on screen, or `null` if object is outside screen.
395
- * @example
396
- * ```js
397
- * const boundingBoxCenter = new THREE.Vector3();
398
- * // Find center of bounding box in world space
399
- * model.getBoundingBox(nodeId).getCenter(boundingBoxCenter);
400
- * // Screen coordinates of that point
401
- * const screenCoordinates = viewer.worldToScreen(boundingBoxCenter);
402
- * ```
403
- * ```js
404
- * const boundingBoxCenter = new THREE.Vector3();
405
- * // Find center of bounding box in world space
406
- * model.getBoundingBox(nodeId).getCenter(boundingBoxCenter);
407
- * // Screen coordinates of that point normalized in the range [0,1]
408
- * const screenCoordinates = viewer.worldToScreen(boundingBoxCenter, true);
409
- * ```
410
- * ```js
411
- * const boundingBoxCenter = new THREE.Vector3();
412
- * // Find center of bounding box in world space
413
- * model.getBoundingBox(nodeId).getCenter(boundingBoxCenter);
414
- * // Screen coordinates of that point
415
- * const screenCoordinates = viewer.worldToScreen(boundingBoxCenter);
416
- * if (screenCoordinates == null) {
417
- * // Object not visible on screen
418
- * } else {
419
- * // Object is visible on screen
420
- * }
421
- * ```
422
- */
423
- worldToScreen(point: THREE.Vector3, normalize?: boolean): THREE.Vector2 | null;
424
- /**
425
- * Take screenshot from the current camera position.
426
- * @param width Width of the final image. Default is current canvas size.
427
- * @param height Height of the final image. Default is current canvas size.
428
- * @returns A {@link https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs Data URL} of the image ('image/png').
429
- * @example
430
- * ```js
431
- * // Take a screenshot with custom resolution
432
- * const url = await viewer.getScreenshot(1920, 1080);
433
- * ```
434
- * ```js
435
- * // Add a screenshot with resolution of the canvas to the page
436
- * const url = await viewer.getScreenshot();
437
- * const image = document.createElement('img');
438
- * image.src = url;
439
- * document.body.appendChild(url);
440
- * ```
441
- */
442
- getScreenshot(width?: number, height?: number): Promise<string>;
443
- /**
444
- * Raycasting model(s) for finding where the ray intersects with the model.
445
- * @param offsetX X coordinate in pixels (relative to the domElement).
446
- * @param offsetY Y coordinate in pixels (relative to the domElement).
447
- * @param options Options to control the behavior of the intersection operation. Optional (new in 1.3.0).
448
- * @returns A promise that if there was an intersection then return the intersection object - otherwise it
449
- * returns `null` if there were no intersections.
450
- * @see {@link https://en.wikipedia.org/wiki/Ray_casting}.
451
- *
452
- * @example For CAD model
453
- * ```js
454
- * const offsetX = 50 // pixels from the left
455
- * const offsetY = 100 // pixels from the top
456
- * const intersection = await viewer.getIntersectionFromPixel(offsetX, offsetY);
457
- * if (intersection) // it was a hit
458
- * console.log(
459
- * 'You hit model ', intersection.model,
460
- * ' at the node with tree index ', intersection.treeIndex,
461
- * ' at this exact point ', intersection.point
462
- * );
463
- * ```
464
- *
465
- * @example For point cloud
466
- * ```js
467
- * const offsetX = 50 // pixels from the left
468
- * const offsetY = 100 // pixels from the top
469
- * const intersection = await viewer.getIntersectionFromPixel(offsetX, offsetY);
470
- * if (intersection) // it was a hit
471
- * console.log(
472
- * 'You hit model ', intersection.model,
473
- * ' at the point index ', intersection.pointIndex,
474
- * ' at this exact point ', intersection.point
475
- * );
476
- * ```
477
- */
478
- getIntersectionFromPixel(offsetX: number, offsetY: number): Promise<null | Intersection>;
479
- /**
480
- * @deprecated Since 3.1 options argument have no effect.
481
- * */
482
- getIntersectionFromPixel(offsetX: number, offsetY: number, options: IntersectionFromPixelOptions): Promise<null | Intersection>;
483
- /** @private */
484
- private getModels;
485
- /**
486
- * Creates a helper for managing viewer state.
487
- */
488
- private createViewStateHelper;
489
- /** @private */
490
- private animate;
491
- /** @private */
492
- private modelIntersectionCallback;
493
- /** @private */
494
- private recalculateBoundingBox;
495
- /** @private */
496
- private resizeIfNecessary;
497
- private readonly startPointerEventListeners;
498
- }
1
+ /*!
2
+ * Copyright 2021 Cognite AS
3
+ */
4
+ import * as THREE from 'three';
5
+ import { PointerEventDelegate, SceneRenderedDelegate, DisposedDelegate } from '../../../../utilities';
6
+ import { Cognite3DModel } from '../../../../cad-model';
7
+ import { PointCloudBudget, CognitePointCloudModel } from '../../../../pointclouds';
8
+ import { AddModelOptions, Cognite3DViewerOptions, Intersection, CadModelBudget, IntersectionFromPixelOptions } from './types';
9
+ import { ViewerState } from '../../utilities/ViewStateHelper';
10
+ import { CameraManager, CameraChangeDelegate } from '../../../../camera-manager';
11
+ import { SupportedModelTypes, CogniteModelBase } from '../../../../model-base';
12
+ /**
13
+ * @example
14
+ * ```js
15
+ * const viewer = new Cognite3DViewer({
16
+ * noBackground: true,
17
+ * sdk: CogniteClient({...})
18
+ * });
19
+ * ```
20
+ * @module @cognite/reveal
21
+ */
22
+ export declare class Cognite3DViewer {
23
+ private readonly _domElementResizeObserver;
24
+ private get canvas();
25
+ /**
26
+ * For now it just always returns true.
27
+ * @see Https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/getContext#Browser_compatibility.
28
+ */
29
+ static isBrowserSupported(): true;
30
+ /**
31
+ * The DOM element the viewer will insert its rendering canvas into.
32
+ * The DOM element can be specified in the options when the viewer is created.
33
+ * If not specified, the DOM element will be created automatically.
34
+ * The DOM element cannot be changed after the viewer has been created.
35
+ */
36
+ get domElement(): HTMLElement;
37
+ /**
38
+ * Returns the renderer used to produce images from 3D geometry.
39
+ */
40
+ get renderer(): THREE.WebGLRenderer;
41
+ private readonly _cdfSdkClient;
42
+ private readonly _dataSource;
43
+ private readonly _sceneHandler;
44
+ private _cameraManager;
45
+ private readonly _subscription;
46
+ private readonly _revealManagerHelper;
47
+ private readonly _domElement;
48
+ private readonly _renderer;
49
+ private readonly _pickingHandler;
50
+ private readonly _pointCloudPickingHandler;
51
+ private readonly _boundAnimate;
52
+ private readonly _events;
53
+ private readonly _mouseHandler;
54
+ private readonly _models;
55
+ private readonly _extraObjects;
56
+ private isDisposed;
57
+ private latestRequestId;
58
+ private readonly clock;
59
+ private _clippingNeedsUpdate;
60
+ private readonly spinner;
61
+ private get revealManager();
62
+ /**
63
+ * Reusable buffers used by functions in Cognite3dViewer to avoid allocations.
64
+ */
65
+ private readonly _updateNearAndFarPlaneBuffers;
66
+ /**
67
+ * Gets the current budget for downloading geometry for CAD models. Note that this
68
+ * budget is shared between all added CAD models and not a per-model budget.
69
+ */
70
+ get cadBudget(): CadModelBudget;
71
+ /**
72
+ * Sets the current budget for downloading geometry for CAD models. Note that this
73
+ * budget is shared between all added CAD models and not a per-model budget.
74
+ */
75
+ set cadBudget(budget: CadModelBudget);
76
+ /**
77
+ * Returns the point cloud budget. The budget is shared between all loaded
78
+ * point cloud models.
79
+ */
80
+ get pointCloudBudget(): PointCloudBudget;
81
+ /**
82
+ * Sets the point cloud budget. The budget is shared between all loaded
83
+ * point cloud models.
84
+ */
85
+ set pointCloudBudget(budget: PointCloudBudget);
86
+ /**
87
+ * Gets a list of models currently added to the viewer.
88
+ */
89
+ get models(): CogniteModelBase[];
90
+ constructor(options: Cognite3DViewerOptions);
91
+ /**
92
+ * Returns reveal version installed.
93
+ */
94
+ getVersion(): string;
95
+ /**
96
+ * Sets the log level. Used for debugging.
97
+ * Defaults to 'none' (which is identical to 'silent').
98
+ * @param level
99
+ */
100
+ setLogLevel(level: 'trace' | 'debug' | 'info' | 'warn' | 'error' | 'silent' | 'none'): void;
101
+ /**
102
+ * Dispose of WebGL resources. Can be used to free up memory when the viewer is no longer in use.
103
+ * @see {@link https://threejs.org/docs/#manual/en/introduction/How-to-dispose-of-objects}
104
+ * ```ts
105
+ * // Viewer is no longer in use, free up memory
106
+ * viewer.dispose();
107
+ * ```.
108
+ */
109
+ dispose(): void;
110
+ /**
111
+ * Triggered when the viewer is disposed. Listeners should clean up any
112
+ * resources held and remove the reference to the viewer.
113
+ */
114
+ on(event: 'disposed', callback: DisposedDelegate): void;
115
+ /**
116
+ * @example
117
+ * ```js
118
+ * const onClick = (event) => { console.log(event.offsetX, event.offsetY) };
119
+ * viewer.on('click', onClick);
120
+ * ```
121
+ */
122
+ on(event: 'click' | 'hover', callback: PointerEventDelegate): void;
123
+ /**
124
+ * @example
125
+ * ```js
126
+ * viewer.on('cameraChange', (position, target) => {
127
+ * console.log('Camera changed: ', position, target);
128
+ * });
129
+ * ```
130
+ */
131
+ on(event: 'cameraChange', callback: CameraChangeDelegate): void;
132
+ /**
133
+ * Event that is triggered immediatly after the scene has been rendered.
134
+ * @param event Metadata about the rendering frame.
135
+ * @param callback Callback to trigger when the event occurs.
136
+ */
137
+ on(event: 'sceneRendered', callback: SceneRenderedDelegate): void;
138
+ /**
139
+ * @example
140
+ * ```js
141
+ * viewer.off('click', onClick);
142
+ * ```
143
+ */
144
+ off(event: 'click' | 'hover', callback: PointerEventDelegate): void;
145
+ /**
146
+ * @example
147
+ * ```js
148
+ * viewer.off('cameraChange', onCameraChange);
149
+ * ```
150
+ */
151
+ off(event: 'cameraChange', callback: CameraChangeDelegate): void;
152
+ /**
153
+ * @example
154
+ * ```js
155
+ * viewer.off('sceneRendered', updateStats);
156
+ * ```
157
+ */
158
+ off(event: 'sceneRendered', callback: SceneRenderedDelegate): void;
159
+ /**
160
+ * @example
161
+ * ```js
162
+ * viewer.off('disposed', clearAll);
163
+ * ```
164
+ */
165
+ off(event: 'disposed', callback: DisposedDelegate): void;
166
+ get cameraManager(): CameraManager;
167
+ /**
168
+ * Sets camera manager instance for current Cognite3Dviewer.
169
+ * @param cameraManager Camera manager instance.
170
+ * @param cameraStateUpdate Whether to set current camera state to new camera manager.
171
+ */
172
+ setCameraManager(cameraManager: CameraManager, cameraStateUpdate?: boolean): void;
173
+ /**
174
+ * Gets the current viewer state which includes the camera pose as well as applied styling.
175
+ * @returns JSON object containing viewer state.
176
+ */
177
+ getViewState(): ViewerState;
178
+ /**
179
+ * Restores camera settings from the state provided, and clears all current styled
180
+ * node collections and applies the `state` object.
181
+ * @param state Viewer state retrieved from {@link Cognite3DViewer.getViewState}.
182
+ */
183
+ setViewState(state: ViewerState): Promise<void>;
184
+ /**
185
+ * Add a new model to the viewer.
186
+ * Call {@link Cognite3DViewer.fitCameraToModel} to see the model after the model has loaded.
187
+ * @param options
188
+ * @example
189
+ * ```js
190
+ * const options = {
191
+ * modelId: 'COGNITE_3D_MODEL_ID',
192
+ * revisionId: 'COGNITE_3D_REVISION_ID',
193
+ * };
194
+ * viewer.addModel(options).then(model => {
195
+ * viewer.fitCameraToModel(model, 0);
196
+ * });
197
+ * ```
198
+ */
199
+ addModel(options: AddModelOptions): Promise<Cognite3DModel | CognitePointCloudModel>;
200
+ /**
201
+ * Add a new CAD 3D model to the viewer.
202
+ * Call {@link Cognite3DViewer.fitCameraToModel} to see the model after the model has loaded.
203
+ * @param options
204
+ * @example
205
+ * ```js
206
+ * const options = {
207
+ * modelId: 'COGNITE_3D_MODEL_ID',
208
+ * revisionId: 'COGNITE_3D_REVISION_ID',
209
+ * };
210
+ * viewer.addCadModel(options).then(model => {
211
+ * viewer.fitCameraToModel(model, 0);
212
+ * });
213
+ * ```
214
+ */
215
+ addCadModel(options: AddModelOptions): Promise<Cognite3DModel>;
216
+ /**
217
+ * Add a new pointcloud 3D model to the viewer.
218
+ * Call {@link Cognite3DViewer.fitCameraToModel} to see the model after the model has loaded.
219
+ * @param options
220
+ * @example
221
+ * ```js
222
+ * const options = {
223
+ * modelId: 'COGNITE_3D_MODEL_ID',
224
+ * revisionId: 'COGNITE_3D_REVISION_ID',
225
+ * };
226
+ * viewer.addPointCloudModel(options).then(model => {
227
+ * viewer.fitCameraToModel(model, 0);
228
+ * });
229
+ * ```
230
+ */
231
+ addPointCloudModel(options: AddModelOptions): Promise<CognitePointCloudModel>;
232
+ /**
233
+ * Removes a model that was previously added using {@link Cognite3DViewer.addModel},
234
+ * {@link Cognite3DViewer.addCadModel} or {@link Cognite3DViewer.addPointCloudModel}
235
+ * .
236
+ * @param model
237
+ */
238
+ removeModel(model: CogniteModelBase): void;
239
+ /**
240
+ * Use to determine of which type the model is.
241
+ *
242
+ * @param modelId The model's id.
243
+ * @param revisionId The model's revision id.
244
+ *
245
+ * @returns Empty string if type is not supported.
246
+ * @example
247
+ * ```typescript
248
+ * const viewer = new Cognite3DViewer(...);
249
+ * const type = await viewer.determineModelType(options.modelId, options.revisionId)
250
+ * let model: Cognite3DModel | CognitePointCloudModel
251
+ * switch (type) {
252
+ * case 'cad':
253
+ * model = await viewer.addCadModel(options);
254
+ * break;
255
+ * case 'pointcloud':
256
+ * model = await viewer.addPointCloudModel(options);
257
+ * break;
258
+ * default:
259
+ * throw new Error('Model is not supported');
260
+ * }
261
+ * viewer.fitCameraToModel(model);
262
+ * ```
263
+ */
264
+ determineModelType(modelId: number, revisionId: number): Promise<SupportedModelTypes | ''>;
265
+ /**
266
+ * Add a THREE.Object3D to the viewer.
267
+ * @param object
268
+ * @example
269
+ * ```js
270
+ * const sphere = new THREE.Mesh(
271
+ * new THREE.SphereBufferGeometry(),
272
+ * new THREE.MeshBasicMaterial()
273
+ * );
274
+ * viewer.addObject3D(sphere);
275
+ * ```
276
+ */
277
+ addObject3D(object: THREE.Object3D): void;
278
+ /**
279
+ * Remove a THREE.Object3D from the viewer.
280
+ * @param object
281
+ * @example
282
+ * ```js
283
+ * const sphere = new THREE.Mesh(new THREE.SphereBufferGeometry(), new THREE.MeshBasicMaterial());
284
+ * viewer.addObject3D(sphere);
285
+ * viewer.removeObject3D(sphere);
286
+ * ```
287
+ */
288
+ removeObject3D(object: THREE.Object3D): void;
289
+ /**
290
+ * Sets the color used as the clear color of the renderer.
291
+ * @param color
292
+ */
293
+ setBackgroundColor(color: THREE.Color): void;
294
+ /**
295
+ * Sets per-pixel clipping planes. Pixels behind any of the planes will be sliced away.
296
+ * @param clippingPlanes The planes to use for clipping.
297
+ * @example
298
+ * ```js
299
+ * // Hide pixels with values less than 0 in the x direction
300
+ * const plane = new THREE.Plane(new THREE.Vector3(1, 0, 0), 0);
301
+ * viewer.setClippingPlanes([plane]);
302
+ * ```
303
+ * ```js
304
+ * // Hide pixels with values greater than 20 in the x direction
305
+ * const plane = new THREE.Plane(new THREE.Vector3(-1, 0, 0), 20);
306
+ * viewer.setClippingPlanes([plane]);
307
+ * ```
308
+ * ```js
309
+ * // Hide pixels with values less than 0 in the x direction or greater than 0 in the y direction
310
+ * const xPlane = new THREE.Plane(new THREE.Vector3(1, 0, 0), 0);
311
+ * const yPlane = new THREE.Plane(new THREE.Vector3(0, -1, 0), 0);
312
+ * viewer.setClippingPlanes([xPlane, yPlane]);
313
+ * ```
314
+ * ```js
315
+ * // Hide pixels behind an arbitrary, non axis-aligned plane
316
+ * const plane = new THREE.Plane(new THREE.Vector3(1.5, 20, -19), 20);
317
+ * viewer.setClippingPlanes([plane]);
318
+ * ```
319
+ * ```js
320
+ * // Disable clipping planes
321
+ * viewer.setClippingPlanes([]);
322
+ * ```
323
+ */
324
+ setClippingPlanes(clippingPlanes: THREE.Plane[]): void;
325
+ /**
326
+ * Returns the current active clipping planes.
327
+ */
328
+ getClippingPlanes(): THREE.Plane[];
329
+ /**
330
+ * @obvious
331
+ * @returns The THREE.Camera used for rendering.
332
+ */
333
+ getCamera(): THREE.PerspectiveCamera;
334
+ /**
335
+ * @obvious
336
+ * @returns The THREE.Scene used for rendering.
337
+ */
338
+ getScene(): THREE.Scene;
339
+ /**
340
+ * Attempts to load the camera settings from the settings stored for the
341
+ * provided model. See {@link https://docs.cognite.com/api/v1/#operation/get3DRevision}
342
+ * and {@link https://docs.cognite.com/api/v1/#operation/update3DRevisions} for
343
+ * information on how this setting is retrieved and stored. This setting can
344
+ * also be changed through the 3D models management interface in Cognite Fusion.
345
+ * If no camera configuration is stored in CDF, {@link Cognite3DViewer.fitCameraToModel}
346
+ * is used as a fallback.
347
+ * @param model The model to load camera settings from.
348
+ */
349
+ loadCameraFromModel(model: CogniteModelBase): void;
350
+ /**
351
+ * Move camera to a place where the 3D model is visible.
352
+ * It uses the bounding box of the 3D model and calls {@link Cognite3DViewer.fitCameraToBoundingBox}.
353
+ * @param model The 3D model.
354
+ * @param duration The duration of the animation moving the camera. Set this to 0 (zero) to disable animation.
355
+ * @example
356
+ * ```js
357
+ * // Fit camera to model
358
+ * viewer.fitCameraToModel(model);
359
+ * ```
360
+ * ```js
361
+ * // Fit camera to model over 500 milliseconds
362
+ * viewer.fitCameraToModel(model, 500);
363
+ * ```
364
+ * ```js
365
+ * // Fit camera to model instantly
366
+ * viewer.fitCameraToModel(model, 0);
367
+ * ```
368
+ */
369
+ fitCameraToModel(model: CogniteModelBase, duration?: number): void;
370
+ /**
371
+ * Move camera to a place where the content of a bounding box is visible to the camera.
372
+ * @param box The bounding box in world space.
373
+ * @param duration The duration of the animation moving the camera. Set this to 0 (zero) to disable animation.
374
+ * @param radiusFactor The ratio of the distance from camera to center of box and radius of the box.
375
+ * @example
376
+ * ```js
377
+ * // Fit camera to bounding box over 500 milliseconds
378
+ * viewer.fitCameraToBoundingBox(boundingBox, 500);
379
+ * ```
380
+ * ```js
381
+ * // Fit camera to bounding box instantaneously
382
+ * viewer.fitCameraToBoundingBox(boundingBox, 0);
383
+ * ```
384
+ * ```js
385
+ * // Place the camera closer to the bounding box
386
+ * viewer.fitCameraToBoundingBox(boundingBox, 500, 2);
387
+ * ```
388
+ */
389
+ fitCameraToBoundingBox(box: THREE.Box3, duration?: number, radiusFactor?: number): void;
390
+ /**
391
+ * Typically used when you perform some changes and can't see them unless you move camera.
392
+ */
393
+ requestRedraw(): void;
394
+ /**
395
+ * Convert a point in world space to its coordinates in the canvas. This can be used to place HTML objects near 3D objects on top of the 3D viewer.
396
+ * @see {@link https://www.w3schools.com/graphics/canvas_coordinates.asp https://www.w3schools.com/graphics/canvas_coordinates.asp}.
397
+ * @param point World space coordinate.
398
+ * @param normalize Optional. If true, coordinates are normalized into [0,1]. If false, the values are in the range [0, <canvas_size>).
399
+ * @returns Returns 2D coordinates if the point is visible on screen, or `null` if object is outside screen.
400
+ * @example
401
+ * ```js
402
+ * const boundingBoxCenter = new THREE.Vector3();
403
+ * // Find center of bounding box in world space
404
+ * model.getBoundingBox(nodeId).getCenter(boundingBoxCenter);
405
+ * // Screen coordinates of that point
406
+ * const screenCoordinates = viewer.worldToScreen(boundingBoxCenter);
407
+ * ```
408
+ * ```js
409
+ * const boundingBoxCenter = new THREE.Vector3();
410
+ * // Find center of bounding box in world space
411
+ * model.getBoundingBox(nodeId).getCenter(boundingBoxCenter);
412
+ * // Screen coordinates of that point normalized in the range [0,1]
413
+ * const screenCoordinates = viewer.worldToScreen(boundingBoxCenter, true);
414
+ * ```
415
+ * ```js
416
+ * const boundingBoxCenter = new THREE.Vector3();
417
+ * // Find center of bounding box in world space
418
+ * model.getBoundingBox(nodeId).getCenter(boundingBoxCenter);
419
+ * // Screen coordinates of that point
420
+ * const screenCoordinates = viewer.worldToScreen(boundingBoxCenter);
421
+ * if (screenCoordinates == null) {
422
+ * // Object not visible on screen
423
+ * } else {
424
+ * // Object is visible on screen
425
+ * }
426
+ * ```
427
+ */
428
+ worldToScreen(point: THREE.Vector3, normalize?: boolean): THREE.Vector2 | null;
429
+ /**
430
+ * Take screenshot from the current camera position.
431
+ * @param width Width of the final image. Default is current canvas size.
432
+ * @param height Height of the final image. Default is current canvas size.
433
+ * @returns A {@link https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs Data URL} of the image ('image/png').
434
+ * @example
435
+ * ```js
436
+ * // Take a screenshot with custom resolution
437
+ * const url = await viewer.getScreenshot(1920, 1080);
438
+ * ```
439
+ * ```js
440
+ * // Add a screenshot with resolution of the canvas to the page
441
+ * const url = await viewer.getScreenshot();
442
+ * const image = document.createElement('img');
443
+ * image.src = url;
444
+ * document.body.appendChild(url);
445
+ * ```
446
+ */
447
+ getScreenshot(width?: number, height?: number): Promise<string>;
448
+ /**
449
+ * Raycasting model(s) for finding where the ray intersects with the model.
450
+ * @param offsetX X coordinate in pixels (relative to the domElement).
451
+ * @param offsetY Y coordinate in pixels (relative to the domElement).
452
+ * @param options Options to control the behavior of the intersection operation. Optional (new in 1.3.0).
453
+ * @returns A promise that if there was an intersection then return the intersection object - otherwise it
454
+ * returns `null` if there were no intersections.
455
+ * @see {@link https://en.wikipedia.org/wiki/Ray_casting}.
456
+ *
457
+ * @example For CAD model
458
+ * ```js
459
+ * const offsetX = 50 // pixels from the left
460
+ * const offsetY = 100 // pixels from the top
461
+ * const intersection = await viewer.getIntersectionFromPixel(offsetX, offsetY);
462
+ * if (intersection) // it was a hit
463
+ * console.log(
464
+ * 'You hit model ', intersection.model,
465
+ * ' at the node with tree index ', intersection.treeIndex,
466
+ * ' at this exact point ', intersection.point
467
+ * );
468
+ * ```
469
+ *
470
+ * @example For point cloud
471
+ * ```js
472
+ * const offsetX = 50 // pixels from the left
473
+ * const offsetY = 100 // pixels from the top
474
+ * const intersection = await viewer.getIntersectionFromPixel(offsetX, offsetY);
475
+ * if (intersection) // it was a hit
476
+ * console.log(
477
+ * 'You hit model ', intersection.model,
478
+ * ' at the point index ', intersection.pointIndex,
479
+ * ' at this exact point ', intersection.point
480
+ * );
481
+ * ```
482
+ */
483
+ getIntersectionFromPixel(offsetX: number, offsetY: number): Promise<null | Intersection>;
484
+ /**
485
+ * @deprecated Since 3.1 options argument have no effect.
486
+ */
487
+ getIntersectionFromPixel(offsetX: number, offsetY: number, options: IntersectionFromPixelOptions): Promise<null | Intersection>;
488
+ /** @private */
489
+ private getModels;
490
+ /**
491
+ * Creates a helper for managing viewer state.
492
+ */
493
+ private createViewStateHelper;
494
+ /** @private */
495
+ private animate;
496
+ /** @private */
497
+ private intersectModels;
498
+ /**
499
+ * Callback used by DefaultCameraManager to do model intersection. Made synchronous to avoid
500
+ * input lag when zooming in and out. Default implementation is async. See PR #2405 for more info.
501
+ * @private
502
+ */
503
+ private modelIntersectionCallback;
504
+ /** @private */
505
+ private recalculateBoundingBox;
506
+ /** @private */
507
+ private setupDomElementResizeListener;
508
+ private readonly startPointerEventListeners;
509
+ }