@pirireis/webglobeplugins 1.0.2 → 1.0.4

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 (277) hide show
  1. package/package.json +2 -2
  2. package/plugins/alarms/alarmFadeInFadeOutPlugin/AlarmTimeLineFadeInFadeOutPlugin.js +399 -0
  3. package/{Math/angle-calculation.ts → webglobeplugins/Math/angle-calculation.js} +14 -18
  4. package/{Math/arc-cdf-points.ts → webglobeplugins/Math/arc-cdf-points.js} +272 -329
  5. package/{Math/arc-generate-points-exponantial.ts → webglobeplugins/Math/arc-generate-points-exponantial.js} +254 -299
  6. package/{Math/arc.ts → webglobeplugins/Math/arc.js} +292 -421
  7. package/{Math → webglobeplugins/Math}/bounds/line-bbox.js +186 -225
  8. package/{Math/circle-cdf-points.ts → webglobeplugins/Math/circle-cdf-points.js} +78 -143
  9. package/{Math/circle.ts → webglobeplugins/Math/circle.js} +33 -49
  10. package/{Math/constants.ts → webglobeplugins/Math/constants.js} +4 -12
  11. package/{Math/contour/quadtreecontours.ts → webglobeplugins/Math/contour/quadtreecontours.js} +300 -371
  12. package/{Math → webglobeplugins/Math}/contour/quadtreecontours1.js +298 -336
  13. package/{Math/finite-line-2d.ts → webglobeplugins/Math/finite-line-2d.js} +58 -68
  14. package/{Math/haversine.ts → webglobeplugins/Math/haversine.js} +22 -33
  15. package/webglobeplugins/Math/index.js +1 -0
  16. package/{Math/juction/arc-plane.ts → webglobeplugins/Math/juction/arc-plane.js} +143 -203
  17. package/{Math/juction/line-sphere.ts → webglobeplugins/Math/juction/line-sphere.js} +22 -32
  18. package/{Math/juction/plane-plane.ts → webglobeplugins/Math/juction/plane-plane.js} +53 -62
  19. package/{Math/line.ts → webglobeplugins/Math/line.js} +52 -84
  20. package/webglobeplugins/Math/matrix4.js +1 -0
  21. package/{Math/methods.ts → webglobeplugins/Math/methods.js} +126 -182
  22. package/{Math/plane.ts → webglobeplugins/Math/plane.js} +56 -92
  23. package/{Math/quaternion.ts → webglobeplugins/Math/quaternion.js} +106 -128
  24. package/{Math/templete-shapes/grid-visually-equal.ts → webglobeplugins/Math/templete-shapes/grid-visually-equal.js} +65 -118
  25. package/webglobeplugins/Math/tessellation/constants.js +1 -0
  26. package/{Math/tessellation/methods.ts → webglobeplugins/Math/tessellation/methods.js} +49 -79
  27. package/{Math/tessellation/nearest-value-padding.ts → webglobeplugins/Math/tessellation/nearest-value-padding.js} +112 -147
  28. package/{Math/tessellation/spherical-triangle-area.ts → webglobeplugins/Math/tessellation/spherical-triangle-area.js} +99 -127
  29. package/{Math/tessellation/tile-merger.ts → webglobeplugins/Math/tessellation/tile-merger.js} +429 -578
  30. package/{Math/tessellation/triangle-tessellation.ts → webglobeplugins/Math/tessellation/triangle-tessellation.js} +464 -533
  31. package/webglobeplugins/Math/tessellation/types.js +1 -0
  32. package/webglobeplugins/Math/types.js +1 -0
  33. package/{Math → webglobeplugins/Math}/utils.js +2 -3
  34. package/{Math/vec3.ts → webglobeplugins/Math/vec3.js} +155 -227
  35. package/{Math/xyz-tile.ts → webglobeplugins/Math/xyz-tile.js} +18 -26
  36. package/{algorithms → webglobeplugins/algorithms}/search-binary.js +16 -14
  37. package/webglobeplugins/altitude-locator/adaptors.js +1 -0
  38. package/webglobeplugins/altitude-locator/keymethod.js +1 -0
  39. package/{altitude-locator → webglobeplugins/altitude-locator}/plugin.js +344 -445
  40. package/{altitude-locator → webglobeplugins/altitude-locator}/types.js +21 -26
  41. package/{compass-rose → webglobeplugins/compass-rose}/compass-rose-padding-flat.js +230 -274
  42. package/{compass-rose/compass-text-writer.ts → webglobeplugins/compass-rose/compass-text-writer.js} +155 -210
  43. package/{compass-rose → webglobeplugins/compass-rose}/index.js +3 -3
  44. package/{constants.ts → webglobeplugins/constants.js} +6 -8
  45. package/{heatwave → webglobeplugins/heatwave}/datamanager.js +149 -168
  46. package/{heatwave → webglobeplugins/heatwave}/heatwave.js +206 -261
  47. package/{heatwave → webglobeplugins/heatwave}/index.js +5 -5
  48. package/{heatwave → webglobeplugins/heatwave}/isobar.js +306 -340
  49. package/{heatwave/texture-point-sampler.ts → webglobeplugins/heatwave/texture-point-sampler.js} +187 -220
  50. package/webglobeplugins/investigation-tools/draw/tiles/adapters.js +67 -0
  51. package/{investigation-tools/draw/tiles/tiles.ts → webglobeplugins/investigation-tools/draw/tiles/tiles.js} +128 -162
  52. package/{jest.config.js → webglobeplugins/jest.config.js} +7 -6
  53. package/{pin → webglobeplugins/pin}/pin-object-array1.js +300 -381
  54. package/{pin → webglobeplugins/pin}/pin-point-totem1.js +60 -77
  55. package/{programs → webglobeplugins/programs}/arrowfield/arrow-field.js +60 -89
  56. package/{programs → webglobeplugins/programs}/arrowfield/logic.js +141 -173
  57. package/{programs → webglobeplugins/programs}/data2legend/density-to-legend.js +68 -86
  58. package/{programs → webglobeplugins/programs}/data2legend/point-to-density-texture.js +67 -84
  59. package/{programs → webglobeplugins/programs}/float2legendwithratio/index.js +2 -3
  60. package/{programs → webglobeplugins/programs}/float2legendwithratio/logic.js +118 -144
  61. package/{programs → webglobeplugins/programs}/float2legendwithratio/object.js +104 -141
  62. package/{programs → webglobeplugins/programs}/helpers/blender.js +58 -73
  63. package/{programs/helpers/fadeaway.ts → webglobeplugins/programs/helpers/fadeaway.js} +60 -73
  64. package/{programs → webglobeplugins/programs}/index.js +20 -19
  65. package/{programs → webglobeplugins/programs}/line-on-globe/circle-accurate-3d.js +85 -112
  66. package/{programs → webglobeplugins/programs}/line-on-globe/circle-accurate-flat.js +148 -200
  67. package/{programs → webglobeplugins/programs}/line-on-globe/degree-padding-around-circle-3d.js +102 -134
  68. package/webglobeplugins/programs/line-on-globe/index.js +1 -0
  69. package/{programs → webglobeplugins/programs}/line-on-globe/lines-color-instanced-flat.js +80 -99
  70. package/webglobeplugins/programs/line-on-globe/linestrip/data.js +4 -0
  71. package/{programs/line-on-globe/linestrip/linestrip.ts → webglobeplugins/programs/line-on-globe/linestrip/linestrip.js} +93 -152
  72. package/{programs/line-on-globe/naive-accurate-flexible.ts → webglobeplugins/programs/line-on-globe/naive-accurate-flexible.js} +126 -175
  73. package/{programs → webglobeplugins/programs}/line-on-globe/util.js +5 -8
  74. package/{programs → webglobeplugins/programs}/picking/pickable-polygon-renderer.js +98 -129
  75. package/{programs → webglobeplugins/programs}/picking/pickable-renderer.js +98 -130
  76. package/{programs → webglobeplugins/programs}/point-on-globe/element-globe-surface-glow.js +93 -122
  77. package/{programs → webglobeplugins/programs}/point-on-globe/element-point-glow.js +80 -114
  78. package/{programs → webglobeplugins/programs}/point-on-globe/square-pixel-point.js +121 -139
  79. package/{programs/polygon-on-globe/texture-dem-triangles.ts → webglobeplugins/programs/polygon-on-globe/texture-dem-triangles.js} +178 -209
  80. package/{programs/programcache.ts → webglobeplugins/programs/programcache.js} +126 -134
  81. package/webglobeplugins/programs/rings/index.js +1 -0
  82. package/{programs/rings/partial-ring/piece-of-pie.ts → webglobeplugins/programs/rings/partial-ring/piece-of-pie.js} +152 -222
  83. package/webglobeplugins/programs/totems/attachments/adaptive-opacity.js +131 -0
  84. package/{programs/totems/dem-textures-manager.ts → webglobeplugins/programs/totems/attachments/dem-textures-manager.js} +263 -360
  85. package/webglobeplugins/programs/totems/camera-totem-attactment-interface.js +1 -0
  86. package/{programs/totems/camerauniformblock.ts → webglobeplugins/programs/totems/camerauniformblock.js} +225 -310
  87. package/{programs/totems/canvas-webglobe-info.ts → webglobeplugins/programs/totems/canvas-webglobe-info.js} +132 -147
  88. package/{programs/totems/globe-changes.ts → webglobeplugins/programs/totems/globe-changes.js} +59 -79
  89. package/{programs → webglobeplugins/programs}/totems/gpu-selection-uniform-block.js +99 -127
  90. package/{programs/totems/index.ts → webglobeplugins/programs/totems/index.js} +2 -2
  91. package/{programs → webglobeplugins/programs}/two-d/pixel-padding-for-compass.js +87 -101
  92. package/{programs → webglobeplugins/programs}/util.js +14 -19
  93. package/{programs/vectorfields/logics/constants.ts → webglobeplugins/programs/vectorfields/logics/constants.js} +4 -5
  94. package/{programs/vectorfields/logics/drawrectangleparticles.ts → webglobeplugins/programs/vectorfields/logics/drawrectangleparticles.js} +107 -136
  95. package/{programs → webglobeplugins/programs}/vectorfields/logics/index.js +2 -4
  96. package/webglobeplugins/programs/vectorfields/logics/particle-ubo.js +19 -0
  97. package/{programs/vectorfields/logics/pixelbased.ts → webglobeplugins/programs/vectorfields/logics/pixelbased.js} +89 -122
  98. package/{programs → webglobeplugins/programs}/vectorfields/logics/ubo.js +51 -57
  99. package/{programs/vectorfields/pingpongbuffermanager.ts → webglobeplugins/programs/vectorfields/pingpongbuffermanager.js} +99 -113
  100. package/{range-tools-on-terrain/bearing-line/adapters.ts → webglobeplugins/range-tools-on-terrain/bearing-line/adapters.js} +114 -154
  101. package/{range-tools-on-terrain/bearing-line/plugin.ts → webglobeplugins/range-tools-on-terrain/bearing-line/plugin.js} +457 -569
  102. package/webglobeplugins/range-tools-on-terrain/bearing-line/types.js +1 -0
  103. package/{range-tools-on-terrain/circle-line-chain/adapters.ts → webglobeplugins/range-tools-on-terrain/circle-line-chain/adapters.js} +85 -104
  104. package/{range-tools-on-terrain/circle-line-chain/chain-list-map.ts → webglobeplugins/range-tools-on-terrain/circle-line-chain/chain-list-map.js} +382 -446
  105. package/{range-tools-on-terrain/circle-line-chain/plugin.ts → webglobeplugins/range-tools-on-terrain/circle-line-chain/plugin.js} +464 -607
  106. package/webglobeplugins/range-tools-on-terrain/circle-line-chain/types.js +1 -0
  107. package/{range-tools-on-terrain/range-ring/adapters.ts → webglobeplugins/range-tools-on-terrain/range-ring/adapters.js} +93 -114
  108. package/{range-tools-on-terrain/range-ring/enum.ts → webglobeplugins/range-tools-on-terrain/range-ring/enum.js} +2 -2
  109. package/{range-tools-on-terrain/range-ring/plugin.ts → webglobeplugins/range-tools-on-terrain/range-ring/plugin.js} +377 -444
  110. package/webglobeplugins/range-tools-on-terrain/range-ring/rangeringangletext.js +331 -0
  111. package/webglobeplugins/range-tools-on-terrain/range-ring/types.js +9 -0
  112. package/webglobeplugins/semiplugins/interface.js +1 -0
  113. package/{semiplugins/lightweight/line-plugin.ts → webglobeplugins/semiplugins/lightweight/line-plugin.js} +221 -342
  114. package/{semiplugins/lightweight/piece-of-pie-plugin.ts → webglobeplugins/semiplugins/lightweight/piece-of-pie-plugin.js} +200 -275
  115. package/{semiplugins/shape-on-terrain/arc-plugin.ts → webglobeplugins/semiplugins/shape-on-terrain/arc-plugin.js} +481 -616
  116. package/{semiplugins/shape-on-terrain/circle-plugin.ts → webglobeplugins/semiplugins/shape-on-terrain/circle-plugin.js} +444 -588
  117. package/{semiplugins/shape-on-terrain/padding-1-degree.ts → webglobeplugins/semiplugins/shape-on-terrain/padding-1-degree.js} +539 -713
  118. package/{semiplugins/shape-on-terrain/terrain-polygon/adapters.ts → webglobeplugins/semiplugins/shape-on-terrain/terrain-polygon/adapters.js} +55 -69
  119. package/{semiplugins/shape-on-terrain/terrain-polygon/data/cache.ts → webglobeplugins/semiplugins/shape-on-terrain/terrain-polygon/data/cache.js} +104 -149
  120. package/{semiplugins/shape-on-terrain/terrain-polygon/data/index-polygon-map.ts → webglobeplugins/semiplugins/shape-on-terrain/terrain-polygon/data/index-polygon-map.js} +45 -58
  121. package/{semiplugins/shape-on-terrain/terrain-polygon/data/manager.ts → webglobeplugins/semiplugins/shape-on-terrain/terrain-polygon/data/manager.js} +4 -4
  122. package/webglobeplugins/semiplugins/shape-on-terrain/terrain-polygon/data/master-worker.js +241 -0
  123. package/webglobeplugins/semiplugins/shape-on-terrain/terrain-polygon/data/polygon-to-triangles.js +76 -0
  124. package/{semiplugins/shape-on-terrain/terrain-polygon/data/random.ts → webglobeplugins/semiplugins/shape-on-terrain/terrain-polygon/data/random.js} +121 -165
  125. package/webglobeplugins/semiplugins/shape-on-terrain/terrain-polygon/data/types.js +1 -0
  126. package/{semiplugins/shape-on-terrain/terrain-polygon/data/worker-contact.ts → webglobeplugins/semiplugins/shape-on-terrain/terrain-polygon/data/worker-contact.js} +64 -81
  127. package/webglobeplugins/semiplugins/shape-on-terrain/terrain-polygon/data/worker.js +162 -0
  128. package/{semiplugins/shape-on-terrain/terrain-polygon/terrain-polygon.ts → webglobeplugins/semiplugins/shape-on-terrain/terrain-polygon/terrain-polygon.js} +282 -265
  129. package/webglobeplugins/semiplugins/shape-on-terrain/terrain-polygon/test-records.js +14 -0
  130. package/webglobeplugins/semiplugins/shape-on-terrain/terrain-polygon/types.js +8 -0
  131. package/webglobeplugins/semiplugins/shell/bbox-renderer/index.js +2 -0
  132. package/{semiplugins/shell/bbox-renderer/logic.ts → webglobeplugins/semiplugins/shell/bbox-renderer/logic.js} +209 -273
  133. package/webglobeplugins/semiplugins/shell/bbox-renderer/object.js +78 -0
  134. package/webglobeplugins/semiplugins/type.js +1 -0
  135. package/{semiplugins/utility/container-plugin.ts → webglobeplugins/semiplugins/utility/container-plugin.js} +94 -126
  136. package/{semiplugins/utility/object-pass-container-plugin.ts → webglobeplugins/semiplugins/utility/object-pass-container-plugin.js} +80 -101
  137. package/{shaders → webglobeplugins/shaders}/fragment-toy/firework.js +1 -1
  138. package/{shaders → webglobeplugins/shaders}/fragment-toy/singularity.js +2 -5
  139. package/{tracks → webglobeplugins/tracks}/point-heat-map/adaptors/timetracksplugin-format-to-this.js +63 -78
  140. package/webglobeplugins/tracks/point-heat-map/index.js +1 -0
  141. package/{tracks → webglobeplugins/tracks}/point-heat-map/plugin-webworker.js +121 -148
  142. package/{tracks → webglobeplugins/tracks}/point-heat-map/point-to-heat-map-flow.js +121 -150
  143. package/{tracks → webglobeplugins/tracks}/point-tracks/key-methods.js +2 -3
  144. package/{tracks → webglobeplugins/tracks}/point-tracks/plugin.js +401 -487
  145. package/{tracks → webglobeplugins/tracks}/timetracks/adaptors-line-strip.js +65 -79
  146. package/{tracks → webglobeplugins/tracks}/timetracks/plugin-line-strip.js +240 -295
  147. package/{tracks → webglobeplugins/tracks}/timetracks/program-line-strip.js +413 -495
  148. package/{tracks → webglobeplugins/tracks}/timetracks/programpoint-line-strip.js +109 -137
  149. package/webglobeplugins/types.js +19 -0
  150. package/{util → webglobeplugins/util}/account/bufferoffsetmanager.js +176 -209
  151. package/webglobeplugins/util/account/create-buffermap-orchastration.js +39 -0
  152. package/{util → webglobeplugins/util}/account/index.js +3 -6
  153. package/{util/account/single-attribute-buffer-management/buffer-manager.ts → webglobeplugins/util/account/single-attribute-buffer-management/buffer-manager.js} +119 -151
  154. package/{util/account/single-attribute-buffer-management/buffer-orchestrator.ts → webglobeplugins/util/account/single-attribute-buffer-management/buffer-orchestrator.js} +212 -238
  155. package/{util/account/single-attribute-buffer-management/buffer-orchestrator1.ts → webglobeplugins/util/account/single-attribute-buffer-management/buffer-orchestrator1.js} +159 -184
  156. package/{util/account/single-attribute-buffer-management/index.ts → webglobeplugins/util/account/single-attribute-buffer-management/index.js} +4 -11
  157. package/{util/account/single-attribute-buffer-management/object-store.ts → webglobeplugins/util/account/single-attribute-buffer-management/object-store.js} +55 -76
  158. package/webglobeplugins/util/account/single-attribute-buffer-management/types.js +1 -0
  159. package/{util → webglobeplugins/util}/account/util.js +18 -22
  160. package/webglobeplugins/util/algorithms/index.js +1 -0
  161. package/{util → webglobeplugins/util}/algorithms/search-binary.js +25 -26
  162. package/{util/build-strategy/static-dynamic.ts → webglobeplugins/util/build-strategy/static-dynamic.js} +41 -50
  163. package/webglobeplugins/util/check/index.js +1 -0
  164. package/webglobeplugins/util/check/typecheck.js +66 -0
  165. package/{util/frame-counter-trigger.ts → webglobeplugins/util/frame-counter-trigger.js} +84 -99
  166. package/{util/geometry/index.ts → webglobeplugins/util/geometry/index.js} +121 -155
  167. package/webglobeplugins/util/gl-util/buffer/attribute-loader.js +74 -0
  168. package/{util/gl-util/buffer/index.ts → webglobeplugins/util/gl-util/buffer/index.js} +3 -6
  169. package/{util/gl-util/draw-options/methods.ts → webglobeplugins/util/gl-util/draw-options/methods.js} +32 -47
  170. package/{util/gl-util/uniform-block/manager.ts → webglobeplugins/util/gl-util/uniform-block/manager.js} +209 -232
  171. package/{util/globe-default-gl-states.ts → webglobeplugins/util/globe-default-gl-states.js} +4 -5
  172. package/{util/helper-methods.ts → webglobeplugins/util/helper-methods.js} +8 -9
  173. package/{util → webglobeplugins/util}/index.js +10 -9
  174. package/webglobeplugins/util/interpolation/index.js +1 -0
  175. package/webglobeplugins/util/interpolation/timetrack/index.js +2 -0
  176. package/{util → webglobeplugins/util}/interpolation/timetrack/timetrack-interpolator.js +79 -94
  177. package/{util → webglobeplugins/util}/interpolation/timetrack/web-worker.js +46 -51
  178. package/{util/picking/fence.ts → webglobeplugins/util/picking/fence.js} +43 -47
  179. package/{util/picking/picker-displayer.ts → webglobeplugins/util/picking/picker-displayer.js} +176 -226
  180. package/{util → webglobeplugins/util}/programs/draw-from-pixel-coords.js +164 -201
  181. package/{util/programs/draw-texture-on-canvas.ts → webglobeplugins/util/programs/draw-texture-on-canvas.js} +69 -91
  182. package/{util → webglobeplugins/util}/programs/supersampletotextures.js +97 -130
  183. package/{util/programs/texturetoglobe.js → webglobeplugins/util/programs/texturetoglobe_delete.js} +128 -153
  184. package/{util/shaderfunctions/geometrytransformations.ts → webglobeplugins/util/shaderfunctions/geometrytransformations.js} +44 -106
  185. package/{util → webglobeplugins/util}/shaderfunctions/index.js +2 -2
  186. package/{util → webglobeplugins/util}/shaderfunctions/nodata.js +2 -4
  187. package/{util → webglobeplugins/util}/shaderfunctions/noisefunctions.js +7 -10
  188. package/{util/webglobjectbuilders.ts → webglobeplugins/util/webglobjectbuilders.js} +358 -446
  189. package/{vectorfield → webglobeplugins/vectorfield}/arrowfield/adaptor.js +11 -11
  190. package/{vectorfield → webglobeplugins/vectorfield}/arrowfield/index.js +3 -3
  191. package/{vectorfield → webglobeplugins/vectorfield}/arrowfield/plugin.js +83 -128
  192. package/{vectorfield → webglobeplugins/vectorfield}/waveparticles/adaptor.js +15 -16
  193. package/{vectorfield → webglobeplugins/vectorfield}/waveparticles/index.js +3 -3
  194. package/{vectorfield/waveparticles/plugin.ts → webglobeplugins/vectorfield/waveparticles/plugin.js} +455 -506
  195. package/webglobeplugins/vectorfield/wind/adapters/image-to-fields.js +92 -0
  196. package/webglobeplugins/vectorfield/wind/adapters/types.js +1 -0
  197. package/{vectorfield/wind/imagetovectorfieldandmagnitude.ts → webglobeplugins/vectorfield/wind/imagetovectorfieldandmagnitude.js} +53 -78
  198. package/{vectorfield → webglobeplugins/vectorfield}/wind/index.js +5 -5
  199. package/{vectorfield/wind/plugin-persistant.ts → webglobeplugins/vectorfield/wind/plugin-persistant.js} +390 -483
  200. package/{vectorfield → webglobeplugins/vectorfield}/wind/plugin.js +685 -883
  201. package/{vectorfield → webglobeplugins/vectorfield}/wind/vectorfieldimage.js +23 -27
  202. package/{write-text/context-text-bulk.ts → webglobeplugins/write-text/context-text-bulk.js} +200 -285
  203. package/webglobeplugins/write-text/context-text3.js +167 -0
  204. package/{write-text/context-text4.ts → webglobeplugins/write-text/context-text4.js} +146 -231
  205. package/{write-text → webglobeplugins/write-text}/context-textDELETE.js +94 -125
  206. package/{write-text/objectarraylabels/index.ts → webglobeplugins/write-text/objectarraylabels/index.js} +2 -2
  207. package/{write-text → webglobeplugins/write-text}/objectarraylabels/objectarraylabels.js +200 -247
  208. package/Math/index.js +0 -0
  209. package/Math/matrix4.ts +0 -0
  210. package/Math/mesh/mapbox-delaunay.d.ts +0 -74
  211. package/Math/roadmap.md +0 -10
  212. package/Math/tessellation/constants.ts +0 -1
  213. package/Math/tessellation/roadmap.md +0 -48
  214. package/Math/tessellation/types.ts +0 -1
  215. package/Math/types.ts +0 -68
  216. package/altitude-locator/adaptors.js +0 -0
  217. package/altitude-locator/keymethod.js +0 -0
  218. package/investigation-tools/draw/tiles/adapters.ts +0 -133
  219. package/programs/line-on-globe/index.js +0 -0
  220. package/programs/line-on-globe/linestrip/data.ts +0 -29
  221. package/programs/polygon-on-globe/roadmap.md +0 -8
  222. package/programs/rings/index.js +0 -1
  223. package/programs/totems/camera-totem-attactment-interface.ts +0 -4
  224. package/programs/vectorfields/logics/particle-ubo.ts +0 -23
  225. package/publish.bat +0 -62
  226. package/range-tools-on-terrain/bearing-line/types.ts +0 -65
  227. package/range-tools-on-terrain/circle-line-chain/types.ts +0 -43
  228. package/range-tools-on-terrain/range-ring/rangeringangletext.ts +0 -396
  229. package/range-tools-on-terrain/range-ring/types.ts +0 -30
  230. package/semiplugins/interface.ts +0 -14
  231. package/semiplugins/shape-on-terrain/goal.md +0 -12
  232. package/semiplugins/shape-on-terrain/terrain-polygon/data/cache-shortcuts.md +0 -20
  233. package/semiplugins/shape-on-terrain/terrain-polygon/data/master-worker.js +0 -196
  234. package/semiplugins/shape-on-terrain/terrain-polygon/data/master-worker.ts +0 -209
  235. package/semiplugins/shape-on-terrain/terrain-polygon/data/polygon-to-triangles.ts +0 -144
  236. package/semiplugins/shape-on-terrain/terrain-polygon/data/readme.md +0 -5
  237. package/semiplugins/shape-on-terrain/terrain-polygon/data/types.ts +0 -37
  238. package/semiplugins/shape-on-terrain/terrain-polygon/data/worker.js +0 -146
  239. package/semiplugins/shape-on-terrain/terrain-polygon/notes.md +0 -90
  240. package/semiplugins/shape-on-terrain/terrain-polygon/types.ts +0 -69
  241. package/semiplugins/shell/bbox-renderer/index.ts +0 -2
  242. package/semiplugins/shell/bbox-renderer/object.ts +0 -129
  243. package/semiplugins/type.ts +0 -8
  244. package/terrain-plugin.mmd +0 -83
  245. package/tests/Math/arc-sampling-test.js +0 -367
  246. package/tests/Math/arc-sampling-test.ts +0 -429
  247. package/tests/Math/arc.test.ts +0 -77
  248. package/tests/Math/junction/arc-limit.test.ts +0 -7
  249. package/tests/Math/junction/arc-plane-points.test.ts +0 -196
  250. package/tests/Math/junction/arc-plane.test.ts +0 -172
  251. package/tests/Math/junction/line-sphere.test.ts +0 -127
  252. package/tests/Math/junction/plane-plane.test.ts +0 -91
  253. package/tests/Math/plane-test.ts +0 -17
  254. package/tests/Math/plane.test.ts +0 -43
  255. package/tests/Math/vec3.test.ts +0 -33
  256. package/tracks/point-heat-map/index.js +0 -0
  257. package/tracks/point-heat-map/readme.md +0 -15
  258. package/tracks/timetracks/readme.md +0 -1
  259. package/tsconfig.json +0 -22
  260. package/types/@pirireis/webglobe.d.ts +0 -102
  261. package/types/delaunator.d.ts +0 -40
  262. package/types/earcut.d.ts +0 -11
  263. package/types/rbush.d.ts +0 -57
  264. package/types.ts +0 -319
  265. package/util/account/create-buffermap-orchastration.ts +0 -85
  266. package/util/account/single-attribute-buffer-management/types.ts +0 -43
  267. package/util/algorithms/index.js +0 -0
  268. package/util/check/index.js +0 -0
  269. package/util/check/typecheck.ts +0 -74
  270. package/util/gl-util/buffer/attribute-loader.ts +0 -84
  271. package/util/interpolation/index.js +0 -0
  272. package/util/interpolation/timetrack/index.js +0 -9
  273. package/vectorfield/wind/adapters/image-to-fields.ts +0 -74
  274. package/vectorfield/wind/adapters/types.ts +0 -12
  275. package/vectorfield/wind/plugin-persistant copy.ts +0 -461
  276. package/write-text/context-text3.ts +0 -252
  277. package/write-text/objectarraylabels/objectarraylabels.d.ts +0 -72
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pirireis/webglobeplugins",
3
- "version": "1.0.2",
3
+ "version": "1.0.4",
4
4
  "main": "index.js",
5
5
  "author": "Toprak Nihat Deniz Ozturk",
6
6
  "license": "MIT",
@@ -13,6 +13,6 @@
13
13
  "rbush": "^4.0.1"
14
14
  },
15
15
  "peerDependencies": {
16
- "@pirireis/webglobe": "^6.2.22"
16
+ "@pirireis/webglobe": "6.2.51^"
17
17
  }
18
18
  }
@@ -0,0 +1,399 @@
1
+ /**
2
+ * Parametreler
3
+ * Toplam Animasyon suresi
4
+ * nokta konumu lat long
5
+ * nokta boyutu
6
+ * nokta rengi
7
+ * buyume kusulme olamlimi? Varsa fade in ile buyuyup, fade out ile kuculecek.
8
+ * fade in suresi
9
+ * fade out suresi
10
+ * */
11
+ /**
12
+ * TODO:
13
+ * AFAD verisini hizli yuklenmesi icin bir formata ceviren kod ekle
14
+ * CONTENT basligi altina veri cevirici ve webgl programini yaz
15
+ */
16
+ /**
17
+ * @typedef {Number[]} Color [r, g, b]
18
+ */
19
+ /**
20
+ * @typedef {Object} FadeAlarmPoint
21
+ * @property {number} long
22
+ * @property {number} lat
23
+ * @property {number} height
24
+ * @property {number} minSize
25
+ * @property {number} maxSize
26
+ * @property {Color} color
27
+ * @property {number} startTime
28
+ * @property {number} fadeInTime
29
+ * @property {number} fadeOutTime
30
+ * @property {number} minAlpha
31
+ * @property {number} maxAlpha
32
+ */
33
+ const floatCount = 13;
34
+ const TIME_STEP = 26;
35
+ export default class AlarmTimeLineFadeInFadeOut {
36
+ constructor(id) {
37
+ this.id = id;
38
+ this.pause();
39
+ this.globe = null;
40
+ this.gl = null;
41
+ this._buildLOD = 6;
42
+ this._lastLOD = 0;
43
+ this._shaderProgram = null;
44
+ this._animationDeltaTime = 0;
45
+ this._animationFullTimeLength = 50000.0;
46
+ this._continue = false;
47
+ this._speedMultiplier = 1.0;
48
+ // time relevant
49
+ this._tickTimerId = null;
50
+ // @type {FadeAlarmPoint[]}
51
+ this._dataArray = [];
52
+ this._translateFloat32Array = new Float32Array(3);
53
+ this._mixtureBuffer = null;
54
+ this._buildTimerId = null;
55
+ this._projectionFunction = null;
56
+ }
57
+ _vertexShaderSource = `
58
+ precision highp float;
59
+
60
+ attribute vec3 aVertexPosition;
61
+ attribute vec3 aVertexColor;
62
+ attribute float aMinSize;
63
+ attribute float aMaxSize;
64
+ attribute float aStartTime;
65
+ attribute float aFadeInTime;
66
+ attribute float aFadeOutTime;
67
+ attribute float aMinAlpha;
68
+ attribute float aMaxAlpha;
69
+
70
+ uniform bool u_is_flat;
71
+ uniform vec2 u_mapWH;
72
+ uniform vec2 u_scrWH;
73
+
74
+ varying vec3 vColor;
75
+ varying float vAlpha;
76
+
77
+ uniform float uDeltaTime;
78
+
79
+ uniform mat4 uModelViewMatrix;
80
+ uniform mat4 uProjectionMatrix;
81
+ uniform vec3 uTranslate;
82
+
83
+ void main(void) {
84
+ float time = uDeltaTime - aStartTime;
85
+
86
+ // exit case
87
+ if (time < 0.0 || (time > (aFadeInTime + aFadeOutTime)) ) {
88
+ gl_Position = vec4(-2.0, -2.0, 0.0, 1.0);
89
+ vColor = vec3(0.0, 0.0, 0.0);
90
+ vAlpha = 0.0;
91
+ return;
92
+ }
93
+ float ratio;
94
+ // fade in case
95
+ if (time < aFadeInTime) {
96
+ ratio = time / aFadeInTime;
97
+ }
98
+ // fade out case
99
+ if (time > aFadeInTime) {
100
+ ratio = 1.0 - ((time - aFadeInTime) / aFadeOutTime);
101
+ }
102
+ if(u_is_flat==true){
103
+ float normalizedX = ( aVertexPosition.x - uTranslate.x) / u_mapWH.x;
104
+ float normalizedY = ( aVertexPosition.y - uTranslate.y) / u_mapWH.y;
105
+ gl_Position = uProjectionMatrix * vec4(normalizedX * u_scrWH.x, (1.0 - normalizedY) * u_scrWH.y, 0.0, 1.0);
106
+ }else{
107
+ gl_Position = uProjectionMatrix * uModelViewMatrix * vec4(aVertexPosition - uTranslate, 1.0);
108
+ }
109
+ gl_PointSize = mix(aMinSize, aMaxSize, ratio);
110
+
111
+ vColor = aVertexColor;
112
+ vAlpha = mix(aMinAlpha, aMaxAlpha, ratio);
113
+ }
114
+ `;
115
+ _fragmentShaderSource = `
116
+ precision highp float;
117
+
118
+ varying vec3 vColor;
119
+ varying float vAlpha;
120
+
121
+ void main(void) {
122
+ // circle
123
+ vec2 cxy = 2.0 * gl_PointCoord - 1.0;
124
+ float r = dot(cxy, cxy);
125
+ if (r > 1.0) discard;
126
+ // square
127
+ // float t = abs(cxy.x) * abs(cxy.y);
128
+ // if (t > 0.1) discard;
129
+ if (vAlpha == 0.0) { discard;}
130
+ float alphaRatio = sqrt(1.0 - r) ;
131
+ gl_FragColor = vec4(vColor, vAlpha ) * alphaRatio;
132
+ }
133
+ `;
134
+ _createProgram() {
135
+ const { gl, _vertexShaderSource, _fragmentShaderSource } = this;
136
+ let vertexShader = gl.createShader(gl.VERTEX_SHADER);
137
+ gl.shaderSource(vertexShader, _vertexShaderSource);
138
+ gl.compileShader(vertexShader);
139
+ if (!gl.getShaderParameter(vertexShader, gl.COMPILE_STATUS)) {
140
+ alert("An error occurred compiling the vertex shader: " + gl.getShaderInfoLog(vertexShader));
141
+ return null;
142
+ }
143
+ let fragmentShader = gl.createShader(gl.FRAGMENT_SHADER);
144
+ gl.shaderSource(fragmentShader, _fragmentShaderSource);
145
+ gl.compileShader(fragmentShader);
146
+ if (!gl.getShaderParameter(fragmentShader, gl.COMPILE_STATUS)) {
147
+ alert("An error occurred compiling the fragment shader: " + gl.getShaderInfoLog(fragmentShader));
148
+ return null;
149
+ }
150
+ this._shaderProgram = gl.createProgram();
151
+ gl.attachShader(this._shaderProgram, vertexShader);
152
+ gl.attachShader(this._shaderProgram, fragmentShader);
153
+ gl.linkProgram(this._shaderProgram);
154
+ if (!gl.getProgramParameter(this._shaderProgram, gl.LINK_STATUS)) {
155
+ alert("Could not initialise shaders");
156
+ console.log(gl.getProgramInfoLog(this._shaderProgram));
157
+ }
158
+ gl.detachShader(this._shaderProgram, vertexShader);
159
+ gl.detachShader(this._shaderProgram, fragmentShader);
160
+ gl.deleteShader(vertexShader);
161
+ gl.deleteShader(fragmentShader);
162
+ }
163
+ _assignProgramLocations() {
164
+ const { gl, _shaderProgram } = this;
165
+ this._aVertexPosition = gl.getAttribLocation(_shaderProgram, "aVertexPosition");
166
+ this._aVertexColor = gl.getAttribLocation(_shaderProgram, "aVertexColor");
167
+ this._aMinSize = gl.getAttribLocation(_shaderProgram, "aMinSize");
168
+ this._aMaxSize = gl.getAttribLocation(_shaderProgram, "aMaxSize");
169
+ this._aStartTime = gl.getAttribLocation(_shaderProgram, "aStartTime");
170
+ this._aFadeInTime = gl.getAttribLocation(_shaderProgram, "aFadeInTime");
171
+ this._aFadeOutTime = gl.getAttribLocation(_shaderProgram, "aFadeOutTime");
172
+ this._aMinAlpha = gl.getAttribLocation(_shaderProgram, "aMinAlpha");
173
+ this._aMaxAlpha = gl.getAttribLocation(_shaderProgram, "aMaxAlpha");
174
+ this._uDeltaTime = gl.getUniformLocation(_shaderProgram, "uDeltaTime");
175
+ this._uModelViewMatrix = gl.getUniformLocation(_shaderProgram, "uModelViewMatrix");
176
+ this._uProjectionMatrix = gl.getUniformLocation(_shaderProgram, "uProjectionMatrix");
177
+ this._uTranslate = gl.getUniformLocation(_shaderProgram, "uTranslate");
178
+ this._uMapWH = gl.getUniformLocation(_shaderProgram, "u_mapWH");
179
+ this._uScrWH = gl.getUniformLocation(_shaderProgram, "u_scrWH");
180
+ this._uIsFlat = gl.getUniformLocation(_shaderProgram, "u_is_flat");
181
+ }
182
+ // registry takes place here
183
+ init(globe, gl) {
184
+ console.log("init AlarmFadeInFadeOut");
185
+ this.globe = globe;
186
+ this.gl = gl;
187
+ this._mixtureBuffer = gl.createBuffer();
188
+ this.setGeometry();
189
+ this._createProgram();
190
+ this._assignProgramLocations();
191
+ this._startTickTimer();
192
+ this._resizeHandler = this._resizeEventHandler.bind(this);
193
+ window.addEventListener('resize', this._resizeHandler, true);
194
+ }
195
+ _resizeEventHandler() {
196
+ this._loadUniforms();
197
+ }
198
+ addPoint(long, lat, height, minSize, maxSize, color, startTime, fadeInTime, fadeOutTime, minAlpha, maxAlpha) {
199
+ // add point to the array
200
+ this._dataArray.push({
201
+ long,
202
+ lat,
203
+ height,
204
+ minSize,
205
+ maxSize,
206
+ color,
207
+ startTime,
208
+ fadeInTime,
209
+ fadeOutTime,
210
+ minAlpha,
211
+ maxAlpha
212
+ });
213
+ }
214
+ setAnimationFullTimeLength(time) {
215
+ this._animationFullTimeLength = time;
216
+ }
217
+ updateBuffer() {
218
+ if (this._dataArray.length === 0)
219
+ return;
220
+ this._build();
221
+ }
222
+ clearPoints() {
223
+ this._dataArray = [];
224
+ this._build();
225
+ }
226
+ setCurrentTimeByPercentage(percentage) {
227
+ const passingTime = this._animationFullTimeLength * (percentage % 100) / 100;
228
+ this._animationDeltaTime = passingTime;
229
+ }
230
+ setSpeedMultiplier(multiplier) {
231
+ this._speedMultiplier = multiplier;
232
+ }
233
+ continue() {
234
+ if (this._animationFullTimeLength == null)
235
+ throw new Error("Animation full time length is not set");
236
+ this._continue = true;
237
+ if (this._tickTimerId == null) {
238
+ this._startTickTimer();
239
+ }
240
+ console.log("continue");
241
+ }
242
+ isContinuing() {
243
+ return this._continue;
244
+ }
245
+ pause() {
246
+ this._continue = false;
247
+ if (this._tickTimerId != null) {
248
+ clearInterval(this._tickTimerId);
249
+ this._tickTimerId = null;
250
+ }
251
+ console.log("pause");
252
+ }
253
+ _tick() {
254
+ this._animationDeltaTime = (this._animationDeltaTime + TIME_STEP * this._speedMultiplier) % this._animationFullTimeLength;
255
+ }
256
+ _startTickTimer() {
257
+ this._tickTimerId = setInterval(() => {
258
+ if (this._continue)
259
+ this._tick();
260
+ }, TIME_STEP);
261
+ }
262
+ getPercentage() {
263
+ return this._animationDeltaTime / this._animationFullTimeLength;
264
+ }
265
+ // globe calls this function
266
+ draw3D(projMatrix, modelMatrix, transPos) {
267
+ // if (this._continue) this._tick();
268
+ this._draw(projMatrix, modelMatrix, transPos);
269
+ }
270
+ _draw(projMatrix, modelMatrix, transPos) {
271
+ if (this._dataArray.length === 0)
272
+ return;
273
+ const { gl, globe } = this;
274
+ if (globe == null) {
275
+ console.log("globe is null");
276
+ return;
277
+ }
278
+ const lastDepth = gl.getParameter(gl.DEPTH_TEST);
279
+ gl.disable(gl.DEPTH_TEST);
280
+ gl.enable(gl.BLEND);
281
+ gl.blendFunc(gl.SRC_ALPHA, gl.ONE_MINUS_SRC_ALPHA);
282
+ this._translateFloat32Array.set([transPos.x, transPos.y, transPos.z], 0);
283
+ gl.useProgram(this._shaderProgram);
284
+ gl.bindBuffer(gl.ARRAY_BUFFER, this._mixtureBuffer);
285
+ gl.enableVertexAttribArray(this._aVertexPosition); // devamli enable edilmesine gerek olmayabilir mi?
286
+ gl.vertexAttribPointer(this._aVertexPosition, 3, gl.FLOAT, false, floatCount * 4, 0);
287
+ gl.enableVertexAttribArray(this._aVertexColor);
288
+ gl.vertexAttribPointer(this._aVertexColor, 3, gl.FLOAT, false, floatCount * 4, 3 * 4);
289
+ gl.enableVertexAttribArray(this._aMinSize);
290
+ gl.vertexAttribPointer(this._aMinSize, 1, gl.FLOAT, false, floatCount * 4, 6 * 4);
291
+ gl.enableVertexAttribArray(this._aMaxSize);
292
+ gl.vertexAttribPointer(this._aMaxSize, 1, gl.FLOAT, false, floatCount * 4, 7 * 4);
293
+ gl.enableVertexAttribArray(this._aStartTime);
294
+ gl.vertexAttribPointer(this._aStartTime, 1, gl.FLOAT, false, floatCount * 4, 8 * 4);
295
+ gl.enableVertexAttribArray(this._aFadeInTime);
296
+ gl.vertexAttribPointer(this._aFadeInTime, 1, gl.FLOAT, false, floatCount * 4, 9 * 4);
297
+ gl.enableVertexAttribArray(this._aFadeOutTime);
298
+ gl.vertexAttribPointer(this._aFadeOutTime, 1, gl.FLOAT, false, floatCount * 4, 10 * 4);
299
+ gl.enableVertexAttribArray(this._aMinAlpha);
300
+ gl.vertexAttribPointer(this._aMinAlpha, 1, gl.FLOAT, false, floatCount * 4, 11 * 4);
301
+ gl.enableVertexAttribArray(this._aMaxAlpha);
302
+ gl.vertexAttribPointer(this._aMaxAlpha, 1, gl.FLOAT, false, floatCount * 4, 12 * 4);
303
+ gl.uniform1f(this._uDeltaTime, this._animationDeltaTime);
304
+ if (globe.api_GetCurrentGeometry() === globe.api_GeometryTypes().FLAT) {
305
+ const { width, height } = globe.api_GetCurrentWorldWH();
306
+ gl.uniform2f(this._uMapWH, width, height);
307
+ }
308
+ else {
309
+ gl.uniformMatrix4fv(this._uModelViewMatrix, false, modelMatrix);
310
+ }
311
+ gl.uniformMatrix4fv(this._uProjectionMatrix, false, projMatrix);
312
+ gl.uniform3fv(this._uTranslate, this._translateFloat32Array);
313
+ gl.drawArrays(gl.POINTS, 0, this._dataArray.length);
314
+ if (lastDepth) {
315
+ gl.enable(gl.DEPTH_TEST);
316
+ }
317
+ gl.disable(gl.BLEND);
318
+ globe.DrawRender();
319
+ }
320
+ _build() {
321
+ // build data and fill the buffer
322
+ const { gl, globe, _mixtureBuffer } = this;
323
+ if (globe == null || _mixtureBuffer == null) {
324
+ console.log("globe is null");
325
+ return;
326
+ }
327
+ const floatArray = new Float32Array(this._dataArray.length * floatCount);
328
+ for (let i = 0; i < this._dataArray.length; i += 1) {
329
+ const data = this._dataArray[i];
330
+ const { long, lat, height, minSize, maxSize, color, fadeInTime, fadeOutTime } = data;
331
+ const [x, y, z] = globe.api_Get3DPoint(long, lat, height, false);
332
+ const [r, g, b] = color;
333
+ const startTime = data.startTime;
334
+ const minAlpha = data.minAlpha;
335
+ const maxAlpha = data.maxAlpha;
336
+ floatArray.set([x, y, z, r, g, b, minSize, maxSize, startTime, fadeInTime, fadeOutTime, minAlpha, maxAlpha], i * floatCount);
337
+ }
338
+ console.log("floatArray", floatArray);
339
+ gl.bindBuffer(gl.ARRAY_BUFFER, _mixtureBuffer);
340
+ gl.bufferData(gl.ARRAY_BUFFER, floatArray, gl.STATIC_DRAW);
341
+ console.log("build");
342
+ if (this._buildTimerId == null) {
343
+ this._startBuildTimer();
344
+ }
345
+ }
346
+ _startBuildTimer() {
347
+ const { globe, _buildLOD } = this;
348
+ this._buildTimerId = setInterval(() => {
349
+ if (globe.api_GetCurrentGeometry() != globe.api_GeometryTypes().SPHERE)
350
+ return;
351
+ const LOD = globe.api_GetCurrentLOD();
352
+ if (!globe.api_IsScreenMoving() && LOD >= _buildLOD && LOD !== this._lastLOD) {
353
+ this._build();
354
+ this._lastLOD = LOD;
355
+ }
356
+ }, 1000);
357
+ console.log("startBuildTimer");
358
+ }
359
+ setGeometry() {
360
+ // arazi yuksekligine gore build tetikleyecek push mekanizmasi globeta yok
361
+ // timer start edilip durdurulacak
362
+ this._loadUniforms();
363
+ this.updateBuffer();
364
+ console.log("setGeometry");
365
+ }
366
+ _loadUniforms() {
367
+ const { gl, globe } = this;
368
+ const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
369
+ gl.useProgram(this._shaderProgram);
370
+ const geometry = globe.api_GetCurrentGeometry();
371
+ if (geometry === globe.api_GeometryTypes().SPHERE) {
372
+ gl.uniform1f(this._uIsFlat, false);
373
+ }
374
+ else if (geometry === globe.api_GeometryTypes().FLAT) {
375
+ gl.uniform1f(this._uIsFlat, true);
376
+ gl.uniform2f(this._uScrWH, globe.api_ScrW(), globe.api_ScrH());
377
+ }
378
+ else {
379
+ alert("Geometry is not supported");
380
+ }
381
+ gl.useProgram(currentProgram);
382
+ }
383
+ free() {
384
+ console.log("free AlarmFadeInFadeOut");
385
+ const { gl } = this;
386
+ this.globe = null;
387
+ this.gl = null;
388
+ this.draw3D = null;
389
+ this._build = null;
390
+ clearInterval(this._buildTimerId);
391
+ clearInterval(this._tickTimerId);
392
+ gl.disableVertexAttribArray(this._aVertexPosition);
393
+ // gl.deleteBuffer(this._mixtureBuffer);
394
+ // gl.deleteProgram(this._shaderProgram);
395
+ this._shaderProgram = null;
396
+ this._mixtureBuffer = null;
397
+ window.removeEventListener('resize', this._resizeHandler, true);
398
+ }
399
+ }
@@ -1,18 +1,14 @@
1
- import { Degree } from "../types";
2
-
3
- const Radians = Math.PI / 180;
4
-
5
- function bearingRealAngle(long: Degree, lat: Degree, endLong: Degree, endLat: Degree): Degree {
6
- const rLong = Radians * long;
7
- const rLat = Radians * lat;
8
- const rEndLong = Radians * endLong;
9
- const rEndLat = Radians * endLat;
10
- const delta_long = rEndLong - rLong;
11
- const x = Math.sin(delta_long) * Math.cos(rEndLat);
12
- const y = Math.cos(rLat) * Math.sin(rEndLat) - Math.sin(rLat) * Math.cos(rEndLat) * Math.cos(delta_long);
13
- let initialBearing = Math.atan2(x, y) / Radians;
14
- initialBearing = (initialBearing + 360) % 360;
15
- return initialBearing;
16
- }
17
-
18
- export { bearingRealAngle };
1
+ const Radians = Math.PI / 180;
2
+ function bearingRealAngle(long, lat, endLong, endLat) {
3
+ const rLong = Radians * long;
4
+ const rLat = Radians * lat;
5
+ const rEndLong = Radians * endLong;
6
+ const rEndLat = Radians * endLat;
7
+ const delta_long = rEndLong - rLong;
8
+ const x = Math.sin(delta_long) * Math.cos(rEndLat);
9
+ const y = Math.cos(rLat) * Math.sin(rEndLat) - Math.sin(rLat) * Math.cos(rEndLat) * Math.cos(delta_long);
10
+ let initialBearing = Math.atan2(x, y) / Radians;
11
+ initialBearing = (initialBearing + 360) % 360;
12
+ return initialBearing;
13
+ }
14
+ export { bearingRealAngle };