@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
@@ -1,340 +1,306 @@
1
- import { DrawFromPixelCoords, } from "../util/programs/draw-from-pixel-coords";
2
- import { latLongToPixelXY } from "../util/geometry/index";
3
-
4
- import ContourMipmap, { scaleParameters } from "../Math/contour/quadtreecontours";
5
-
6
- import ObjectArrayLabels from "../write-text/objectarraylabels";
7
-
8
- import { isBoolean, opacityCheck } from "../util/check/typecheck";
9
-
10
-
11
- export class IsobarRasterToVector {
12
-
13
-
14
- /**
15
- * @typedef {Object} IsobarData
16
- * @property {number} threshold
17
- * @property {[number, number, number]} color | rgb color
18
- * @property {string} label
19
- *
20
- * @param {*} id
21
- * @param {Array<IsobarData>} isabors
22
- * @param {number} width
23
- * @param {number} height
24
- * @param {Object} options
25
- * @param {boolean} options.xFlip
26
- * @param {boolean} options.yFlip
27
- * @param {boolean} options.isOn
28
- * @param {boolean} options.isLabelsOn
29
- * @param {Object} options.labelStyle
30
- */
31
- constructor(id, dataManager, isobars, width, height, [minLon, minLat, maxLon, maxLat] = [-180, -90, 180, 90], { xFlip = false, yFlip = true, isOn = true, isLabelsOn = true, labelStyle = null, maxMipmapLevel = null } = {}) {
32
- this.id = id;
33
- this._isobarsCheckAndComplete(isobars);
34
- this.isobars = isobars;
35
- this.contourMipmap = null;
36
- this.width = width;
37
- this.height = height;
38
- this.xFlip = xFlip;
39
- this.yFlip = yFlip;
40
- this.bbox = [minLon, minLat, maxLon, maxLat];
41
- this.dataManager = dataManager;
42
-
43
- this._transformationMethod = getTransformationMethod(xFlip, yFlip, width, height, minLon, minLat, maxLon, maxLat);
44
- this._isOn = isOn;
45
- this._isLabelsOn = isLabelsOn;
46
- this._labelsLayer = null;
47
- this._labelsLayerId = id + '_isobar-labels';
48
- this._lineStrignRanges = [];
49
- this._transpos = new Float32Array(3);
50
- this._maxMipmapLevel = maxMipmapLevel;
51
- this._labelStyle = labelStyle;
52
-
53
- // this._transformationMethod = null;
54
- }
55
-
56
- // API
57
-
58
- setData(data, on = false) {
59
- if (!data) return;
60
- this._data = data;
61
- if (on) this._isOn = true;
62
- if (this._isOn) this._calculateAll(data);
63
- }
64
-
65
- on() {
66
- this._isOn = true;
67
- if (this._data) this._calculateAll(this._data);
68
- }
69
-
70
- off() {
71
- this._isOn = false;
72
- this.clean();
73
- }
74
-
75
-
76
- clean() {
77
- this.flush();
78
- this.globe.DrawRender();
79
- }
80
-
81
- setFlip(xFlip, yFlip) {
82
- isBoolean(xFlip); isBoolean(yFlip);
83
- if (this.xFlip === xFlip && this.yFlip === yFlip) return;
84
- this.xFlip = xFlip;
85
- this.yFlip = yFlip;
86
- const [minLon, minLat, maxLon, maxLat] = this.bbox;
87
- const { width, height } = this
88
- this._transformationMethod = getTransformationMethod(xFlip, yFlip, width, height, minLon, minLat, maxLon, maxLat);
89
- this._calculateLines();
90
- this.globe.DrawRender();
91
- }
92
-
93
- setBoundingBox([minLon, minLat, maxLon, maxLat]) {
94
- this.bbox = [minLon, minLat, maxLon, maxLat];
95
- const { width, height, xFlip, yFlip } = this;
96
- this._transformationMethod = getTransformationMethod(xFlip, yFlip, width, height, minLon, minLat, maxLon, maxLat);
97
- this._calculateLines();
98
- this.globe.DrawRender();
99
- }
100
-
101
-
102
- setIsLabelsOn(isLabelsOn) {
103
- isBoolean(isLabelsOn);
104
- if (this._isLabelsOn === isLabelsOn) return;
105
- this._isLabelsOn = isLabelsOn;
106
- if (!isLabelsOn) {
107
- this._labelsLayer.removeFromMap();
108
- } else {
109
- if (this._labelsLayer === null) this._createLabelsLayer();
110
- this._labelsLayer.addToMap();
111
- this._createBufferData();
112
- }
113
- }
114
-
115
- getIsobars() {
116
- return this.isobars;
117
- }
118
-
119
- setIsobars(isobars) {
120
- this._isobarsCheckAndComplete(isobars);
121
- this.isobars = isobars;
122
- this._calculateLines();
123
- this.globe.DrawRender();
124
- }
125
-
126
- setWidthHeight(width, height) {
127
- this.width = width;
128
- this.height = height;
129
- const { xFlip, yFlip } = this;
130
- const [minLon, minLat, maxLon, maxLat] = this.bbox;
131
- this._transformationMethod = getTransformationMethod(xFlip, yFlip, width, height, minLon, minLat, maxLon, maxLat);
132
- this._calculateLines();
133
- this.globe.DrawRender();
134
- }
135
-
136
-
137
- getLabelStyle() {
138
- return this._labelsLayer.getLabelStyle();
139
- }
140
-
141
- setOpacity(opacity) {
142
- opacityCheck(opacity);
143
- this.program.setOpacity(opacity);
144
- }
145
-
146
-
147
- setLabelStyle(style) {
148
- this._labelStyle = style;
149
- if (this._labelsLayer) this._labelsLayer.setLabelStyle(style);
150
- const lastState = this._isLabelsOn;
151
- this.setIsLabelsOn(false);
152
- this.setIsLabelsOn(lastState);
153
- if (lastState) this._createBufferData();
154
- }
155
-
156
- setMaxMipmapLevel(maxMipmapLevel = null) {
157
- this._maxMipmapLevel = maxMipmapLevel;
158
- this._calculateLines();
159
- this.globe.DrawRender();
160
- }
161
-
162
-
163
- flush() {
164
- this.program.setBufferData(new Float32Array(0));
165
- this._lineStrignRanges = [];
166
- if (this._isLabelsOn) this._labelsLayer.flush();
167
- }
168
-
169
- //
170
- // implicit methods
171
-
172
- init(globe, gl) {
173
- this.gl = gl
174
- this.globe = globe
175
-
176
- this.program = new DrawFromPixelCoords(gl, globe, 'line_strip');
177
- if (this._isLabelsOn) {
178
- this._createLabelsLayer();
179
- this._labelsLayer.addToMap();
180
- }
181
-
182
- this.dataManager.register(this.id, (ratio, t1, t2) => {
183
- if (!t1 || !t2) {
184
- this.clean();
185
- return;
186
- }
187
- const data = dataMixer(t1, t2, ratio);
188
- if (this._isOn) this.setData(data);
189
- });
190
- }
191
-
192
-
193
- resize(width, height) {
194
- this.program.resize(width, height);
195
- }
196
-
197
- draw3D(projMatrix, modelviewMatrix, transPos) {
198
- if (!this._ready) return;
199
- this._drawContour(projMatrix, modelviewMatrix, transPos);
200
- }
201
-
202
- _calculateLines() {
203
- this._calculateContours();
204
- this._bufferData = this._createBufferData();
205
- this.program.setBufferData(this._bufferData);
206
- }
207
-
208
- _drawContour(projMatrix, modelviewMatrix, transPos) {
209
- this.program.draw(projMatrix, modelviewMatrix, transPos, this._lineStrignRanges);
210
- }
211
-
212
-
213
-
214
- _calculateIntersections(threshold) {
215
- const { _transformationMethod } = this;
216
- const lines = this.contourMipmap.contour([threshold], { maxMipmapLevel: this._maxMipmapLevel }).map(coords => {
217
- return coords.map(([x, y]) => _transformationMethod(x, y))
218
- }
219
- );
220
- return lines;
221
- }
222
-
223
-
224
- _calculateAll(data) {
225
- this.contourMipmap = new ContourMipmap(data, this.width, this.height);
226
- this._calculateContours();
227
- this._bufferData = this._createBufferData();
228
- this.program.setBufferData(this._bufferData);
229
-
230
- this.globe.DrawRender();
231
- this._ready = true;
232
- }
233
-
234
- _calculateContours() {
235
- const { isobars } = this;
236
- for (const isobar of isobars) {
237
- const { threshold } = isobar;
238
- const lines = this._calculateIntersections(threshold);
239
- isobar.lines = lines;
240
- }
241
- }
242
-
243
-
244
- _isobarsCheckAndComplete(isobars) {
245
- if (!Array.isArray(isobars)) throw new Error("isobars must be an array");
246
- if (isobars.length === 0) throw new Error("isobars must contain at least one element");
247
- for (const isobar of isobars) {
248
- if (!isobar || typeof isobar !== 'object') throw new Error("isobar must be an object");
249
- if (typeof isobar.threshold !== 'number') throw new Error("isobar.threshold must be a number");
250
- if (isobar.color) {
251
- if (!Array.isArray(isobar.color) || isobar.color.length !== 3) throw new Error("isobar.color must be an array with 3 elements");
252
- for (const color of isobar.color) {
253
- if (color < 0 || color > 1) throw new Error("isobar.color elements must be between 0 and 1");
254
- }
255
- }
256
- if (!isobar.color) isobar.color = [1, 1, 1];
257
- }
258
- }
259
-
260
- _createBufferData() {
261
- const { isobars } = this;
262
- const pointCount = isobars.reduce((acc, { lines }) => acc + lines.reduce((acc, line) => acc + line.length, 0), 0);
263
- const bufferData = new Float32Array(pointCount * 6);
264
-
265
- let index = 0;
266
- let pointCounter = 0;
267
- this._lineStrignRanges = [];
268
-
269
- // gather label data label
270
- const labelPoints = {
271
- coords: [],
272
- coordsZ: [],
273
- attribs: []
274
- };
275
- const { coords, coordsZ, attribs } = labelPoints;
276
- let fidCounter = 0;
277
- for (const { lines, color, threshold } of isobars) {
278
- for (const line of lines) {
279
- let startIndex = pointCounter;
280
- for (const [x, y] of line) {
281
- const pixXY = latLongToPixelXY(y, x)
282
- bufferData[index++] = pixXY.x;
283
- bufferData[index++] = pixXY.y;
284
- bufferData[index++] = color[0];
285
- bufferData[index++] = color[1];
286
- bufferData[index++] = color[2];
287
- bufferData[index++] = 1.0;
288
- pointCounter++;
289
- }
290
-
291
- coords.push(line[0][0], line[0][1]);
292
- coordsZ.push(0)
293
- attribs.push({ value: threshold, fid: fidCounter++ })
294
- this._lineStrignRanges.push([startIndex, pointCounter - startIndex]);
295
- }
296
- }
297
- if (this._isLabelsOn) this._labelsLayer.setData(labelPoints);
298
-
299
- return bufferData;
300
- }
301
-
302
-
303
-
304
- _createLabelsLayer() {
305
- this._labelsLayer = new ObjectArrayLabels(this._labelsLayerId, this.globe, this._labelStyle);
306
- }
307
-
308
- setGeometry() {
309
- this.program.setGeometry();
310
- }
311
-
312
-
313
- free() {
314
- this.flush();
315
- this.program.free();
316
- if (this._isLabelsOn) this._labelsLayer.removeFromMap();
317
- this.dataManager.unregister(this.id);
318
- }
319
-
320
-
321
-
322
- }
323
-
324
- const getTransformationMethod = (xFlip, yFlip, width, height, minX, minY, maxX, maxY) => {
325
- const { scaleX, scaleY } = scaleParameters(minX, minY, maxX, maxY, width, height);
326
- if (xFlip && yFlip) return (x, y) => [maxX - x * scaleX, maxY - y * scaleY];
327
- if (xFlip && !yFlip) return (x, y) => [maxX - x * scaleX, minY + y * scaleY];
328
- if (!xFlip && yFlip) return (x, y) => [minX + x * scaleX, maxY - y * scaleY];
329
- return (x, y) => [minX + x * scaleX, minY + y * scaleY];
330
- }
331
-
332
- function dataMixer(data1, data2, ratio) {
333
- if (!data1 || !data2) return null;
334
- if (data1.length !== data2.length) throw new Error("Data length mismatch");
335
- const data = new Float32Array(data1.length);
336
- for (let i = 0; i < data1.length; i++) {
337
- data[i] = data1[i] * (1 - ratio) + data2[i] * ratio;
338
- }
339
- return data;
340
- }
1
+ /**
2
+ * Author: Toprak Nihat Deniz Ozturk
3
+ */
4
+ import { DrawFromPixelCoords, } from "../util/programs/draw-from-pixel-coords";
5
+ import { latLongToPixelXY } from "../util/geometry/index";
6
+ import ContourMipmap, { scaleParameters } from "../Math/contour/quadtreecontours";
7
+ import ObjectArrayLabels from "../write-text/objectarraylabels";
8
+ import { isBoolean, opacityCheck } from "../util/check/typecheck";
9
+ export class IsobarRasterToVector {
10
+ /**
11
+ * @typedef {Object} IsobarData
12
+ * @property {number} threshold
13
+ * @property {[number, number, number]} color | rgb color
14
+ * @property {string} label
15
+ *
16
+ * @param {*} id
17
+ * @param {Array<IsobarData>} isabors
18
+ * @param {number} width
19
+ * @param {number} height
20
+ * @param {Object} options
21
+ * @param {boolean} options.xFlip
22
+ * @param {boolean} options.yFlip
23
+ * @param {boolean} options.isOn
24
+ * @param {boolean} options.isLabelsOn
25
+ * @param {Object} options.labelStyle
26
+ */
27
+ constructor(id, dataManager, isobars, width, height, [minLon, minLat, maxLon, maxLat] = [-180, -90, 180, 90], { xFlip = false, yFlip = true, isOn = true, isLabelsOn = true, labelStyle = null, maxMipmapLevel = null } = {}) {
28
+ this.id = id;
29
+ this._isobarsCheckAndComplete(isobars);
30
+ this.isobars = isobars;
31
+ this.contourMipmap = null;
32
+ this.width = width;
33
+ this.height = height;
34
+ this.xFlip = xFlip;
35
+ this.yFlip = yFlip;
36
+ this.bbox = [minLon, minLat, maxLon, maxLat];
37
+ this.dataManager = dataManager;
38
+ this._transformationMethod = getTransformationMethod(xFlip, yFlip, width, height, minLon, minLat, maxLon, maxLat);
39
+ this._isOn = isOn;
40
+ this._isLabelsOn = isLabelsOn;
41
+ this._labelsLayer = null;
42
+ this._labelsLayerId = id + '_isobar-labels';
43
+ this._lineStrignRanges = [];
44
+ this._transpos = new Float32Array(3);
45
+ this._maxMipmapLevel = maxMipmapLevel;
46
+ this._labelStyle = labelStyle;
47
+ // this._transformationMethod = null;
48
+ }
49
+ // API
50
+ setData(data, on = false) {
51
+ if (!data)
52
+ return;
53
+ this._data = data;
54
+ if (on)
55
+ this._isOn = true;
56
+ if (this._isOn)
57
+ this._calculateAll(data);
58
+ }
59
+ on() {
60
+ this._isOn = true;
61
+ if (this._data)
62
+ this._calculateAll(this._data);
63
+ }
64
+ off() {
65
+ this._isOn = false;
66
+ this.clean();
67
+ }
68
+ clean() {
69
+ this.flush();
70
+ this.globe.DrawRender();
71
+ }
72
+ setFlip(xFlip, yFlip) {
73
+ isBoolean(xFlip);
74
+ isBoolean(yFlip);
75
+ if (this.xFlip === xFlip && this.yFlip === yFlip)
76
+ return;
77
+ this.xFlip = xFlip;
78
+ this.yFlip = yFlip;
79
+ const [minLon, minLat, maxLon, maxLat] = this.bbox;
80
+ const { width, height } = this;
81
+ this._transformationMethod = getTransformationMethod(xFlip, yFlip, width, height, minLon, minLat, maxLon, maxLat);
82
+ this._calculateLines();
83
+ this.globe.DrawRender();
84
+ }
85
+ setBoundingBox([minLon, minLat, maxLon, maxLat]) {
86
+ this.bbox = [minLon, minLat, maxLon, maxLat];
87
+ const { width, height, xFlip, yFlip } = this;
88
+ this._transformationMethod = getTransformationMethod(xFlip, yFlip, width, height, minLon, minLat, maxLon, maxLat);
89
+ this._calculateLines();
90
+ this.globe.DrawRender();
91
+ }
92
+ setIsLabelsOn(isLabelsOn) {
93
+ isBoolean(isLabelsOn);
94
+ if (this._isLabelsOn === isLabelsOn)
95
+ return;
96
+ this._isLabelsOn = isLabelsOn;
97
+ if (!isLabelsOn) {
98
+ this._labelsLayer.removeFromMap();
99
+ }
100
+ else {
101
+ if (this._labelsLayer === null)
102
+ this._createLabelsLayer();
103
+ this._labelsLayer.addToMap();
104
+ this._createBufferData();
105
+ }
106
+ }
107
+ getIsobars() {
108
+ return this.isobars;
109
+ }
110
+ setIsobars(isobars) {
111
+ this._isobarsCheckAndComplete(isobars);
112
+ this.isobars = isobars;
113
+ this._calculateLines();
114
+ this.globe.DrawRender();
115
+ }
116
+ setWidthHeight(width, height) {
117
+ this.width = width;
118
+ this.height = height;
119
+ const { xFlip, yFlip } = this;
120
+ const [minLon, minLat, maxLon, maxLat] = this.bbox;
121
+ this._transformationMethod = getTransformationMethod(xFlip, yFlip, width, height, minLon, minLat, maxLon, maxLat);
122
+ this._calculateLines();
123
+ this.globe.DrawRender();
124
+ }
125
+ getLabelStyle() {
126
+ return this._labelsLayer.getLabelStyle();
127
+ }
128
+ setOpacity(opacity) {
129
+ opacityCheck(opacity);
130
+ this.program.setOpacity(opacity);
131
+ }
132
+ setLabelStyle(style) {
133
+ this._labelStyle = style;
134
+ if (this._labelsLayer)
135
+ this._labelsLayer.setLabelStyle(style);
136
+ const lastState = this._isLabelsOn;
137
+ this.setIsLabelsOn(false);
138
+ this.setIsLabelsOn(lastState);
139
+ if (lastState)
140
+ this._createBufferData();
141
+ }
142
+ setMaxMipmapLevel(maxMipmapLevel = null) {
143
+ this._maxMipmapLevel = maxMipmapLevel;
144
+ this._calculateLines();
145
+ this.globe.DrawRender();
146
+ }
147
+ flush() {
148
+ this.program.setBufferData(new Float32Array(0));
149
+ this._lineStrignRanges = [];
150
+ if (this._isLabelsOn)
151
+ this._labelsLayer.flush();
152
+ }
153
+ //
154
+ // implicit methods
155
+ init(globe, gl) {
156
+ this.gl = gl;
157
+ this.globe = globe;
158
+ this.program = new DrawFromPixelCoords(gl, globe, 'line_strip');
159
+ if (this._isLabelsOn) {
160
+ this._createLabelsLayer();
161
+ this._labelsLayer.addToMap();
162
+ }
163
+ this.dataManager.register(this.id, (ratio, t1, t2) => {
164
+ if (!t1 || !t2) {
165
+ this.clean();
166
+ return;
167
+ }
168
+ const data = dataMixer(t1, t2, ratio);
169
+ if (this._isOn)
170
+ this.setData(data);
171
+ });
172
+ }
173
+ resize(width, height) {
174
+ this.program.resize(width, height);
175
+ }
176
+ draw3D(projMatrix, modelviewMatrix, transPos) {
177
+ if (!this._ready)
178
+ return;
179
+ this._drawContour(projMatrix, modelviewMatrix, transPos);
180
+ }
181
+ _calculateLines() {
182
+ this._calculateContours();
183
+ this._bufferData = this._createBufferData();
184
+ this.program.setBufferData(this._bufferData);
185
+ }
186
+ _drawContour(projMatrix, modelviewMatrix, transPos) {
187
+ this.program.draw(projMatrix, modelviewMatrix, transPos, this._lineStrignRanges);
188
+ }
189
+ _calculateIntersections(threshold) {
190
+ const { _transformationMethod } = this;
191
+ const lines = this.contourMipmap.contour([threshold], { maxMipmapLevel: this._maxMipmapLevel }).map(coords => {
192
+ return coords.map(([x, y]) => _transformationMethod(x, y));
193
+ });
194
+ return lines;
195
+ }
196
+ _calculateAll(data) {
197
+ this.contourMipmap = new ContourMipmap(data, this.width, this.height);
198
+ this._calculateContours();
199
+ this._bufferData = this._createBufferData();
200
+ this.program.setBufferData(this._bufferData);
201
+ this.globe.DrawRender();
202
+ this._ready = true;
203
+ }
204
+ _calculateContours() {
205
+ const { isobars } = this;
206
+ for (const isobar of isobars) {
207
+ const { threshold } = isobar;
208
+ const lines = this._calculateIntersections(threshold);
209
+ isobar.lines = lines;
210
+ }
211
+ }
212
+ _isobarsCheckAndComplete(isobars) {
213
+ if (!Array.isArray(isobars))
214
+ throw new Error("isobars must be an array");
215
+ if (isobars.length === 0)
216
+ throw new Error("isobars must contain at least one element");
217
+ for (const isobar of isobars) {
218
+ if (!isobar || typeof isobar !== 'object')
219
+ throw new Error("isobar must be an object");
220
+ if (typeof isobar.threshold !== 'number')
221
+ throw new Error("isobar.threshold must be a number");
222
+ if (isobar.color) {
223
+ if (!Array.isArray(isobar.color) || isobar.color.length !== 3)
224
+ throw new Error("isobar.color must be an array with 3 elements");
225
+ for (const color of isobar.color) {
226
+ if (color < 0 || color > 1)
227
+ throw new Error("isobar.color elements must be between 0 and 1");
228
+ }
229
+ }
230
+ if (!isobar.color)
231
+ isobar.color = [1, 1, 1];
232
+ }
233
+ }
234
+ _createBufferData() {
235
+ const { isobars } = this;
236
+ const pointCount = isobars.reduce((acc, { lines }) => acc + lines.reduce((acc, line) => acc + line.length, 0), 0);
237
+ const bufferData = new Float32Array(pointCount * 6);
238
+ let index = 0;
239
+ let pointCounter = 0;
240
+ this._lineStrignRanges = [];
241
+ // gather label data label
242
+ const labelPoints = {
243
+ coords: [],
244
+ coordsZ: [],
245
+ attribs: []
246
+ };
247
+ const { coords, coordsZ, attribs } = labelPoints;
248
+ let fidCounter = 0;
249
+ for (const { lines, color, threshold } of isobars) {
250
+ for (const line of lines) {
251
+ let startIndex = pointCounter;
252
+ for (const [x, y] of line) {
253
+ const pixXY = latLongToPixelXY(y, x);
254
+ bufferData[index++] = pixXY.x;
255
+ bufferData[index++] = pixXY.y;
256
+ bufferData[index++] = color[0];
257
+ bufferData[index++] = color[1];
258
+ bufferData[index++] = color[2];
259
+ bufferData[index++] = 1.0;
260
+ pointCounter++;
261
+ }
262
+ coords.push(line[0][0], line[0][1]);
263
+ coordsZ.push(0);
264
+ attribs.push({ value: threshold, fid: fidCounter++ });
265
+ this._lineStrignRanges.push([startIndex, pointCounter - startIndex]);
266
+ }
267
+ }
268
+ if (this._isLabelsOn)
269
+ this._labelsLayer.setData(labelPoints);
270
+ return bufferData;
271
+ }
272
+ _createLabelsLayer() {
273
+ this._labelsLayer = new ObjectArrayLabels(this._labelsLayerId, this.globe, this._labelStyle);
274
+ }
275
+ setGeometry() {
276
+ this.program.setGeometry();
277
+ }
278
+ free() {
279
+ this.flush();
280
+ this.program.free();
281
+ if (this._isLabelsOn)
282
+ this._labelsLayer.removeFromMap();
283
+ this.dataManager.unregister(this.id);
284
+ }
285
+ }
286
+ const getTransformationMethod = (xFlip, yFlip, width, height, minX, minY, maxX, maxY) => {
287
+ const { scaleX, scaleY } = scaleParameters(minX, minY, maxX, maxY, width, height);
288
+ if (xFlip && yFlip)
289
+ return (x, y) => [maxX - x * scaleX, maxY - y * scaleY];
290
+ if (xFlip && !yFlip)
291
+ return (x, y) => [maxX - x * scaleX, minY + y * scaleY];
292
+ if (!xFlip && yFlip)
293
+ return (x, y) => [minX + x * scaleX, maxY - y * scaleY];
294
+ return (x, y) => [minX + x * scaleX, minY + y * scaleY];
295
+ };
296
+ function dataMixer(data1, data2, ratio) {
297
+ if (!data1 || !data2)
298
+ return null;
299
+ if (data1.length !== data2.length)
300
+ throw new Error("Data length mismatch");
301
+ const data = new Float32Array(data1.length);
302
+ for (let i = 0; i < data1.length; i++) {
303
+ data[i] = data1[i] * (1 - ratio) + data2[i] * ratio;
304
+ }
305
+ return data;
306
+ }