@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,456 @@
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
+ Cartesian3_default,
28
+ Cartographic_default,
29
+ Ellipsoid_default
30
+ } from "./chunk-LGJUI2CE.js";
31
+ import {
32
+ Math_default
33
+ } from "./chunk-BP467WX3.js";
34
+ import {
35
+ defaultValue_default
36
+ } from "./chunk-CWJQGBWT.js";
37
+ import {
38
+ Check_default,
39
+ DeveloperError_default
40
+ } from "./chunk-5HLGKKG3.js";
41
+ import {
42
+ defined_default
43
+ } from "./chunk-YBKFS53K.js";
44
+
45
+ // packages/engine/Source/Core/EllipsoidRhumbLine.js
46
+ function calculateM(ellipticity, major, latitude) {
47
+ if (ellipticity === 0) {
48
+ return major * latitude;
49
+ }
50
+ const e2 = ellipticity * ellipticity;
51
+ const e4 = e2 * e2;
52
+ const e6 = e4 * e2;
53
+ const e8 = e6 * e2;
54
+ const e10 = e8 * e2;
55
+ const e12 = e10 * e2;
56
+ const phi = latitude;
57
+ const sin2Phi = Math.sin(2 * phi);
58
+ const sin4Phi = Math.sin(4 * phi);
59
+ const sin6Phi = Math.sin(6 * phi);
60
+ const sin8Phi = Math.sin(8 * phi);
61
+ const sin10Phi = Math.sin(10 * phi);
62
+ const sin12Phi = Math.sin(12 * phi);
63
+ return major * ((1 - e2 / 4 - 3 * e4 / 64 - 5 * e6 / 256 - 175 * e8 / 16384 - 441 * e10 / 65536 - 4851 * e12 / 1048576) * phi - (3 * e2 / 8 + 3 * e4 / 32 + 45 * e6 / 1024 + 105 * e8 / 4096 + 2205 * e10 / 131072 + 6237 * e12 / 524288) * sin2Phi + (15 * e4 / 256 + 45 * e6 / 1024 + 525 * e8 / 16384 + 1575 * e10 / 65536 + 155925 * e12 / 8388608) * sin4Phi - (35 * e6 / 3072 + 175 * e8 / 12288 + 3675 * e10 / 262144 + 13475 * e12 / 1048576) * sin6Phi + (315 * e8 / 131072 + 2205 * e10 / 524288 + 43659 * e12 / 8388608) * sin8Phi - (693 * e10 / 1310720 + 6237 * e12 / 5242880) * sin10Phi + 1001 * e12 / 8388608 * sin12Phi);
64
+ }
65
+ function calculateInverseM(M, ellipticity, major) {
66
+ const d = M / major;
67
+ if (ellipticity === 0) {
68
+ return d;
69
+ }
70
+ const d2 = d * d;
71
+ const d3 = d2 * d;
72
+ const d4 = d3 * d;
73
+ const e = ellipticity;
74
+ const e2 = e * e;
75
+ const e4 = e2 * e2;
76
+ const e6 = e4 * e2;
77
+ const e8 = e6 * e2;
78
+ const e10 = e8 * e2;
79
+ const e12 = e10 * e2;
80
+ const sin2D = Math.sin(2 * d);
81
+ const cos2D = Math.cos(2 * d);
82
+ const sin4D = Math.sin(4 * d);
83
+ const cos4D = Math.cos(4 * d);
84
+ const sin6D = Math.sin(6 * d);
85
+ const cos6D = Math.cos(6 * d);
86
+ const sin8D = Math.sin(8 * d);
87
+ const cos8D = Math.cos(8 * d);
88
+ const sin10D = Math.sin(10 * d);
89
+ const cos10D = Math.cos(10 * d);
90
+ const sin12D = Math.sin(12 * d);
91
+ return d + d * e2 / 4 + 7 * d * e4 / 64 + 15 * d * e6 / 256 + 579 * d * e8 / 16384 + 1515 * d * e10 / 65536 + 16837 * d * e12 / 1048576 + (3 * d * e4 / 16 + 45 * d * e6 / 256 - d * (32 * d2 - 561) * e8 / 4096 - d * (232 * d2 - 1677) * e10 / 16384 + d * (399985 - 90560 * d2 + 512 * d4) * e12 / 5242880) * cos2D + (21 * d * e6 / 256 + 483 * d * e8 / 4096 - d * (224 * d2 - 1969) * e10 / 16384 - d * (33152 * d2 - 112599) * e12 / 1048576) * cos4D + (151 * d * e8 / 4096 + 4681 * d * e10 / 65536 + 1479 * d * e12 / 16384 - 453 * d3 * e12 / 32768) * cos6D + (1097 * d * e10 / 65536 + 42783 * d * e12 / 1048576) * cos8D + 8011 * d * e12 / 1048576 * cos10D + (3 * e2 / 8 + 3 * e4 / 16 + 213 * e6 / 2048 - 3 * d2 * e6 / 64 + 255 * e8 / 4096 - 33 * d2 * e8 / 512 + 20861 * e10 / 524288 - 33 * d2 * e10 / 512 + d4 * e10 / 1024 + 28273 * e12 / 1048576 - 471 * d2 * e12 / 8192 + 9 * d4 * e12 / 4096) * sin2D + (21 * e4 / 256 + 21 * e6 / 256 + 533 * e8 / 8192 - 21 * d2 * e8 / 512 + 197 * e10 / 4096 - 315 * d2 * e10 / 4096 + 584039 * e12 / 16777216 - 12517 * d2 * e12 / 131072 + 7 * d4 * e12 / 2048) * sin4D + (151 * e6 / 6144 + 151 * e8 / 4096 + 5019 * e10 / 131072 - 453 * d2 * e10 / 16384 + 26965 * e12 / 786432 - 8607 * d2 * e12 / 131072) * sin6D + (1097 * e8 / 131072 + 1097 * e10 / 65536 + 225797 * e12 / 10485760 - 1097 * d2 * e12 / 65536) * sin8D + (8011 * e10 / 2621440 + 8011 * e12 / 1048576) * sin10D + 293393 * e12 / 251658240 * sin12D;
92
+ }
93
+ function calculateSigma(ellipticity, latitude) {
94
+ if (ellipticity === 0) {
95
+ return Math.log(Math.tan(0.5 * (Math_default.PI_OVER_TWO + latitude)));
96
+ }
97
+ const eSinL = ellipticity * Math.sin(latitude);
98
+ return Math.log(Math.tan(0.5 * (Math_default.PI_OVER_TWO + latitude))) - ellipticity / 2 * Math.log((1 + eSinL) / (1 - eSinL));
99
+ }
100
+ function calculateHeading(ellipsoidRhumbLine, firstLongitude, firstLatitude, secondLongitude, secondLatitude) {
101
+ const sigma1 = calculateSigma(ellipsoidRhumbLine._ellipticity, firstLatitude);
102
+ const sigma2 = calculateSigma(
103
+ ellipsoidRhumbLine._ellipticity,
104
+ secondLatitude
105
+ );
106
+ return Math.atan2(
107
+ Math_default.negativePiToPi(secondLongitude - firstLongitude),
108
+ sigma2 - sigma1
109
+ );
110
+ }
111
+ function calculateArcLength(ellipsoidRhumbLine, major, minor, firstLongitude, firstLatitude, secondLongitude, secondLatitude) {
112
+ const heading = ellipsoidRhumbLine._heading;
113
+ const deltaLongitude = secondLongitude - firstLongitude;
114
+ let distance = 0;
115
+ if (Math_default.equalsEpsilon(
116
+ Math.abs(heading),
117
+ Math_default.PI_OVER_TWO,
118
+ Math_default.EPSILON8
119
+ )) {
120
+ if (major === minor) {
121
+ distance = major * Math.cos(firstLatitude) * Math_default.negativePiToPi(deltaLongitude);
122
+ } else {
123
+ const sinPhi = Math.sin(firstLatitude);
124
+ distance = major * Math.cos(firstLatitude) * Math_default.negativePiToPi(deltaLongitude) / Math.sqrt(1 - ellipsoidRhumbLine._ellipticitySquared * sinPhi * sinPhi);
125
+ }
126
+ } else {
127
+ const M1 = calculateM(
128
+ ellipsoidRhumbLine._ellipticity,
129
+ major,
130
+ firstLatitude
131
+ );
132
+ const M2 = calculateM(
133
+ ellipsoidRhumbLine._ellipticity,
134
+ major,
135
+ secondLatitude
136
+ );
137
+ distance = (M2 - M1) / Math.cos(heading);
138
+ }
139
+ return Math.abs(distance);
140
+ }
141
+ var scratchCart1 = new Cartesian3_default();
142
+ var scratchCart2 = new Cartesian3_default();
143
+ function computeProperties(ellipsoidRhumbLine, start, end, ellipsoid) {
144
+ const firstCartesian = Cartesian3_default.normalize(
145
+ ellipsoid.cartographicToCartesian(start, scratchCart2),
146
+ scratchCart1
147
+ );
148
+ const lastCartesian = Cartesian3_default.normalize(
149
+ ellipsoid.cartographicToCartesian(end, scratchCart2),
150
+ scratchCart2
151
+ );
152
+ Check_default.typeOf.number.greaterThanOrEquals(
153
+ "value",
154
+ Math.abs(
155
+ Math.abs(Cartesian3_default.angleBetween(firstCartesian, lastCartesian)) - Math.PI
156
+ ),
157
+ 0.0125
158
+ );
159
+ const major = ellipsoid.maximumRadius;
160
+ const minor = ellipsoid.minimumRadius;
161
+ const majorSquared = major * major;
162
+ const minorSquared = minor * minor;
163
+ ellipsoidRhumbLine._ellipticitySquared = (majorSquared - minorSquared) / majorSquared;
164
+ ellipsoidRhumbLine._ellipticity = Math.sqrt(
165
+ ellipsoidRhumbLine._ellipticitySquared
166
+ );
167
+ ellipsoidRhumbLine._start = Cartographic_default.clone(
168
+ start,
169
+ ellipsoidRhumbLine._start
170
+ );
171
+ ellipsoidRhumbLine._start.height = 0;
172
+ ellipsoidRhumbLine._end = Cartographic_default.clone(end, ellipsoidRhumbLine._end);
173
+ ellipsoidRhumbLine._end.height = 0;
174
+ ellipsoidRhumbLine._heading = calculateHeading(
175
+ ellipsoidRhumbLine,
176
+ start.longitude,
177
+ start.latitude,
178
+ end.longitude,
179
+ end.latitude
180
+ );
181
+ ellipsoidRhumbLine._distance = calculateArcLength(
182
+ ellipsoidRhumbLine,
183
+ ellipsoid.maximumRadius,
184
+ ellipsoid.minimumRadius,
185
+ start.longitude,
186
+ start.latitude,
187
+ end.longitude,
188
+ end.latitude
189
+ );
190
+ }
191
+ function interpolateUsingSurfaceDistance(start, heading, distance, major, ellipticity, result) {
192
+ if (distance === 0) {
193
+ return Cartographic_default.clone(start, result);
194
+ }
195
+ const ellipticitySquared = ellipticity * ellipticity;
196
+ let longitude;
197
+ let latitude;
198
+ let deltaLongitude;
199
+ if (Math.abs(Math_default.PI_OVER_TWO - Math.abs(heading)) > Math_default.EPSILON8) {
200
+ const M1 = calculateM(ellipticity, major, start.latitude);
201
+ const deltaM = distance * Math.cos(heading);
202
+ const M2 = M1 + deltaM;
203
+ latitude = calculateInverseM(M2, ellipticity, major);
204
+ if (Math.abs(heading) < Math_default.EPSILON10) {
205
+ longitude = Math_default.negativePiToPi(start.longitude);
206
+ } else {
207
+ const sigma1 = calculateSigma(ellipticity, start.latitude);
208
+ const sigma2 = calculateSigma(ellipticity, latitude);
209
+ deltaLongitude = Math.tan(heading) * (sigma2 - sigma1);
210
+ longitude = Math_default.negativePiToPi(start.longitude + deltaLongitude);
211
+ }
212
+ } else {
213
+ latitude = start.latitude;
214
+ let localRad;
215
+ if (ellipticity === 0) {
216
+ localRad = major * Math.cos(start.latitude);
217
+ } else {
218
+ const sinPhi = Math.sin(start.latitude);
219
+ localRad = major * Math.cos(start.latitude) / Math.sqrt(1 - ellipticitySquared * sinPhi * sinPhi);
220
+ }
221
+ deltaLongitude = distance / localRad;
222
+ if (heading > 0) {
223
+ longitude = Math_default.negativePiToPi(start.longitude + deltaLongitude);
224
+ } else {
225
+ longitude = Math_default.negativePiToPi(start.longitude - deltaLongitude);
226
+ }
227
+ }
228
+ if (defined_default(result)) {
229
+ result.longitude = longitude;
230
+ result.latitude = latitude;
231
+ result.height = 0;
232
+ return result;
233
+ }
234
+ return new Cartographic_default(longitude, latitude, 0);
235
+ }
236
+ function EllipsoidRhumbLine(start, end, ellipsoid) {
237
+ const e = defaultValue_default(ellipsoid, Ellipsoid_default.WGS84);
238
+ this._ellipsoid = e;
239
+ this._start = new Cartographic_default();
240
+ this._end = new Cartographic_default();
241
+ this._heading = void 0;
242
+ this._distance = void 0;
243
+ this._ellipticity = void 0;
244
+ this._ellipticitySquared = void 0;
245
+ if (defined_default(start) && defined_default(end)) {
246
+ computeProperties(this, start, end, e);
247
+ }
248
+ }
249
+ Object.defineProperties(EllipsoidRhumbLine.prototype, {
250
+ /**
251
+ * Gets the ellipsoid.
252
+ * @memberof EllipsoidRhumbLine.prototype
253
+ * @type {Ellipsoid}
254
+ * @readonly
255
+ */
256
+ ellipsoid: {
257
+ get: function() {
258
+ return this._ellipsoid;
259
+ }
260
+ },
261
+ /**
262
+ * Gets the surface distance between the start and end point
263
+ * @memberof EllipsoidRhumbLine.prototype
264
+ * @type {number}
265
+ * @readonly
266
+ */
267
+ surfaceDistance: {
268
+ get: function() {
269
+ Check_default.defined("distance", this._distance);
270
+ return this._distance;
271
+ }
272
+ },
273
+ /**
274
+ * Gets the initial planetodetic point on the path.
275
+ * @memberof EllipsoidRhumbLine.prototype
276
+ * @type {Cartographic}
277
+ * @readonly
278
+ */
279
+ start: {
280
+ get: function() {
281
+ return this._start;
282
+ }
283
+ },
284
+ /**
285
+ * Gets the final planetodetic point on the path.
286
+ * @memberof EllipsoidRhumbLine.prototype
287
+ * @type {Cartographic}
288
+ * @readonly
289
+ */
290
+ end: {
291
+ get: function() {
292
+ return this._end;
293
+ }
294
+ },
295
+ /**
296
+ * Gets the heading from the start point to the end point.
297
+ * @memberof EllipsoidRhumbLine.prototype
298
+ * @type {number}
299
+ * @readonly
300
+ */
301
+ heading: {
302
+ get: function() {
303
+ Check_default.defined("distance", this._distance);
304
+ return this._heading;
305
+ }
306
+ }
307
+ });
308
+ EllipsoidRhumbLine.fromStartHeadingDistance = function(start, heading, distance, ellipsoid, result) {
309
+ Check_default.defined("start", start);
310
+ Check_default.defined("heading", heading);
311
+ Check_default.defined("distance", distance);
312
+ Check_default.typeOf.number.greaterThan("distance", distance, 0);
313
+ const e = defaultValue_default(ellipsoid, Ellipsoid_default.WGS84);
314
+ const major = e.maximumRadius;
315
+ const minor = e.minimumRadius;
316
+ const majorSquared = major * major;
317
+ const minorSquared = minor * minor;
318
+ const ellipticity = Math.sqrt((majorSquared - minorSquared) / majorSquared);
319
+ heading = Math_default.negativePiToPi(heading);
320
+ const end = interpolateUsingSurfaceDistance(
321
+ start,
322
+ heading,
323
+ distance,
324
+ e.maximumRadius,
325
+ ellipticity
326
+ );
327
+ if (!defined_default(result) || defined_default(ellipsoid) && !ellipsoid.equals(result.ellipsoid)) {
328
+ return new EllipsoidRhumbLine(start, end, e);
329
+ }
330
+ result.setEndPoints(start, end);
331
+ return result;
332
+ };
333
+ EllipsoidRhumbLine.prototype.setEndPoints = function(start, end) {
334
+ Check_default.defined("start", start);
335
+ Check_default.defined("end", end);
336
+ computeProperties(this, start, end, this._ellipsoid);
337
+ };
338
+ EllipsoidRhumbLine.prototype.interpolateUsingFraction = function(fraction, result) {
339
+ return this.interpolateUsingSurfaceDistance(
340
+ fraction * this._distance,
341
+ result
342
+ );
343
+ };
344
+ EllipsoidRhumbLine.prototype.interpolateUsingSurfaceDistance = function(distance, result) {
345
+ Check_default.typeOf.number("distance", distance);
346
+ if (!defined_default(this._distance) || this._distance === 0) {
347
+ throw new DeveloperError_default(
348
+ "EllipsoidRhumbLine must have distinct start and end set."
349
+ );
350
+ }
351
+ return interpolateUsingSurfaceDistance(
352
+ this._start,
353
+ this._heading,
354
+ distance,
355
+ this._ellipsoid.maximumRadius,
356
+ this._ellipticity,
357
+ result
358
+ );
359
+ };
360
+ EllipsoidRhumbLine.prototype.findIntersectionWithLongitude = function(intersectionLongitude, result) {
361
+ Check_default.typeOf.number("intersectionLongitude", intersectionLongitude);
362
+ if (!defined_default(this._distance) || this._distance === 0) {
363
+ throw new DeveloperError_default(
364
+ "EllipsoidRhumbLine must have distinct start and end set."
365
+ );
366
+ }
367
+ const ellipticity = this._ellipticity;
368
+ const heading = this._heading;
369
+ const absHeading = Math.abs(heading);
370
+ const start = this._start;
371
+ intersectionLongitude = Math_default.negativePiToPi(intersectionLongitude);
372
+ if (Math_default.equalsEpsilon(
373
+ Math.abs(intersectionLongitude),
374
+ Math.PI,
375
+ Math_default.EPSILON14
376
+ )) {
377
+ intersectionLongitude = Math_default.sign(start.longitude) * Math.PI;
378
+ }
379
+ if (!defined_default(result)) {
380
+ result = new Cartographic_default();
381
+ }
382
+ if (Math.abs(Math_default.PI_OVER_TWO - absHeading) <= Math_default.EPSILON8) {
383
+ result.longitude = intersectionLongitude;
384
+ result.latitude = start.latitude;
385
+ result.height = 0;
386
+ return result;
387
+ } else if (Math_default.equalsEpsilon(
388
+ Math.abs(Math_default.PI_OVER_TWO - absHeading),
389
+ Math_default.PI_OVER_TWO,
390
+ Math_default.EPSILON8
391
+ )) {
392
+ if (Math_default.equalsEpsilon(
393
+ intersectionLongitude,
394
+ start.longitude,
395
+ Math_default.EPSILON12
396
+ )) {
397
+ return void 0;
398
+ }
399
+ result.longitude = intersectionLongitude;
400
+ result.latitude = Math_default.PI_OVER_TWO * Math_default.sign(Math_default.PI_OVER_TWO - heading);
401
+ result.height = 0;
402
+ return result;
403
+ }
404
+ const phi1 = start.latitude;
405
+ const eSinPhi1 = ellipticity * Math.sin(phi1);
406
+ const leftComponent = Math.tan(0.5 * (Math_default.PI_OVER_TWO + phi1)) * Math.exp((intersectionLongitude - start.longitude) / Math.tan(heading));
407
+ const denominator = (1 + eSinPhi1) / (1 - eSinPhi1);
408
+ let newPhi = start.latitude;
409
+ let phi;
410
+ do {
411
+ phi = newPhi;
412
+ const eSinPhi = ellipticity * Math.sin(phi);
413
+ const numerator = (1 + eSinPhi) / (1 - eSinPhi);
414
+ newPhi = 2 * Math.atan(
415
+ leftComponent * Math.pow(numerator / denominator, ellipticity / 2)
416
+ ) - Math_default.PI_OVER_TWO;
417
+ } while (!Math_default.equalsEpsilon(newPhi, phi, Math_default.EPSILON12));
418
+ result.longitude = intersectionLongitude;
419
+ result.latitude = newPhi;
420
+ result.height = 0;
421
+ return result;
422
+ };
423
+ EllipsoidRhumbLine.prototype.findIntersectionWithLatitude = function(intersectionLatitude, result) {
424
+ Check_default.typeOf.number("intersectionLatitude", intersectionLatitude);
425
+ if (!defined_default(this._distance) || this._distance === 0) {
426
+ throw new DeveloperError_default(
427
+ "EllipsoidRhumbLine must have distinct start and end set."
428
+ );
429
+ }
430
+ const ellipticity = this._ellipticity;
431
+ const heading = this._heading;
432
+ const start = this._start;
433
+ if (Math_default.equalsEpsilon(
434
+ Math.abs(heading),
435
+ Math_default.PI_OVER_TWO,
436
+ Math_default.EPSILON8
437
+ )) {
438
+ return;
439
+ }
440
+ const sigma1 = calculateSigma(ellipticity, start.latitude);
441
+ const sigma2 = calculateSigma(ellipticity, intersectionLatitude);
442
+ const deltaLongitude = Math.tan(heading) * (sigma2 - sigma1);
443
+ const longitude = Math_default.negativePiToPi(start.longitude + deltaLongitude);
444
+ if (defined_default(result)) {
445
+ result.longitude = longitude;
446
+ result.latitude = intersectionLatitude;
447
+ result.height = 0;
448
+ return result;
449
+ }
450
+ return new Cartographic_default(longitude, intersectionLatitude, 0);
451
+ };
452
+ var EllipsoidRhumbLine_default = EllipsoidRhumbLine;
453
+
454
+ export {
455
+ EllipsoidRhumbLine_default
456
+ };
@@ -0,0 +1,236 @@
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
+ GeographicProjection_default
28
+ } from "./chunk-HOT2SNXP.js";
29
+ import {
30
+ Matrix2_default,
31
+ Rectangle_default
32
+ } from "./chunk-3PW6ZBN4.js";
33
+ import {
34
+ Cartesian3_default,
35
+ Cartographic_default
36
+ } from "./chunk-LGJUI2CE.js";
37
+ import {
38
+ Math_default
39
+ } from "./chunk-BP467WX3.js";
40
+ import {
41
+ DeveloperError_default
42
+ } from "./chunk-5HLGKKG3.js";
43
+ import {
44
+ defined_default
45
+ } from "./chunk-YBKFS53K.js";
46
+
47
+ // packages/engine/Source/Core/RectangleGeometryLibrary.js
48
+ var cos = Math.cos;
49
+ var sin = Math.sin;
50
+ var sqrt = Math.sqrt;
51
+ var RectangleGeometryLibrary = {};
52
+ RectangleGeometryLibrary.computePosition = function(computedOptions, ellipsoid, computeST, row, col, position, st) {
53
+ const radiiSquared = ellipsoid.radiiSquared;
54
+ const nwCorner = computedOptions.nwCorner;
55
+ const rectangle = computedOptions.boundingRectangle;
56
+ let stLatitude = nwCorner.latitude - computedOptions.granYCos * row + col * computedOptions.granXSin;
57
+ const cosLatitude = cos(stLatitude);
58
+ const nZ = sin(stLatitude);
59
+ const kZ = radiiSquared.z * nZ;
60
+ let stLongitude = nwCorner.longitude + row * computedOptions.granYSin + col * computedOptions.granXCos;
61
+ const nX = cosLatitude * cos(stLongitude);
62
+ const nY = cosLatitude * sin(stLongitude);
63
+ const kX = radiiSquared.x * nX;
64
+ const kY = radiiSquared.y * nY;
65
+ const gamma = sqrt(kX * nX + kY * nY + kZ * nZ);
66
+ position.x = kX / gamma;
67
+ position.y = kY / gamma;
68
+ position.z = kZ / gamma;
69
+ if (computeST) {
70
+ const stNwCorner = computedOptions.stNwCorner;
71
+ if (defined_default(stNwCorner)) {
72
+ stLatitude = stNwCorner.latitude - computedOptions.stGranYCos * row + col * computedOptions.stGranXSin;
73
+ stLongitude = stNwCorner.longitude + row * computedOptions.stGranYSin + col * computedOptions.stGranXCos;
74
+ st.x = (stLongitude - computedOptions.stWest) * computedOptions.lonScalar;
75
+ st.y = (stLatitude - computedOptions.stSouth) * computedOptions.latScalar;
76
+ } else {
77
+ st.x = (stLongitude - rectangle.west) * computedOptions.lonScalar;
78
+ st.y = (stLatitude - rectangle.south) * computedOptions.latScalar;
79
+ }
80
+ }
81
+ };
82
+ var rotationMatrixScratch = new Matrix2_default();
83
+ var nwCartesian = new Cartesian3_default();
84
+ var centerScratch = new Cartographic_default();
85
+ var centerCartesian = new Cartesian3_default();
86
+ var proj = new GeographicProjection_default();
87
+ function getRotationOptions(nwCorner, rotation, granularityX, granularityY, center, width, height) {
88
+ const cosRotation = Math.cos(rotation);
89
+ const granYCos = granularityY * cosRotation;
90
+ const granXCos = granularityX * cosRotation;
91
+ const sinRotation = Math.sin(rotation);
92
+ const granYSin = granularityY * sinRotation;
93
+ const granXSin = granularityX * sinRotation;
94
+ nwCartesian = proj.project(nwCorner, nwCartesian);
95
+ nwCartesian = Cartesian3_default.subtract(nwCartesian, centerCartesian, nwCartesian);
96
+ const rotationMatrix = Matrix2_default.fromRotation(rotation, rotationMatrixScratch);
97
+ nwCartesian = Matrix2_default.multiplyByVector(
98
+ rotationMatrix,
99
+ nwCartesian,
100
+ nwCartesian
101
+ );
102
+ nwCartesian = Cartesian3_default.add(nwCartesian, centerCartesian, nwCartesian);
103
+ nwCorner = proj.unproject(nwCartesian, nwCorner);
104
+ width -= 1;
105
+ height -= 1;
106
+ const latitude = nwCorner.latitude;
107
+ const latitude0 = latitude + width * granXSin;
108
+ const latitude1 = latitude - granYCos * height;
109
+ const latitude2 = latitude - granYCos * height + width * granXSin;
110
+ const north = Math.max(latitude, latitude0, latitude1, latitude2);
111
+ const south = Math.min(latitude, latitude0, latitude1, latitude2);
112
+ const longitude = nwCorner.longitude;
113
+ const longitude0 = longitude + width * granXCos;
114
+ const longitude1 = longitude + height * granYSin;
115
+ const longitude2 = longitude + height * granYSin + width * granXCos;
116
+ const east = Math.max(longitude, longitude0, longitude1, longitude2);
117
+ const west = Math.min(longitude, longitude0, longitude1, longitude2);
118
+ return {
119
+ north,
120
+ south,
121
+ east,
122
+ west,
123
+ granYCos,
124
+ granYSin,
125
+ granXCos,
126
+ granXSin,
127
+ nwCorner
128
+ };
129
+ }
130
+ RectangleGeometryLibrary.computeOptions = function(rectangle, granularity, rotation, stRotation, boundingRectangleScratch, nwCornerResult, stNwCornerResult) {
131
+ let east = rectangle.east;
132
+ let west = rectangle.west;
133
+ let north = rectangle.north;
134
+ let south = rectangle.south;
135
+ let northCap = false;
136
+ let southCap = false;
137
+ if (north === Math_default.PI_OVER_TWO) {
138
+ northCap = true;
139
+ }
140
+ if (south === -Math_default.PI_OVER_TWO) {
141
+ southCap = true;
142
+ }
143
+ let dx;
144
+ const dy = north - south;
145
+ if (west > east) {
146
+ dx = Math_default.TWO_PI - west + east;
147
+ } else {
148
+ dx = east - west;
149
+ }
150
+ const width = Math.ceil(dx / granularity) + 1;
151
+ const height = Math.ceil(dy / granularity) + 1;
152
+ const granularityX = dx / (width - 1);
153
+ const granularityY = dy / (height - 1);
154
+ const nwCorner = Rectangle_default.northwest(rectangle, nwCornerResult);
155
+ const center = Rectangle_default.center(rectangle, centerScratch);
156
+ if (rotation !== 0 || stRotation !== 0) {
157
+ if (center.longitude < nwCorner.longitude) {
158
+ center.longitude += Math_default.TWO_PI;
159
+ }
160
+ centerCartesian = proj.project(center, centerCartesian);
161
+ }
162
+ const granYCos = granularityY;
163
+ const granXCos = granularityX;
164
+ const granYSin = 0;
165
+ const granXSin = 0;
166
+ const boundingRectangle = Rectangle_default.clone(
167
+ rectangle,
168
+ boundingRectangleScratch
169
+ );
170
+ const computedOptions = {
171
+ granYCos,
172
+ granYSin,
173
+ granXCos,
174
+ granXSin,
175
+ nwCorner,
176
+ boundingRectangle,
177
+ width,
178
+ height,
179
+ northCap,
180
+ southCap
181
+ };
182
+ if (rotation !== 0) {
183
+ const rotationOptions = getRotationOptions(
184
+ nwCorner,
185
+ rotation,
186
+ granularityX,
187
+ granularityY,
188
+ center,
189
+ width,
190
+ height
191
+ );
192
+ north = rotationOptions.north;
193
+ south = rotationOptions.south;
194
+ east = rotationOptions.east;
195
+ west = rotationOptions.west;
196
+ if (north < -Math_default.PI_OVER_TWO || north > Math_default.PI_OVER_TWO || south < -Math_default.PI_OVER_TWO || south > Math_default.PI_OVER_TWO) {
197
+ throw new DeveloperError_default(
198
+ "Rotated rectangle is invalid. It crosses over either the north or south pole."
199
+ );
200
+ }
201
+ computedOptions.granYCos = rotationOptions.granYCos;
202
+ computedOptions.granYSin = rotationOptions.granYSin;
203
+ computedOptions.granXCos = rotationOptions.granXCos;
204
+ computedOptions.granXSin = rotationOptions.granXSin;
205
+ boundingRectangle.north = north;
206
+ boundingRectangle.south = south;
207
+ boundingRectangle.east = east;
208
+ boundingRectangle.west = west;
209
+ }
210
+ if (stRotation !== 0) {
211
+ rotation = rotation - stRotation;
212
+ const stNwCorner = Rectangle_default.northwest(boundingRectangle, stNwCornerResult);
213
+ const stRotationOptions = getRotationOptions(
214
+ stNwCorner,
215
+ rotation,
216
+ granularityX,
217
+ granularityY,
218
+ center,
219
+ width,
220
+ height
221
+ );
222
+ computedOptions.stGranYCos = stRotationOptions.granYCos;
223
+ computedOptions.stGranXCos = stRotationOptions.granXCos;
224
+ computedOptions.stGranYSin = stRotationOptions.granYSin;
225
+ computedOptions.stGranXSin = stRotationOptions.granXSin;
226
+ computedOptions.stNwCorner = stNwCorner;
227
+ computedOptions.stWest = stRotationOptions.west;
228
+ computedOptions.stSouth = stRotationOptions.south;
229
+ }
230
+ return computedOptions;
231
+ };
232
+ var RectangleGeometryLibrary_default = RectangleGeometryLibrary;
233
+
234
+ export {
235
+ RectangleGeometryLibrary_default
236
+ };