@pggis/pg-sdk 3.2.9

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 (320) hide show
  1. package/README.md +152 -0
  2. package/dist/index.cjs +43 -0
  3. package/dist/pggis.min.css +1 -0
  4. package/dist/pggis.min.js +42 -0
  5. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_0.json +1 -0
  6. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_1.json +1 -0
  7. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_10.json +1 -0
  8. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_11.json +1 -0
  9. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_12.json +1 -0
  10. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_13.json +1 -0
  11. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_14.json +1 -0
  12. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_15.json +1 -0
  13. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_16.json +1 -0
  14. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_17.json +1 -0
  15. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_18.json +1 -0
  16. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_19.json +1 -0
  17. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_2.json +1 -0
  18. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_20.json +1 -0
  19. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_21.json +1 -0
  20. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_22.json +1 -0
  21. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_23.json +1 -0
  22. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_24.json +1 -0
  23. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_25.json +1 -0
  24. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_26.json +1 -0
  25. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_27.json +1 -0
  26. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_3.json +1 -0
  27. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_4.json +1 -0
  28. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_5.json +1 -0
  29. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_6.json +1 -0
  30. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_7.json +1 -0
  31. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_8.json +1 -0
  32. package/dist/resources/Assets/IAU2006_XYS/IAU2006_XYS_9.json +1 -0
  33. package/dist/resources/Assets/Images/bing_maps_credit.png +0 -0
  34. package/dist/resources/Assets/Images/cesium_credit.png +0 -0
  35. package/dist/resources/Assets/Images/google_earth_credit.png +0 -0
  36. package/dist/resources/Assets/Images/ion-credit.png +0 -0
  37. package/dist/resources/Assets/Textures/LensFlare/DirtMask.jpg +0 -0
  38. package/dist/resources/Assets/Textures/LensFlare/StarBurst.jpg +0 -0
  39. package/dist/resources/Assets/Textures/NaturalEarthII/0/0/0.jpg +0 -0
  40. package/dist/resources/Assets/Textures/NaturalEarthII/0/1/0.jpg +0 -0
  41. package/dist/resources/Assets/Textures/NaturalEarthII/1/0/0.jpg +0 -0
  42. package/dist/resources/Assets/Textures/NaturalEarthII/1/0/1.jpg +0 -0
  43. package/dist/resources/Assets/Textures/NaturalEarthII/1/1/0.jpg +0 -0
  44. package/dist/resources/Assets/Textures/NaturalEarthII/1/1/1.jpg +0 -0
  45. package/dist/resources/Assets/Textures/NaturalEarthII/1/2/0.jpg +0 -0
  46. package/dist/resources/Assets/Textures/NaturalEarthII/1/2/1.jpg +0 -0
  47. package/dist/resources/Assets/Textures/NaturalEarthII/1/3/0.jpg +0 -0
  48. package/dist/resources/Assets/Textures/NaturalEarthII/1/3/1.jpg +0 -0
  49. package/dist/resources/Assets/Textures/NaturalEarthII/2/0/0.jpg +0 -0
  50. package/dist/resources/Assets/Textures/NaturalEarthII/2/0/1.jpg +0 -0
  51. package/dist/resources/Assets/Textures/NaturalEarthII/2/0/2.jpg +0 -0
  52. package/dist/resources/Assets/Textures/NaturalEarthII/2/0/3.jpg +0 -0
  53. package/dist/resources/Assets/Textures/NaturalEarthII/2/1/0.jpg +0 -0
  54. package/dist/resources/Assets/Textures/NaturalEarthII/2/1/1.jpg +0 -0
  55. package/dist/resources/Assets/Textures/NaturalEarthII/2/1/2.jpg +0 -0
  56. package/dist/resources/Assets/Textures/NaturalEarthII/2/1/3.jpg +0 -0
  57. package/dist/resources/Assets/Textures/NaturalEarthII/2/2/0.jpg +0 -0
  58. package/dist/resources/Assets/Textures/NaturalEarthII/2/2/1.jpg +0 -0
  59. package/dist/resources/Assets/Textures/NaturalEarthII/2/2/2.jpg +0 -0
  60. package/dist/resources/Assets/Textures/NaturalEarthII/2/2/3.jpg +0 -0
  61. package/dist/resources/Assets/Textures/NaturalEarthII/2/3/0.jpg +0 -0
  62. package/dist/resources/Assets/Textures/NaturalEarthII/2/3/1.jpg +0 -0
  63. package/dist/resources/Assets/Textures/NaturalEarthII/2/3/2.jpg +0 -0
  64. package/dist/resources/Assets/Textures/NaturalEarthII/2/3/3.jpg +0 -0
  65. package/dist/resources/Assets/Textures/NaturalEarthII/2/4/0.jpg +0 -0
  66. package/dist/resources/Assets/Textures/NaturalEarthII/2/4/1.jpg +0 -0
  67. package/dist/resources/Assets/Textures/NaturalEarthII/2/4/2.jpg +0 -0
  68. package/dist/resources/Assets/Textures/NaturalEarthII/2/4/3.jpg +0 -0
  69. package/dist/resources/Assets/Textures/NaturalEarthII/2/5/0.jpg +0 -0
  70. package/dist/resources/Assets/Textures/NaturalEarthII/2/5/1.jpg +0 -0
  71. package/dist/resources/Assets/Textures/NaturalEarthII/2/5/2.jpg +0 -0
  72. package/dist/resources/Assets/Textures/NaturalEarthII/2/5/3.jpg +0 -0
  73. package/dist/resources/Assets/Textures/NaturalEarthII/2/6/0.jpg +0 -0
  74. package/dist/resources/Assets/Textures/NaturalEarthII/2/6/1.jpg +0 -0
  75. package/dist/resources/Assets/Textures/NaturalEarthII/2/6/2.jpg +0 -0
  76. package/dist/resources/Assets/Textures/NaturalEarthII/2/6/3.jpg +0 -0
  77. package/dist/resources/Assets/Textures/NaturalEarthII/2/7/0.jpg +0 -0
  78. package/dist/resources/Assets/Textures/NaturalEarthII/2/7/1.jpg +0 -0
  79. package/dist/resources/Assets/Textures/NaturalEarthII/2/7/2.jpg +0 -0
  80. package/dist/resources/Assets/Textures/NaturalEarthII/2/7/3.jpg +0 -0
  81. package/dist/resources/Assets/Textures/NaturalEarthII/tilemapresource.xml +14 -0
  82. package/dist/resources/Assets/Textures/SkyBox/tycho2t3_80_mx.jpg +0 -0
  83. package/dist/resources/Assets/Textures/SkyBox/tycho2t3_80_my.jpg +0 -0
  84. package/dist/resources/Assets/Textures/SkyBox/tycho2t3_80_mz.jpg +0 -0
  85. package/dist/resources/Assets/Textures/SkyBox/tycho2t3_80_px.jpg +0 -0
  86. package/dist/resources/Assets/Textures/SkyBox/tycho2t3_80_py.jpg +0 -0
  87. package/dist/resources/Assets/Textures/SkyBox/tycho2t3_80_pz.jpg +0 -0
  88. package/dist/resources/Assets/Textures/maki/airfield.png +0 -0
  89. package/dist/resources/Assets/Textures/maki/airport.png +0 -0
  90. package/dist/resources/Assets/Textures/maki/alcohol-shop.png +0 -0
  91. package/dist/resources/Assets/Textures/maki/america-football.png +0 -0
  92. package/dist/resources/Assets/Textures/maki/art-gallery.png +0 -0
  93. package/dist/resources/Assets/Textures/maki/bakery.png +0 -0
  94. package/dist/resources/Assets/Textures/maki/bank.png +0 -0
  95. package/dist/resources/Assets/Textures/maki/bar.png +0 -0
  96. package/dist/resources/Assets/Textures/maki/baseball.png +0 -0
  97. package/dist/resources/Assets/Textures/maki/basketball.png +0 -0
  98. package/dist/resources/Assets/Textures/maki/beer.png +0 -0
  99. package/dist/resources/Assets/Textures/maki/bicycle.png +0 -0
  100. package/dist/resources/Assets/Textures/maki/building.png +0 -0
  101. package/dist/resources/Assets/Textures/maki/bus.png +0 -0
  102. package/dist/resources/Assets/Textures/maki/cafe.png +0 -0
  103. package/dist/resources/Assets/Textures/maki/camera.png +0 -0
  104. package/dist/resources/Assets/Textures/maki/campsite.png +0 -0
  105. package/dist/resources/Assets/Textures/maki/car.png +0 -0
  106. package/dist/resources/Assets/Textures/maki/cemetery.png +0 -0
  107. package/dist/resources/Assets/Textures/maki/cesium.png +0 -0
  108. package/dist/resources/Assets/Textures/maki/chemist.png +0 -0
  109. package/dist/resources/Assets/Textures/maki/cinema.png +0 -0
  110. package/dist/resources/Assets/Textures/maki/circle-stroked.png +0 -0
  111. package/dist/resources/Assets/Textures/maki/circle.png +0 -0
  112. package/dist/resources/Assets/Textures/maki/city.png +0 -0
  113. package/dist/resources/Assets/Textures/maki/clothing-store.png +0 -0
  114. package/dist/resources/Assets/Textures/maki/college.png +0 -0
  115. package/dist/resources/Assets/Textures/maki/commercial.png +0 -0
  116. package/dist/resources/Assets/Textures/maki/cricket.png +0 -0
  117. package/dist/resources/Assets/Textures/maki/cross.png +0 -0
  118. package/dist/resources/Assets/Textures/maki/dam.png +0 -0
  119. package/dist/resources/Assets/Textures/maki/danger.png +0 -0
  120. package/dist/resources/Assets/Textures/maki/disability.png +0 -0
  121. package/dist/resources/Assets/Textures/maki/dog-park.png +0 -0
  122. package/dist/resources/Assets/Textures/maki/embassy.png +0 -0
  123. package/dist/resources/Assets/Textures/maki/emergency-telephone.png +0 -0
  124. package/dist/resources/Assets/Textures/maki/entrance.png +0 -0
  125. package/dist/resources/Assets/Textures/maki/farm.png +0 -0
  126. package/dist/resources/Assets/Textures/maki/fast-food.png +0 -0
  127. package/dist/resources/Assets/Textures/maki/ferry.png +0 -0
  128. package/dist/resources/Assets/Textures/maki/fire-station.png +0 -0
  129. package/dist/resources/Assets/Textures/maki/fuel.png +0 -0
  130. package/dist/resources/Assets/Textures/maki/garden.png +0 -0
  131. package/dist/resources/Assets/Textures/maki/gift.png +0 -0
  132. package/dist/resources/Assets/Textures/maki/golf.png +0 -0
  133. package/dist/resources/Assets/Textures/maki/grocery.png +0 -0
  134. package/dist/resources/Assets/Textures/maki/hairdresser.png +0 -0
  135. package/dist/resources/Assets/Textures/maki/harbor.png +0 -0
  136. package/dist/resources/Assets/Textures/maki/heart.png +0 -0
  137. package/dist/resources/Assets/Textures/maki/heliport.png +0 -0
  138. package/dist/resources/Assets/Textures/maki/hospital.png +0 -0
  139. package/dist/resources/Assets/Textures/maki/ice-cream.png +0 -0
  140. package/dist/resources/Assets/Textures/maki/industrial.png +0 -0
  141. package/dist/resources/Assets/Textures/maki/land-use.png +0 -0
  142. package/dist/resources/Assets/Textures/maki/laundry.png +0 -0
  143. package/dist/resources/Assets/Textures/maki/library.png +0 -0
  144. package/dist/resources/Assets/Textures/maki/lighthouse.png +0 -0
  145. package/dist/resources/Assets/Textures/maki/lodging.png +0 -0
  146. package/dist/resources/Assets/Textures/maki/logging.png +0 -0
  147. package/dist/resources/Assets/Textures/maki/london-underground.png +0 -0
  148. package/dist/resources/Assets/Textures/maki/marker-stroked.png +0 -0
  149. package/dist/resources/Assets/Textures/maki/marker.png +0 -0
  150. package/dist/resources/Assets/Textures/maki/minefield.png +0 -0
  151. package/dist/resources/Assets/Textures/maki/mobilephone.png +0 -0
  152. package/dist/resources/Assets/Textures/maki/monument.png +0 -0
  153. package/dist/resources/Assets/Textures/maki/museum.png +0 -0
  154. package/dist/resources/Assets/Textures/maki/music.png +0 -0
  155. package/dist/resources/Assets/Textures/maki/oil-well.png +0 -0
  156. package/dist/resources/Assets/Textures/maki/park.png +0 -0
  157. package/dist/resources/Assets/Textures/maki/park2.png +0 -0
  158. package/dist/resources/Assets/Textures/maki/parking-garage.png +0 -0
  159. package/dist/resources/Assets/Textures/maki/parking.png +0 -0
  160. package/dist/resources/Assets/Textures/maki/pharmacy.png +0 -0
  161. package/dist/resources/Assets/Textures/maki/pitch.png +0 -0
  162. package/dist/resources/Assets/Textures/maki/place-of-worship.png +0 -0
  163. package/dist/resources/Assets/Textures/maki/playground.png +0 -0
  164. package/dist/resources/Assets/Textures/maki/police.png +0 -0
  165. package/dist/resources/Assets/Textures/maki/polling-place.png +0 -0
  166. package/dist/resources/Assets/Textures/maki/post.png +0 -0
  167. package/dist/resources/Assets/Textures/maki/prison.png +0 -0
  168. package/dist/resources/Assets/Textures/maki/rail-above.png +0 -0
  169. package/dist/resources/Assets/Textures/maki/rail-light.png +0 -0
  170. package/dist/resources/Assets/Textures/maki/rail-metro.png +0 -0
  171. package/dist/resources/Assets/Textures/maki/rail-underground.png +0 -0
  172. package/dist/resources/Assets/Textures/maki/rail.png +0 -0
  173. package/dist/resources/Assets/Textures/maki/religious-christian.png +0 -0
  174. package/dist/resources/Assets/Textures/maki/religious-jewish.png +0 -0
  175. package/dist/resources/Assets/Textures/maki/religious-muslim.png +0 -0
  176. package/dist/resources/Assets/Textures/maki/restaurant.png +0 -0
  177. package/dist/resources/Assets/Textures/maki/roadblock.png +0 -0
  178. package/dist/resources/Assets/Textures/maki/rocket.png +0 -0
  179. package/dist/resources/Assets/Textures/maki/school.png +0 -0
  180. package/dist/resources/Assets/Textures/maki/scooter.png +0 -0
  181. package/dist/resources/Assets/Textures/maki/shop.png +0 -0
  182. package/dist/resources/Assets/Textures/maki/skiing.png +0 -0
  183. package/dist/resources/Assets/Textures/maki/slaughterhouse.png +0 -0
  184. package/dist/resources/Assets/Textures/maki/soccer.png +0 -0
  185. package/dist/resources/Assets/Textures/maki/square-stroked.png +0 -0
  186. package/dist/resources/Assets/Textures/maki/square.png +0 -0
  187. package/dist/resources/Assets/Textures/maki/star-stroked.png +0 -0
  188. package/dist/resources/Assets/Textures/maki/star.png +0 -0
  189. package/dist/resources/Assets/Textures/maki/suitcase.png +0 -0
  190. package/dist/resources/Assets/Textures/maki/swimming.png +0 -0
  191. package/dist/resources/Assets/Textures/maki/telephone.png +0 -0
  192. package/dist/resources/Assets/Textures/maki/tennis.png +0 -0
  193. package/dist/resources/Assets/Textures/maki/theatre.png +0 -0
  194. package/dist/resources/Assets/Textures/maki/toilets.png +0 -0
  195. package/dist/resources/Assets/Textures/maki/town-hall.png +0 -0
  196. package/dist/resources/Assets/Textures/maki/town.png +0 -0
  197. package/dist/resources/Assets/Textures/maki/triangle-stroked.png +0 -0
  198. package/dist/resources/Assets/Textures/maki/triangle.png +0 -0
  199. package/dist/resources/Assets/Textures/maki/village.png +0 -0
  200. package/dist/resources/Assets/Textures/maki/warehouse.png +0 -0
  201. package/dist/resources/Assets/Textures/maki/waste-basket.png +0 -0
  202. package/dist/resources/Assets/Textures/maki/water.png +0 -0
  203. package/dist/resources/Assets/Textures/maki/wetland.png +0 -0
  204. package/dist/resources/Assets/Textures/maki/zoo.png +0 -0
  205. package/dist/resources/Assets/Textures/moonSmall.jpg +0 -0
  206. package/dist/resources/Assets/Textures/pin.svg +1 -0
  207. package/dist/resources/Assets/Textures/waterNormals.jpg +0 -0
  208. package/dist/resources/Assets/Textures/waterNormalsSmall.jpg +0 -0
  209. package/dist/resources/Assets/approximateTerrainHeights.json +1 -0
  210. package/dist/resources/ThirdParty/Workers/basis_transcoder.js +21 -0
  211. package/dist/resources/ThirdParty/Workers/package.json +1 -0
  212. package/dist/resources/ThirdParty/Workers/pako_deflate.min.js +2 -0
  213. package/dist/resources/ThirdParty/Workers/pako_inflate.min.js +2 -0
  214. package/dist/resources/ThirdParty/Workers/z-worker-pako.js +1 -0
  215. package/dist/resources/ThirdParty/basis_transcoder.wasm +0 -0
  216. package/dist/resources/ThirdParty/draco_decoder.wasm +0 -0
  217. package/dist/resources/ThirdParty/google-earth-dbroot-parser.js +8337 -0
  218. package/dist/resources/Workers/chunk-3PW6ZBN4.js +2977 -0
  219. package/dist/resources/Workers/chunk-434ZTTFX.js +73 -0
  220. package/dist/resources/Workers/chunk-4KP73B43.js +73 -0
  221. package/dist/resources/Workers/chunk-52VSIKEA.js +2716 -0
  222. package/dist/resources/Workers/chunk-5GDBZTHX.js +1075 -0
  223. package/dist/resources/Workers/chunk-5HLGKKG3.js +163 -0
  224. package/dist/resources/Workers/chunk-5IRLXUTA.js +1258 -0
  225. package/dist/resources/Workers/chunk-5SK36PU4.js +430 -0
  226. package/dist/resources/Workers/chunk-ARPTYYKS.js +258 -0
  227. package/dist/resources/Workers/chunk-ATB2I7OS.js +55 -0
  228. package/dist/resources/Workers/chunk-AXFRNOVC.js +368 -0
  229. package/dist/resources/Workers/chunk-BP467WX3.js +501 -0
  230. package/dist/resources/Workers/chunk-BUZDZBUH.js +1007 -0
  231. package/dist/resources/Workers/chunk-CDGHUKQ4.js +1477 -0
  232. package/dist/resources/Workers/chunk-CSIZ3BGT.js +398 -0
  233. package/dist/resources/Workers/chunk-CWJQGBWT.js +39 -0
  234. package/dist/resources/Workers/chunk-DMCSY5BU.js +100 -0
  235. package/dist/resources/Workers/chunk-DR5XZ6K5.js +390 -0
  236. package/dist/resources/Workers/chunk-FWGNCYP6.js +476 -0
  237. package/dist/resources/Workers/chunk-GF5TNNKP.js +353 -0
  238. package/dist/resources/Workers/chunk-GVL5I7TC.js +1052 -0
  239. package/dist/resources/Workers/chunk-H5DUXHCV.js +421 -0
  240. package/dist/resources/Workers/chunk-HFKSAB5K.js +511 -0
  241. package/dist/resources/Workers/chunk-HOT2SNXP.js +8639 -0
  242. package/dist/resources/Workers/chunk-HPH5HSFE.js +1860 -0
  243. package/dist/resources/Workers/chunk-HPP4JLNH.js +218 -0
  244. package/dist/resources/Workers/chunk-HUPNRBWW.js +196 -0
  245. package/dist/resources/Workers/chunk-JGG36SQV.js +102 -0
  246. package/dist/resources/Workers/chunk-LGJUI2CE.js +2361 -0
  247. package/dist/resources/Workers/chunk-LGL4P5KL.js +171 -0
  248. package/dist/resources/Workers/chunk-LX6XV4DK.js +138 -0
  249. package/dist/resources/Workers/chunk-MN34FIF5.js +37 -0
  250. package/dist/resources/Workers/chunk-MW3CJYLX.js +101 -0
  251. package/dist/resources/Workers/chunk-NE4JNU6H.js +767 -0
  252. package/dist/resources/Workers/chunk-O43GWBSF.js +55 -0
  253. package/dist/resources/Workers/chunk-PIXK6KHB.js +44 -0
  254. package/dist/resources/Workers/chunk-PZ2WJWUG.js +634 -0
  255. package/dist/resources/Workers/chunk-QRBRVGZC.js +305 -0
  256. package/dist/resources/Workers/chunk-QTZQZY2C.js +669 -0
  257. package/dist/resources/Workers/chunk-R3HUGXBH.js +302 -0
  258. package/dist/resources/Workers/chunk-R4OZKBXH.js +456 -0
  259. package/dist/resources/Workers/chunk-RH4N2ONY.js +236 -0
  260. package/dist/resources/Workers/chunk-RIDPF7PO.js +58 -0
  261. package/dist/resources/Workers/chunk-SNN7WOC2.js +781 -0
  262. package/dist/resources/Workers/chunk-SQVTYRZY.js +122 -0
  263. package/dist/resources/Workers/chunk-SV7DDPAC.js +629 -0
  264. package/dist/resources/Workers/chunk-TIXXVKUY.js +834 -0
  265. package/dist/resources/Workers/chunk-TMPVBFJQ.js +289 -0
  266. package/dist/resources/Workers/chunk-XUTVA4K5.js +684 -0
  267. package/dist/resources/Workers/chunk-Y4OJ4B23.js +59 -0
  268. package/dist/resources/Workers/chunk-YBKFS53K.js +77 -0
  269. package/dist/resources/Workers/chunk-Z2SIPUKB.js +117 -0
  270. package/dist/resources/Workers/chunk-Z4JUBRHP.js +157 -0
  271. package/dist/resources/Workers/chunk-ZQRZBHYI.js +138 -0
  272. package/dist/resources/Workers/combineGeometry.js +67 -0
  273. package/dist/resources/Workers/createBoxGeometry.js +57 -0
  274. package/dist/resources/Workers/createBoxOutlineGeometry.js +234 -0
  275. package/dist/resources/Workers/createCircleGeometry.js +196 -0
  276. package/dist/resources/Workers/createCircleOutlineGeometry.js +146 -0
  277. package/dist/resources/Workers/createCoplanarPolygonGeometry.js +505 -0
  278. package/dist/resources/Workers/createCoplanarPolygonOutlineGeometry.js +224 -0
  279. package/dist/resources/Workers/createCorridorGeometry.js +1263 -0
  280. package/dist/resources/Workers/createCorridorOutlineGeometry.js +568 -0
  281. package/dist/resources/Workers/createCylinderGeometry.js +59 -0
  282. package/dist/resources/Workers/createCylinderOutlineGeometry.js +230 -0
  283. package/dist/resources/Workers/createEllipseGeometry.js +70 -0
  284. package/dist/resources/Workers/createEllipseOutlineGeometry.js +63 -0
  285. package/dist/resources/Workers/createEllipsoidGeometry.js +58 -0
  286. package/dist/resources/Workers/createEllipsoidOutlineGeometry.js +60 -0
  287. package/dist/resources/Workers/createFrustumGeometry.js +57 -0
  288. package/dist/resources/Workers/createFrustumOutlineGeometry.js +234 -0
  289. package/dist/resources/Workers/createGeometry.js +150 -0
  290. package/dist/resources/Workers/createGroundPolylineGeometry.js +1607 -0
  291. package/dist/resources/Workers/createPlaneGeometry.js +223 -0
  292. package/dist/resources/Workers/createPlaneOutlineGeometry.js +123 -0
  293. package/dist/resources/Workers/createPolygonGeometry.js +1545 -0
  294. package/dist/resources/Workers/createPolygonOutlineGeometry.js +542 -0
  295. package/dist/resources/Workers/createPolylineGeometry.js +495 -0
  296. package/dist/resources/Workers/createPolylineVolumeGeometry.js +380 -0
  297. package/dist/resources/Workers/createPolylineVolumeOutlineGeometry.js +277 -0
  298. package/dist/resources/Workers/createRectangleGeometry.js +1273 -0
  299. package/dist/resources/Workers/createRectangleOutlineGeometry.js +478 -0
  300. package/dist/resources/Workers/createSimplePolylineGeometry.js +399 -0
  301. package/dist/resources/Workers/createSphereGeometry.js +117 -0
  302. package/dist/resources/Workers/createSphereOutlineGeometry.js +117 -0
  303. package/dist/resources/Workers/createTaskProcessorWorker.js +32 -0
  304. package/dist/resources/Workers/createVectorTileClampedPolylines.js +492 -0
  305. package/dist/resources/Workers/createVectorTileGeometries.js +386 -0
  306. package/dist/resources/Workers/createVectorTilePoints.js +112 -0
  307. package/dist/resources/Workers/createVectorTilePolygons.js +384 -0
  308. package/dist/resources/Workers/createVectorTilePolylines.js +262 -0
  309. package/dist/resources/Workers/createVerticesFromGoogleEarthEnterpriseBuffer.js +568 -0
  310. package/dist/resources/Workers/createVerticesFromHeightmap.js +2277 -0
  311. package/dist/resources/Workers/createVerticesFromQuantizedTerrainMesh.js +745 -0
  312. package/dist/resources/Workers/createWallGeometry.js +489 -0
  313. package/dist/resources/Workers/createWallOutlineGeometry.js +337 -0
  314. package/dist/resources/Workers/decodeDraco.js +369 -0
  315. package/dist/resources/Workers/decodeGoogleEarthEnterprisePacket.js +2650 -0
  316. package/dist/resources/Workers/decodeI3S.js +835 -0
  317. package/dist/resources/Workers/transcodeKTX2.js +3425 -0
  318. package/dist/resources/Workers/transferTypedArrayTest.js +41 -0
  319. package/dist/resources/Workers/upsampleQuantizedTerrainMesh.js +818 -0
  320. package/package.json +81 -0
@@ -0,0 +1,745 @@
1
+ /**
2
+ * @license
3
+ * Cesium - https://github.com/CesiumGS/cesium
4
+ * Version 1.113
5
+ *
6
+ * Copyright 2011-2022 Cesium Contributors
7
+ *
8
+ * Licensed under the Apache License, Version 2.0 (the "License");
9
+ * you may not use this file except in compliance with the License.
10
+ * You may obtain a copy of the License at
11
+ *
12
+ * http://www.apache.org/licenses/LICENSE-2.0
13
+ *
14
+ * Unless required by applicable law or agreed to in writing, software
15
+ * distributed under the License is distributed on an "AS IS" BASIS,
16
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17
+ * See the License for the specific language governing permissions and
18
+ * limitations under the License.
19
+ *
20
+ * Columbus View (Pat. Pend.)
21
+ *
22
+ * Portions licensed separately.
23
+ * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details.
24
+ */
25
+
26
+ import {
27
+ EllipsoidalOccluder_default,
28
+ TerrainEncoding_default
29
+ } from "./chunk-NE4JNU6H.js";
30
+ import {
31
+ createTaskProcessorWorker_default
32
+ } from "./chunk-MW3CJYLX.js";
33
+ import {
34
+ WebMercatorProjection_default
35
+ } from "./chunk-Z2SIPUKB.js";
36
+ import "./chunk-5SK36PU4.js";
37
+ import {
38
+ AxisAlignedBoundingBox_default
39
+ } from "./chunk-Z4JUBRHP.js";
40
+ import {
41
+ IndexDatatype_default
42
+ } from "./chunk-LX6XV4DK.js";
43
+ import {
44
+ Transforms_default
45
+ } from "./chunk-HOT2SNXP.js";
46
+ import "./chunk-4KP73B43.js";
47
+ import {
48
+ Matrix4_default,
49
+ Rectangle_default
50
+ } from "./chunk-3PW6ZBN4.js";
51
+ import "./chunk-ARPTYYKS.js";
52
+ import {
53
+ Cartesian2_default,
54
+ Cartesian3_default,
55
+ Cartographic_default,
56
+ Ellipsoid_default
57
+ } from "./chunk-LGJUI2CE.js";
58
+ import {
59
+ Math_default
60
+ } from "./chunk-BP467WX3.js";
61
+ import "./chunk-SV7DDPAC.js";
62
+ import "./chunk-RIDPF7PO.js";
63
+ import "./chunk-CWJQGBWT.js";
64
+ import {
65
+ DeveloperError_default
66
+ } from "./chunk-5HLGKKG3.js";
67
+ import {
68
+ defined_default
69
+ } from "./chunk-YBKFS53K.js";
70
+
71
+ // packages/engine/Source/Core/TerrainProvider.js
72
+ function TerrainProvider() {
73
+ DeveloperError_default.throwInstantiationError();
74
+ }
75
+ Object.defineProperties(TerrainProvider.prototype, {
76
+ /**
77
+ * Gets an event that is raised when the terrain provider encounters an asynchronous error. By subscribing
78
+ * to the event, you will be notified of the error and can potentially recover from it. Event listeners
79
+ * are passed an instance of {@link TileProviderError}.
80
+ * @memberof TerrainProvider.prototype
81
+ * @type {Event<TerrainProvider.ErrorEvent>}
82
+ * @readonly
83
+ */
84
+ errorEvent: {
85
+ get: DeveloperError_default.throwInstantiationError
86
+ },
87
+ /**
88
+ * Gets the credit to display when this terrain provider is active. Typically this is used to credit
89
+ * the source of the terrain.
90
+ * @memberof TerrainProvider.prototype
91
+ * @type {Credit}
92
+ * @readonly
93
+ */
94
+ credit: {
95
+ get: DeveloperError_default.throwInstantiationError
96
+ },
97
+ /**
98
+ * Gets the tiling scheme used by the provider.
99
+ * @memberof TerrainProvider.prototype
100
+ * @type {TilingScheme}
101
+ * @readonly
102
+ */
103
+ tilingScheme: {
104
+ get: DeveloperError_default.throwInstantiationError
105
+ },
106
+ /**
107
+ * Gets a value indicating whether or not the provider includes a water mask. The water mask
108
+ * indicates which areas of the globe are water rather than land, so they can be rendered
109
+ * as a reflective surface with animated waves.
110
+ * @memberof TerrainProvider.prototype
111
+ * @type {boolean}
112
+ * @readonly
113
+ */
114
+ hasWaterMask: {
115
+ get: DeveloperError_default.throwInstantiationError
116
+ },
117
+ /**
118
+ * Gets a value indicating whether or not the requested tiles include vertex normals.
119
+ * @memberof TerrainProvider.prototype
120
+ * @type {boolean}
121
+ * @readonly
122
+ */
123
+ hasVertexNormals: {
124
+ get: DeveloperError_default.throwInstantiationError
125
+ },
126
+ /**
127
+ * Gets an object that can be used to determine availability of terrain from this provider, such as
128
+ * at points and in rectangles. This property may be undefined if availability
129
+ * information is not available.
130
+ * @memberof TerrainProvider.prototype
131
+ * @type {TileAvailability}
132
+ * @readonly
133
+ */
134
+ availability: {
135
+ get: DeveloperError_default.throwInstantiationError
136
+ }
137
+ });
138
+ var regularGridIndicesCache = [];
139
+ TerrainProvider.getRegularGridIndices = function(width, height) {
140
+ if (width * height >= Math_default.FOUR_GIGABYTES) {
141
+ throw new DeveloperError_default(
142
+ "The total number of vertices (width * height) must be less than 4,294,967,296."
143
+ );
144
+ }
145
+ let byWidth = regularGridIndicesCache[width];
146
+ if (!defined_default(byWidth)) {
147
+ regularGridIndicesCache[width] = byWidth = [];
148
+ }
149
+ let indices = byWidth[height];
150
+ if (!defined_default(indices)) {
151
+ if (width * height < Math_default.SIXTY_FOUR_KILOBYTES) {
152
+ indices = byWidth[height] = new Uint16Array(
153
+ (width - 1) * (height - 1) * 6
154
+ );
155
+ } else {
156
+ indices = byWidth[height] = new Uint32Array(
157
+ (width - 1) * (height - 1) * 6
158
+ );
159
+ }
160
+ addRegularGridIndices(width, height, indices, 0);
161
+ }
162
+ return indices;
163
+ };
164
+ var regularGridAndEdgeIndicesCache = [];
165
+ TerrainProvider.getRegularGridIndicesAndEdgeIndices = function(width, height) {
166
+ if (width * height >= Math_default.FOUR_GIGABYTES) {
167
+ throw new DeveloperError_default(
168
+ "The total number of vertices (width * height) must be less than 4,294,967,296."
169
+ );
170
+ }
171
+ let byWidth = regularGridAndEdgeIndicesCache[width];
172
+ if (!defined_default(byWidth)) {
173
+ regularGridAndEdgeIndicesCache[width] = byWidth = [];
174
+ }
175
+ let indicesAndEdges = byWidth[height];
176
+ if (!defined_default(indicesAndEdges)) {
177
+ const indices = TerrainProvider.getRegularGridIndices(width, height);
178
+ const edgeIndices = getEdgeIndices(width, height);
179
+ const westIndicesSouthToNorth = edgeIndices.westIndicesSouthToNorth;
180
+ const southIndicesEastToWest = edgeIndices.southIndicesEastToWest;
181
+ const eastIndicesNorthToSouth = edgeIndices.eastIndicesNorthToSouth;
182
+ const northIndicesWestToEast = edgeIndices.northIndicesWestToEast;
183
+ indicesAndEdges = byWidth[height] = {
184
+ indices,
185
+ westIndicesSouthToNorth,
186
+ southIndicesEastToWest,
187
+ eastIndicesNorthToSouth,
188
+ northIndicesWestToEast
189
+ };
190
+ }
191
+ return indicesAndEdges;
192
+ };
193
+ var regularGridAndSkirtAndEdgeIndicesCache = [];
194
+ TerrainProvider.getRegularGridAndSkirtIndicesAndEdgeIndices = function(width, height) {
195
+ if (width * height >= Math_default.FOUR_GIGABYTES) {
196
+ throw new DeveloperError_default(
197
+ "The total number of vertices (width * height) must be less than 4,294,967,296."
198
+ );
199
+ }
200
+ let byWidth = regularGridAndSkirtAndEdgeIndicesCache[width];
201
+ if (!defined_default(byWidth)) {
202
+ regularGridAndSkirtAndEdgeIndicesCache[width] = byWidth = [];
203
+ }
204
+ let indicesAndEdges = byWidth[height];
205
+ if (!defined_default(indicesAndEdges)) {
206
+ const gridVertexCount = width * height;
207
+ const gridIndexCount = (width - 1) * (height - 1) * 6;
208
+ const edgeVertexCount = width * 2 + height * 2;
209
+ const edgeIndexCount = Math.max(0, edgeVertexCount - 4) * 6;
210
+ const vertexCount = gridVertexCount + edgeVertexCount;
211
+ const indexCount = gridIndexCount + edgeIndexCount;
212
+ const edgeIndices = getEdgeIndices(width, height);
213
+ const westIndicesSouthToNorth = edgeIndices.westIndicesSouthToNorth;
214
+ const southIndicesEastToWest = edgeIndices.southIndicesEastToWest;
215
+ const eastIndicesNorthToSouth = edgeIndices.eastIndicesNorthToSouth;
216
+ const northIndicesWestToEast = edgeIndices.northIndicesWestToEast;
217
+ const indices = IndexDatatype_default.createTypedArray(vertexCount, indexCount);
218
+ addRegularGridIndices(width, height, indices, 0);
219
+ TerrainProvider.addSkirtIndices(
220
+ westIndicesSouthToNorth,
221
+ southIndicesEastToWest,
222
+ eastIndicesNorthToSouth,
223
+ northIndicesWestToEast,
224
+ gridVertexCount,
225
+ indices,
226
+ gridIndexCount
227
+ );
228
+ indicesAndEdges = byWidth[height] = {
229
+ indices,
230
+ westIndicesSouthToNorth,
231
+ southIndicesEastToWest,
232
+ eastIndicesNorthToSouth,
233
+ northIndicesWestToEast,
234
+ indexCountWithoutSkirts: gridIndexCount
235
+ };
236
+ }
237
+ return indicesAndEdges;
238
+ };
239
+ TerrainProvider.addSkirtIndices = function(westIndicesSouthToNorth, southIndicesEastToWest, eastIndicesNorthToSouth, northIndicesWestToEast, vertexCount, indices, offset) {
240
+ let vertexIndex = vertexCount;
241
+ offset = addSkirtIndices(
242
+ westIndicesSouthToNorth,
243
+ vertexIndex,
244
+ indices,
245
+ offset
246
+ );
247
+ vertexIndex += westIndicesSouthToNorth.length;
248
+ offset = addSkirtIndices(
249
+ southIndicesEastToWest,
250
+ vertexIndex,
251
+ indices,
252
+ offset
253
+ );
254
+ vertexIndex += southIndicesEastToWest.length;
255
+ offset = addSkirtIndices(
256
+ eastIndicesNorthToSouth,
257
+ vertexIndex,
258
+ indices,
259
+ offset
260
+ );
261
+ vertexIndex += eastIndicesNorthToSouth.length;
262
+ addSkirtIndices(northIndicesWestToEast, vertexIndex, indices, offset);
263
+ };
264
+ function getEdgeIndices(width, height) {
265
+ const westIndicesSouthToNorth = new Array(height);
266
+ const southIndicesEastToWest = new Array(width);
267
+ const eastIndicesNorthToSouth = new Array(height);
268
+ const northIndicesWestToEast = new Array(width);
269
+ let i;
270
+ for (i = 0; i < width; ++i) {
271
+ northIndicesWestToEast[i] = i;
272
+ southIndicesEastToWest[i] = width * height - 1 - i;
273
+ }
274
+ for (i = 0; i < height; ++i) {
275
+ eastIndicesNorthToSouth[i] = (i + 1) * width - 1;
276
+ westIndicesSouthToNorth[i] = (height - i - 1) * width;
277
+ }
278
+ return {
279
+ westIndicesSouthToNorth,
280
+ southIndicesEastToWest,
281
+ eastIndicesNorthToSouth,
282
+ northIndicesWestToEast
283
+ };
284
+ }
285
+ function addRegularGridIndices(width, height, indices, offset) {
286
+ let index = 0;
287
+ for (let j = 0; j < height - 1; ++j) {
288
+ for (let i = 0; i < width - 1; ++i) {
289
+ const upperLeft = index;
290
+ const lowerLeft = upperLeft + width;
291
+ const lowerRight = lowerLeft + 1;
292
+ const upperRight = upperLeft + 1;
293
+ indices[offset++] = upperLeft;
294
+ indices[offset++] = lowerLeft;
295
+ indices[offset++] = upperRight;
296
+ indices[offset++] = upperRight;
297
+ indices[offset++] = lowerLeft;
298
+ indices[offset++] = lowerRight;
299
+ ++index;
300
+ }
301
+ ++index;
302
+ }
303
+ }
304
+ function addSkirtIndices(edgeIndices, vertexIndex, indices, offset) {
305
+ let previousIndex = edgeIndices[0];
306
+ const length = edgeIndices.length;
307
+ for (let i = 1; i < length; ++i) {
308
+ const index = edgeIndices[i];
309
+ indices[offset++] = previousIndex;
310
+ indices[offset++] = index;
311
+ indices[offset++] = vertexIndex;
312
+ indices[offset++] = vertexIndex;
313
+ indices[offset++] = index;
314
+ indices[offset++] = vertexIndex + 1;
315
+ previousIndex = index;
316
+ ++vertexIndex;
317
+ }
318
+ return offset;
319
+ }
320
+ TerrainProvider.heightmapTerrainQuality = 0.25;
321
+ TerrainProvider.getEstimatedLevelZeroGeometricErrorForAHeightmap = function(ellipsoid, tileImageWidth, numberOfTilesAtLevelZero) {
322
+ return ellipsoid.maximumRadius * 2 * Math.PI * TerrainProvider.heightmapTerrainQuality / (tileImageWidth * numberOfTilesAtLevelZero);
323
+ };
324
+ TerrainProvider.prototype.requestTileGeometry = DeveloperError_default.throwInstantiationError;
325
+ TerrainProvider.prototype.getLevelMaximumGeometricError = DeveloperError_default.throwInstantiationError;
326
+ TerrainProvider.prototype.getTileDataAvailable = DeveloperError_default.throwInstantiationError;
327
+ TerrainProvider.prototype.loadTileDataAvailability = DeveloperError_default.throwInstantiationError;
328
+ var TerrainProvider_default = TerrainProvider;
329
+
330
+ // packages/engine/Source/Workers/createVerticesFromQuantizedTerrainMesh.js
331
+ var maxShort = 32767;
332
+ var cartesian3Scratch = new Cartesian3_default();
333
+ var scratchMinimum = new Cartesian3_default();
334
+ var scratchMaximum = new Cartesian3_default();
335
+ var cartographicScratch = new Cartographic_default();
336
+ var toPack = new Cartesian2_default();
337
+ function createVerticesFromQuantizedTerrainMesh(parameters, transferableObjects) {
338
+ const quantizedVertices = parameters.quantizedVertices;
339
+ const quantizedVertexCount = quantizedVertices.length / 3;
340
+ const octEncodedNormals = parameters.octEncodedNormals;
341
+ const edgeVertexCount = parameters.westIndices.length + parameters.eastIndices.length + parameters.southIndices.length + parameters.northIndices.length;
342
+ const includeWebMercatorT = parameters.includeWebMercatorT;
343
+ const exaggeration = parameters.exaggeration;
344
+ const exaggerationRelativeHeight = parameters.exaggerationRelativeHeight;
345
+ const hasExaggeration = exaggeration !== 1;
346
+ const includeGeodeticSurfaceNormals = hasExaggeration;
347
+ const rectangle = Rectangle_default.clone(parameters.rectangle);
348
+ const west = rectangle.west;
349
+ const south = rectangle.south;
350
+ const east = rectangle.east;
351
+ const north = rectangle.north;
352
+ const ellipsoid = Ellipsoid_default.clone(parameters.ellipsoid);
353
+ const minimumHeight = parameters.minimumHeight;
354
+ const maximumHeight = parameters.maximumHeight;
355
+ const center = parameters.relativeToCenter;
356
+ const fromENU = Transforms_default.eastNorthUpToFixedFrame(center, ellipsoid);
357
+ const toENU = Matrix4_default.inverseTransformation(fromENU, new Matrix4_default());
358
+ let southMercatorY;
359
+ let oneOverMercatorHeight;
360
+ if (includeWebMercatorT) {
361
+ southMercatorY = WebMercatorProjection_default.geodeticLatitudeToMercatorAngle(
362
+ south
363
+ );
364
+ oneOverMercatorHeight = 1 / (WebMercatorProjection_default.geodeticLatitudeToMercatorAngle(north) - southMercatorY);
365
+ }
366
+ const uBuffer = quantizedVertices.subarray(0, quantizedVertexCount);
367
+ const vBuffer = quantizedVertices.subarray(
368
+ quantizedVertexCount,
369
+ 2 * quantizedVertexCount
370
+ );
371
+ const heightBuffer = quantizedVertices.subarray(
372
+ quantizedVertexCount * 2,
373
+ 3 * quantizedVertexCount
374
+ );
375
+ const hasVertexNormals = defined_default(octEncodedNormals);
376
+ const uvs = new Array(quantizedVertexCount);
377
+ const heights = new Array(quantizedVertexCount);
378
+ const positions = new Array(quantizedVertexCount);
379
+ const webMercatorTs = includeWebMercatorT ? new Array(quantizedVertexCount) : [];
380
+ const geodeticSurfaceNormals = includeGeodeticSurfaceNormals ? new Array(quantizedVertexCount) : [];
381
+ const minimum = scratchMinimum;
382
+ minimum.x = Number.POSITIVE_INFINITY;
383
+ minimum.y = Number.POSITIVE_INFINITY;
384
+ minimum.z = Number.POSITIVE_INFINITY;
385
+ const maximum = scratchMaximum;
386
+ maximum.x = Number.NEGATIVE_INFINITY;
387
+ maximum.y = Number.NEGATIVE_INFINITY;
388
+ maximum.z = Number.NEGATIVE_INFINITY;
389
+ let minLongitude = Number.POSITIVE_INFINITY;
390
+ let maxLongitude = Number.NEGATIVE_INFINITY;
391
+ let minLatitude = Number.POSITIVE_INFINITY;
392
+ let maxLatitude = Number.NEGATIVE_INFINITY;
393
+ for (let i = 0; i < quantizedVertexCount; ++i) {
394
+ const rawU = uBuffer[i];
395
+ const rawV = vBuffer[i];
396
+ const u = rawU / maxShort;
397
+ const v = rawV / maxShort;
398
+ const height = Math_default.lerp(
399
+ minimumHeight,
400
+ maximumHeight,
401
+ heightBuffer[i] / maxShort
402
+ );
403
+ cartographicScratch.longitude = Math_default.lerp(west, east, u);
404
+ cartographicScratch.latitude = Math_default.lerp(south, north, v);
405
+ cartographicScratch.height = height;
406
+ minLongitude = Math.min(cartographicScratch.longitude, minLongitude);
407
+ maxLongitude = Math.max(cartographicScratch.longitude, maxLongitude);
408
+ minLatitude = Math.min(cartographicScratch.latitude, minLatitude);
409
+ maxLatitude = Math.max(cartographicScratch.latitude, maxLatitude);
410
+ const position = ellipsoid.cartographicToCartesian(cartographicScratch);
411
+ uvs[i] = new Cartesian2_default(u, v);
412
+ heights[i] = height;
413
+ positions[i] = position;
414
+ if (includeWebMercatorT) {
415
+ webMercatorTs[i] = (WebMercatorProjection_default.geodeticLatitudeToMercatorAngle(
416
+ cartographicScratch.latitude
417
+ ) - southMercatorY) * oneOverMercatorHeight;
418
+ }
419
+ if (includeGeodeticSurfaceNormals) {
420
+ geodeticSurfaceNormals[i] = ellipsoid.geodeticSurfaceNormal(position);
421
+ }
422
+ Matrix4_default.multiplyByPoint(toENU, position, cartesian3Scratch);
423
+ Cartesian3_default.minimumByComponent(cartesian3Scratch, minimum, minimum);
424
+ Cartesian3_default.maximumByComponent(cartesian3Scratch, maximum, maximum);
425
+ }
426
+ const westIndicesSouthToNorth = copyAndSort(parameters.westIndices, function(a, b) {
427
+ return uvs[a].y - uvs[b].y;
428
+ });
429
+ const eastIndicesNorthToSouth = copyAndSort(parameters.eastIndices, function(a, b) {
430
+ return uvs[b].y - uvs[a].y;
431
+ });
432
+ const southIndicesEastToWest = copyAndSort(parameters.southIndices, function(a, b) {
433
+ return uvs[b].x - uvs[a].x;
434
+ });
435
+ const northIndicesWestToEast = copyAndSort(parameters.northIndices, function(a, b) {
436
+ return uvs[a].x - uvs[b].x;
437
+ });
438
+ let occludeePointInScaledSpace;
439
+ if (minimumHeight < 0) {
440
+ const occluder = new EllipsoidalOccluder_default(ellipsoid);
441
+ occludeePointInScaledSpace = occluder.computeHorizonCullingPointPossiblyUnderEllipsoid(
442
+ center,
443
+ positions,
444
+ minimumHeight
445
+ );
446
+ }
447
+ let hMin = minimumHeight;
448
+ hMin = Math.min(
449
+ hMin,
450
+ findMinMaxSkirts(
451
+ parameters.westIndices,
452
+ parameters.westSkirtHeight,
453
+ heights,
454
+ uvs,
455
+ rectangle,
456
+ ellipsoid,
457
+ toENU,
458
+ minimum,
459
+ maximum
460
+ )
461
+ );
462
+ hMin = Math.min(
463
+ hMin,
464
+ findMinMaxSkirts(
465
+ parameters.southIndices,
466
+ parameters.southSkirtHeight,
467
+ heights,
468
+ uvs,
469
+ rectangle,
470
+ ellipsoid,
471
+ toENU,
472
+ minimum,
473
+ maximum
474
+ )
475
+ );
476
+ hMin = Math.min(
477
+ hMin,
478
+ findMinMaxSkirts(
479
+ parameters.eastIndices,
480
+ parameters.eastSkirtHeight,
481
+ heights,
482
+ uvs,
483
+ rectangle,
484
+ ellipsoid,
485
+ toENU,
486
+ minimum,
487
+ maximum
488
+ )
489
+ );
490
+ hMin = Math.min(
491
+ hMin,
492
+ findMinMaxSkirts(
493
+ parameters.northIndices,
494
+ parameters.northSkirtHeight,
495
+ heights,
496
+ uvs,
497
+ rectangle,
498
+ ellipsoid,
499
+ toENU,
500
+ minimum,
501
+ maximum
502
+ )
503
+ );
504
+ const aaBox = new AxisAlignedBoundingBox_default(minimum, maximum, center);
505
+ const encoding = new TerrainEncoding_default(
506
+ center,
507
+ aaBox,
508
+ hMin,
509
+ maximumHeight,
510
+ fromENU,
511
+ hasVertexNormals,
512
+ includeWebMercatorT,
513
+ includeGeodeticSurfaceNormals,
514
+ exaggeration,
515
+ exaggerationRelativeHeight
516
+ );
517
+ const vertexStride = encoding.stride;
518
+ const size = quantizedVertexCount * vertexStride + edgeVertexCount * vertexStride;
519
+ const vertexBuffer = new Float32Array(size);
520
+ let bufferIndex = 0;
521
+ for (let j = 0; j < quantizedVertexCount; ++j) {
522
+ if (hasVertexNormals) {
523
+ const n = j * 2;
524
+ toPack.x = octEncodedNormals[n];
525
+ toPack.y = octEncodedNormals[n + 1];
526
+ }
527
+ bufferIndex = encoding.encode(
528
+ vertexBuffer,
529
+ bufferIndex,
530
+ positions[j],
531
+ uvs[j],
532
+ heights[j],
533
+ toPack,
534
+ webMercatorTs[j],
535
+ geodeticSurfaceNormals[j]
536
+ );
537
+ }
538
+ const edgeTriangleCount = Math.max(0, (edgeVertexCount - 4) * 2);
539
+ const indexBufferLength = parameters.indices.length + edgeTriangleCount * 3;
540
+ const indexBuffer = IndexDatatype_default.createTypedArray(
541
+ quantizedVertexCount + edgeVertexCount,
542
+ indexBufferLength
543
+ );
544
+ indexBuffer.set(parameters.indices, 0);
545
+ const percentage = 1e-4;
546
+ const lonOffset = (maxLongitude - minLongitude) * percentage;
547
+ const latOffset = (maxLatitude - minLatitude) * percentage;
548
+ const westLongitudeOffset = -lonOffset;
549
+ const westLatitudeOffset = 0;
550
+ const eastLongitudeOffset = lonOffset;
551
+ const eastLatitudeOffset = 0;
552
+ const northLongitudeOffset = 0;
553
+ const northLatitudeOffset = latOffset;
554
+ const southLongitudeOffset = 0;
555
+ const southLatitudeOffset = -latOffset;
556
+ let vertexBufferIndex = quantizedVertexCount * vertexStride;
557
+ addSkirt(
558
+ vertexBuffer,
559
+ vertexBufferIndex,
560
+ westIndicesSouthToNorth,
561
+ encoding,
562
+ heights,
563
+ uvs,
564
+ octEncodedNormals,
565
+ ellipsoid,
566
+ rectangle,
567
+ parameters.westSkirtHeight,
568
+ southMercatorY,
569
+ oneOverMercatorHeight,
570
+ westLongitudeOffset,
571
+ westLatitudeOffset
572
+ );
573
+ vertexBufferIndex += parameters.westIndices.length * vertexStride;
574
+ addSkirt(
575
+ vertexBuffer,
576
+ vertexBufferIndex,
577
+ southIndicesEastToWest,
578
+ encoding,
579
+ heights,
580
+ uvs,
581
+ octEncodedNormals,
582
+ ellipsoid,
583
+ rectangle,
584
+ parameters.southSkirtHeight,
585
+ southMercatorY,
586
+ oneOverMercatorHeight,
587
+ southLongitudeOffset,
588
+ southLatitudeOffset
589
+ );
590
+ vertexBufferIndex += parameters.southIndices.length * vertexStride;
591
+ addSkirt(
592
+ vertexBuffer,
593
+ vertexBufferIndex,
594
+ eastIndicesNorthToSouth,
595
+ encoding,
596
+ heights,
597
+ uvs,
598
+ octEncodedNormals,
599
+ ellipsoid,
600
+ rectangle,
601
+ parameters.eastSkirtHeight,
602
+ southMercatorY,
603
+ oneOverMercatorHeight,
604
+ eastLongitudeOffset,
605
+ eastLatitudeOffset
606
+ );
607
+ vertexBufferIndex += parameters.eastIndices.length * vertexStride;
608
+ addSkirt(
609
+ vertexBuffer,
610
+ vertexBufferIndex,
611
+ northIndicesWestToEast,
612
+ encoding,
613
+ heights,
614
+ uvs,
615
+ octEncodedNormals,
616
+ ellipsoid,
617
+ rectangle,
618
+ parameters.northSkirtHeight,
619
+ southMercatorY,
620
+ oneOverMercatorHeight,
621
+ northLongitudeOffset,
622
+ northLatitudeOffset
623
+ );
624
+ TerrainProvider_default.addSkirtIndices(
625
+ westIndicesSouthToNorth,
626
+ southIndicesEastToWest,
627
+ eastIndicesNorthToSouth,
628
+ northIndicesWestToEast,
629
+ quantizedVertexCount,
630
+ indexBuffer,
631
+ parameters.indices.length
632
+ );
633
+ transferableObjects.push(vertexBuffer.buffer, indexBuffer.buffer);
634
+ return {
635
+ vertices: vertexBuffer.buffer,
636
+ indices: indexBuffer.buffer,
637
+ westIndicesSouthToNorth,
638
+ southIndicesEastToWest,
639
+ eastIndicesNorthToSouth,
640
+ northIndicesWestToEast,
641
+ vertexStride,
642
+ center,
643
+ minimumHeight,
644
+ maximumHeight,
645
+ occludeePointInScaledSpace,
646
+ encoding,
647
+ indexCountWithoutSkirts: parameters.indices.length
648
+ };
649
+ }
650
+ function findMinMaxSkirts(edgeIndices, edgeHeight, heights, uvs, rectangle, ellipsoid, toENU, minimum, maximum) {
651
+ let hMin = Number.POSITIVE_INFINITY;
652
+ const north = rectangle.north;
653
+ const south = rectangle.south;
654
+ let east = rectangle.east;
655
+ const west = rectangle.west;
656
+ if (east < west) {
657
+ east += Math_default.TWO_PI;
658
+ }
659
+ const length = edgeIndices.length;
660
+ for (let i = 0; i < length; ++i) {
661
+ const index = edgeIndices[i];
662
+ const h = heights[index];
663
+ const uv = uvs[index];
664
+ cartographicScratch.longitude = Math_default.lerp(west, east, uv.x);
665
+ cartographicScratch.latitude = Math_default.lerp(south, north, uv.y);
666
+ cartographicScratch.height = h - edgeHeight;
667
+ const position = ellipsoid.cartographicToCartesian(
668
+ cartographicScratch,
669
+ cartesian3Scratch
670
+ );
671
+ Matrix4_default.multiplyByPoint(toENU, position, position);
672
+ Cartesian3_default.minimumByComponent(position, minimum, minimum);
673
+ Cartesian3_default.maximumByComponent(position, maximum, maximum);
674
+ hMin = Math.min(hMin, cartographicScratch.height);
675
+ }
676
+ return hMin;
677
+ }
678
+ function addSkirt(vertexBuffer, vertexBufferIndex, edgeVertices, encoding, heights, uvs, octEncodedNormals, ellipsoid, rectangle, skirtLength, southMercatorY, oneOverMercatorHeight, longitudeOffset, latitudeOffset) {
679
+ const hasVertexNormals = defined_default(octEncodedNormals);
680
+ const north = rectangle.north;
681
+ const south = rectangle.south;
682
+ let east = rectangle.east;
683
+ const west = rectangle.west;
684
+ if (east < west) {
685
+ east += Math_default.TWO_PI;
686
+ }
687
+ const length = edgeVertices.length;
688
+ for (let i = 0; i < length; ++i) {
689
+ const index = edgeVertices[i];
690
+ const h = heights[index];
691
+ const uv = uvs[index];
692
+ cartographicScratch.longitude = Math_default.lerp(west, east, uv.x) + longitudeOffset;
693
+ cartographicScratch.latitude = Math_default.lerp(south, north, uv.y) + latitudeOffset;
694
+ cartographicScratch.height = h - skirtLength;
695
+ const position = ellipsoid.cartographicToCartesian(
696
+ cartographicScratch,
697
+ cartesian3Scratch
698
+ );
699
+ if (hasVertexNormals) {
700
+ const n = index * 2;
701
+ toPack.x = octEncodedNormals[n];
702
+ toPack.y = octEncodedNormals[n + 1];
703
+ }
704
+ let webMercatorT;
705
+ if (encoding.hasWebMercatorT) {
706
+ webMercatorT = (WebMercatorProjection_default.geodeticLatitudeToMercatorAngle(
707
+ cartographicScratch.latitude
708
+ ) - southMercatorY) * oneOverMercatorHeight;
709
+ }
710
+ let geodeticSurfaceNormal;
711
+ if (encoding.hasGeodeticSurfaceNormals) {
712
+ geodeticSurfaceNormal = ellipsoid.geodeticSurfaceNormal(position);
713
+ }
714
+ vertexBufferIndex = encoding.encode(
715
+ vertexBuffer,
716
+ vertexBufferIndex,
717
+ position,
718
+ uv,
719
+ cartographicScratch.height,
720
+ toPack,
721
+ webMercatorT,
722
+ geodeticSurfaceNormal
723
+ );
724
+ }
725
+ }
726
+ function copyAndSort(typedArray, comparator) {
727
+ let copy;
728
+ if (typeof typedArray.slice === "function") {
729
+ copy = typedArray.slice();
730
+ if (typeof copy.sort !== "function") {
731
+ copy = void 0;
732
+ }
733
+ }
734
+ if (!defined_default(copy)) {
735
+ copy = Array.prototype.slice.call(typedArray);
736
+ }
737
+ copy.sort(comparator);
738
+ return copy;
739
+ }
740
+ var createVerticesFromQuantizedTerrainMesh_default = createTaskProcessorWorker_default(
741
+ createVerticesFromQuantizedTerrainMesh
742
+ );
743
+ export {
744
+ createVerticesFromQuantizedTerrainMesh_default as default
745
+ };