@itwin/core-orbitgt 5.0.0-dev.7 → 5.0.0-dev.72

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 (350) hide show
  1. package/CHANGELOG.md +31 -1
  2. package/lib/cjs/pointcloud/format/opc/AttributeMask.js +4 -0
  3. package/lib/cjs/pointcloud/format/opc/AttributeMask.js.map +1 -1
  4. package/lib/cjs/pointcloud/format/opc/BlockRecord.js +2 -2
  5. package/lib/cjs/pointcloud/format/opc/BlockRecord.js.map +1 -1
  6. package/lib/cjs/pointcloud/format/opc/ContainerFile.js +10 -2
  7. package/lib/cjs/pointcloud/format/opc/ContainerFile.js.map +1 -1
  8. package/lib/cjs/pointcloud/format/opc/ContainerFilePart.js +8 -0
  9. package/lib/cjs/pointcloud/format/opc/ContainerFilePart.js.map +1 -1
  10. package/lib/cjs/pointcloud/format/opc/DirectoryReader.js +12 -0
  11. package/lib/cjs/pointcloud/format/opc/DirectoryReader.js.map +1 -1
  12. package/lib/cjs/pointcloud/format/opc/DirectoryRecord.js +6 -0
  13. package/lib/cjs/pointcloud/format/opc/DirectoryRecord.js.map +1 -1
  14. package/lib/cjs/pointcloud/format/opc/EmbeddedAttributeReader.js +21 -0
  15. package/lib/cjs/pointcloud/format/opc/EmbeddedAttributeReader.js.map +1 -1
  16. package/lib/cjs/pointcloud/format/opc/FileAccess.js +6 -0
  17. package/lib/cjs/pointcloud/format/opc/FileAccess.js.map +1 -1
  18. package/lib/cjs/pointcloud/format/opc/FileReader.js +16 -2
  19. package/lib/cjs/pointcloud/format/opc/FileReader.js.map +1 -1
  20. package/lib/cjs/pointcloud/format/opc/FileRecord.js +14 -0
  21. package/lib/cjs/pointcloud/format/opc/FileRecord.js.map +1 -1
  22. package/lib/cjs/pointcloud/format/opc/GeometryReader.js +14 -6
  23. package/lib/cjs/pointcloud/format/opc/GeometryReader.js.map +1 -1
  24. package/lib/cjs/pointcloud/format/opc/GeometryRecord.js +4 -0
  25. package/lib/cjs/pointcloud/format/opc/GeometryRecord.js.map +1 -1
  26. package/lib/cjs/pointcloud/format/opc/OPCReader.js +6 -0
  27. package/lib/cjs/pointcloud/format/opc/OPCReader.js.map +1 -1
  28. package/lib/cjs/pointcloud/format/opc/TileReadBuffer.js +4 -0
  29. package/lib/cjs/pointcloud/format/opc/TileReadBuffer.js.map +1 -1
  30. package/lib/cjs/pointcloud/format/opc/TileRecord.js +2 -2
  31. package/lib/cjs/pointcloud/format/opc/TileRecord.js.map +1 -1
  32. package/lib/cjs/pointcloud/model/AttributeTypes.js +16 -16
  33. package/lib/cjs/pointcloud/model/AttributeTypes.js.map +1 -1
  34. package/lib/cjs/pointcloud/model/AttributeValue.js +14 -4
  35. package/lib/cjs/pointcloud/model/AttributeValue.js.map +1 -1
  36. package/lib/cjs/pointcloud/model/BlockIndex.js +18 -0
  37. package/lib/cjs/pointcloud/model/BlockIndex.js.map +1 -1
  38. package/lib/cjs/pointcloud/model/CloudPoint.js +22 -2
  39. package/lib/cjs/pointcloud/model/CloudPoint.js.map +1 -1
  40. package/lib/cjs/pointcloud/model/Grid.js +4 -0
  41. package/lib/cjs/pointcloud/model/Grid.js.map +1 -1
  42. package/lib/cjs/pointcloud/model/GridIndex.js +6 -0
  43. package/lib/cjs/pointcloud/model/GridIndex.js.map +1 -1
  44. package/lib/cjs/pointcloud/model/PointAttribute.js +14 -0
  45. package/lib/cjs/pointcloud/model/PointAttribute.js.map +1 -1
  46. package/lib/cjs/pointcloud/model/PointData.js +4 -0
  47. package/lib/cjs/pointcloud/model/PointData.js.map +1 -1
  48. package/lib/cjs/pointcloud/model/PointDataRaw.js +8 -2
  49. package/lib/cjs/pointcloud/model/PointDataRaw.js.map +1 -1
  50. package/lib/cjs/pointcloud/model/ReadRequest.js +28 -6
  51. package/lib/cjs/pointcloud/model/ReadRequest.js.map +1 -1
  52. package/lib/cjs/pointcloud/model/StandardAttributes.js +21 -21
  53. package/lib/cjs/pointcloud/model/StandardAttributes.js.map +1 -1
  54. package/lib/cjs/pointcloud/model/TileIndex.js +16 -0
  55. package/lib/cjs/pointcloud/model/TileIndex.js.map +1 -1
  56. package/lib/cjs/pointcloud/render/Block.js +6 -0
  57. package/lib/cjs/pointcloud/render/Block.js.map +1 -1
  58. package/lib/cjs/pointcloud/render/DataManager.js +36 -6
  59. package/lib/cjs/pointcloud/render/DataManager.js.map +1 -1
  60. package/lib/cjs/pointcloud/render/FrameData.js +8 -0
  61. package/lib/cjs/pointcloud/render/FrameData.js.map +1 -1
  62. package/lib/cjs/pointcloud/render/Level.js +12 -0
  63. package/lib/cjs/pointcloud/render/Level.js.map +1 -1
  64. package/lib/cjs/pointcloud/render/TileLoadSorter.js +9 -4
  65. package/lib/cjs/pointcloud/render/TileLoadSorter.js.map +1 -1
  66. package/lib/cjs/pointcloud/render/ViewTree.js +12 -4
  67. package/lib/cjs/pointcloud/render/ViewTree.js.map +1 -1
  68. package/lib/cjs/spatial/crs/CRSManager.js +2 -2
  69. package/lib/cjs/spatial/crs/CRSManager.js.map +1 -1
  70. package/lib/cjs/spatial/ecrs/Axis.js +12 -0
  71. package/lib/cjs/spatial/ecrs/Axis.js.map +1 -1
  72. package/lib/cjs/spatial/ecrs/CRS.js +68 -34
  73. package/lib/cjs/spatial/ecrs/CRS.js.map +1 -1
  74. package/lib/cjs/spatial/ecrs/CoordinateSystem.js +20 -2
  75. package/lib/cjs/spatial/ecrs/CoordinateSystem.js.map +1 -1
  76. package/lib/cjs/spatial/ecrs/DataFileUnit.js +1 -1
  77. package/lib/cjs/spatial/ecrs/DataFileUnit.js.map +1 -1
  78. package/lib/cjs/spatial/ecrs/Datum.js +16 -4
  79. package/lib/cjs/spatial/ecrs/Datum.js.map +1 -1
  80. package/lib/cjs/spatial/ecrs/Ellipsoid.js +18 -0
  81. package/lib/cjs/spatial/ecrs/Ellipsoid.js.map +1 -1
  82. package/lib/cjs/spatial/ecrs/OnlineEngine.js +2 -0
  83. package/lib/cjs/spatial/ecrs/OnlineEngine.js.map +1 -1
  84. package/lib/cjs/spatial/ecrs/OnlineRegistry.js +6 -2
  85. package/lib/cjs/spatial/ecrs/OnlineRegistry.js.map +1 -1
  86. package/lib/cjs/spatial/ecrs/Operation.js +28 -6
  87. package/lib/cjs/spatial/ecrs/Operation.js.map +1 -1
  88. package/lib/cjs/spatial/ecrs/OperationMethod.js +6 -0
  89. package/lib/cjs/spatial/ecrs/OperationMethod.js.map +1 -1
  90. package/lib/cjs/spatial/ecrs/ParameterValue.js +6 -0
  91. package/lib/cjs/spatial/ecrs/ParameterValue.js.map +1 -1
  92. package/lib/cjs/spatial/ecrs/ParameterValueList.js +2 -0
  93. package/lib/cjs/spatial/ecrs/ParameterValueList.js.map +1 -1
  94. package/lib/cjs/spatial/ecrs/PrimeMeridian.js +8 -0
  95. package/lib/cjs/spatial/ecrs/PrimeMeridian.js.map +1 -1
  96. package/lib/cjs/spatial/ecrs/Registry.js +17 -17
  97. package/lib/cjs/spatial/ecrs/Registry.js.map +1 -1
  98. package/lib/cjs/spatial/ecrs/Transform.js +11 -11
  99. package/lib/cjs/spatial/ecrs/Transform.js.map +1 -1
  100. package/lib/cjs/spatial/ecrs/Unit.js +40 -24
  101. package/lib/cjs/spatial/ecrs/Unit.js.map +1 -1
  102. package/lib/cjs/spatial/ecrs/WellKnownText.js +8 -8
  103. package/lib/cjs/spatial/ecrs/WellKnownText.js.map +1 -1
  104. package/lib/cjs/spatial/ecrs/WellKnownTextNode.js +4 -0
  105. package/lib/cjs/spatial/ecrs/WellKnownTextNode.js.map +1 -1
  106. package/lib/cjs/spatial/ecrs/projection/HotineObliqueMercator.js +36 -2
  107. package/lib/cjs/spatial/ecrs/projection/HotineObliqueMercator.js.map +1 -1
  108. package/lib/cjs/spatial/ecrs/projection/KrovakObliqueConformalConic.js +23 -2
  109. package/lib/cjs/spatial/ecrs/projection/KrovakObliqueConformalConic.js.map +1 -1
  110. package/lib/cjs/spatial/ecrs/projection/KrovakObliqueConformalConicEN.js +4 -2
  111. package/lib/cjs/spatial/ecrs/projection/KrovakObliqueConformalConicEN.js.map +1 -1
  112. package/lib/cjs/spatial/ecrs/projection/LambertConical1SP.js +12 -2
  113. package/lib/cjs/spatial/ecrs/projection/LambertConical1SP.js.map +1 -1
  114. package/lib/cjs/spatial/ecrs/projection/LambertConical2SP.js +29 -6
  115. package/lib/cjs/spatial/ecrs/projection/LambertConical2SP.js.map +1 -1
  116. package/lib/cjs/spatial/ecrs/projection/Mercator1SP.js +14 -4
  117. package/lib/cjs/spatial/ecrs/projection/Mercator1SP.js.map +1 -1
  118. package/lib/cjs/spatial/ecrs/projection/ObliqueMercator.js +38 -4
  119. package/lib/cjs/spatial/ecrs/projection/ObliqueMercator.js.map +1 -1
  120. package/lib/cjs/spatial/ecrs/projection/ObliqueStereographic.js +24 -4
  121. package/lib/cjs/spatial/ecrs/projection/ObliqueStereographic.js.map +1 -1
  122. package/lib/cjs/spatial/ecrs/projection/TransverseMercator.js +28 -4
  123. package/lib/cjs/spatial/ecrs/projection/TransverseMercator.js.map +1 -1
  124. package/lib/cjs/spatial/ecrs/transformation/PositionVector.js +12 -2
  125. package/lib/cjs/spatial/ecrs/transformation/PositionVector.js.map +1 -1
  126. package/lib/cjs/spatial/geom/Bounds.js +3 -0
  127. package/lib/cjs/spatial/geom/Bounds.js.map +1 -1
  128. package/lib/cjs/spatial/geom/Coordinate.js +3 -0
  129. package/lib/cjs/spatial/geom/Coordinate.js.map +1 -1
  130. package/lib/cjs/spatial/geom/Line.js +4 -0
  131. package/lib/cjs/spatial/geom/Line.js.map +1 -1
  132. package/lib/cjs/spatial/geom/Transform.js +2 -0
  133. package/lib/cjs/spatial/geom/Transform.js.map +1 -1
  134. package/lib/cjs/system/buffer/ABuffer.js +4 -0
  135. package/lib/cjs/system/buffer/ABuffer.js.map +1 -1
  136. package/lib/cjs/system/buffer/Float32Buffer.js +8 -2
  137. package/lib/cjs/system/buffer/Float32Buffer.js.map +1 -1
  138. package/lib/cjs/system/buffer/Uint16Buffer.js +8 -2
  139. package/lib/cjs/system/buffer/Uint16Buffer.js.map +1 -1
  140. package/lib/cjs/system/buffer/Uint8Buffer.js +8 -2
  141. package/lib/cjs/system/buffer/Uint8Buffer.js.map +1 -1
  142. package/lib/cjs/system/collection/AList.js +1 -0
  143. package/lib/cjs/system/collection/AList.js.map +1 -1
  144. package/lib/cjs/system/collection/IntMap.js +1 -0
  145. package/lib/cjs/system/collection/IntMap.js.map +1 -1
  146. package/lib/cjs/system/collection/StringMap.js +1 -0
  147. package/lib/cjs/system/collection/StringMap.js.map +1 -1
  148. package/lib/cjs/system/io/ABufferInStream.js +5 -0
  149. package/lib/cjs/system/io/ABufferInStream.js.map +1 -1
  150. package/lib/cjs/system/runtime/ALong.js +30 -26
  151. package/lib/cjs/system/runtime/ALong.js.map +1 -1
  152. package/lib/cjs/system/runtime/ASystem.js +1 -1
  153. package/lib/cjs/system/runtime/ASystem.js.map +1 -1
  154. package/lib/cjs/system/runtime/Downloader.js +2 -2
  155. package/lib/cjs/system/runtime/Downloader.js.map +1 -1
  156. package/lib/cjs/system/runtime/Message.js +2 -2
  157. package/lib/cjs/system/runtime/Message.js.map +1 -1
  158. package/lib/cjs/system/runtime/Numbers.js +6 -6
  159. package/lib/cjs/system/runtime/Numbers.js.map +1 -1
  160. package/lib/cjs/system/runtime/Strings.js +14 -14
  161. package/lib/cjs/system/runtime/Strings.js.map +1 -1
  162. package/lib/cjs/system/storage/CacheList.js +8 -0
  163. package/lib/cjs/system/storage/CacheList.js.map +1 -1
  164. package/lib/cjs/system/storage/CachedItem.js +6 -0
  165. package/lib/cjs/system/storage/CachedItem.js.map +1 -1
  166. package/lib/cjs/system/storage/ContentLoader.js +14 -2
  167. package/lib/cjs/system/storage/ContentLoader.js.map +1 -1
  168. package/lib/cjs/system/storage/FileContent.js +4 -0
  169. package/lib/cjs/system/storage/FileContent.js.map +1 -1
  170. package/lib/cjs/system/storage/FileRange.js +4 -0
  171. package/lib/cjs/system/storage/FileRange.js.map +1 -1
  172. package/lib/cjs/system/storage/PageCachedFile.js +8 -0
  173. package/lib/cjs/system/storage/PageCachedFile.js.map +1 -1
  174. package/lib/cjs/system/storage/UrlFS.js +6 -0
  175. package/lib/cjs/system/storage/UrlFS.js.map +1 -1
  176. package/lib/esm/pointcloud/format/opc/AttributeMask.js +4 -0
  177. package/lib/esm/pointcloud/format/opc/AttributeMask.js.map +1 -1
  178. package/lib/esm/pointcloud/format/opc/BlockRecord.js +2 -2
  179. package/lib/esm/pointcloud/format/opc/BlockRecord.js.map +1 -1
  180. package/lib/esm/pointcloud/format/opc/ContainerFile.js +10 -2
  181. package/lib/esm/pointcloud/format/opc/ContainerFile.js.map +1 -1
  182. package/lib/esm/pointcloud/format/opc/ContainerFilePart.js +8 -0
  183. package/lib/esm/pointcloud/format/opc/ContainerFilePart.js.map +1 -1
  184. package/lib/esm/pointcloud/format/opc/DirectoryReader.js +12 -0
  185. package/lib/esm/pointcloud/format/opc/DirectoryReader.js.map +1 -1
  186. package/lib/esm/pointcloud/format/opc/DirectoryRecord.js +6 -0
  187. package/lib/esm/pointcloud/format/opc/DirectoryRecord.js.map +1 -1
  188. package/lib/esm/pointcloud/format/opc/EmbeddedAttributeReader.js +21 -0
  189. package/lib/esm/pointcloud/format/opc/EmbeddedAttributeReader.js.map +1 -1
  190. package/lib/esm/pointcloud/format/opc/FileAccess.js +6 -0
  191. package/lib/esm/pointcloud/format/opc/FileAccess.js.map +1 -1
  192. package/lib/esm/pointcloud/format/opc/FileReader.js +16 -2
  193. package/lib/esm/pointcloud/format/opc/FileReader.js.map +1 -1
  194. package/lib/esm/pointcloud/format/opc/FileRecord.js +14 -0
  195. package/lib/esm/pointcloud/format/opc/FileRecord.js.map +1 -1
  196. package/lib/esm/pointcloud/format/opc/GeometryReader.js +14 -6
  197. package/lib/esm/pointcloud/format/opc/GeometryReader.js.map +1 -1
  198. package/lib/esm/pointcloud/format/opc/GeometryRecord.js +4 -0
  199. package/lib/esm/pointcloud/format/opc/GeometryRecord.js.map +1 -1
  200. package/lib/esm/pointcloud/format/opc/OPCReader.js +6 -0
  201. package/lib/esm/pointcloud/format/opc/OPCReader.js.map +1 -1
  202. package/lib/esm/pointcloud/format/opc/TileReadBuffer.js +4 -0
  203. package/lib/esm/pointcloud/format/opc/TileReadBuffer.js.map +1 -1
  204. package/lib/esm/pointcloud/format/opc/TileRecord.js +2 -2
  205. package/lib/esm/pointcloud/format/opc/TileRecord.js.map +1 -1
  206. package/lib/esm/pointcloud/model/AttributeTypes.js +16 -16
  207. package/lib/esm/pointcloud/model/AttributeTypes.js.map +1 -1
  208. package/lib/esm/pointcloud/model/AttributeValue.js +14 -4
  209. package/lib/esm/pointcloud/model/AttributeValue.js.map +1 -1
  210. package/lib/esm/pointcloud/model/BlockIndex.js +18 -0
  211. package/lib/esm/pointcloud/model/BlockIndex.js.map +1 -1
  212. package/lib/esm/pointcloud/model/CloudPoint.js +22 -2
  213. package/lib/esm/pointcloud/model/CloudPoint.js.map +1 -1
  214. package/lib/esm/pointcloud/model/Grid.js +4 -0
  215. package/lib/esm/pointcloud/model/Grid.js.map +1 -1
  216. package/lib/esm/pointcloud/model/GridIndex.js +6 -0
  217. package/lib/esm/pointcloud/model/GridIndex.js.map +1 -1
  218. package/lib/esm/pointcloud/model/PointAttribute.js +14 -0
  219. package/lib/esm/pointcloud/model/PointAttribute.js.map +1 -1
  220. package/lib/esm/pointcloud/model/PointData.js +4 -0
  221. package/lib/esm/pointcloud/model/PointData.js.map +1 -1
  222. package/lib/esm/pointcloud/model/PointDataRaw.js +8 -2
  223. package/lib/esm/pointcloud/model/PointDataRaw.js.map +1 -1
  224. package/lib/esm/pointcloud/model/ReadRequest.js +28 -6
  225. package/lib/esm/pointcloud/model/ReadRequest.js.map +1 -1
  226. package/lib/esm/pointcloud/model/StandardAttributes.js +21 -21
  227. package/lib/esm/pointcloud/model/StandardAttributes.js.map +1 -1
  228. package/lib/esm/pointcloud/model/TileIndex.js +16 -0
  229. package/lib/esm/pointcloud/model/TileIndex.js.map +1 -1
  230. package/lib/esm/pointcloud/render/Block.js +6 -0
  231. package/lib/esm/pointcloud/render/Block.js.map +1 -1
  232. package/lib/esm/pointcloud/render/DataManager.js +36 -6
  233. package/lib/esm/pointcloud/render/DataManager.js.map +1 -1
  234. package/lib/esm/pointcloud/render/FrameData.js +8 -0
  235. package/lib/esm/pointcloud/render/FrameData.js.map +1 -1
  236. package/lib/esm/pointcloud/render/Level.js +12 -0
  237. package/lib/esm/pointcloud/render/Level.js.map +1 -1
  238. package/lib/esm/pointcloud/render/TileLoadSorter.js +9 -4
  239. package/lib/esm/pointcloud/render/TileLoadSorter.js.map +1 -1
  240. package/lib/esm/pointcloud/render/ViewTree.js +12 -4
  241. package/lib/esm/pointcloud/render/ViewTree.js.map +1 -1
  242. package/lib/esm/spatial/crs/CRSManager.js +2 -2
  243. package/lib/esm/spatial/crs/CRSManager.js.map +1 -1
  244. package/lib/esm/spatial/ecrs/Axis.js +12 -0
  245. package/lib/esm/spatial/ecrs/Axis.js.map +1 -1
  246. package/lib/esm/spatial/ecrs/CRS.js +68 -34
  247. package/lib/esm/spatial/ecrs/CRS.js.map +1 -1
  248. package/lib/esm/spatial/ecrs/CoordinateSystem.js +20 -2
  249. package/lib/esm/spatial/ecrs/CoordinateSystem.js.map +1 -1
  250. package/lib/esm/spatial/ecrs/DataFileUnit.js +1 -1
  251. package/lib/esm/spatial/ecrs/DataFileUnit.js.map +1 -1
  252. package/lib/esm/spatial/ecrs/Datum.js +16 -4
  253. package/lib/esm/spatial/ecrs/Datum.js.map +1 -1
  254. package/lib/esm/spatial/ecrs/Ellipsoid.js +18 -0
  255. package/lib/esm/spatial/ecrs/Ellipsoid.js.map +1 -1
  256. package/lib/esm/spatial/ecrs/OnlineEngine.js +2 -0
  257. package/lib/esm/spatial/ecrs/OnlineEngine.js.map +1 -1
  258. package/lib/esm/spatial/ecrs/OnlineRegistry.js +6 -2
  259. package/lib/esm/spatial/ecrs/OnlineRegistry.js.map +1 -1
  260. package/lib/esm/spatial/ecrs/Operation.js +28 -6
  261. package/lib/esm/spatial/ecrs/Operation.js.map +1 -1
  262. package/lib/esm/spatial/ecrs/OperationMethod.js +6 -0
  263. package/lib/esm/spatial/ecrs/OperationMethod.js.map +1 -1
  264. package/lib/esm/spatial/ecrs/ParameterValue.js +6 -0
  265. package/lib/esm/spatial/ecrs/ParameterValue.js.map +1 -1
  266. package/lib/esm/spatial/ecrs/ParameterValueList.js +2 -0
  267. package/lib/esm/spatial/ecrs/ParameterValueList.js.map +1 -1
  268. package/lib/esm/spatial/ecrs/PrimeMeridian.js +8 -0
  269. package/lib/esm/spatial/ecrs/PrimeMeridian.js.map +1 -1
  270. package/lib/esm/spatial/ecrs/Registry.js +17 -17
  271. package/lib/esm/spatial/ecrs/Registry.js.map +1 -1
  272. package/lib/esm/spatial/ecrs/Transform.js +11 -11
  273. package/lib/esm/spatial/ecrs/Transform.js.map +1 -1
  274. package/lib/esm/spatial/ecrs/Unit.js +40 -24
  275. package/lib/esm/spatial/ecrs/Unit.js.map +1 -1
  276. package/lib/esm/spatial/ecrs/WellKnownText.js +8 -8
  277. package/lib/esm/spatial/ecrs/WellKnownText.js.map +1 -1
  278. package/lib/esm/spatial/ecrs/WellKnownTextNode.js +4 -0
  279. package/lib/esm/spatial/ecrs/WellKnownTextNode.js.map +1 -1
  280. package/lib/esm/spatial/ecrs/projection/HotineObliqueMercator.js +36 -2
  281. package/lib/esm/spatial/ecrs/projection/HotineObliqueMercator.js.map +1 -1
  282. package/lib/esm/spatial/ecrs/projection/KrovakObliqueConformalConic.js +23 -2
  283. package/lib/esm/spatial/ecrs/projection/KrovakObliqueConformalConic.js.map +1 -1
  284. package/lib/esm/spatial/ecrs/projection/KrovakObliqueConformalConicEN.js +4 -2
  285. package/lib/esm/spatial/ecrs/projection/KrovakObliqueConformalConicEN.js.map +1 -1
  286. package/lib/esm/spatial/ecrs/projection/LambertConical1SP.js +12 -2
  287. package/lib/esm/spatial/ecrs/projection/LambertConical1SP.js.map +1 -1
  288. package/lib/esm/spatial/ecrs/projection/LambertConical2SP.js +29 -6
  289. package/lib/esm/spatial/ecrs/projection/LambertConical2SP.js.map +1 -1
  290. package/lib/esm/spatial/ecrs/projection/Mercator1SP.js +14 -4
  291. package/lib/esm/spatial/ecrs/projection/Mercator1SP.js.map +1 -1
  292. package/lib/esm/spatial/ecrs/projection/ObliqueMercator.js +38 -4
  293. package/lib/esm/spatial/ecrs/projection/ObliqueMercator.js.map +1 -1
  294. package/lib/esm/spatial/ecrs/projection/ObliqueStereographic.js +24 -4
  295. package/lib/esm/spatial/ecrs/projection/ObliqueStereographic.js.map +1 -1
  296. package/lib/esm/spatial/ecrs/projection/TransverseMercator.js +28 -4
  297. package/lib/esm/spatial/ecrs/projection/TransverseMercator.js.map +1 -1
  298. package/lib/esm/spatial/ecrs/transformation/PositionVector.js +12 -2
  299. package/lib/esm/spatial/ecrs/transformation/PositionVector.js.map +1 -1
  300. package/lib/esm/spatial/geom/Bounds.js +3 -0
  301. package/lib/esm/spatial/geom/Bounds.js.map +1 -1
  302. package/lib/esm/spatial/geom/Coordinate.js +3 -0
  303. package/lib/esm/spatial/geom/Coordinate.js.map +1 -1
  304. package/lib/esm/spatial/geom/Line.js +4 -0
  305. package/lib/esm/spatial/geom/Line.js.map +1 -1
  306. package/lib/esm/spatial/geom/Transform.js +2 -0
  307. package/lib/esm/spatial/geom/Transform.js.map +1 -1
  308. package/lib/esm/system/buffer/ABuffer.js +4 -0
  309. package/lib/esm/system/buffer/ABuffer.js.map +1 -1
  310. package/lib/esm/system/buffer/Float32Buffer.js +8 -2
  311. package/lib/esm/system/buffer/Float32Buffer.js.map +1 -1
  312. package/lib/esm/system/buffer/Uint16Buffer.js +8 -2
  313. package/lib/esm/system/buffer/Uint16Buffer.js.map +1 -1
  314. package/lib/esm/system/buffer/Uint8Buffer.js +8 -2
  315. package/lib/esm/system/buffer/Uint8Buffer.js.map +1 -1
  316. package/lib/esm/system/collection/AList.js +1 -0
  317. package/lib/esm/system/collection/AList.js.map +1 -1
  318. package/lib/esm/system/collection/IntMap.js +1 -0
  319. package/lib/esm/system/collection/IntMap.js.map +1 -1
  320. package/lib/esm/system/collection/StringMap.js +1 -0
  321. package/lib/esm/system/collection/StringMap.js.map +1 -1
  322. package/lib/esm/system/io/ABufferInStream.js +5 -0
  323. package/lib/esm/system/io/ABufferInStream.js.map +1 -1
  324. package/lib/esm/system/runtime/ALong.js +30 -26
  325. package/lib/esm/system/runtime/ALong.js.map +1 -1
  326. package/lib/esm/system/runtime/ASystem.js +1 -1
  327. package/lib/esm/system/runtime/ASystem.js.map +1 -1
  328. package/lib/esm/system/runtime/Downloader.js +2 -2
  329. package/lib/esm/system/runtime/Downloader.js.map +1 -1
  330. package/lib/esm/system/runtime/Message.js +2 -2
  331. package/lib/esm/system/runtime/Message.js.map +1 -1
  332. package/lib/esm/system/runtime/Numbers.js +6 -6
  333. package/lib/esm/system/runtime/Numbers.js.map +1 -1
  334. package/lib/esm/system/runtime/Strings.js +14 -14
  335. package/lib/esm/system/runtime/Strings.js.map +1 -1
  336. package/lib/esm/system/storage/CacheList.js +8 -0
  337. package/lib/esm/system/storage/CacheList.js.map +1 -1
  338. package/lib/esm/system/storage/CachedItem.js +6 -0
  339. package/lib/esm/system/storage/CachedItem.js.map +1 -1
  340. package/lib/esm/system/storage/ContentLoader.js +14 -2
  341. package/lib/esm/system/storage/ContentLoader.js.map +1 -1
  342. package/lib/esm/system/storage/FileContent.js +4 -0
  343. package/lib/esm/system/storage/FileContent.js.map +1 -1
  344. package/lib/esm/system/storage/FileRange.js +4 -0
  345. package/lib/esm/system/storage/FileRange.js.map +1 -1
  346. package/lib/esm/system/storage/PageCachedFile.js +8 -0
  347. package/lib/esm/system/storage/PageCachedFile.js.map +1 -1
  348. package/lib/esm/system/storage/UrlFS.js +6 -0
  349. package/lib/esm/system/storage/UrlFS.js.map +1 -1
  350. package/package.json +5 -5
@@ -12,6 +12,22 @@
12
12
  */
13
13
  /** @internal */
14
14
  export class TileIndex {
15
+ /** The level */
16
+ level;
17
+ /** The unique key of the block */
18
+ key;
19
+ /** The index of the tile in the level */
20
+ index;
21
+ /** The grid index */
22
+ gridIndex;
23
+ /** The index of the first point in the tile (derived) */
24
+ pointIndex;
25
+ /** The point count */
26
+ pointCount;
27
+ /** The children */
28
+ children;
29
+ /** The last access time */
30
+ accessTime;
15
31
  /**
16
32
  * Create a new index.
17
33
  */
@@ -1 +1 @@
1
- {"version":3,"file":"TileIndex.js","sourceRoot":"","sources":["../../../../src/pointcloud/model/TileIndex.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAcH;;;;GAIG;AACH,gBAAgB;AAChB,MAAM,OAAO,SAAS;IAkBlB;;OAEG;IACH,YAAmB,KAAY,EAAE,KAAY,EAAE,SAAoB,EAAE,UAAiB,EAAE,UAAiB;QACrG,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC;QACtB,IAAI,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,CAAC,KAAK,GAAG,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;IACvD,CAAC;IAED;;;;OAIG;IACI,IAAI,CAAC,KAAgB;QACxB,OAAO,CAAC,KAAK,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC;IACtE,CAAC;IAED;;;OAGG;IACI,MAAM;QACT,OAAO,GAAG,GAAG,IAAI,CAAC,KAAK,GAAG,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,GAAG,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,GAAG,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;IACvG,CAAC;CACJ","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module OrbitGT\r\n */\r\n\r\n//package orbitgt.pointcloud.model;\r\n\r\ntype int8 = number;\r\ntype int16 = number;\r\ntype int32 = number;\r\ntype float32 = number;\r\ntype float64 = number;\r\n\r\n\r\nimport { ALong } from \"../../system/runtime/ALong\";\r\nimport { GridIndex } from \"./GridIndex\";\r\n\r\n/**\r\n * Class TileIndex defines a tile index in a pointcloud file.\r\n *\r\n * @version 1.0 January 2014\r\n */\r\n/** @internal */\r\nexport class TileIndex {\r\n /** The level */\r\n public level: int32;\r\n /** The unique key of the block */\r\n public key: string;\r\n /** The index of the tile in the level */\r\n public index: int32;\r\n /** The grid index */\r\n public gridIndex: GridIndex;\r\n /** The index of the first point in the tile (derived) */\r\n public pointIndex: ALong;\r\n /** The point count */\r\n public pointCount: int32;\r\n /** The children */\r\n public children: Array<TileIndex>;\r\n /** The last access time */\r\n public accessTime: float64;\r\n\r\n /**\r\n * Create a new index.\r\n */\r\n public constructor(level: int32, index: int32, gridIndex: GridIndex, pointIndex: ALong, pointCount: int32) {\r\n this.level = level;\r\n this.index = index;\r\n this.gridIndex = gridIndex;\r\n this.pointIndex = pointIndex;\r\n this.pointCount = pointCount;\r\n this.children = null;\r\n this.accessTime = 0.0;\r\n this.key = (\"L\" + this.level + \",T:\" + this.index);\r\n }\r\n\r\n /**\r\n * Check if two indexes are the same.\r\n * @param other another index.\r\n * @return true if same.\r\n */\r\n public same(other: TileIndex): boolean {\r\n return (other.level == this.level) && (other.index == this.index);\r\n }\r\n\r\n /**\r\n * Get the unique key of the tile in the pointcloud file.\r\n * @return the unique key (combines level and grid index).\r\n */\r\n public getKey(): string {\r\n return \"T\" + this.level + \"/\" + this.gridIndex.x + \"/\" + this.gridIndex.y + \"/\" + this.gridIndex.z;\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"TileIndex.js","sourceRoot":"","sources":["../../../../src/pointcloud/model/TileIndex.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAcH;;;;GAIG;AACH,gBAAgB;AAChB,MAAM,OAAO,SAAS;IAClB,gBAAgB;IACT,KAAK,CAAQ;IACpB,kCAAkC;IAC3B,GAAG,CAAS;IACnB,yCAAyC;IAClC,KAAK,CAAQ;IACpB,qBAAqB;IACd,SAAS,CAAY;IAC5B,yDAAyD;IAClD,UAAU,CAAQ;IACzB,sBAAsB;IACf,UAAU,CAAQ;IACzB,mBAAmB;IACZ,QAAQ,CAAmB;IAClC,2BAA2B;IACpB,UAAU,CAAU;IAE3B;;OAEG;IACH,YAAmB,KAAY,EAAE,KAAY,EAAE,SAAoB,EAAE,UAAiB,EAAE,UAAiB;QACrG,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC;QACtB,IAAI,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,CAAC,KAAK,GAAG,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;IACvD,CAAC;IAED;;;;OAIG;IACI,IAAI,CAAC,KAAgB;QACxB,OAAO,CAAC,KAAK,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC;IACtE,CAAC;IAED;;;OAGG;IACI,MAAM;QACT,OAAO,GAAG,GAAG,IAAI,CAAC,KAAK,GAAG,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,GAAG,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,GAAG,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;IACvG,CAAC;CACJ","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module OrbitGT\r\n */\r\n\r\n//package orbitgt.pointcloud.model;\r\n\r\ntype int8 = number;\r\ntype int16 = number;\r\ntype int32 = number;\r\ntype float32 = number;\r\ntype float64 = number;\r\n\r\n\r\nimport { ALong } from \"../../system/runtime/ALong\";\r\nimport { GridIndex } from \"./GridIndex\";\r\n\r\n/**\r\n * Class TileIndex defines a tile index in a pointcloud file.\r\n *\r\n * @version 1.0 January 2014\r\n */\r\n/** @internal */\r\nexport class TileIndex {\r\n /** The level */\r\n public level: int32;\r\n /** The unique key of the block */\r\n public key: string;\r\n /** The index of the tile in the level */\r\n public index: int32;\r\n /** The grid index */\r\n public gridIndex: GridIndex;\r\n /** The index of the first point in the tile (derived) */\r\n public pointIndex: ALong;\r\n /** The point count */\r\n public pointCount: int32;\r\n /** The children */\r\n public children: Array<TileIndex>;\r\n /** The last access time */\r\n public accessTime: float64;\r\n\r\n /**\r\n * Create a new index.\r\n */\r\n public constructor(level: int32, index: int32, gridIndex: GridIndex, pointIndex: ALong, pointCount: int32) {\r\n this.level = level;\r\n this.index = index;\r\n this.gridIndex = gridIndex;\r\n this.pointIndex = pointIndex;\r\n this.pointCount = pointCount;\r\n this.children = null;\r\n this.accessTime = 0.0;\r\n this.key = (\"L\" + this.level + \",T:\" + this.index);\r\n }\r\n\r\n /**\r\n * Check if two indexes are the same.\r\n * @param other another index.\r\n * @return true if same.\r\n */\r\n public same(other: TileIndex): boolean {\r\n return (other.level == this.level) && (other.index == this.index);\r\n }\r\n\r\n /**\r\n * Get the unique key of the tile in the pointcloud file.\r\n * @return the unique key (combines level and grid index).\r\n */\r\n public getKey(): string {\r\n return \"T\" + this.level + \"/\" + this.gridIndex.x + \"/\" + this.gridIndex.y + \"/\" + this.gridIndex.z;\r\n }\r\n}\r\n"]}
@@ -13,6 +13,12 @@ import { IntMap } from "../../system/collection/IntMap";
13
13
  */
14
14
  /** @internal */
15
15
  export class Block {
16
+ /** The index of the block */
17
+ _index;
18
+ /** The full list of tiles in the block (can be null if the tile-list has not been loaded) */
19
+ _tileList;
20
+ /** The map of tiles in the block */
21
+ _tileMap;
16
22
  /**
17
23
  * Create a new block.
18
24
  * @param index the index of the block.
@@ -1 +1 @@
1
- {"version":3,"file":"Block.js","sourceRoot":"","sources":["../../../../src/pointcloud/render/Block.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module OrbitGT\r\n */\r\n\r\n//package orbitgt.pointcloud.render;\r\n\r\ntype int8 = number;\r\ntype int16 = number;\r\ntype int32 = number;\r\ntype float32 = number;\r\ntype float64 = number;\r\n\r\nimport { Bounds } from \"../../spatial/geom/Bounds\";\r\nimport { AList } from \"../../system/collection/AList\";\r\nimport { IntMap } from \"../../system/collection/IntMap\";\r\nimport { BlockIndex } from \"../model/BlockIndex\";\r\nimport { GridIndex } from \"../model/GridIndex\";\r\nimport { TileIndex } from \"../model/TileIndex\";\r\nimport { Level } from \"./Level\";\r\n\r\n/**\r\n * Class Block defines a block of tiles.\r\n *\r\n * @version 1.0 November 2015\r\n */\r\n/** @internal */\r\nexport class Block {\r\n\t/** The index of the block */\r\n\tprivate _index: BlockIndex;\r\n\t/** The full list of tiles in the block (can be null if the tile-list has not been loaded) */\r\n\tprivate _tileList: Array<TileIndex>;\r\n\t/** The map of tiles in the block */\r\n\tprivate _tileMap: IntMap<IntMap<IntMap<TileIndex>>>;\r\n\r\n\t/**\r\n\t * Create a new block.\r\n\t * @param index the index of the block.\r\n\t */\r\n\tpublic constructor(index: BlockIndex) {\r\n\t\tthis._index = index;\r\n\t\tthis._tileList = null;\r\n\t\tthis._tileMap = null;\r\n\t}\r\n\r\n\t/**\r\n\t * Get the index of the block.\r\n\t * @return the index of the block.\r\n\t */\r\n\tpublic getBlockIndex(): BlockIndex {\r\n\t\treturn this._index;\r\n\t}\r\n\r\n\t/**\r\n\t * Get the spatial bounds of the block.\r\n\t * @param level the level to which the block belongs.\r\n\t * @return the spatial bounds of the block.\r\n\t */\r\n\tpublic getBlockBounds(level: Level): Bounds {\r\n\t\treturn level.getBlockGrid().getCellBounds(this._index.gridIndex);\r\n\t}\r\n\r\n\t/**\r\n\t * Add a block to the list of blocks to load.\r\n * @param blocksToLoad the list of blocks to load.\r\n * @param block the block to add.\r\n */\r\n\tprivate static addToLoadList(blocksToLoad: AList<BlockIndex>, block: BlockIndex): void {\r\n\t\tfor (let i: number = 0; i < blocksToLoad.size(); i++) if (blocksToLoad.get(i).same(block)) return;\r\n\t\tblocksToLoad.add(block);\r\n\t}\r\n\r\n\t/**\r\n\t * Set the tiles in the block.\r\n\t * @param tileList the list of tiles.\r\n\t */\r\n\tpublic setTiles(tileList: Array<TileIndex>): void {\r\n\t\t/* Store the list */\r\n\t\tthis._tileList = tileList;\r\n\t\t/* Make the map */\r\n\t\tthis._tileMap = new IntMap<IntMap<IntMap<TileIndex>>>();\r\n\t\tfor (let tile of this._tileList) {\r\n\t\t\tlet tileX: int32 = tile.gridIndex.x;\r\n\t\t\tlet yzMap: IntMap<IntMap<TileIndex>> = this._tileMap.get(tileX);\r\n\t\t\tif (yzMap == null) {\r\n\t\t\t\tyzMap = new IntMap<IntMap<TileIndex>>();\r\n\t\t\t\tthis._tileMap.set(tileX, yzMap);\r\n\t\t\t}\r\n\t\t\tlet tileY: int32 = tile.gridIndex.y;\r\n\t\t\tlet zMap: IntMap<TileIndex> = yzMap.get(tileY);\r\n\t\t\tif (zMap == null) {\r\n\t\t\t\tzMap = new IntMap<TileIndex>();\r\n\t\t\t\tyzMap.set(tileY, zMap);\r\n\t\t\t}\r\n\t\t\tlet tileZ: int32 = tile.gridIndex.z;\r\n\t\t\tzMap.set(tileZ, tile);\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t * Have the tiles been set?\r\n\t * @return true if the tiles have been set.\r\n\t */\r\n\tpublic hasTiles(): boolean {\r\n\t\treturn (this._tileList != null);\r\n\t}\r\n\r\n\t/**\r\n\t * List all tiles.\r\n * @param blocksToLoad the list of blocks to load.\r\n\t * @return all tiles (null if tiles are not loaded).\r\n\t */\r\n\tpublic getTiles(blocksToLoad: AList<BlockIndex>): Array<TileIndex> {\r\n\t\tif (this._tileList == null) {\r\n\t\t\tBlock.addToLoadList(blocksToLoad, this._index);\r\n\t\t\treturn null;\r\n\t\t}\r\n\t\treturn this._tileList;\r\n\t}\r\n\r\n\t/**\r\n\t * Find a tile.\r\n * @param tileGridIndex the grid index of the tile.\r\n\t * @return the tile (null if not found).\r\n\t */\r\n\tpublic findTile(tileGridIndex: GridIndex): TileIndex {\r\n\t\tif (this._tileMap == null) return null;\r\n\t\tlet tileX: int32 = tileGridIndex.x;\r\n\t\tlet yzMap: IntMap<IntMap<TileIndex>> = this._tileMap.get(tileX);\r\n\t\tif (yzMap == null) return null;\r\n\t\tlet tileY: int32 = tileGridIndex.y;\r\n\t\tlet zMap: IntMap<TileIndex> = yzMap.get(tileY);\r\n\t\tif (zMap == null) return null;\r\n\t\tlet tileZ: int32 = tileGridIndex.z;\r\n\t\treturn zMap.get(tileZ);\r\n\t}\r\n}\r\n"]}
1
+ {"version":3,"file":"Block.js","sourceRoot":"","sources":["../../../../src/pointcloud/render/Block.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module OrbitGT\r\n */\r\n\r\n//package orbitgt.pointcloud.render;\r\n\r\ntype int8 = number;\r\ntype int16 = number;\r\ntype int32 = number;\r\ntype float32 = number;\r\ntype float64 = number;\r\n\r\nimport { Bounds } from \"../../spatial/geom/Bounds\";\r\nimport { AList } from \"../../system/collection/AList\";\r\nimport { IntMap } from \"../../system/collection/IntMap\";\r\nimport { BlockIndex } from \"../model/BlockIndex\";\r\nimport { GridIndex } from \"../model/GridIndex\";\r\nimport { TileIndex } from \"../model/TileIndex\";\r\nimport { Level } from \"./Level\";\r\n\r\n/**\r\n * Class Block defines a block of tiles.\r\n *\r\n * @version 1.0 November 2015\r\n */\r\n/** @internal */\r\nexport class Block {\r\n\t/** The index of the block */\r\n\tprivate _index: BlockIndex;\r\n\t/** The full list of tiles in the block (can be null if the tile-list has not been loaded) */\r\n\tprivate _tileList: Array<TileIndex>;\r\n\t/** The map of tiles in the block */\r\n\tprivate _tileMap: IntMap<IntMap<IntMap<TileIndex>>>;\r\n\r\n\t/**\r\n\t * Create a new block.\r\n\t * @param index the index of the block.\r\n\t */\r\n\tpublic constructor(index: BlockIndex) {\r\n\t\tthis._index = index;\r\n\t\tthis._tileList = null;\r\n\t\tthis._tileMap = null;\r\n\t}\r\n\r\n\t/**\r\n\t * Get the index of the block.\r\n\t * @return the index of the block.\r\n\t */\r\n\tpublic getBlockIndex(): BlockIndex {\r\n\t\treturn this._index;\r\n\t}\r\n\r\n\t/**\r\n\t * Get the spatial bounds of the block.\r\n\t * @param level the level to which the block belongs.\r\n\t * @return the spatial bounds of the block.\r\n\t */\r\n\tpublic getBlockBounds(level: Level): Bounds {\r\n\t\treturn level.getBlockGrid().getCellBounds(this._index.gridIndex);\r\n\t}\r\n\r\n\t/**\r\n\t * Add a block to the list of blocks to load.\r\n * @param blocksToLoad the list of blocks to load.\r\n * @param block the block to add.\r\n */\r\n\tprivate static addToLoadList(blocksToLoad: AList<BlockIndex>, block: BlockIndex): void {\r\n\t\tfor (let i: number = 0; i < blocksToLoad.size(); i++) if (blocksToLoad.get(i).same(block)) return;\r\n\t\tblocksToLoad.add(block);\r\n\t}\r\n\r\n\t/**\r\n\t * Set the tiles in the block.\r\n\t * @param tileList the list of tiles.\r\n\t */\r\n\tpublic setTiles(tileList: Array<TileIndex>): void {\r\n\t\t/* Store the list */\r\n\t\tthis._tileList = tileList;\r\n\t\t/* Make the map */\r\n\t\tthis._tileMap = new IntMap<IntMap<IntMap<TileIndex>>>();\r\n\t\tfor (let tile of this._tileList) {\r\n\t\t\tlet tileX: int32 = tile.gridIndex.x;\r\n\t\t\tlet yzMap: IntMap<IntMap<TileIndex>> = this._tileMap.get(tileX);\r\n\t\t\tif (yzMap == null) {\r\n\t\t\t\tyzMap = new IntMap<IntMap<TileIndex>>();\r\n\t\t\t\tthis._tileMap.set(tileX, yzMap);\r\n\t\t\t}\r\n\t\t\tlet tileY: int32 = tile.gridIndex.y;\r\n\t\t\tlet zMap: IntMap<TileIndex> = yzMap.get(tileY);\r\n\t\t\tif (zMap == null) {\r\n\t\t\t\tzMap = new IntMap<TileIndex>();\r\n\t\t\t\tyzMap.set(tileY, zMap);\r\n\t\t\t}\r\n\t\t\tlet tileZ: int32 = tile.gridIndex.z;\r\n\t\t\tzMap.set(tileZ, tile);\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t * Have the tiles been set?\r\n\t * @return true if the tiles have been set.\r\n\t */\r\n\tpublic hasTiles(): boolean {\r\n\t\treturn (this._tileList != null);\r\n\t}\r\n\r\n\t/**\r\n\t * List all tiles.\r\n * @param blocksToLoad the list of blocks to load.\r\n\t * @return all tiles (null if tiles are not loaded).\r\n\t */\r\n\tpublic getTiles(blocksToLoad: AList<BlockIndex>): Array<TileIndex> {\r\n\t\tif (this._tileList == null) {\r\n\t\t\tBlock.addToLoadList(blocksToLoad, this._index);\r\n\t\t\treturn null;\r\n\t\t}\r\n\t\treturn this._tileList;\r\n\t}\r\n\r\n\t/**\r\n\t * Find a tile.\r\n * @param tileGridIndex the grid index of the tile.\r\n\t * @return the tile (null if not found).\r\n\t */\r\n\tpublic findTile(tileGridIndex: GridIndex): TileIndex {\r\n\t\tif (this._tileMap == null) return null;\r\n\t\tlet tileX: int32 = tileGridIndex.x;\r\n\t\tlet yzMap: IntMap<IntMap<TileIndex>> = this._tileMap.get(tileX);\r\n\t\tif (yzMap == null) return null;\r\n\t\tlet tileY: int32 = tileGridIndex.y;\r\n\t\tlet zMap: IntMap<TileIndex> = yzMap.get(tileY);\r\n\t\tif (zMap == null) return null;\r\n\t\tlet tileZ: int32 = tileGridIndex.z;\r\n\t\treturn zMap.get(tileZ);\r\n\t}\r\n}\r\n"]}
@@ -21,6 +21,42 @@ import { ViewTree } from "./ViewTree";
21
21
  */
22
22
  /** @internal */
23
23
  export class DataManager {
24
+ /** The name of this module */
25
+ static MODULE = "DataManager";
26
+ /** The maximum size of a single file-content request */
27
+ static MAX_FILE_CONTENT_SIZE = 128 * 1024;
28
+ /** The expire time to unload unused point data (seconds) */
29
+ static POINT_DATA_EXIRE_TIME = 5 * 60.0;
30
+ /** The reader of the pointcloud */
31
+ _pointCloudReader;
32
+ /*** The CRS of the pointcloud */
33
+ _pointCloudCRS;
34
+ /** The data format to read */
35
+ _dataFormat;
36
+ /** The spatial index */
37
+ _fileTileIndex;
38
+ /** The data pool */
39
+ _dataPool;
40
+ /** The set of levels we requested (index) */
41
+ _levelsLoading;
42
+ /** The set of levels we received (index) */
43
+ _levelsLoaded;
44
+ /** The set of blocks we requested (key) */
45
+ _blocksLoading;
46
+ /** The set of blocks we received (key) */
47
+ _blocksLoaded;
48
+ /** The set of tiles we requested (key) */
49
+ _tilesLoading;
50
+ /** The set of tiles we received (key) */
51
+ _tilesLoaded;
52
+ /** Is new data being loaded? */
53
+ _loadingData;
54
+ /** The time when the data loading stopped */
55
+ _loadedDataTime;
56
+ /** The total size of data that has been loaded */
57
+ _dataLoadSize;
58
+ /** The last garbage collection time */
59
+ _lastGarbageCollectTime;
24
60
  /**
25
61
  * Create a new data model (to be shared between different views).
26
62
  * @param pointCloudReader the reader of the pointcloud file.
@@ -330,10 +366,4 @@ export class DataManager {
330
366
  Message.print(DataManager.MODULE, "Dropped the point data of " + dropCount + " tiles");
331
367
  }
332
368
  }
333
- /** The name of this module */
334
- DataManager.MODULE = "DataManager";
335
- /** The maximum size of a single file-content request */
336
- DataManager.MAX_FILE_CONTENT_SIZE = 128 * 1024;
337
- /** The expire time to unload unused point data (seconds) */
338
- DataManager.POINT_DATA_EXIRE_TIME = 5 * 60.0;
339
369
  //# sourceMappingURL=DataManager.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"DataManager.js","sourceRoot":"","sources":["../../../../src/pointcloud/render/DataManager.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module OrbitGT\r\n */\r\n\r\n//package orbitgt.pointcloud.render;\r\n\r\ntype int8 = number;\r\ntype int16 = number;\r\ntype int32 = number;\r\ntype float32 = number;\r\ntype float64 = number;\r\n\r\nimport { Bounds } from \"../../spatial/geom/Bounds\";\r\nimport { Transform } from \"../../spatial/geom/Transform\";\r\nimport { AList } from \"../../system/collection/AList\";\r\nimport { StringMap } from \"../../system/collection/StringMap\";\r\nimport { ALong } from \"../../system/runtime/ALong\";\r\nimport { ASystem } from \"../../system/runtime/ASystem\";\r\nimport { Message } from \"../../system/runtime/Message\";\r\nimport { ContentLoader } from \"../../system/storage/ContentLoader\";\r\nimport { BlockIndex } from \"../model/BlockIndex\";\r\nimport { Grid } from \"../model/Grid\";\r\nimport { PointCloudReader } from \"../model/PointCloudReader\";\r\nimport { PointData } from \"../model/PointData\";\r\nimport { TileIndex } from \"../model/TileIndex\";\r\nimport { Block } from \"./Block\";\r\nimport { FrameData } from \"./FrameData\";\r\nimport { Level } from \"./Level\";\r\nimport { ViewTree } from \"./ViewTree\";\r\n\r\n/**\r\n * Class DataManager manages the (shared) data model part of the rendering in multiple layers (see the CLOUD-461 issue).\r\n *\r\n * @version 1.0 December 2017\r\n */\r\n/** @internal */\r\nexport class DataManager {\r\n\t/** The name of this module */\r\n\tprivate static readonly MODULE: string = \"DataManager\";\r\n\r\n\t/** The maximum size of a single file-content request */\r\n\tprivate static readonly MAX_FILE_CONTENT_SIZE: int32 = 128 * 1024;\r\n\t/** The expire time to unload unused point data (seconds) */\r\n\tprivate static readonly POINT_DATA_EXIRE_TIME: float64 = 5 * 60.0;\r\n\r\n\t/** The reader of the pointcloud */\r\n\tprivate _pointCloudReader: PointCloudReader;\r\n\t/*** The CRS of the pointcloud */\r\n\tprivate _pointCloudCRS: string;\r\n\t/** The data format to read */\r\n\tprivate _dataFormat: int32;\r\n\r\n\t/** The spatial index */\r\n\tprivate _fileTileIndex: ViewTree;\r\n\t/** The data pool */\r\n\tprivate _dataPool: StringMap<PointData>;\r\n\t/** The set of levels we requested (index) */\r\n\tprivate _levelsLoading: StringMap<Level>;\r\n\t/** The set of levels we received (index) */\r\n\tprivate _levelsLoaded: StringMap<Level>;\r\n\t/** The set of blocks we requested (key) */\r\n\tprivate _blocksLoading: StringMap<BlockIndex>;\r\n\t/** The set of blocks we received (key) */\r\n\tprivate _blocksLoaded: StringMap<BlockIndex>;\r\n\t/** The set of tiles we requested (key) */\r\n\tprivate _tilesLoading: StringMap<TileIndex>;\r\n\t/** The set of tiles we received (key) */\r\n\tprivate _tilesLoaded: StringMap<TileIndex>;\r\n\t/** Is new data being loaded? */\r\n\tprivate _loadingData: boolean;\r\n\t/** The time when the data loading stopped */\r\n\tprivate _loadedDataTime: float64;\r\n\t/** The total size of data that has been loaded */\r\n\tprivate _dataLoadSize: ALong;\r\n\r\n\t/** The last garbage collection time */\r\n\tprivate _lastGarbageCollectTime: float64;\r\n\r\n\t/**\r\n\t * Create a new data model (to be shared between different views).\r\n\t * @param pointCloudReader the reader of the pointcloud file.\r\n\t * @param pointCloudCRS the CRS of the point cloud.\r\n\t * @param dataFormat the requested data format to load point data (PointDataRaw.TYPE for example).\r\n\t */\r\n\tpublic constructor(pointCloudReader: PointCloudReader, pointCloudCRS: string, dataFormat: int32) {\r\n\t\t/* Store the parameters */\r\n\t\tthis._pointCloudReader = pointCloudReader;\r\n\t\tthis._pointCloudCRS = pointCloudCRS;\r\n\t\tthis._dataFormat = dataFormat;\r\n\t\t/* Initialize */\r\n\t\tif (this._pointCloudCRS == null) this._pointCloudCRS = this._pointCloudReader.getFileCRS();\r\n\t\t/* Clear */\r\n\t\tthis._fileTileIndex = this.createSpatialIndex();\r\n\t\tthis._dataPool = new StringMap<PointData>();\r\n\t\tthis._levelsLoading = new StringMap<Level>();\r\n\t\tthis._levelsLoaded = new StringMap<Level>();\r\n\t\tthis._blocksLoading = new StringMap<BlockIndex>();\r\n\t\tthis._blocksLoaded = new StringMap<BlockIndex>();\r\n\t\tthis._tilesLoading = new StringMap<TileIndex>();\r\n\t\tthis._tilesLoaded = new StringMap<TileIndex>();\r\n\t\tthis._loadingData = false;\r\n\t\tthis._loadedDataTime = 0.0;\r\n\t\tthis._dataLoadSize = ALong.ZERO;\r\n\t\tthis._lastGarbageCollectTime = 0.0;\r\n\t\t/* Log */\r\n\t\tMessage.print(DataManager.MODULE, \"Pointcloud CRS is \" + this._pointCloudCRS);\r\n\t}\r\n\r\n\t/**\r\n\t * Close the data model.\r\n\t */\r\n\tpublic close(): void {\r\n\t\tif (this._pointCloudReader != null) {\r\n\t\t\tthis._pointCloudReader.close();\r\n\t\t\tthis._pointCloudReader = null;\r\n\t\t}\r\n\t\tthis._fileTileIndex = null;\r\n\t\tthis._dataPool.clear();\r\n\t\tthis._levelsLoading.clear();\r\n\t\tthis._levelsLoaded.clear();\r\n\t\tthis._blocksLoading.clear();\r\n\t\tthis._blocksLoaded.clear();\r\n\t\tthis._tilesLoading.clear();\r\n\t\tthis._tilesLoaded.clear();\r\n\t}\r\n\r\n\t/**\r\n\t * Create a spatial index of a pointcloud.\r\n\t * @return the spatial index.\r\n\t */\r\n\tprivate createSpatialIndex(): ViewTree {\r\n\t\t/* Create the levels */\r\n\t\tMessage.print(DataManager.MODULE, \"Creating pointcloud spatial index\");\r\n\t\tlet levels: Array<Level> = new Array<Level>(this._pointCloudReader.getLevelCount());\r\n\t\tfor (let i: number = 0; i < levels.length; i++) {\r\n\t\t\t/* Get the grids */\r\n\t\t\tlet blockGrid: Grid = this._pointCloudReader.getLevelBlockGrid(i);\r\n\t\t\tlet tileGrid: Grid = this._pointCloudReader.getLevelTileGrid(i);\r\n\t\t\t/* Get the blocks */\r\n\t\t\tlet blockIndexes: Array<BlockIndex> = this._pointCloudReader.peekBlockIndexes(i);\r\n\t\t\tlet blockList: Array<Block> = new Array<Block>(blockIndexes.length);\r\n\t\t\tfor (let j: number = 0; j < blockList.length; j++) blockList[j] = new Block(blockIndexes[j]);\r\n\t\t\t/* Create the level */\r\n\t\t\tlevels[i] = new Level(i, blockGrid, tileGrid, blockList);\r\n\t\t\tMessage.print(DataManager.MODULE, \"Level \" + i + \" has \" + blockList.length + \" blocks\");\r\n\t\t}\r\n\t\t/* Get the data bounds */\r\n\t\tlet dataBounds: Bounds = this._pointCloudReader.getFileBounds();\r\n\t\tMessage.print(DataManager.MODULE, \"The data bounds are \" + dataBounds);\r\n\t\t/* Return a new spatial index */\r\n\t\treturn new ViewTree(this, levels, dataBounds);\r\n\t}\r\n\r\n\t/**\r\n\t * Get the pointcloud reader.\r\n\t * @return the pointcloud reader.\r\n\t */\r\n\tpublic getPointCloudReader(): PointCloudReader {\r\n\t\treturn this._pointCloudReader;\r\n\t}\r\n\r\n\t/**\r\n\t * Get the pointcloud CRS.\r\n\t * @return the pointcloud CRS.\r\n\t */\r\n\tpublic getPointCloudCRS(): string {\r\n\t\treturn this._pointCloudCRS;\r\n\t}\r\n\r\n\t/**\r\n\t * Get the bounds of the data.\r\n\t * @return the bounds of the data.\r\n\t */\r\n\tpublic getPointCloudBounds(): Bounds {\r\n\t\treturn this._pointCloudReader.getFileBounds();\r\n\t}\r\n\r\n\t/**\r\n\t * Get the spatial index.\r\n\t * @return the spatial index.\r\n\t */\r\n\tpublic getViewTree(): ViewTree {\r\n\t\treturn this._fileTileIndex;\r\n\t}\r\n\r\n\t/**\r\n\t * Check if a tile has been loaded to the data pool.\r\n\t * @param tileIndex the index of the tile.\r\n\t * @return the point data if loaded, null otherwise.\r\n\t */\r\n\tpublic isTileLoaded(tileIndex: TileIndex): PointData {\r\n\t\treturn this._dataPool.get(tileIndex.key);\r\n\t}\r\n\r\n\t/**\r\n\t * Is the model loading data?\r\n\t * @return true when loading data.\r\n\t */\r\n\tpublic isLoadingData(): boolean {\r\n\t\treturn this._loadingData;\r\n\t}\r\n\r\n\t/**\r\n\t * Get the size of the loaded data.\r\n\t * @return the size of the loaded data.\r\n\t */\r\n\tpublic getDataLoadSize(): ALong {\r\n\t\treturn this._dataLoadSize;\r\n\t}\r\n\r\n\t/**\r\n\t * Filter the list of blocks and tiles that should be loaded.\r\n\t * @param levelsToLoad the list of levels to load.\r\n\t * @param blocksToLoad the list of blocks to load.\r\n\t * @param tilesToLoad the list of tiles to load.\r\n\t * @param levelList the filtered list of levels to load.\r\n\t * @param blockList the filtered list of blocks to load.\r\n\t * @param tileList the filtered list of tiles to load.\r\n\t */\r\n\tpublic filterLoadList(levelsToLoad: AList<Level>, blocksToLoad: AList<BlockIndex>, tilesToLoad: AList<TileIndex>, levelList: AList<Level>, blockList: AList<BlockIndex>, tileList: AList<TileIndex>): void {\r\n\t\t/* Filter the levels to load */\r\n\t\tfor (let i: number = 0; i < levelsToLoad.size(); i++) {\r\n\t\t\t/* Do not request the same level twice */\r\n\t\t\tlet level: Level = levelsToLoad.get(i);\r\n\t\t\tif (this._levelsLoading.contains(level.getKey())) continue;\r\n\t\t\tif (this._levelsLoaded.contains(level.getKey())) continue;\r\n\t\t\t/* Add the level */\r\n\t\t\tlevelList.add(level);\r\n\t\t}\r\n\t\tlevelsToLoad.clear();\r\n\t\t/* Filter the blocks to load */\r\n\t\tfor (let i: number = 0; i < blocksToLoad.size(); i++) {\r\n\t\t\t/* Do not request the same block twice */\r\n\t\t\tlet blockIndex: BlockIndex = blocksToLoad.get(i);\r\n\t\t\tif (this._blocksLoading.contains(blockIndex.key)) continue;\r\n\t\t\tif (this._blocksLoaded.contains(blockIndex.key)) continue;\r\n\t\t\t/* Add the block */\r\n\t\t\tblockList.add(blockIndex);\r\n\t\t}\r\n\t\tblocksToLoad.clear();\r\n\t\t/* Filter the tiles to load */\r\n\t\tfor (let i: number = 0; i < tilesToLoad.size(); i++) {\r\n\t\t\t/* Do not request the same tile twice */\r\n\t\t\tlet tileIndex: TileIndex = tilesToLoad.get(i);\r\n\t\t\tif (this._tilesLoading.contains(tileIndex.key)) continue;\r\n\t\t\tif (this._tilesLoaded.contains(tileIndex.key)) continue;\r\n\t\t\t/* Add the tile */\r\n\t\t\ttileList.add(tileIndex);\r\n\t\t}\r\n\t\ttilesToLoad.clear();\r\n\t}\r\n\r\n\t/**\r\n\t * Load blocks and tiles.\r\n\t * @param layer the layer requesting the load.\r\n\t * @param levelList the filtered list of levels to load.\r\n\t * @param blockList the filtered list of blocks to load.\r\n\t * @param tileList the filtered list of tiles to load.\r\n\t * @return the data model.\r\n\t */\r\n\tpublic async loadData(frameData: FrameData): Promise<FrameData> {\r\n\t\t/* No data to load? */\r\n\t\tif (frameData.hasMissingData() == false) return frameData;\r\n\t\t/* Do not make overlapping load requests */\r\n\t\tif (this._loadingData) return frameData;\r\n\t\tthis._loadingData = true;\r\n\t\t/* Log */\r\n\t\tlet levelList: AList<Level> = frameData.levelsToLoad;\r\n\t\tlet blockList: AList<BlockIndex> = frameData.blocksToLoad;\r\n\t\tlet tileList: AList<TileIndex> = frameData.tilesToLoad;\r\n\t\t//\t\tMessage.print(MODULE,\"Loading \"+levelList.size()+\" levels, \"+blockList.size()+\" blocks and \"+tileList.size()+\" tiles\");\r\n\t\t//\t\tMessage.print(MODULE,\"Already loaded \"+this._blocksLoaded.size()+\" blocks\");\r\n\t\t//\t\tMessage.print(MODULE,\"Already loading \"+this._blocksLoading.size()+\" blocks\");\r\n\t\t//\t\tMessage.print(MODULE,\"Already loaded \"+this._tilesLoaded.size()+\" tiles\");\r\n\t\t//\t\tMessage.print(MODULE,\"Already loading \"+this._tilesLoading.size()+\" tiles\");\r\n\t\t/* Define the content we are going to need */\r\n\t\tlet loadTime: float64 = ASystem.time();\r\n\t\tlet fileContents: ContentLoader = new ContentLoader(this._pointCloudReader.getFileStorage(), this._pointCloudReader.getFileName());\r\n\t\t/* Prepare the loading of the levels */\r\n\t\tfor (let i: number = 0; i < levelList.size(); i++) {\r\n\t\t\t/* Prepare to load the block */\r\n\t\t\tlet level: Level = levelList.get(i);\r\n\t\t\tthis._levelsLoading.set(level.getKey(), level);\r\n\t\t\tthis._pointCloudReader.readBlockIndexes(level.getIndex(), fileContents);\r\n\t\t\tMessage.print(DataManager.MODULE, \"Loading level \" + level.getIndex());\r\n\t\t}\r\n\t\t/* Prepare the loading of the blocks */\r\n\t\tfor (let i: number = 0; i < blockList.size(); i++) {\r\n\t\t\t/* Prepare to load the block */\r\n\t\t\tlet blockIndex: BlockIndex = blockList.get(i);\r\n\t\t\tthis._blocksLoading.set(blockIndex.key, blockIndex);\r\n\t\t\tthis._pointCloudReader.readTileIndexes(blockIndex, fileContents);\r\n\t\t}\r\n\t\t/* Prepare the loading of the tiles */\r\n\t\tlet loadTileCount: int32 = 0;\r\n\t\tfor (let i: number = 0; i < tileList.size(); i++) {\r\n\t\t\t/* Prepare to load the tile */\r\n\t\t\tlet tileIndex: TileIndex = tileList.get(i);\r\n\t\t\tthis._tilesLoading.set(tileIndex.key, tileIndex);\r\n\t\t\tthis._pointCloudReader.readPointData(tileIndex, this._dataFormat, loadTime, fileContents);\r\n\t\t\tloadTileCount++;\r\n\t\t\t/* Do not load too many tiles at once */\r\n\t\t\tif (fileContents.getTotalRequestSize() > DataManager.MAX_FILE_CONTENT_SIZE) {\r\n\t\t\t\t/* Stop loading tiles */\r\n\t\t\t\tMessage.print(DataManager.MODULE, \"Limited pointcloud content load request to \" + fileContents.getTotalRequestSize() + \" bytes\");\r\n\t\t\t\tbreak;\r\n\t\t\t}\r\n\t\t}\r\n\t\t/* Log */\r\n\t\tMessage.print(DataManager.MODULE, \"Loading of \" + blockList.size() + \" blocks, \" + loadTileCount + \"/\" + tileList.size() + \" tiles, \" + fileContents.getTotalRequestSize() + \" bytes\");\r\n\t\t/* Load the data */\r\n\t\tthis._dataLoadSize = this._dataLoadSize.addInt(fileContents.getTotalRequestSize());\r\n\t\tfileContents = await fileContents.load();\r\n\t\t//Message.print(MODULE,\"Creating \"+blockList.size()+\" blocks and \"+tileList.size()+\" tiles\");\r\n\t\t/* Load the levels */\r\n\t\tfor (let i: number = 0; i < levelList.size(); i++) {\r\n\t\t\t/* Load the block list */\r\n\t\t\tlet level: Level = levelList.get(i);\r\n\t\t\tthis._levelsLoaded.set(level.getKey(), level);\r\n\t\t\tthis._levelsLoading.remove(level.getKey());\r\n\t\t\tlet blockIndexes: Array<BlockIndex> = this._pointCloudReader.readBlockIndexes(level.getIndex(), fileContents);\r\n\t\t\t/* Add the blocks */\r\n\t\t\tthis._fileTileIndex.setLevelBlocks(level, blockIndexes);\r\n\t\t}\r\n\t\t/* Load the blocks */\r\n\t\tfor (let i: number = 0; i < blockList.size(); i++) {\r\n\t\t\t/* Load the block */\r\n\t\t\tlet blockIndex: BlockIndex = blockList.get(i);\r\n\t\t\tthis._blocksLoaded.set(blockIndex.key, blockIndex);\r\n\t\t\tthis._blocksLoading.remove(blockIndex.key);\r\n\t\t\tlet tileIndexes: Array<TileIndex> = this._pointCloudReader.readTileIndexes(blockIndex, fileContents);\r\n\t\t\t/* Add the block */\r\n\t\t\tthis._fileTileIndex.setBlockTiles(blockIndex, tileIndexes);\r\n\t\t}\r\n\t\t/* Load the tiles */\r\n\t\tlet newTiles: AList<TileIndex> = new AList<TileIndex>();\r\n\t\tfor (let i: number = 0; i < loadTileCount; i++) {\r\n\t\t\t/* Get the next tile */\r\n\t\t\tlet tileIndex: TileIndex = tileList.get(i);\r\n\t\t\tnewTiles.add(tileIndex);\r\n\t\t\t/* Load the tile */\r\n\t\t\tthis._tilesLoaded.set(tileIndex.key, tileIndex);\r\n\t\t\tthis._tilesLoading.remove(tileIndex.key);\r\n\t\t\tlet pointData: PointData = this._pointCloudReader.readPointData(tileIndex, this._dataFormat, loadTime, fileContents);\r\n\t\t\t/* Add the tile */\r\n\t\t\tthis._dataPool.set(tileIndex.key, pointData);\r\n\t\t}\r\n\t\t/* We stopped loading */\r\n\t\tthis._loadingData = false;\r\n\t\tthis._loadedDataTime = ASystem.time();\r\n\t\t/* Log */\r\n\t\tMessage.print(DataManager.MODULE, \"Created \" + blockList.size() + \" blocks and \" + loadTileCount + \" tiles\");\r\n\t\t/* Return the frame data */\r\n\t\treturn frameData;\r\n\t}\r\n\r\n\t/**\r\n\t * Do a garbage collect (this method can be called often, it throttles itself to once per minute).\r\n\t * @param time the current time.\r\n\t */\r\n\tpublic doGarbageCollect(time: float64): void {\r\n\t\t/* First call? */\r\n\t\tif (this._lastGarbageCollectTime == 0.0) this._lastGarbageCollectTime = time;\r\n\t\t/* Throttle to one per minute */\r\n\t\tif (time < this._lastGarbageCollectTime + 60.0) return;\r\n\t\tthis._lastGarbageCollectTime = time;\r\n\t\t/* Define the expire time */\r\n\t\tlet expireTime: float64 = (time - DataManager.POINT_DATA_EXIRE_TIME);\r\n\t\t/* Check all loaded tiles */\r\n\t\tlet dropCount: int32 = 0;\r\n\t\tlet dataKeys: AList<string> = this._dataPool.keys();\r\n\t\tfor (let i: number = 0; i < dataKeys.size(); i++) {\r\n\t\t\t/* Get the next tile */\r\n\t\t\tlet tileKey: string = dataKeys.get(i);\r\n\t\t\tlet pointData: PointData = this._dataPool.get(tileKey);\r\n\t\t\t/* Expired? */\r\n\t\t\tif (pointData.tileIndex.accessTime < expireTime) {\r\n\t\t\t\tthis._dataPool.remove(tileKey);\r\n\t\t\t\tthis._tilesLoaded.remove(tileKey);\r\n\t\t\t\tdropCount++;\r\n\t\t\t}\r\n\t\t}\r\n\t\t/* Log? */\r\n\t\tif (dropCount > 0) Message.print(DataManager.MODULE, \"Dropped the point data of \" + dropCount + \" tiles\");\r\n\t}\r\n}\r\n"]}
1
+ {"version":3,"file":"DataManager.js","sourceRoot":"","sources":["../../../../src/pointcloud/render/DataManager.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAYH,OAAO,EAAE,KAAK,EAAE,MAAM,+BAA+B,CAAC;AACtD,OAAO,EAAE,SAAS,EAAE,MAAM,mCAAmC,CAAC;AAC9D,OAAO,EAAE,KAAK,EAAE,MAAM,4BAA4B,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,8BAA8B,CAAC;AACvD,OAAO,EAAE,OAAO,EAAE,MAAM,8BAA8B,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,oCAAoC,CAAC;AAMnE,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAEhC,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAChC,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEtC;;;;GAIG;AACH,gBAAgB;AAChB,MAAM,OAAO,WAAW;IACvB,8BAA8B;IACtB,MAAM,CAAU,MAAM,GAAW,aAAa,CAAC;IAEvD,wDAAwD;IAChD,MAAM,CAAU,qBAAqB,GAAU,GAAG,GAAG,IAAI,CAAC;IAClE,4DAA4D;IACpD,MAAM,CAAU,qBAAqB,GAAY,CAAC,GAAG,IAAI,CAAC;IAElE,mCAAmC;IAC3B,iBAAiB,CAAmB;IAC5C,iCAAiC;IACzB,cAAc,CAAS;IAC/B,8BAA8B;IACtB,WAAW,CAAQ;IAE3B,wBAAwB;IAChB,cAAc,CAAW;IACjC,oBAAoB;IACZ,SAAS,CAAuB;IACxC,6CAA6C;IACrC,cAAc,CAAmB;IACzC,4CAA4C;IACpC,aAAa,CAAmB;IACxC,2CAA2C;IACnC,cAAc,CAAwB;IAC9C,0CAA0C;IAClC,aAAa,CAAwB;IAC7C,0CAA0C;IAClC,aAAa,CAAuB;IAC5C,yCAAyC;IACjC,YAAY,CAAuB;IAC3C,gCAAgC;IACxB,YAAY,CAAU;IAC9B,6CAA6C;IACrC,eAAe,CAAU;IACjC,kDAAkD;IAC1C,aAAa,CAAQ;IAE7B,uCAAuC;IAC/B,uBAAuB,CAAU;IAEzC;;;;;OAKG;IACH,YAAmB,gBAAkC,EAAE,aAAqB,EAAE,UAAiB;QAC9F,0BAA0B;QAC1B,IAAI,CAAC,iBAAiB,GAAG,gBAAgB,CAAC;QAC1C,IAAI,CAAC,cAAc,GAAG,aAAa,CAAC;QACpC,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC;QAC9B,gBAAgB;QAChB,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI;YAAE,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,iBAAiB,CAAC,UAAU,EAAE,CAAC;QAC3F,WAAW;QACX,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAChD,IAAI,CAAC,SAAS,GAAG,IAAI,SAAS,EAAa,CAAC;QAC5C,IAAI,CAAC,cAAc,GAAG,IAAI,SAAS,EAAS,CAAC;QAC7C,IAAI,CAAC,aAAa,GAAG,IAAI,SAAS,EAAS,CAAC;QAC5C,IAAI,CAAC,cAAc,GAAG,IAAI,SAAS,EAAc,CAAC;QAClD,IAAI,CAAC,aAAa,GAAG,IAAI,SAAS,EAAc,CAAC;QACjD,IAAI,CAAC,aAAa,GAAG,IAAI,SAAS,EAAa,CAAC;QAChD,IAAI,CAAC,YAAY,GAAG,IAAI,SAAS,EAAa,CAAC;QAC/C,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,eAAe,GAAG,GAAG,CAAC;QAC3B,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,IAAI,CAAC;QAChC,IAAI,CAAC,uBAAuB,GAAG,GAAG,CAAC;QACnC,SAAS;QACT,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,EAAE,oBAAoB,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC;IAC/E,CAAC;IAED;;OAEG;IACI,KAAK;QACX,IAAI,IAAI,CAAC,iBAAiB,IAAI,IAAI,EAAE,CAAC;YACpC,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,CAAC;YAC/B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC/B,CAAC;QACD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;QACvB,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;QAC5B,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QAC3B,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;QAC5B,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QAC3B,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QAC3B,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;IAC3B,CAAC;IAED;;;OAGG;IACK,kBAAkB;QACzB,uBAAuB;QACvB,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,EAAE,mCAAmC,CAAC,CAAC;QACvE,IAAI,MAAM,GAAiB,IAAI,KAAK,CAAQ,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC,CAAC;QACpF,KAAK,IAAI,CAAC,GAAW,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAChD,mBAAmB;YACnB,IAAI,SAAS,GAAS,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;YAClE,IAAI,QAAQ,GAAS,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;YAChE,oBAAoB;YACpB,IAAI,YAAY,GAAsB,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;YACjF,IAAI,SAAS,GAAiB,IAAI,KAAK,CAAQ,YAAY,CAAC,MAAM,CAAC,CAAC;YACpE,KAAK,IAAI,CAAC,GAAW,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE;gBAAE,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;YAC7F,sBAAsB;YACtB,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,KAAK,CAAC,CAAC,EAAE,SAAS,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;YACzD,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,EAAE,QAAQ,GAAG,CAAC,GAAG,OAAO,GAAG,SAAS,CAAC,MAAM,GAAG,SAAS,CAAC,CAAC;QAC1F,CAAC;QACD,yBAAyB;QACzB,IAAI,UAAU,GAAW,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;QAChE,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,EAAE,sBAAsB,GAAG,UAAU,CAAC,CAAC;QACvE,gCAAgC;QAChC,OAAO,IAAI,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;IAC/C,CAAC;IAED;;;OAGG;IACI,mBAAmB;QACzB,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAC/B,CAAC;IAED;;;OAGG;IACI,gBAAgB;QACtB,OAAO,IAAI,CAAC,cAAc,CAAC;IAC5B,CAAC;IAED;;;OAGG;IACI,mBAAmB;QACzB,OAAO,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;IAC/C,CAAC;IAED;;;OAGG;IACI,WAAW;QACjB,OAAO,IAAI,CAAC,cAAc,CAAC;IAC5B,CAAC;IAED;;;;OAIG;IACI,YAAY,CAAC,SAAoB;QACvC,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;IAC1C,CAAC;IAED;;;OAGG;IACI,aAAa;QACnB,OAAO,IAAI,CAAC,YAAY,CAAC;IAC1B,CAAC;IAED;;;OAGG;IACI,eAAe;QACrB,OAAO,IAAI,CAAC,aAAa,CAAC;IAC3B,CAAC;IAED;;;;;;;;OAQG;IACI,cAAc,CAAC,YAA0B,EAAE,YAA+B,EAAE,WAA6B,EAAE,SAAuB,EAAE,SAA4B,EAAE,QAA0B;QAClM,+BAA+B;QAC/B,KAAK,IAAI,CAAC,GAAW,CAAC,EAAE,CAAC,GAAG,YAAY,CAAC,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;YACtD,yCAAyC;YACzC,IAAI,KAAK,GAAU,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACvC,IAAI,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;gBAAE,SAAS;YAC3D,IAAI,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;gBAAE,SAAS;YAC1D,mBAAmB;YACnB,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACtB,CAAC;QACD,YAAY,CAAC,KAAK,EAAE,CAAC;QACrB,+BAA+B;QAC/B,KAAK,IAAI,CAAC,GAAW,CAAC,EAAE,CAAC,GAAG,YAAY,CAAC,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;YACtD,yCAAyC;YACzC,IAAI,UAAU,GAAe,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACjD,IAAI,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC;gBAAE,SAAS;YAC3D,IAAI,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC;gBAAE,SAAS;YAC1D,mBAAmB;YACnB,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QAC3B,CAAC;QACD,YAAY,CAAC,KAAK,EAAE,CAAC;QACrB,8BAA8B;QAC9B,KAAK,IAAI,CAAC,GAAW,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;YACrD,wCAAwC;YACxC,IAAI,SAAS,GAAc,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAC9C,IAAI,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC;gBAAE,SAAS;YACzD,IAAI,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC;gBAAE,SAAS;YACxD,kBAAkB;YAClB,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACzB,CAAC;QACD,WAAW,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;IAED;;;;;;;OAOG;IACI,KAAK,CAAC,QAAQ,CAAC,SAAoB;QACzC,sBAAsB;QACtB,IAAI,SAAS,CAAC,cAAc,EAAE,IAAI,KAAK;YAAE,OAAO,SAAS,CAAC;QAC1D,2CAA2C;QAC3C,IAAI,IAAI,CAAC,YAAY;YAAE,OAAO,SAAS,CAAC;QACxC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,SAAS;QACT,IAAI,SAAS,GAAiB,SAAS,CAAC,YAAY,CAAC;QACrD,IAAI,SAAS,GAAsB,SAAS,CAAC,YAAY,CAAC;QAC1D,IAAI,QAAQ,GAAqB,SAAS,CAAC,WAAW,CAAC;QACvD,2HAA2H;QAC3H,gFAAgF;QAChF,kFAAkF;QAClF,8EAA8E;QAC9E,gFAAgF;QAChF,6CAA6C;QAC7C,IAAI,QAAQ,GAAY,OAAO,CAAC,IAAI,EAAE,CAAC;QACvC,IAAI,YAAY,GAAkB,IAAI,aAAa,CAAC,IAAI,CAAC,iBAAiB,CAAC,cAAc,EAAE,EAAE,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAC,CAAC;QACnI,uCAAuC;QACvC,KAAK,IAAI,CAAC,GAAW,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;YACnD,+BAA+B;YAC/B,IAAI,KAAK,GAAU,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACpC,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,EAAE,EAAE,KAAK,CAAC,CAAC;YAC/C,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,KAAK,CAAC,QAAQ,EAAE,EAAE,YAAY,CAAC,CAAC;YACxE,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,EAAE,gBAAgB,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC;QACxE,CAAC;QACD,uCAAuC;QACvC,KAAK,IAAI,CAAC,GAAW,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;YACnD,+BAA+B;YAC/B,IAAI,UAAU,GAAe,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAC9C,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,UAAU,CAAC,GAAG,EAAE,UAAU,CAAC,CAAC;YACpD,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;QAClE,CAAC;QACD,sCAAsC;QACtC,IAAI,aAAa,GAAU,CAAC,CAAC;QAC7B,KAAK,IAAI,CAAC,GAAW,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;YAClD,8BAA8B;YAC9B,IAAI,SAAS,GAAc,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAC3C,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,SAAS,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;YACjD,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,SAAS,EAAE,IAAI,CAAC,WAAW,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAC;YAC1F,aAAa,EAAE,CAAC;YAChB,wCAAwC;YACxC,IAAI,YAAY,CAAC,mBAAmB,EAAE,GAAG,WAAW,CAAC,qBAAqB,EAAE,CAAC;gBAC5E,wBAAwB;gBACxB,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,EAAE,6CAA6C,GAAG,YAAY,CAAC,mBAAmB,EAAE,GAAG,QAAQ,CAAC,CAAC;gBACjI,MAAM;YACP,CAAC;QACF,CAAC;QACD,SAAS;QACT,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,EAAE,aAAa,GAAG,SAAS,CAAC,IAAI,EAAE,GAAG,WAAW,GAAG,aAAa,GAAG,GAAG,GAAG,QAAQ,CAAC,IAAI,EAAE,GAAG,UAAU,GAAG,YAAY,CAAC,mBAAmB,EAAE,GAAG,QAAQ,CAAC,CAAC;QACvL,mBAAmB;QACnB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,YAAY,CAAC,mBAAmB,EAAE,CAAC,CAAC;QACnF,YAAY,GAAG,MAAM,YAAY,CAAC,IAAI,EAAE,CAAC;QACzC,6FAA6F;QAC7F,qBAAqB;QACrB,KAAK,IAAI,CAAC,GAAW,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;YACnD,yBAAyB;YACzB,IAAI,KAAK,GAAU,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACpC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,EAAE,EAAE,KAAK,CAAC,CAAC;YAC9C,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC;YAC3C,IAAI,YAAY,GAAsB,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,KAAK,CAAC,QAAQ,EAAE,EAAE,YAAY,CAAC,CAAC;YAC9G,oBAAoB;YACpB,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC;QACzD,CAAC;QACD,qBAAqB;QACrB,KAAK,IAAI,CAAC,GAAW,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;YACnD,oBAAoB;YACpB,IAAI,UAAU,GAAe,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAC9C,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,UAAU,CAAC,GAAG,EAAE,UAAU,CAAC,CAAC;YACnD,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;YAC3C,IAAI,WAAW,GAAqB,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;YACrG,mBAAmB;YACnB,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC;QAC5D,CAAC;QACD,oBAAoB;QACpB,IAAI,QAAQ,GAAqB,IAAI,KAAK,EAAa,CAAC;QACxD,KAAK,IAAI,CAAC,GAAW,CAAC,EAAE,CAAC,GAAG,aAAa,EAAE,CAAC,EAAE,EAAE,CAAC;YAChD,uBAAuB;YACvB,IAAI,SAAS,GAAc,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAC3C,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;YACxB,mBAAmB;YACnB,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,SAAS,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;YAChD,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;YACzC,IAAI,SAAS,GAAc,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,SAAS,EAAE,IAAI,CAAC,WAAW,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAC;YACrH,kBAAkB;YAClB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;QAC9C,CAAC;QACD,wBAAwB;QACxB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,eAAe,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;QACtC,SAAS;QACT,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,EAAE,UAAU,GAAG,SAAS,CAAC,IAAI,EAAE,GAAG,cAAc,GAAG,aAAa,GAAG,QAAQ,CAAC,CAAC;QAC7G,2BAA2B;QAC3B,OAAO,SAAS,CAAC;IAClB,CAAC;IAED;;;OAGG;IACI,gBAAgB,CAAC,IAAa;QACpC,iBAAiB;QACjB,IAAI,IAAI,CAAC,uBAAuB,IAAI,GAAG;YAAE,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC;QAC7E,gCAAgC;QAChC,IAAI,IAAI,GAAG,IAAI,CAAC,uBAAuB,GAAG,IAAI;YAAE,OAAO;QACvD,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC;QACpC,4BAA4B;QAC5B,IAAI,UAAU,GAAY,CAAC,IAAI,GAAG,WAAW,CAAC,qBAAqB,CAAC,CAAC;QACrE,4BAA4B;QAC5B,IAAI,SAAS,GAAU,CAAC,CAAC;QACzB,IAAI,QAAQ,GAAkB,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACpD,KAAK,IAAI,CAAC,GAAW,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,IAAI,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;YAClD,uBAAuB;YACvB,IAAI,OAAO,GAAW,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACtC,IAAI,SAAS,GAAc,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;YACvD,cAAc;YACd,IAAI,SAAS,CAAC,SAAS,CAAC,UAAU,GAAG,UAAU,EAAE,CAAC;gBACjD,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;gBAC/B,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;gBAClC,SAAS,EAAE,CAAC;YACb,CAAC;QACF,CAAC;QACD,UAAU;QACV,IAAI,SAAS,GAAG,CAAC;YAAE,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,MAAM,EAAE,4BAA4B,GAAG,SAAS,GAAG,QAAQ,CAAC,CAAC;IAC3G,CAAC","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module OrbitGT\r\n */\r\n\r\n//package orbitgt.pointcloud.render;\r\n\r\ntype int8 = number;\r\ntype int16 = number;\r\ntype int32 = number;\r\ntype float32 = number;\r\ntype float64 = number;\r\n\r\nimport { Bounds } from \"../../spatial/geom/Bounds\";\r\nimport { Transform } from \"../../spatial/geom/Transform\";\r\nimport { AList } from \"../../system/collection/AList\";\r\nimport { StringMap } from \"../../system/collection/StringMap\";\r\nimport { ALong } from \"../../system/runtime/ALong\";\r\nimport { ASystem } from \"../../system/runtime/ASystem\";\r\nimport { Message } from \"../../system/runtime/Message\";\r\nimport { ContentLoader } from \"../../system/storage/ContentLoader\";\r\nimport { BlockIndex } from \"../model/BlockIndex\";\r\nimport { Grid } from \"../model/Grid\";\r\nimport { PointCloudReader } from \"../model/PointCloudReader\";\r\nimport { PointData } from \"../model/PointData\";\r\nimport { TileIndex } from \"../model/TileIndex\";\r\nimport { Block } from \"./Block\";\r\nimport { FrameData } from \"./FrameData\";\r\nimport { Level } from \"./Level\";\r\nimport { ViewTree } from \"./ViewTree\";\r\n\r\n/**\r\n * Class DataManager manages the (shared) data model part of the rendering in multiple layers (see the CLOUD-461 issue).\r\n *\r\n * @version 1.0 December 2017\r\n */\r\n/** @internal */\r\nexport class DataManager {\r\n\t/** The name of this module */\r\n\tprivate static readonly MODULE: string = \"DataManager\";\r\n\r\n\t/** The maximum size of a single file-content request */\r\n\tprivate static readonly MAX_FILE_CONTENT_SIZE: int32 = 128 * 1024;\r\n\t/** The expire time to unload unused point data (seconds) */\r\n\tprivate static readonly POINT_DATA_EXIRE_TIME: float64 = 5 * 60.0;\r\n\r\n\t/** The reader of the pointcloud */\r\n\tprivate _pointCloudReader: PointCloudReader;\r\n\t/*** The CRS of the pointcloud */\r\n\tprivate _pointCloudCRS: string;\r\n\t/** The data format to read */\r\n\tprivate _dataFormat: int32;\r\n\r\n\t/** The spatial index */\r\n\tprivate _fileTileIndex: ViewTree;\r\n\t/** The data pool */\r\n\tprivate _dataPool: StringMap<PointData>;\r\n\t/** The set of levels we requested (index) */\r\n\tprivate _levelsLoading: StringMap<Level>;\r\n\t/** The set of levels we received (index) */\r\n\tprivate _levelsLoaded: StringMap<Level>;\r\n\t/** The set of blocks we requested (key) */\r\n\tprivate _blocksLoading: StringMap<BlockIndex>;\r\n\t/** The set of blocks we received (key) */\r\n\tprivate _blocksLoaded: StringMap<BlockIndex>;\r\n\t/** The set of tiles we requested (key) */\r\n\tprivate _tilesLoading: StringMap<TileIndex>;\r\n\t/** The set of tiles we received (key) */\r\n\tprivate _tilesLoaded: StringMap<TileIndex>;\r\n\t/** Is new data being loaded? */\r\n\tprivate _loadingData: boolean;\r\n\t/** The time when the data loading stopped */\r\n\tprivate _loadedDataTime: float64;\r\n\t/** The total size of data that has been loaded */\r\n\tprivate _dataLoadSize: ALong;\r\n\r\n\t/** The last garbage collection time */\r\n\tprivate _lastGarbageCollectTime: float64;\r\n\r\n\t/**\r\n\t * Create a new data model (to be shared between different views).\r\n\t * @param pointCloudReader the reader of the pointcloud file.\r\n\t * @param pointCloudCRS the CRS of the point cloud.\r\n\t * @param dataFormat the requested data format to load point data (PointDataRaw.TYPE for example).\r\n\t */\r\n\tpublic constructor(pointCloudReader: PointCloudReader, pointCloudCRS: string, dataFormat: int32) {\r\n\t\t/* Store the parameters */\r\n\t\tthis._pointCloudReader = pointCloudReader;\r\n\t\tthis._pointCloudCRS = pointCloudCRS;\r\n\t\tthis._dataFormat = dataFormat;\r\n\t\t/* Initialize */\r\n\t\tif (this._pointCloudCRS == null) this._pointCloudCRS = this._pointCloudReader.getFileCRS();\r\n\t\t/* Clear */\r\n\t\tthis._fileTileIndex = this.createSpatialIndex();\r\n\t\tthis._dataPool = new StringMap<PointData>();\r\n\t\tthis._levelsLoading = new StringMap<Level>();\r\n\t\tthis._levelsLoaded = new StringMap<Level>();\r\n\t\tthis._blocksLoading = new StringMap<BlockIndex>();\r\n\t\tthis._blocksLoaded = new StringMap<BlockIndex>();\r\n\t\tthis._tilesLoading = new StringMap<TileIndex>();\r\n\t\tthis._tilesLoaded = new StringMap<TileIndex>();\r\n\t\tthis._loadingData = false;\r\n\t\tthis._loadedDataTime = 0.0;\r\n\t\tthis._dataLoadSize = ALong.ZERO;\r\n\t\tthis._lastGarbageCollectTime = 0.0;\r\n\t\t/* Log */\r\n\t\tMessage.print(DataManager.MODULE, \"Pointcloud CRS is \" + this._pointCloudCRS);\r\n\t}\r\n\r\n\t/**\r\n\t * Close the data model.\r\n\t */\r\n\tpublic close(): void {\r\n\t\tif (this._pointCloudReader != null) {\r\n\t\t\tthis._pointCloudReader.close();\r\n\t\t\tthis._pointCloudReader = null;\r\n\t\t}\r\n\t\tthis._fileTileIndex = null;\r\n\t\tthis._dataPool.clear();\r\n\t\tthis._levelsLoading.clear();\r\n\t\tthis._levelsLoaded.clear();\r\n\t\tthis._blocksLoading.clear();\r\n\t\tthis._blocksLoaded.clear();\r\n\t\tthis._tilesLoading.clear();\r\n\t\tthis._tilesLoaded.clear();\r\n\t}\r\n\r\n\t/**\r\n\t * Create a spatial index of a pointcloud.\r\n\t * @return the spatial index.\r\n\t */\r\n\tprivate createSpatialIndex(): ViewTree {\r\n\t\t/* Create the levels */\r\n\t\tMessage.print(DataManager.MODULE, \"Creating pointcloud spatial index\");\r\n\t\tlet levels: Array<Level> = new Array<Level>(this._pointCloudReader.getLevelCount());\r\n\t\tfor (let i: number = 0; i < levels.length; i++) {\r\n\t\t\t/* Get the grids */\r\n\t\t\tlet blockGrid: Grid = this._pointCloudReader.getLevelBlockGrid(i);\r\n\t\t\tlet tileGrid: Grid = this._pointCloudReader.getLevelTileGrid(i);\r\n\t\t\t/* Get the blocks */\r\n\t\t\tlet blockIndexes: Array<BlockIndex> = this._pointCloudReader.peekBlockIndexes(i);\r\n\t\t\tlet blockList: Array<Block> = new Array<Block>(blockIndexes.length);\r\n\t\t\tfor (let j: number = 0; j < blockList.length; j++) blockList[j] = new Block(blockIndexes[j]);\r\n\t\t\t/* Create the level */\r\n\t\t\tlevels[i] = new Level(i, blockGrid, tileGrid, blockList);\r\n\t\t\tMessage.print(DataManager.MODULE, \"Level \" + i + \" has \" + blockList.length + \" blocks\");\r\n\t\t}\r\n\t\t/* Get the data bounds */\r\n\t\tlet dataBounds: Bounds = this._pointCloudReader.getFileBounds();\r\n\t\tMessage.print(DataManager.MODULE, \"The data bounds are \" + dataBounds);\r\n\t\t/* Return a new spatial index */\r\n\t\treturn new ViewTree(this, levels, dataBounds);\r\n\t}\r\n\r\n\t/**\r\n\t * Get the pointcloud reader.\r\n\t * @return the pointcloud reader.\r\n\t */\r\n\tpublic getPointCloudReader(): PointCloudReader {\r\n\t\treturn this._pointCloudReader;\r\n\t}\r\n\r\n\t/**\r\n\t * Get the pointcloud CRS.\r\n\t * @return the pointcloud CRS.\r\n\t */\r\n\tpublic getPointCloudCRS(): string {\r\n\t\treturn this._pointCloudCRS;\r\n\t}\r\n\r\n\t/**\r\n\t * Get the bounds of the data.\r\n\t * @return the bounds of the data.\r\n\t */\r\n\tpublic getPointCloudBounds(): Bounds {\r\n\t\treturn this._pointCloudReader.getFileBounds();\r\n\t}\r\n\r\n\t/**\r\n\t * Get the spatial index.\r\n\t * @return the spatial index.\r\n\t */\r\n\tpublic getViewTree(): ViewTree {\r\n\t\treturn this._fileTileIndex;\r\n\t}\r\n\r\n\t/**\r\n\t * Check if a tile has been loaded to the data pool.\r\n\t * @param tileIndex the index of the tile.\r\n\t * @return the point data if loaded, null otherwise.\r\n\t */\r\n\tpublic isTileLoaded(tileIndex: TileIndex): PointData {\r\n\t\treturn this._dataPool.get(tileIndex.key);\r\n\t}\r\n\r\n\t/**\r\n\t * Is the model loading data?\r\n\t * @return true when loading data.\r\n\t */\r\n\tpublic isLoadingData(): boolean {\r\n\t\treturn this._loadingData;\r\n\t}\r\n\r\n\t/**\r\n\t * Get the size of the loaded data.\r\n\t * @return the size of the loaded data.\r\n\t */\r\n\tpublic getDataLoadSize(): ALong {\r\n\t\treturn this._dataLoadSize;\r\n\t}\r\n\r\n\t/**\r\n\t * Filter the list of blocks and tiles that should be loaded.\r\n\t * @param levelsToLoad the list of levels to load.\r\n\t * @param blocksToLoad the list of blocks to load.\r\n\t * @param tilesToLoad the list of tiles to load.\r\n\t * @param levelList the filtered list of levels to load.\r\n\t * @param blockList the filtered list of blocks to load.\r\n\t * @param tileList the filtered list of tiles to load.\r\n\t */\r\n\tpublic filterLoadList(levelsToLoad: AList<Level>, blocksToLoad: AList<BlockIndex>, tilesToLoad: AList<TileIndex>, levelList: AList<Level>, blockList: AList<BlockIndex>, tileList: AList<TileIndex>): void {\r\n\t\t/* Filter the levels to load */\r\n\t\tfor (let i: number = 0; i < levelsToLoad.size(); i++) {\r\n\t\t\t/* Do not request the same level twice */\r\n\t\t\tlet level: Level = levelsToLoad.get(i);\r\n\t\t\tif (this._levelsLoading.contains(level.getKey())) continue;\r\n\t\t\tif (this._levelsLoaded.contains(level.getKey())) continue;\r\n\t\t\t/* Add the level */\r\n\t\t\tlevelList.add(level);\r\n\t\t}\r\n\t\tlevelsToLoad.clear();\r\n\t\t/* Filter the blocks to load */\r\n\t\tfor (let i: number = 0; i < blocksToLoad.size(); i++) {\r\n\t\t\t/* Do not request the same block twice */\r\n\t\t\tlet blockIndex: BlockIndex = blocksToLoad.get(i);\r\n\t\t\tif (this._blocksLoading.contains(blockIndex.key)) continue;\r\n\t\t\tif (this._blocksLoaded.contains(blockIndex.key)) continue;\r\n\t\t\t/* Add the block */\r\n\t\t\tblockList.add(blockIndex);\r\n\t\t}\r\n\t\tblocksToLoad.clear();\r\n\t\t/* Filter the tiles to load */\r\n\t\tfor (let i: number = 0; i < tilesToLoad.size(); i++) {\r\n\t\t\t/* Do not request the same tile twice */\r\n\t\t\tlet tileIndex: TileIndex = tilesToLoad.get(i);\r\n\t\t\tif (this._tilesLoading.contains(tileIndex.key)) continue;\r\n\t\t\tif (this._tilesLoaded.contains(tileIndex.key)) continue;\r\n\t\t\t/* Add the tile */\r\n\t\t\ttileList.add(tileIndex);\r\n\t\t}\r\n\t\ttilesToLoad.clear();\r\n\t}\r\n\r\n\t/**\r\n\t * Load blocks and tiles.\r\n\t * @param layer the layer requesting the load.\r\n\t * @param levelList the filtered list of levels to load.\r\n\t * @param blockList the filtered list of blocks to load.\r\n\t * @param tileList the filtered list of tiles to load.\r\n\t * @return the data model.\r\n\t */\r\n\tpublic async loadData(frameData: FrameData): Promise<FrameData> {\r\n\t\t/* No data to load? */\r\n\t\tif (frameData.hasMissingData() == false) return frameData;\r\n\t\t/* Do not make overlapping load requests */\r\n\t\tif (this._loadingData) return frameData;\r\n\t\tthis._loadingData = true;\r\n\t\t/* Log */\r\n\t\tlet levelList: AList<Level> = frameData.levelsToLoad;\r\n\t\tlet blockList: AList<BlockIndex> = frameData.blocksToLoad;\r\n\t\tlet tileList: AList<TileIndex> = frameData.tilesToLoad;\r\n\t\t//\t\tMessage.print(MODULE,\"Loading \"+levelList.size()+\" levels, \"+blockList.size()+\" blocks and \"+tileList.size()+\" tiles\");\r\n\t\t//\t\tMessage.print(MODULE,\"Already loaded \"+this._blocksLoaded.size()+\" blocks\");\r\n\t\t//\t\tMessage.print(MODULE,\"Already loading \"+this._blocksLoading.size()+\" blocks\");\r\n\t\t//\t\tMessage.print(MODULE,\"Already loaded \"+this._tilesLoaded.size()+\" tiles\");\r\n\t\t//\t\tMessage.print(MODULE,\"Already loading \"+this._tilesLoading.size()+\" tiles\");\r\n\t\t/* Define the content we are going to need */\r\n\t\tlet loadTime: float64 = ASystem.time();\r\n\t\tlet fileContents: ContentLoader = new ContentLoader(this._pointCloudReader.getFileStorage(), this._pointCloudReader.getFileName());\r\n\t\t/* Prepare the loading of the levels */\r\n\t\tfor (let i: number = 0; i < levelList.size(); i++) {\r\n\t\t\t/* Prepare to load the block */\r\n\t\t\tlet level: Level = levelList.get(i);\r\n\t\t\tthis._levelsLoading.set(level.getKey(), level);\r\n\t\t\tthis._pointCloudReader.readBlockIndexes(level.getIndex(), fileContents);\r\n\t\t\tMessage.print(DataManager.MODULE, \"Loading level \" + level.getIndex());\r\n\t\t}\r\n\t\t/* Prepare the loading of the blocks */\r\n\t\tfor (let i: number = 0; i < blockList.size(); i++) {\r\n\t\t\t/* Prepare to load the block */\r\n\t\t\tlet blockIndex: BlockIndex = blockList.get(i);\r\n\t\t\tthis._blocksLoading.set(blockIndex.key, blockIndex);\r\n\t\t\tthis._pointCloudReader.readTileIndexes(blockIndex, fileContents);\r\n\t\t}\r\n\t\t/* Prepare the loading of the tiles */\r\n\t\tlet loadTileCount: int32 = 0;\r\n\t\tfor (let i: number = 0; i < tileList.size(); i++) {\r\n\t\t\t/* Prepare to load the tile */\r\n\t\t\tlet tileIndex: TileIndex = tileList.get(i);\r\n\t\t\tthis._tilesLoading.set(tileIndex.key, tileIndex);\r\n\t\t\tthis._pointCloudReader.readPointData(tileIndex, this._dataFormat, loadTime, fileContents);\r\n\t\t\tloadTileCount++;\r\n\t\t\t/* Do not load too many tiles at once */\r\n\t\t\tif (fileContents.getTotalRequestSize() > DataManager.MAX_FILE_CONTENT_SIZE) {\r\n\t\t\t\t/* Stop loading tiles */\r\n\t\t\t\tMessage.print(DataManager.MODULE, \"Limited pointcloud content load request to \" + fileContents.getTotalRequestSize() + \" bytes\");\r\n\t\t\t\tbreak;\r\n\t\t\t}\r\n\t\t}\r\n\t\t/* Log */\r\n\t\tMessage.print(DataManager.MODULE, \"Loading of \" + blockList.size() + \" blocks, \" + loadTileCount + \"/\" + tileList.size() + \" tiles, \" + fileContents.getTotalRequestSize() + \" bytes\");\r\n\t\t/* Load the data */\r\n\t\tthis._dataLoadSize = this._dataLoadSize.addInt(fileContents.getTotalRequestSize());\r\n\t\tfileContents = await fileContents.load();\r\n\t\t//Message.print(MODULE,\"Creating \"+blockList.size()+\" blocks and \"+tileList.size()+\" tiles\");\r\n\t\t/* Load the levels */\r\n\t\tfor (let i: number = 0; i < levelList.size(); i++) {\r\n\t\t\t/* Load the block list */\r\n\t\t\tlet level: Level = levelList.get(i);\r\n\t\t\tthis._levelsLoaded.set(level.getKey(), level);\r\n\t\t\tthis._levelsLoading.remove(level.getKey());\r\n\t\t\tlet blockIndexes: Array<BlockIndex> = this._pointCloudReader.readBlockIndexes(level.getIndex(), fileContents);\r\n\t\t\t/* Add the blocks */\r\n\t\t\tthis._fileTileIndex.setLevelBlocks(level, blockIndexes);\r\n\t\t}\r\n\t\t/* Load the blocks */\r\n\t\tfor (let i: number = 0; i < blockList.size(); i++) {\r\n\t\t\t/* Load the block */\r\n\t\t\tlet blockIndex: BlockIndex = blockList.get(i);\r\n\t\t\tthis._blocksLoaded.set(blockIndex.key, blockIndex);\r\n\t\t\tthis._blocksLoading.remove(blockIndex.key);\r\n\t\t\tlet tileIndexes: Array<TileIndex> = this._pointCloudReader.readTileIndexes(blockIndex, fileContents);\r\n\t\t\t/* Add the block */\r\n\t\t\tthis._fileTileIndex.setBlockTiles(blockIndex, tileIndexes);\r\n\t\t}\r\n\t\t/* Load the tiles */\r\n\t\tlet newTiles: AList<TileIndex> = new AList<TileIndex>();\r\n\t\tfor (let i: number = 0; i < loadTileCount; i++) {\r\n\t\t\t/* Get the next tile */\r\n\t\t\tlet tileIndex: TileIndex = tileList.get(i);\r\n\t\t\tnewTiles.add(tileIndex);\r\n\t\t\t/* Load the tile */\r\n\t\t\tthis._tilesLoaded.set(tileIndex.key, tileIndex);\r\n\t\t\tthis._tilesLoading.remove(tileIndex.key);\r\n\t\t\tlet pointData: PointData = this._pointCloudReader.readPointData(tileIndex, this._dataFormat, loadTime, fileContents);\r\n\t\t\t/* Add the tile */\r\n\t\t\tthis._dataPool.set(tileIndex.key, pointData);\r\n\t\t}\r\n\t\t/* We stopped loading */\r\n\t\tthis._loadingData = false;\r\n\t\tthis._loadedDataTime = ASystem.time();\r\n\t\t/* Log */\r\n\t\tMessage.print(DataManager.MODULE, \"Created \" + blockList.size() + \" blocks and \" + loadTileCount + \" tiles\");\r\n\t\t/* Return the frame data */\r\n\t\treturn frameData;\r\n\t}\r\n\r\n\t/**\r\n\t * Do a garbage collect (this method can be called often, it throttles itself to once per minute).\r\n\t * @param time the current time.\r\n\t */\r\n\tpublic doGarbageCollect(time: float64): void {\r\n\t\t/* First call? */\r\n\t\tif (this._lastGarbageCollectTime == 0.0) this._lastGarbageCollectTime = time;\r\n\t\t/* Throttle to one per minute */\r\n\t\tif (time < this._lastGarbageCollectTime + 60.0) return;\r\n\t\tthis._lastGarbageCollectTime = time;\r\n\t\t/* Define the expire time */\r\n\t\tlet expireTime: float64 = (time - DataManager.POINT_DATA_EXIRE_TIME);\r\n\t\t/* Check all loaded tiles */\r\n\t\tlet dropCount: int32 = 0;\r\n\t\tlet dataKeys: AList<string> = this._dataPool.keys();\r\n\t\tfor (let i: number = 0; i < dataKeys.size(); i++) {\r\n\t\t\t/* Get the next tile */\r\n\t\t\tlet tileKey: string = dataKeys.get(i);\r\n\t\t\tlet pointData: PointData = this._dataPool.get(tileKey);\r\n\t\t\t/* Expired? */\r\n\t\t\tif (pointData.tileIndex.accessTime < expireTime) {\r\n\t\t\t\tthis._dataPool.remove(tileKey);\r\n\t\t\t\tthis._tilesLoaded.remove(tileKey);\r\n\t\t\t\tdropCount++;\r\n\t\t\t}\r\n\t\t}\r\n\t\t/* Log? */\r\n\t\tif (dropCount > 0) Message.print(DataManager.MODULE, \"Dropped the point data of \" + dropCount + \" tiles\");\r\n\t}\r\n}\r\n"]}
@@ -11,6 +11,14 @@ import { AList } from "../../system/collection/AList";
11
11
  */
12
12
  /** @internal */
13
13
  export class FrameData {
14
+ /** The list of tiles that have been loaded and need to be rendered */
15
+ tilesToRender;
16
+ /** The levels of which the block indexes need to be loaded */
17
+ levelsToLoad;
18
+ /** The blocks of which the tile indexes need to be loaded */
19
+ blocksToLoad;
20
+ /** The tiles of which the points need to be loaded */
21
+ tilesToLoad;
14
22
  /**
15
23
  * Create a new frame data holder.
16
24
  */
@@ -1 +1 @@
1
- {"version":3,"file":"FrameData.js","sourceRoot":"","sources":["../../../../src/pointcloud/render/FrameData.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAWH,OAAO,EAAE,KAAK,EAAE,MAAM,+BAA+B,CAAC;AAMtD;;GAEG;AACH,gBAAgB;AAChB,MAAM,OAAO,SAAS;IAUlB;;OAEG;IACH;QACI,IAAI,CAAC,aAAa,GAAG,IAAI,KAAK,EAAa,CAAC;QAC5C,IAAI,CAAC,YAAY,GAAG,IAAI,KAAK,EAAS,CAAC;QACvC,IAAI,CAAC,YAAY,GAAG,IAAI,KAAK,EAAc,CAAC;QAC5C,IAAI,CAAC,WAAW,GAAG,IAAI,KAAK,EAAa,CAAC;IAC9C,CAAC;IAED;;OAEG;IACI,cAAc;QACjB,IAAI,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,GAAG,CAAC;YAAE,OAAO,IAAI,CAAC;QAC9C,IAAI,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,GAAG,CAAC;YAAE,OAAO,IAAI,CAAC;QAC9C,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,GAAG,CAAC;YAAE,OAAO,IAAI,CAAC;QAC7C,OAAO,KAAK,CAAC;IACjB,CAAC;CACJ","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module OrbitGT\r\n */\r\n\r\n//package orbitgt.pointcloud.render;\r\n\r\ntype int8 = number;\r\ntype int16 = number;\r\ntype int32 = number;\r\ntype float32 = number;\r\ntype float64 = number;\r\n\r\n\r\nimport { AList } from \"../../system/collection/AList\";\r\nimport { BlockIndex } from \"../model/BlockIndex\";\r\nimport { PointData } from \"../model/PointData\";\r\nimport { TileIndex } from \"../model/TileIndex\";\r\nimport { Level } from \"./Level\";\r\n\r\n/**\r\n * Class FrameData bundles the data needed to render a certain view, some data is available, some data needs to be loaded.\r\n */\r\n/** @internal */\r\nexport class FrameData {\r\n /** The list of tiles that have been loaded and need to be rendered */\r\n public tilesToRender: AList<PointData>;\r\n /** The levels of which the block indexes need to be loaded */\r\n public levelsToLoad: AList<Level>;\r\n /** The blocks of which the tile indexes need to be loaded */\r\n public blocksToLoad: AList<BlockIndex>;\r\n /** The tiles of which the points need to be loaded */\r\n public tilesToLoad: AList<TileIndex>;\r\n\r\n /**\r\n * Create a new frame data holder.\r\n */\r\n public constructor() {\r\n this.tilesToRender = new AList<PointData>();\r\n this.levelsToLoad = new AList<Level>();\r\n this.blocksToLoad = new AList<BlockIndex>();\r\n this.tilesToLoad = new AList<TileIndex>();\r\n }\r\n\r\n /**\r\n * Is frame data missing? (so a data load is needed).\r\n */\r\n public hasMissingData(): boolean {\r\n if (this.levelsToLoad.size() > 0) return true;\r\n if (this.blocksToLoad.size() > 0) return true;\r\n if (this.tilesToLoad.size() > 0) return true;\r\n return false;\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"FrameData.js","sourceRoot":"","sources":["../../../../src/pointcloud/render/FrameData.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAWH,OAAO,EAAE,KAAK,EAAE,MAAM,+BAA+B,CAAC;AAMtD;;GAEG;AACH,gBAAgB;AAChB,MAAM,OAAO,SAAS;IAClB,sEAAsE;IAC/D,aAAa,CAAmB;IACvC,8DAA8D;IACvD,YAAY,CAAe;IAClC,6DAA6D;IACtD,YAAY,CAAoB;IACvC,sDAAsD;IAC/C,WAAW,CAAmB;IAErC;;OAEG;IACH;QACI,IAAI,CAAC,aAAa,GAAG,IAAI,KAAK,EAAa,CAAC;QAC5C,IAAI,CAAC,YAAY,GAAG,IAAI,KAAK,EAAS,CAAC;QACvC,IAAI,CAAC,YAAY,GAAG,IAAI,KAAK,EAAc,CAAC;QAC5C,IAAI,CAAC,WAAW,GAAG,IAAI,KAAK,EAAa,CAAC;IAC9C,CAAC;IAED;;OAEG;IACI,cAAc;QACjB,IAAI,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,GAAG,CAAC;YAAE,OAAO,IAAI,CAAC;QAC9C,IAAI,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,GAAG,CAAC;YAAE,OAAO,IAAI,CAAC;QAC9C,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,GAAG,CAAC;YAAE,OAAO,IAAI,CAAC;QAC7C,OAAO,KAAK,CAAC;IACjB,CAAC;CACJ","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module OrbitGT\r\n */\r\n\r\n//package orbitgt.pointcloud.render;\r\n\r\ntype int8 = number;\r\ntype int16 = number;\r\ntype int32 = number;\r\ntype float32 = number;\r\ntype float64 = number;\r\n\r\n\r\nimport { AList } from \"../../system/collection/AList\";\r\nimport { BlockIndex } from \"../model/BlockIndex\";\r\nimport { PointData } from \"../model/PointData\";\r\nimport { TileIndex } from \"../model/TileIndex\";\r\nimport { Level } from \"./Level\";\r\n\r\n/**\r\n * Class FrameData bundles the data needed to render a certain view, some data is available, some data needs to be loaded.\r\n */\r\n/** @internal */\r\nexport class FrameData {\r\n /** The list of tiles that have been loaded and need to be rendered */\r\n public tilesToRender: AList<PointData>;\r\n /** The levels of which the block indexes need to be loaded */\r\n public levelsToLoad: AList<Level>;\r\n /** The blocks of which the tile indexes need to be loaded */\r\n public blocksToLoad: AList<BlockIndex>;\r\n /** The tiles of which the points need to be loaded */\r\n public tilesToLoad: AList<TileIndex>;\r\n\r\n /**\r\n * Create a new frame data holder.\r\n */\r\n public constructor() {\r\n this.tilesToRender = new AList<PointData>();\r\n this.levelsToLoad = new AList<Level>();\r\n this.blocksToLoad = new AList<BlockIndex>();\r\n this.tilesToLoad = new AList<TileIndex>();\r\n }\r\n\r\n /**\r\n * Is frame data missing? (so a data load is needed).\r\n */\r\n public hasMissingData(): boolean {\r\n if (this.levelsToLoad.size() > 0) return true;\r\n if (this.blocksToLoad.size() > 0) return true;\r\n if (this.tilesToLoad.size() > 0) return true;\r\n return false;\r\n }\r\n}\r\n"]}
@@ -13,6 +13,18 @@ import { StringMap } from "../../system/collection/StringMap";
13
13
  */
14
14
  /** @internal */
15
15
  export class Level {
16
+ /** The index of the level */
17
+ _index;
18
+ /** The unique key of the level */
19
+ _key;
20
+ /** The grid of the blocks */
21
+ _blockGrid;
22
+ /** The grid of the tiles */
23
+ _tileGrid;
24
+ /** The list of blocks */
25
+ _blockList;
26
+ /** The map of blocks */
27
+ _blockMap;
16
28
  /**
17
29
  * Create a new level.
18
30
  * @param index the index of the level.
@@ -1 +1 @@
1
- {"version":3,"file":"Level.js","sourceRoot":"","sources":["../../../../src/pointcloud/render/Level.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAWH,OAAO,EAAE,SAAS,EAAE,MAAM,mCAAmC,CAAC;AAM9D;;;;GAIG;AACH,gBAAgB;AAChB,MAAM,OAAO,KAAK;IAcjB;;;;;;OAMG;IACH,YAAmB,KAAY,EAAE,SAAe,EAAE,QAAc,EAAE,SAAuB;QACxF,0BAA0B;QAC1B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,IAAI,GAAG,CAAC,GAAG,GAAG,KAAK,CAAC,CAAC;QAC1B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC1B,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;IAC9B,CAAC;IAED;;;OAGG;IACI,YAAY,CAAC,SAAuB;QAC1C,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,oBAAoB;QACpB,IAAI,CAAC,SAAS,GAAG,IAAI,SAAS,EAAS,CAAC;QACxC,KAAK,IAAI,KAAK,IAAI,IAAI,CAAC,UAAU;YAAE,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,SAAS,CAAC,MAAM,EAAE,EAAE,KAAK,CAAC,CAAC;IACxG,CAAC;IAED;;;OAGG;IACI,QAAQ;QACd,OAAO,IAAI,CAAC,MAAM,CAAC;IACpB,CAAC;IAED;;;OAGG;IACI,MAAM;QACZ,OAAO,IAAI,CAAC,IAAI,CAAC;IAClB,CAAC;IAED;;;OAGG;IACI,YAAY;QAClB,OAAO,IAAI,CAAC,UAAU,CAAC;IACxB,CAAC;IAED;;;OAGG;IACI,WAAW;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC;IACvB,CAAC;IAED;;;OAGG;IACI,SAAS;QACf,OAAO,IAAI,CAAC,UAAU,CAAC;IACxB,CAAC;IAED;;;OAGG;IACI,aAAa;QACnB,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC;IAC/B,CAAC;IAED;;;;OAIG;IACI,SAAS,CAAC,UAAsB;QACtC,KAAK,IAAI,KAAK,IAAI,IAAI,CAAC,UAAU;YAAE,IAAI,KAAK,CAAC,aAAa,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC;gBAAE,OAAO,KAAK,CAAC;QAC5F,OAAO,IAAI,CAAC;IACb,CAAC;IAED;;;;OAIG;IACI,kBAAkB,CAAC,UAAqB;QAC9C,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC;IAChD,CAAC;IAED;;;;OAIG;IACI,gBAAgB,CAAC,aAAwB;QAC/C,yBAAyB;QACzB,IAAI,UAAU,GAAe,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC;QACzE,IAAI,cAAc,GAAc,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;QACzE,2BAA2B;QAC3B,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC,CAAC;IACpD,CAAC;CACD","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module OrbitGT\r\n */\r\n\r\n//package orbitgt.pointcloud.render;\r\n\r\ntype int8 = number;\r\ntype int16 = number;\r\ntype int32 = number;\r\ntype float32 = number;\r\ntype float64 = number;\r\n\r\nimport { Coordinate } from \"../../spatial/geom/Coordinate\";\r\nimport { StringMap } from \"../../system/collection/StringMap\";\r\nimport { BlockIndex } from \"../model/BlockIndex\";\r\nimport { Grid } from \"../model/Grid\";\r\nimport { GridIndex } from \"../model/GridIndex\";\r\nimport { Block } from \"./Block\";\r\n\r\n/**\r\n * Class Level defines a resolution level of a pointcloud.\r\n *\r\n * @version 1.0 November 2015\r\n */\r\n/** @internal */\r\nexport class Level {\r\n\t/** The index of the level */\r\n\tprivate _index: int32;\r\n\t/** The unique key of the level */\r\n\tprivate _key: string;\r\n\t/** The grid of the blocks */\r\n\tprivate _blockGrid: Grid;\r\n\t/** The grid of the tiles */\r\n\tprivate _tileGrid: Grid;\r\n\t/** The list of blocks */\r\n\tprivate _blockList: Array<Block>;\r\n\t/** The map of blocks */\r\n\tprivate _blockMap: StringMap<Block>;\r\n\r\n\t/**\r\n\t * Create a new level.\r\n\t * @param index the index of the level.\r\n\t * @param blockGrid the grid of the blocks.\r\n\t * @param tileGrid the grid of the tiles.\r\n\t * @param blockList the list of blocks.\r\n\t */\r\n\tpublic constructor(index: int32, blockGrid: Grid, tileGrid: Grid, blockList: Array<Block>) {\r\n\t\t/* Store the parameters */\r\n\t\tthis._index = index;\r\n\t\tthis._key = (\"L\" + index);\r\n\t\tthis._blockGrid = blockGrid;\r\n\t\tthis._tileGrid = tileGrid;\r\n\t\tthis.setBlockList(blockList);\r\n\t}\r\n\r\n\t/**\r\n\t * Set the block list.\r\n\t * @param blockList the list of blocks.\r\n\t */\r\n\tpublic setBlockList(blockList: Array<Block>): void {\r\n\t\tthis._blockList = blockList;\r\n\t\t/* Map the blocks */\r\n\t\tthis._blockMap = new StringMap<Block>();\r\n\t\tfor (let block of this._blockList) this._blockMap.set(block.getBlockIndex().gridIndex.getKey(), block);\r\n\t}\r\n\r\n\t/**\r\n\t * Get the index of the level.\r\n\t * @return the index of the level.\r\n\t */\r\n\tpublic getIndex(): int32 {\r\n\t\treturn this._index;\r\n\t}\r\n\r\n\t/**\r\n\t * Get the unique key of the level.\r\n\t * @return the unique key of the level.\r\n\t */\r\n\tpublic getKey(): string {\r\n\t\treturn this._key;\r\n\t}\r\n\r\n\t/**\r\n\t * Get the block grid.\r\n\t * @return the block grid.\r\n\t */\r\n\tpublic getBlockGrid(): Grid {\r\n\t\treturn this._blockGrid;\r\n\t}\r\n\r\n\t/**\r\n\t * Get the tile grid.\r\n\t * @return the tile grid.\r\n\t */\r\n\tpublic getTileGrid(): Grid {\r\n\t\treturn this._tileGrid;\r\n\t}\r\n\r\n\t/**\r\n\t * List all blocks.\r\n\t * @return all blocks.\r\n\t */\r\n\tpublic getBlocks(): Array<Block> {\r\n\t\treturn this._blockList;\r\n\t}\r\n\r\n\t/**\r\n\t * Get the number of blocks.\r\n\t * @return the number of blocks.\r\n\t */\r\n\tpublic getBlockCount(): int32 {\r\n\t\treturn this._blockList.length;\r\n\t}\r\n\r\n\t/**\r\n\t * Find a block.\r\n\t * @param blockIndex the index of the block to find.\r\n\t * @return the block.\r\n\t */\r\n\tpublic findBlock(blockIndex: BlockIndex): Block {\r\n\t\tfor (let block of this._blockList) if (block.getBlockIndex().same(blockIndex)) return block;\r\n\t\treturn null;\r\n\t}\r\n\r\n\t/**\r\n\t * Find a block index.\r\n\t * @param blockIndex the index of the block to find.\r\n\t * @return the block (can be null).\r\n\t */\r\n\tpublic findBlockGridIndex(blockIndex: GridIndex): Block {\r\n\t\treturn this._blockMap.get(blockIndex.getKey());\r\n\t}\r\n\r\n\t/**\r\n\t * Find the block for a tile.\r\n\t * @param tileGridIndex the grid index of the tile.\r\n\t * @return the block (can be null).\r\n\t */\r\n\tpublic findBlockForTile(tileGridIndex: GridIndex): Block {\r\n\t\t/* Get the block index */\r\n\t\tlet tileCenter: Coordinate = this._tileGrid.getCellCenter(tileGridIndex);\r\n\t\tlet blockGridIndex: GridIndex = this._blockGrid.getCellIndex(tileCenter);\r\n\t\t/* Try to find the block */\r\n\t\treturn this._blockMap.get(blockGridIndex.getKey());\r\n\t}\r\n}\r\n"]}
1
+ {"version":3,"file":"Level.js","sourceRoot":"","sources":["../../../../src/pointcloud/render/Level.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAWH,OAAO,EAAE,SAAS,EAAE,MAAM,mCAAmC,CAAC;AAM9D;;;;GAIG;AACH,gBAAgB;AAChB,MAAM,OAAO,KAAK;IACjB,6BAA6B;IACrB,MAAM,CAAQ;IACtB,kCAAkC;IAC1B,IAAI,CAAS;IACrB,6BAA6B;IACrB,UAAU,CAAO;IACzB,4BAA4B;IACpB,SAAS,CAAO;IACxB,yBAAyB;IACjB,UAAU,CAAe;IACjC,wBAAwB;IAChB,SAAS,CAAmB;IAEpC;;;;;;OAMG;IACH,YAAmB,KAAY,EAAE,SAAe,EAAE,QAAc,EAAE,SAAuB;QACxF,0BAA0B;QAC1B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,IAAI,GAAG,CAAC,GAAG,GAAG,KAAK,CAAC,CAAC;QAC1B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC1B,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;IAC9B,CAAC;IAED;;;OAGG;IACI,YAAY,CAAC,SAAuB;QAC1C,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,oBAAoB;QACpB,IAAI,CAAC,SAAS,GAAG,IAAI,SAAS,EAAS,CAAC;QACxC,KAAK,IAAI,KAAK,IAAI,IAAI,CAAC,UAAU;YAAE,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,SAAS,CAAC,MAAM,EAAE,EAAE,KAAK,CAAC,CAAC;IACxG,CAAC;IAED;;;OAGG;IACI,QAAQ;QACd,OAAO,IAAI,CAAC,MAAM,CAAC;IACpB,CAAC;IAED;;;OAGG;IACI,MAAM;QACZ,OAAO,IAAI,CAAC,IAAI,CAAC;IAClB,CAAC;IAED;;;OAGG;IACI,YAAY;QAClB,OAAO,IAAI,CAAC,UAAU,CAAC;IACxB,CAAC;IAED;;;OAGG;IACI,WAAW;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC;IACvB,CAAC;IAED;;;OAGG;IACI,SAAS;QACf,OAAO,IAAI,CAAC,UAAU,CAAC;IACxB,CAAC;IAED;;;OAGG;IACI,aAAa;QACnB,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC;IAC/B,CAAC;IAED;;;;OAIG;IACI,SAAS,CAAC,UAAsB;QACtC,KAAK,IAAI,KAAK,IAAI,IAAI,CAAC,UAAU;YAAE,IAAI,KAAK,CAAC,aAAa,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC;gBAAE,OAAO,KAAK,CAAC;QAC5F,OAAO,IAAI,CAAC;IACb,CAAC;IAED;;;;OAIG;IACI,kBAAkB,CAAC,UAAqB;QAC9C,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC;IAChD,CAAC;IAED;;;;OAIG;IACI,gBAAgB,CAAC,aAAwB;QAC/C,yBAAyB;QACzB,IAAI,UAAU,GAAe,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC;QACzE,IAAI,cAAc,GAAc,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;QACzE,2BAA2B;QAC3B,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC,CAAC;IACpD,CAAC;CACD","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module OrbitGT\r\n */\r\n\r\n//package orbitgt.pointcloud.render;\r\n\r\ntype int8 = number;\r\ntype int16 = number;\r\ntype int32 = number;\r\ntype float32 = number;\r\ntype float64 = number;\r\n\r\nimport { Coordinate } from \"../../spatial/geom/Coordinate\";\r\nimport { StringMap } from \"../../system/collection/StringMap\";\r\nimport { BlockIndex } from \"../model/BlockIndex\";\r\nimport { Grid } from \"../model/Grid\";\r\nimport { GridIndex } from \"../model/GridIndex\";\r\nimport { Block } from \"./Block\";\r\n\r\n/**\r\n * Class Level defines a resolution level of a pointcloud.\r\n *\r\n * @version 1.0 November 2015\r\n */\r\n/** @internal */\r\nexport class Level {\r\n\t/** The index of the level */\r\n\tprivate _index: int32;\r\n\t/** The unique key of the level */\r\n\tprivate _key: string;\r\n\t/** The grid of the blocks */\r\n\tprivate _blockGrid: Grid;\r\n\t/** The grid of the tiles */\r\n\tprivate _tileGrid: Grid;\r\n\t/** The list of blocks */\r\n\tprivate _blockList: Array<Block>;\r\n\t/** The map of blocks */\r\n\tprivate _blockMap: StringMap<Block>;\r\n\r\n\t/**\r\n\t * Create a new level.\r\n\t * @param index the index of the level.\r\n\t * @param blockGrid the grid of the blocks.\r\n\t * @param tileGrid the grid of the tiles.\r\n\t * @param blockList the list of blocks.\r\n\t */\r\n\tpublic constructor(index: int32, blockGrid: Grid, tileGrid: Grid, blockList: Array<Block>) {\r\n\t\t/* Store the parameters */\r\n\t\tthis._index = index;\r\n\t\tthis._key = (\"L\" + index);\r\n\t\tthis._blockGrid = blockGrid;\r\n\t\tthis._tileGrid = tileGrid;\r\n\t\tthis.setBlockList(blockList);\r\n\t}\r\n\r\n\t/**\r\n\t * Set the block list.\r\n\t * @param blockList the list of blocks.\r\n\t */\r\n\tpublic setBlockList(blockList: Array<Block>): void {\r\n\t\tthis._blockList = blockList;\r\n\t\t/* Map the blocks */\r\n\t\tthis._blockMap = new StringMap<Block>();\r\n\t\tfor (let block of this._blockList) this._blockMap.set(block.getBlockIndex().gridIndex.getKey(), block);\r\n\t}\r\n\r\n\t/**\r\n\t * Get the index of the level.\r\n\t * @return the index of the level.\r\n\t */\r\n\tpublic getIndex(): int32 {\r\n\t\treturn this._index;\r\n\t}\r\n\r\n\t/**\r\n\t * Get the unique key of the level.\r\n\t * @return the unique key of the level.\r\n\t */\r\n\tpublic getKey(): string {\r\n\t\treturn this._key;\r\n\t}\r\n\r\n\t/**\r\n\t * Get the block grid.\r\n\t * @return the block grid.\r\n\t */\r\n\tpublic getBlockGrid(): Grid {\r\n\t\treturn this._blockGrid;\r\n\t}\r\n\r\n\t/**\r\n\t * Get the tile grid.\r\n\t * @return the tile grid.\r\n\t */\r\n\tpublic getTileGrid(): Grid {\r\n\t\treturn this._tileGrid;\r\n\t}\r\n\r\n\t/**\r\n\t * List all blocks.\r\n\t * @return all blocks.\r\n\t */\r\n\tpublic getBlocks(): Array<Block> {\r\n\t\treturn this._blockList;\r\n\t}\r\n\r\n\t/**\r\n\t * Get the number of blocks.\r\n\t * @return the number of blocks.\r\n\t */\r\n\tpublic getBlockCount(): int32 {\r\n\t\treturn this._blockList.length;\r\n\t}\r\n\r\n\t/**\r\n\t * Find a block.\r\n\t * @param blockIndex the index of the block to find.\r\n\t * @return the block.\r\n\t */\r\n\tpublic findBlock(blockIndex: BlockIndex): Block {\r\n\t\tfor (let block of this._blockList) if (block.getBlockIndex().same(blockIndex)) return block;\r\n\t\treturn null;\r\n\t}\r\n\r\n\t/**\r\n\t * Find a block index.\r\n\t * @param blockIndex the index of the block to find.\r\n\t * @return the block (can be null).\r\n\t */\r\n\tpublic findBlockGridIndex(blockIndex: GridIndex): Block {\r\n\t\treturn this._blockMap.get(blockIndex.getKey());\r\n\t}\r\n\r\n\t/**\r\n\t * Find the block for a tile.\r\n\t * @param tileGridIndex the grid index of the tile.\r\n\t * @return the block (can be null).\r\n\t */\r\n\tpublic findBlockForTile(tileGridIndex: GridIndex): Block {\r\n\t\t/* Get the block index */\r\n\t\tlet tileCenter: Coordinate = this._tileGrid.getCellCenter(tileGridIndex);\r\n\t\tlet blockGridIndex: GridIndex = this._blockGrid.getCellIndex(tileCenter);\r\n\t\t/* Try to find the block */\r\n\t\treturn this._blockMap.get(blockGridIndex.getKey());\r\n\t}\r\n}\r\n"]}
@@ -16,6 +16,15 @@ import { GridIndex } from "../model/GridIndex";
16
16
  * @internal
17
17
  */
18
18
  export class TileLoadSorter {
19
+ viewProjector;
20
+ /** @ignore */
21
+ static _CLASSNAME_ = "orbitgt.pointcloud.render.TileLoadSorter"; // the full name of the original java class
22
+ // the interface implementation markers:
23
+ isiComparator_TileIndex_Instance = true;
24
+ /** The global tile index */
25
+ tileIndex;
26
+ /** The model transformation */
27
+ projectToView;
19
28
  /** The view projection */
20
29
  /**
21
30
  * Create a new sorter.
@@ -25,8 +34,6 @@ export class TileLoadSorter {
25
34
  */
26
35
  constructor(tileIndex, viewProjector) {
27
36
  this.viewProjector = viewProjector;
28
- // the interface implementation markers:
29
- this.isiComparator_TileIndex_Instance = true;
30
37
  this.tileIndex = tileIndex;
31
38
  }
32
39
  /**
@@ -91,6 +98,4 @@ export class TileLoadSorter {
91
98
  return (d > 0.0) ? 1 : (d < 0.0) ? -1 : 0;
92
99
  }
93
100
  }
94
- /** @ignore */
95
- TileLoadSorter._CLASSNAME_ = "orbitgt.pointcloud.render.TileLoadSorter"; // the full name of the original java class
96
101
  //# sourceMappingURL=TileLoadSorter.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TileLoadSorter.js","sourceRoot":"","sources":["../../../../src/pointcloud/render/TileLoadSorter.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module OrbitGT\r\n */\r\n/** @internal */\r\n// NOTE: this class has been translated from Java.\r\n// Do not modify this file, changes will be overwritten.\r\n\r\n//package orbitgt.pointcloud.render;\r\n\r\ntype int8 = number;\r\ntype int16 = number;\r\ntype int32 = number;\r\ntype float32 = number;\r\ntype float64 = number;\r\n\r\nimport { Coordinate } from \"../../spatial/geom/Coordinate\";\r\nimport { iComparator } from \"../../system/runtime/iComparator\";\r\nimport { Grid } from \"../model/Grid\";\r\nimport { GridIndex } from \"../model/GridIndex\";\r\nimport { TileIndex } from \"../model/TileIndex\";\r\nimport { ViewTree } from \"./ViewTree\";\r\n\r\n/** @internal */\r\nexport interface IProjectToViewForSort {\r\n projectToViewForSort(point: Coordinate): void;\r\n}\r\n\r\n/**\r\n * Class TileLoadSorter sorts file tiles by their angle with the forward view direction (smaller angles first to load tiles in the view center first).\r\n *\r\n * @internal\r\n */\r\nexport class TileLoadSorter implements iComparator<TileIndex>\r\n{\r\n /** @ignore */\r\n public static readonly _CLASSNAME_: string = \"orbitgt.pointcloud.render.TileLoadSorter\"; // the full name of the original java class\r\n // the interface implementation markers:\r\n private isiComparator_TileIndex_Instance: boolean = true;\r\n\r\n /** The global tile index */\r\n private tileIndex: ViewTree;\r\n /** The model transformation */\r\n private projectToView: (point: Coordinate) => void;\r\n /** The view projection */\r\n\r\n /**\r\n * Create a new sorter.\r\n * @param tileIndex the global tile index.\r\n * @param modelTransform the model transformation.\r\n * @param projection the view projection.\r\n */\r\n public constructor(tileIndex: ViewTree, private viewProjector: IProjectToViewForSort) {\r\n this.tileIndex = tileIndex;\r\n }\r\n\r\n /**\r\n * Get the position of a tile in the view (camera) space.\r\n * @param tile the grid index of the tile.\r\n * @param dX the x grid index offset.\r\n * @param dY the y grid index offset.\r\n * @param dZ the z grid index offset.\r\n * @return the position in view space.\r\n */\r\n private getTilePosition(tile: TileIndex, dX: int32, dY: int32, dZ: int32): Coordinate {\r\n /* Get the position of the tile center in the view world space */\r\n let tileGrid: Grid = this.tileIndex.getLevel(tile.level).getTileGrid();\r\n let tileCenter: Coordinate = tileGrid.getCellCenter(new GridIndex(tile.gridIndex.x + dX, tile.gridIndex.y + dY, tile.gridIndex.z + dZ));\r\n this.viewProjector.projectToViewForSort(tileCenter);\r\n /* Return the position */\r\n return tileCenter;\r\n }\r\n\r\n /**\r\n * Get the radius of a tile.\r\n * @param tile the grid index of the tile.\r\n * @param tilePosition the position of the tile in view space.\r\n * @return the radius of the tile.\r\n */\r\n private getTileRadius(tile: TileIndex, tilePosition: Coordinate): float64 {\r\n /* Get the position of the next tile */\r\n let nextTilePosition: Coordinate = this.getTilePosition(tile, 1, 0, 0);\r\n /* Get the distance (in view space) */\r\n return nextTilePosition.distance3D(tilePosition);\r\n }\r\n\r\n /**\r\n * Get the score of a tile.\r\n * @param tile the tile index.\r\n * @return the score (the lower the better).\r\n */\r\n private getScore(tile: TileIndex): float64 {\r\n /* We need a tile index */\r\n if (tile == null) return 0.0;\r\n /* Get the position of the tile center in the view (camera) space */\r\n let tileCenter: Coordinate = this.getTilePosition(tile, 0, 0, 0);\r\n if (tileCenter == null) return 0.0;\r\n /* Get the angle from the camera boresight (screen center) (the smaller the better) (radians) */\r\n let angleFromScreenCenter: float64 = Coordinate.getAngleRad(tileCenter, new Coordinate(0.0, 0.0, 1.0)/*forward*/);\r\n /* Get the radius of the tile in the view (camera) space */\r\n let tileRadius: float64 = this.getTileRadius(tile, tileCenter);\r\n /* Get the angular extent of the tile (the bigger the better) (radians) */\r\n let tileDistance: float64 = tileCenter.getLength();\r\n let tileExtent: float64 = 2.0 * Math.atan2(tileRadius, tileDistance);\r\n /* We want tiles with a small screen center angle and with a big screen extent */\r\n return (angleFromScreenCenter - tileExtent);\r\n }\r\n\r\n // Comparator interface method\r\n public compare(tile1: TileIndex, tile2: TileIndex): int32 {\r\n /* Load higher level tiles first (added on 21/03/2017 by LER) */\r\n let dLevel: int32 = (tile1.level - tile2.level);\r\n if (dLevel != 0) return (-dLevel);\r\n /* Compare the scores inside the level */\r\n let d: float64 = (this.getScore(tile1) - this.getScore(tile2)); // new scoring method on 02/02/2017 by LER\r\n return (d > 0.0) ? 1 : (d < 0.0) ? -1 : 0;\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"TileLoadSorter.js","sourceRoot":"","sources":["../../../../src/pointcloud/render/TileLoadSorter.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module OrbitGT\r\n */\r\n/** @internal */\r\n// NOTE: this class has been translated from Java.\r\n// Do not modify this file, changes will be overwritten.\r\n\r\n//package orbitgt.pointcloud.render;\r\n\r\ntype int8 = number;\r\ntype int16 = number;\r\ntype int32 = number;\r\ntype float32 = number;\r\ntype float64 = number;\r\n\r\nimport { Coordinate } from \"../../spatial/geom/Coordinate\";\r\nimport { iComparator } from \"../../system/runtime/iComparator\";\r\nimport { Grid } from \"../model/Grid\";\r\nimport { GridIndex } from \"../model/GridIndex\";\r\nimport { TileIndex } from \"../model/TileIndex\";\r\nimport { ViewTree } from \"./ViewTree\";\r\n\r\n/** @internal */\r\nexport interface IProjectToViewForSort {\r\n projectToViewForSort(point: Coordinate): void;\r\n}\r\n\r\n/**\r\n * Class TileLoadSorter sorts file tiles by their angle with the forward view direction (smaller angles first to load tiles in the view center first).\r\n *\r\n * @internal\r\n */\r\nexport class TileLoadSorter implements iComparator<TileIndex>\r\n{\r\n /** @ignore */\r\n public static readonly _CLASSNAME_: string = \"orbitgt.pointcloud.render.TileLoadSorter\"; // the full name of the original java class\r\n // the interface implementation markers:\r\n private isiComparator_TileIndex_Instance: boolean = true;\r\n\r\n /** The global tile index */\r\n private tileIndex: ViewTree;\r\n /** The model transformation */\r\n private projectToView: (point: Coordinate) => void;\r\n /** The view projection */\r\n\r\n /**\r\n * Create a new sorter.\r\n * @param tileIndex the global tile index.\r\n * @param modelTransform the model transformation.\r\n * @param projection the view projection.\r\n */\r\n public constructor(tileIndex: ViewTree, private viewProjector: IProjectToViewForSort) {\r\n this.tileIndex = tileIndex;\r\n }\r\n\r\n /**\r\n * Get the position of a tile in the view (camera) space.\r\n * @param tile the grid index of the tile.\r\n * @param dX the x grid index offset.\r\n * @param dY the y grid index offset.\r\n * @param dZ the z grid index offset.\r\n * @return the position in view space.\r\n */\r\n private getTilePosition(tile: TileIndex, dX: int32, dY: int32, dZ: int32): Coordinate {\r\n /* Get the position of the tile center in the view world space */\r\n let tileGrid: Grid = this.tileIndex.getLevel(tile.level).getTileGrid();\r\n let tileCenter: Coordinate = tileGrid.getCellCenter(new GridIndex(tile.gridIndex.x + dX, tile.gridIndex.y + dY, tile.gridIndex.z + dZ));\r\n this.viewProjector.projectToViewForSort(tileCenter);\r\n /* Return the position */\r\n return tileCenter;\r\n }\r\n\r\n /**\r\n * Get the radius of a tile.\r\n * @param tile the grid index of the tile.\r\n * @param tilePosition the position of the tile in view space.\r\n * @return the radius of the tile.\r\n */\r\n private getTileRadius(tile: TileIndex, tilePosition: Coordinate): float64 {\r\n /* Get the position of the next tile */\r\n let nextTilePosition: Coordinate = this.getTilePosition(tile, 1, 0, 0);\r\n /* Get the distance (in view space) */\r\n return nextTilePosition.distance3D(tilePosition);\r\n }\r\n\r\n /**\r\n * Get the score of a tile.\r\n * @param tile the tile index.\r\n * @return the score (the lower the better).\r\n */\r\n private getScore(tile: TileIndex): float64 {\r\n /* We need a tile index */\r\n if (tile == null) return 0.0;\r\n /* Get the position of the tile center in the view (camera) space */\r\n let tileCenter: Coordinate = this.getTilePosition(tile, 0, 0, 0);\r\n if (tileCenter == null) return 0.0;\r\n /* Get the angle from the camera boresight (screen center) (the smaller the better) (radians) */\r\n let angleFromScreenCenter: float64 = Coordinate.getAngleRad(tileCenter, new Coordinate(0.0, 0.0, 1.0)/*forward*/);\r\n /* Get the radius of the tile in the view (camera) space */\r\n let tileRadius: float64 = this.getTileRadius(tile, tileCenter);\r\n /* Get the angular extent of the tile (the bigger the better) (radians) */\r\n let tileDistance: float64 = tileCenter.getLength();\r\n let tileExtent: float64 = 2.0 * Math.atan2(tileRadius, tileDistance);\r\n /* We want tiles with a small screen center angle and with a big screen extent */\r\n return (angleFromScreenCenter - tileExtent);\r\n }\r\n\r\n // Comparator interface method\r\n public compare(tile1: TileIndex, tile2: TileIndex): int32 {\r\n /* Load higher level tiles first (added on 21/03/2017 by LER) */\r\n let dLevel: int32 = (tile1.level - tile2.level);\r\n if (dLevel != 0) return (-dLevel);\r\n /* Compare the scores inside the level */\r\n let d: float64 = (this.getScore(tile1) - this.getScore(tile2)); // new scoring method on 02/02/2017 by LER\r\n return (d > 0.0) ? 1 : (d < 0.0) ? -1 : 0;\r\n }\r\n}\r\n"]}
@@ -16,6 +16,18 @@ import { Block } from "./Block";
16
16
  */
17
17
  /** @internal */
18
18
  export class ViewTree {
19
+ /** The name of this module */
20
+ static MODULE = "ViewTree";
21
+ /** Debug mode? */
22
+ static DEBUG = false;
23
+ /** The data manager */
24
+ _dataManager;
25
+ /** The levels */
26
+ _levels;
27
+ /** The data bounds */
28
+ _dataBounds;
29
+ /** The root blocks */
30
+ _rootBlocks;
19
31
  /**
20
32
  * Create a new tree.
21
33
  * @param levels the levels.
@@ -353,8 +365,4 @@ export class ViewTree {
353
365
  }
354
366
  }
355
367
  }
356
- /** The name of this module */
357
- ViewTree.MODULE = "ViewTree";
358
- /** Debug mode? */
359
- ViewTree.DEBUG = false;
360
368
  //# sourceMappingURL=ViewTree.js.map