@pirireis/webglobeplugins 0.9.6 → 0.9.8

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 (304) hide show
  1. package/{Math → dist/Math}/angle-calculation.js +15 -14
  2. package/dist/Math/arc.js +65 -0
  3. package/{Math → dist/Math}/bounds/line-bbox.js +188 -225
  4. package/dist/Math/constants.js +9 -0
  5. package/{Math/frustum/camera.ts → dist/Math/frustum/camera.js} +24 -32
  6. package/{Math/frustum/from-globeinfo.ts → dist/Math/frustum/from-globeinfo.js} +48 -63
  7. package/dist/Math/frustum/types.js +2 -0
  8. package/{Math/globe-util/horizon-plane.ts → dist/Math/globe-util/horizon-plane.js} +112 -137
  9. package/dist/Math/index.js +1 -0
  10. package/dist/Math/juction/arc-plane.js +83 -0
  11. package/dist/Math/juction/line-sphere.js +25 -0
  12. package/{Math/juction/plane-plane.ts → dist/Math/juction/plane-plane.js} +58 -66
  13. package/dist/Math/line.js +56 -0
  14. package/dist/Math/matrix4.js +1 -0
  15. package/{Math → dist/Math}/methods.js +201 -237
  16. package/dist/Math/plane.js +60 -0
  17. package/{Math/quaternion.ts → dist/Math/quaternion.js} +104 -120
  18. package/dist/Math/types.js +2 -0
  19. package/dist/Math/utils.js +4 -0
  20. package/{Math/vec3.ts → dist/Math/vec3.js} +126 -155
  21. package/dist/algorithms/search-binary.js +19 -0
  22. package/dist/altitude-locator/adaptors.js +1 -0
  23. package/{altitude-locator → dist/altitude-locator}/draw-subset-obj.js +18 -27
  24. package/dist/altitude-locator/keymethod.js +1 -0
  25. package/{altitude-locator → dist/altitude-locator}/plugin.js +341 -439
  26. package/{altitude-locator → dist/altitude-locator}/types.js +23 -26
  27. package/{arrowfield → dist/arrowfield}/adaptor.js +14 -11
  28. package/dist/arrowfield/index.js +10 -0
  29. package/{arrowfield → dist/arrowfield}/plugin.js +86 -128
  30. package/dist/bearing-line/index.js +8 -0
  31. package/{bearing-line → dist/bearing-line}/plugin.js +449 -512
  32. package/{circle-line-chain → dist/circle-line-chain}/chain-list-map.js +205 -221
  33. package/dist/circle-line-chain/init.js +1 -0
  34. package/{circle-line-chain → dist/circle-line-chain}/plugin.js +424 -469
  35. package/dist/circle-line-chain/util.js +5 -0
  36. package/{compass-rose → dist/compass-rose}/compass-rose-padding-flat.js +225 -266
  37. package/{compass-rose → dist/compass-rose}/compass-text-writer.js +153 -173
  38. package/dist/compass-rose/index.js +7 -0
  39. package/{compassrose → dist/compassrose}/compassrose.js +296 -341
  40. package/dist/compassrose/index.js +8 -0
  41. package/dist/globe-types.js +1 -0
  42. package/dist/heatwave/index.js +10 -0
  43. package/{heatwave → dist/heatwave}/isobar/objectarraylabels.js +202 -247
  44. package/{heatwave → dist/heatwave}/isobar/plugin.js +343 -340
  45. package/{heatwave → dist/heatwave}/isobar/quadtreecontours.js +300 -336
  46. package/{heatwave → dist/heatwave}/plugins/heatwaveglobeshell.js +206 -258
  47. package/dist/index.js +58 -0
  48. package/{jest.config.js → dist/jest.config.js} +7 -6
  49. package/{partialrings → dist/partialrings}/buffer-manager.js +81 -89
  50. package/dist/partialrings/index.js +41 -0
  51. package/{partialrings → dist/partialrings}/plugin.js +135 -160
  52. package/{partialrings → dist/partialrings}/program.js +204 -242
  53. package/{pin → dist/pin}/pin-object-array.js +305 -381
  54. package/{pin → dist/pin}/pin-point-totem.js +60 -77
  55. package/{point-heat-map → dist/point-heat-map}/adaptors/timetracksplugin-format-to-this.js +66 -78
  56. package/dist/point-heat-map/index.js +1 -0
  57. package/{point-heat-map → dist/point-heat-map}/plugin-webworker.js +126 -151
  58. package/{point-heat-map → dist/point-heat-map}/point-to-heat-map-flow.js +127 -150
  59. package/dist/point-tracks/key-methods.js +5 -0
  60. package/{point-tracks → dist/point-tracks}/plugin.js +338 -394
  61. package/dist/programs/arrowfield/index.js +7 -0
  62. package/{programs → dist/programs}/arrowfield/logic.js +144 -173
  63. package/{programs → dist/programs}/arrowfield/object.js +66 -89
  64. package/{programs → dist/programs}/data2legend/density-to-legend.js +76 -90
  65. package/{programs → dist/programs}/data2legend/point-to-density-texture.js +76 -90
  66. package/dist/programs/float2legendwithratio/index.js +8 -0
  67. package/{programs → dist/programs}/float2legendwithratio/logic.js +122 -145
  68. package/{programs → dist/programs}/float2legendwithratio/object.js +110 -141
  69. package/{programs → dist/programs}/globe-util/is-globe-moved.js +21 -27
  70. package/dist/programs/globeshell/index.js +8 -0
  71. package/dist/programs/globeshell/noise/noises.js +1 -0
  72. package/dist/programs/globeshell/wiggle/index.js +8 -0
  73. package/{programs → dist/programs}/globeshell/wiggle/logic.js +246 -272
  74. package/{programs → dist/programs}/globeshell/wiggle/object.js +72 -93
  75. package/dist/programs/helpers/blender/index.js +1 -0
  76. package/{programs → dist/programs}/helpers/blender/program.js +61 -73
  77. package/dist/programs/helpers/fadeaway/index.js +7 -0
  78. package/{programs → dist/programs}/helpers/fadeaway/logic.js +49 -53
  79. package/dist/programs/helpers/fadeaway/object.js +20 -0
  80. package/dist/programs/helpers/index.js +8 -0
  81. package/dist/programs/index.js +58 -0
  82. package/dist/programs/interface.js +1 -0
  83. package/{programs → dist/programs}/line-on-globe/angled-line.js +125 -155
  84. package/{programs → dist/programs}/line-on-globe/circle-accurate-3d.js +95 -121
  85. package/{programs → dist/programs}/line-on-globe/circle-accurate-flat.js +158 -204
  86. package/{programs → dist/programs}/line-on-globe/circle-accurate.js +117 -141
  87. package/{programs → dist/programs}/line-on-globe/circle.js +111 -135
  88. package/{programs → dist/programs}/line-on-globe/degree-padding-around-circle-3d.js +111 -140
  89. package/dist/programs/line-on-globe/index.js +1 -0
  90. package/{programs → dist/programs}/line-on-globe/lines-color-instanced-flat.js +91 -106
  91. package/{programs/line-on-globe/linestrip.ts → dist/programs/line-on-globe/linestrip.js} +108 -165
  92. package/{programs → dist/programs}/line-on-globe/naive-accurate-flexible.js +127 -171
  93. package/{programs → dist/programs}/line-on-globe/to-the-surface.js +83 -101
  94. package/dist/programs/line-on-globe/util.js +8 -0
  95. package/{programs → dist/programs}/picking/pickable-renderer.js +107 -135
  96. package/{programs → dist/programs}/point-on-globe/element-globe-surface-glow.js +101 -127
  97. package/{programs → dist/programs}/point-on-globe/element-point-glow.js +88 -119
  98. package/{programs → dist/programs}/point-on-globe/square-pixel-point.js +126 -141
  99. package/{programs/programcache.ts → dist/programs/programcache.js} +131 -131
  100. package/{programs → dist/programs}/rings/distancering/circleflatprogram.js +115 -95
  101. package/{programs → dist/programs}/rings/distancering/circlepaddingfreeangleprogram.js +320 -329
  102. package/{programs → dist/programs}/rings/distancering/circlepaddysharedbuffer.js +357 -420
  103. package/dist/programs/rings/distancering/index.js +14 -0
  104. package/{programs → dist/programs}/rings/distancering/paddyflatprogram.js +120 -94
  105. package/{programs → dist/programs}/rings/distancering/paddyflatprogram2d.js +122 -98
  106. package/{programs → dist/programs}/rings/distancering/paddyflatprogram3d.js +120 -94
  107. package/dist/programs/rings/distancering/shader.js +1 -0
  108. package/dist/programs/rings/index.js +17 -0
  109. package/{programs → dist/programs}/rings/partial-ring/piece-of-pie.js +181 -221
  110. package/{programs → dist/programs}/totems/camerauniformblock.js +147 -184
  111. package/{programs → dist/programs}/totems/canvas-webglobe-info.js +102 -128
  112. package/{programs → dist/programs}/totems/gpu-selection-uniform-block.js +104 -128
  113. package/dist/programs/totems/index.js +40 -0
  114. package/dist/programs/two-d/pixel-circle.js +1 -0
  115. package/{programs → dist/programs}/two-d/pixel-padding-for-compass.js +101 -113
  116. package/{programs → dist/programs}/util.js +17 -20
  117. package/dist/programs/vectorfields/index.js +23 -0
  118. package/{programs → dist/programs}/vectorfields/logics/drawrectangleparticles.js +65 -83
  119. package/dist/programs/vectorfields/logics/index.js +12 -0
  120. package/{programs → dist/programs}/vectorfields/logics/pixelbased.js +84 -103
  121. package/{programs → dist/programs}/vectorfields/logics/ubo.js +55 -56
  122. package/{programs → dist/programs}/vectorfields/pingpongbuffermanager.js +76 -80
  123. package/dist/rangerings/enum.js +5 -0
  124. package/dist/rangerings/index.js +15 -0
  125. package/{rangerings → dist/rangerings}/plugin.js +560 -649
  126. package/{rangerings → dist/rangerings}/rangeringangletext.js +329 -368
  127. package/{rangerings → dist/rangerings}/ring-account.js +117 -129
  128. package/{shaders → dist/shaders}/fragment-toy/firework.js +5 -2
  129. package/{shaders → dist/shaders}/fragment-toy/singularity.js +5 -5
  130. package/{shape-on-terrain/arc/naive/plugin.ts → dist/shape-on-terrain/arc/naive/plugin.js} +252 -304
  131. package/{timetracks → dist/timetracks}/adaptors-line-strip.js +71 -80
  132. package/{timetracks → dist/timetracks}/adaptors.js +122 -133
  133. package/dist/timetracks/index.js +19 -0
  134. package/{timetracks → dist/timetracks}/plugin-line-strip.js +250 -295
  135. package/{timetracks → dist/timetracks}/plugin.js +258 -304
  136. package/{timetracks → dist/timetracks}/program-line-strip.js +416 -493
  137. package/{timetracks → dist/timetracks}/program.js +464 -542
  138. package/{timetracks → dist/timetracks}/programpoint-line-strip.js +101 -122
  139. package/{timetracks → dist/timetracks}/programpoint.js +101 -122
  140. package/{types.ts → dist/types.js} +15 -17
  141. package/{util → dist/util}/account/bufferoffsetmanager.js +179 -209
  142. package/dist/util/account/index.js +23 -0
  143. package/{util/account/single-attribute-buffer-management/buffer-manager.ts → dist/util/account/single-attribute-buffer-management/buffer-manager.js} +108 -119
  144. package/{util/account/single-attribute-buffer-management/buffer-orchestrator.ts → dist/util/account/single-attribute-buffer-management/buffer-orchestrator.js} +150 -173
  145. package/dist/util/account/single-attribute-buffer-management/index.js +9 -0
  146. package/{util/account/single-attribute-buffer-management/object-store.ts → dist/util/account/single-attribute-buffer-management/object-store.js} +51 -65
  147. package/dist/util/account/single-attribute-buffer-management/types.js +2 -0
  148. package/{util → dist/util}/account/util.js +22 -22
  149. package/dist/util/algorithms/index.js +1 -0
  150. package/{util → dist/util}/algorithms/search-binary.js +28 -26
  151. package/dist/util/check/get.js +18 -0
  152. package/dist/util/check/index.js +1 -0
  153. package/dist/util/check/typecheck.js +49 -0
  154. package/{util → dist/util}/geometry/index.js +51 -53
  155. package/{util/gl-util/buffer/attribute-loader.ts → dist/util/gl-util/buffer/attribute-loader.js} +69 -85
  156. package/dist/util/gl-util/buffer/index.js +6 -0
  157. package/dist/util/gl-util/buffer/types.js +1 -0
  158. package/dist/util/gl-util/draw-options/methods.js +38 -0
  159. package/dist/util/gl-util/draw-options/types.js +15 -0
  160. package/{util/gl-util/uniform-block/manager.ts → dist/util/gl-util/uniform-block/manager.js} +156 -187
  161. package/dist/util/gl-util/uniform-block/shader.js +1 -0
  162. package/dist/util/gl-util/uniform-block/types.js +8 -0
  163. package/{util → dist/util}/heatwavedatamanager/datamanager.js +152 -168
  164. package/dist/util/heatwavedatamanager/index.js +10 -0
  165. package/{util → dist/util}/heatwavedatamanager/pointcoordinatesdatacalculator.js +122 -133
  166. package/{util → dist/util}/heatwavedatamanager/pointcoordsmeta.js +20 -22
  167. package/dist/util/index.js +57 -0
  168. package/dist/util/interpolation/index.js +1 -0
  169. package/dist/util/interpolation/timetrack/index.js +5 -0
  170. package/{util → dist/util}/interpolation/timetrack/timetrack-interpolator.js +79 -88
  171. package/{util → dist/util}/interpolation/timetrack/web-worker-str.js +5 -2
  172. package/{util → dist/util}/interpolation/timetrack/web-worker.js +48 -51
  173. package/{util → dist/util}/jshelpers/data-filler.js +20 -19
  174. package/{util → dist/util}/jshelpers/equality.js +20 -17
  175. package/dist/util/jshelpers/index.js +37 -0
  176. package/{util → dist/util}/jshelpers/timefilters.js +32 -32
  177. package/{util → dist/util}/picking/fence.js +46 -46
  178. package/{util → dist/util}/picking/picker-displayer.js +139 -177
  179. package/{util → dist/util}/programs/draw-texture-on-canvas.js +69 -82
  180. package/dist/util/programs/index.js +17 -0
  181. package/{util → dist/util}/programs/shapesonglobe.js +174 -206
  182. package/{util → dist/util}/programs/supersampletotextures.js +103 -132
  183. package/{util → dist/util}/programs/texturetoglobe.js +133 -154
  184. package/{util/shaderfunctions/geometrytransformations.ts → dist/util/shaderfunctions/geometrytransformations.js} +68 -116
  185. package/dist/util/shaderfunctions/index.js +18 -0
  186. package/{util → dist/util}/shaderfunctions/nodata.js +5 -4
  187. package/{util → dist/util}/shaderfunctions/noisefunctions.js +9 -10
  188. package/{util/surface-line-data/arc-bboxes.ts → dist/util/surface-line-data/arc-bboxes.js} +25 -42
  189. package/{util → dist/util}/surface-line-data/arcs-to-cuts.js +50 -74
  190. package/dist/util/surface-line-data/cut-arc.js +1 -0
  191. package/{util/surface-line-data/flow.ts → dist/util/surface-line-data/flow.js} +28 -52
  192. package/dist/util/surface-line-data/rbush-manager.js +1 -0
  193. package/dist/util/surface-line-data/types.js +1 -0
  194. package/dist/util/surface-line-data/web-worker.js +1 -0
  195. package/dist/util/webglobe/gldefaultstates.js +7 -0
  196. package/dist/util/webglobe/index.js +18 -0
  197. package/{util → dist/util}/webglobe/rasteroverlay.js +78 -96
  198. package/{util/webglobjectbuilders.ts → dist/util/webglobjectbuilders.js} +388 -456
  199. package/{util → dist/util}/webglobjectbuilders1.js +237 -271
  200. package/{waveparticles → dist/waveparticles}/adaptor.js +17 -16
  201. package/dist/waveparticles/index.js +10 -0
  202. package/{waveparticles → dist/waveparticles}/plugin.js +266 -313
  203. package/{wind → dist/wind}/imagetovectorfieldandmagnitude.js +35 -39
  204. package/dist/wind/index.js +14 -0
  205. package/{wind → dist/wind}/plugin.js +681 -812
  206. package/{wind → dist/wind}/vectorfieldimage.js +25 -27
  207. package/{write-text → dist/write-text}/attached-text-writer.js +91 -105
  208. package/{write-text → dist/write-text}/context-text.js +98 -125
  209. package/{write-text → dist/write-text}/context-text3.js +155 -178
  210. package/dist/write-text/index.js +5 -0
  211. package/{write-text → dist/write-text}/writer-plugin.js +8 -7
  212. package/package.json +5 -2
  213. package/Math/arc.ts +0 -76
  214. package/Math/constants.ts +0 -11
  215. package/Math/frustum/types.ts +0 -11
  216. package/Math/index.js +0 -0
  217. package/Math/juction/arc-plane.ts +0 -114
  218. package/Math/juction/line-sphere.ts +0 -30
  219. package/Math/line.ts +0 -70
  220. package/Math/matrix4.ts +0 -0
  221. package/Math/plane.ts +0 -86
  222. package/Math/roadmap.md +0 -10
  223. package/Math/types.ts +0 -45
  224. package/Math/utils.js +0 -3
  225. package/algorithms/search-binary.js +0 -14
  226. package/altitude-locator/adaptors.js +0 -0
  227. package/altitude-locator/keymethod.js +0 -0
  228. package/arrowfield/index.js +0 -3
  229. package/bearing-line/index.js +0 -2
  230. package/circle-line-chain/init.js +0 -0
  231. package/circle-line-chain/readme.md +0 -57
  232. package/circle-line-chain/util.js +0 -1
  233. package/compass-rose/index.js +0 -3
  234. package/compassrose/index.js +0 -2
  235. package/depth-locator/readme.md +0 -26
  236. package/globe-types.ts +0 -13
  237. package/heatwave/index.js +0 -4
  238. package/partialrings/goals.md +0 -17
  239. package/partialrings/index.js +0 -3
  240. package/point-heat-map/index.js +0 -0
  241. package/point-heat-map/readme.md +0 -15
  242. package/point-tracks/key-methods.js +0 -3
  243. package/programs/arrowfield/index.js +0 -2
  244. package/programs/float2legendwithratio/index.js +0 -3
  245. package/programs/globeshell/index.js +0 -2
  246. package/programs/globeshell/noise/noises.js +0 -0
  247. package/programs/globeshell/wiggle/index.js +0 -6
  248. package/programs/helpers/blender/index.js +0 -0
  249. package/programs/helpers/fadeaway/index.js +0 -3
  250. package/programs/helpers/fadeaway/object.js +0 -20
  251. package/programs/helpers/index.js +0 -2
  252. package/programs/index.js +0 -21
  253. package/programs/interface.ts +0 -7
  254. package/programs/line-on-globe/index.js +0 -0
  255. package/programs/line-on-globe/util.js +0 -8
  256. package/programs/rings/distancering/index.js +0 -5
  257. package/programs/rings/distancering/shader.js +0 -0
  258. package/programs/rings/index.js +0 -1
  259. package/programs/totems/camerauniformblock.d.ts +0 -48
  260. package/programs/totems/index.ts +0 -2
  261. package/programs/two-d/pixel-circle.js +0 -0
  262. package/programs/vectorfields/index.js +0 -3
  263. package/programs/vectorfields/logics/index.js +0 -5
  264. package/publish.bat +0 -60
  265. package/rangerings/enum.js +0 -3
  266. package/rangerings/index.js +0 -5
  267. package/shape-on-terrain/goal.md +0 -12
  268. package/tests/Math/junction/arc-plane.test.ts +0 -133
  269. package/tests/Math/junction/plane-plane.test.ts +0 -82
  270. package/tests/Math/plane.test.ts +0 -43
  271. package/tests/Math/vec3.test.ts +0 -14
  272. package/timetracks/index.js +0 -6
  273. package/timetracks/readme.md +0 -1
  274. package/tsconfig.json +0 -22
  275. package/util/account/index.js +0 -6
  276. package/util/account/single-attribute-buffer-management/index.ts +0 -13
  277. package/util/account/single-attribute-buffer-management/types.ts +0 -39
  278. package/util/algorithms/index.js +0 -0
  279. package/util/check/get.js +0 -13
  280. package/util/check/index.js +0 -0
  281. package/util/check/typecheck.js +0 -39
  282. package/util/gl-util/buffer/index.ts +0 -6
  283. package/util/gl-util/buffer/types.ts +0 -13
  284. package/util/gl-util/draw-options/methods.ts +0 -66
  285. package/util/gl-util/draw-options/types.ts +0 -28
  286. package/util/gl-util/uniform-block/roadmap.md +0 -70
  287. package/util/gl-util/uniform-block/shader.js +0 -0
  288. package/util/gl-util/uniform-block/types.ts +0 -27
  289. package/util/heatwavedatamanager/index.js +0 -3
  290. package/util/index.js +0 -13
  291. package/util/interpolation/index.js +0 -0
  292. package/util/interpolation/timetrack/index.js +0 -9
  293. package/util/jshelpers/index.js +0 -1
  294. package/util/programs/index.js +0 -1
  295. package/util/shaderfunctions/index.js +0 -2
  296. package/util/surface-line-data/cut-arc.js +0 -0
  297. package/util/surface-line-data/rbush-manager.js +0 -0
  298. package/util/surface-line-data/types.ts +0 -27
  299. package/util/surface-line-data/web-worker.js +0 -0
  300. package/util/webglobe/gldefaultstates.js +0 -5
  301. package/util/webglobe/index.js +0 -2
  302. package/waveparticles/index.js +0 -3
  303. package/wind/index.js +0 -5
  304. package/write-text/index.js +0 -1
@@ -1,340 +1,343 @@
1
- import { ShapesOnGlobeProgram, latLongToPixelXY } from "../../util";
2
-
3
- import ContourMipmap, { scaleParameters } from "./quadtreecontours";
4
-
5
- import ObjectArrayLabels from "./objectarraylabels";
6
-
7
- import { isBoolean, opacityCheck } from "../../util/check/typecheck";
8
-
9
-
10
- export class IsobarRasterToVector {
11
-
12
-
13
- /**
14
- * @typedef {Object} IsobarData
15
- * @property {number} threshold
16
- * @property {[number, number, number]} color | rgb color
17
- * @property {string} label
18
- *
19
- * @param {*} id
20
- * @param {Array<IsobarData>} isabors
21
- * @param {number} width
22
- * @param {number} height
23
- * @param {Object} options
24
- * @param {boolean} options.xFlip
25
- * @param {boolean} options.yFlip
26
- * @param {boolean} options.isOn
27
- * @param {boolean} options.isLabelsOn
28
- * @param {Object} options.labelStyle
29
- */
30
- 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 } = {}) {
31
- this.id = id;
32
- this._isobarsCheckAndComplete(isobars);
33
- this.isobars = isobars;
34
- this.contourMipmap = null;
35
- this.width = width;
36
- this.height = height;
37
- this.xFlip = xFlip;
38
- this.yFlip = yFlip;
39
- this.bbox = [minLon, minLat, maxLon, maxLat];
40
- this.dataManager = dataManager;
41
-
42
- this._transformationMethod = getTransformationMethod(xFlip, yFlip, width, height, minLon, minLat, maxLon, maxLat);
43
- this._isOn = isOn;
44
- this._isLabelsOn = isLabelsOn;
45
- this._labelsLayer = null;
46
- this._labelsLayerId = id + '_isobar-labels';
47
- this._lineStrignRanges = [];
48
- this._transpos = new Float32Array(3);
49
- this._maxMipmapLevel = maxMipmapLevel;
50
- this._labelStyle = labelStyle;
51
-
52
- // this._transformationMethod = null;
53
- }
54
-
55
- // API
56
-
57
- setData(data, on = false) {
58
- if (!data) return;
59
- this._data = data;
60
- if (on) this._isOn = true;
61
- if (this._isOn) this._calculateAll(data);
62
- }
63
-
64
- on() {
65
- this._isOn = true;
66
- if (this._data) this._calculateAll(this._data);
67
- }
68
-
69
- off() {
70
- this._isOn = false;
71
- this.clean();
72
- }
73
-
74
-
75
- clean() {
76
- this.flush();
77
- this.globe.DrawRender();
78
- }
79
-
80
- setFlip(xFlip, yFlip) {
81
- isBoolean(xFlip); isBoolean(yFlip);
82
- if (this.xFlip === xFlip && this.yFlip === yFlip) return;
83
- this.xFlip = xFlip;
84
- this.yFlip = yFlip;
85
- const [minLon, minLat, maxLon, maxLat] = this.bbox;
86
- const { width, height } = this
87
- this._transformationMethod = getTransformationMethod(xFlip, yFlip, width, height, minLon, minLat, maxLon, maxLat);
88
- this._calculateLines();
89
- this.globe.DrawRender();
90
- }
91
-
92
- setBoundingBox([minLon, minLat, maxLon, maxLat]) {
93
- this.bbox = [minLon, minLat, maxLon, maxLat];
94
- const { width, height, xFlip, yFlip } = this;
95
- this._transformationMethod = getTransformationMethod(xFlip, yFlip, width, height, minLon, minLat, maxLon, maxLat);
96
- this._calculateLines();
97
- this.globe.DrawRender();
98
- }
99
-
100
-
101
- setIsLabelsOn(isLabelsOn) {
102
- isBoolean(isLabelsOn);
103
- if (this._isLabelsOn === isLabelsOn) return;
104
- this._isLabelsOn = isLabelsOn;
105
- if (!isLabelsOn) {
106
- this._labelsLayer.removeFromMap();
107
- } else {
108
- if (this._labelsLayer === null) this._createLabelsLayer();
109
- this._labelsLayer.addToMap();
110
- this._createBufferData();
111
- }
112
- }
113
-
114
- getIsobars() {
115
- return this.isobars;
116
- }
117
-
118
- setIsobars(isobars) {
119
- this._isobarsCheckAndComplete(isobars);
120
- this.isobars = isobars;
121
- this._calculateLines();
122
- this.globe.DrawRender();
123
- }
124
-
125
- setWidthHeight(width, height) {
126
- this.width = width;
127
- this.height = height;
128
- const { xFlip, yFlip } = this;
129
- const [minLon, minLat, maxLon, maxLat] = this.bbox;
130
- this._transformationMethod = getTransformationMethod(xFlip, yFlip, width, height, minLon, minLat, maxLon, maxLat);
131
- this._calculateLines();
132
- this.globe.DrawRender();
133
- }
134
-
135
-
136
- getLabelStyle() {
137
- return this._labelsLayer.getLabelStyle();
138
- }
139
-
140
- setOpacity(opacity) {
141
- opacityCheck(opacity);
142
- this.program.setOpacity(opacity);
143
- }
144
-
145
-
146
- setLabelStyle(style) {
147
- this._labelStyle = style;
148
- if (this._labelsLayer) this._labelsLayer.setLabelStyle(style);
149
- const lastState = this._isLabelsOn;
150
- this.setIsLabelsOn(false);
151
- this.setIsLabelsOn(lastState);
152
- if (lastState) this._createBufferData();
153
- }
154
-
155
- setMaxMipmapLevel(maxMipmapLevel = null) {
156
- this._maxMipmapLevel = maxMipmapLevel;
157
- this._calculateLines();
158
- this.globe.DrawRender();
159
- }
160
-
161
-
162
- flush() {
163
- this.program.setBufferData(new Float32Array(0));
164
- this._lineStrignRanges = [];
165
- if (this._isLabelsOn) this._labelsLayer.flush();
166
- }
167
-
168
- //
169
- // implicit methods
170
-
171
- init(globe, gl) {
172
- this.gl = gl
173
- this.globe = globe
174
-
175
- this.program = new ShapesOnGlobeProgram(gl, globe, 'line_strip');
176
- if (this._isLabelsOn) {
177
- this._createLabelsLayer();
178
- this._labelsLayer.addToMap();
179
- }
180
-
181
- this.dataManager.register(this.id, (ratio, t1, t2) => {
182
- if (!t1 || !t2) {
183
- this.clean();
184
- return;
185
- }
186
- const data = dataMixer(t1, t2, ratio);
187
- if (this._isOn) this.setData(data);
188
- });
189
- }
190
-
191
-
192
- resize(width, height) {
193
- this.program.resize(width, height);
194
- }
195
-
196
- draw3D(projMatrix, modelviewMatrix, transPos) {
197
- if (!this._ready) return;
198
- this._drawContour(projMatrix, modelviewMatrix, transPos);
199
- }
200
-
201
- _calculateLines() {
202
- this._calculateContours();
203
- this._bufferData = this._createBufferData();
204
- this.program.setBufferData(this._bufferData);
205
- }
206
-
207
- _drawContour(projMatrix, modelviewMatrix, transPos) {
208
- this.program.draw(projMatrix, modelviewMatrix, transPos, this._lineStrignRanges);
209
- }
210
-
211
-
212
-
213
- _calculateIntersections(threshold) {
214
- const { _transformationMethod } = this;
215
- const lines = this.contourMipmap.contour([threshold], { maxMipmapLevel: this._maxMipmapLevel }).map(coords => {
216
- return coords.map(([x, y]) => _transformationMethod(x, y))
217
- }
218
- );
219
- return lines;
220
- }
221
-
222
-
223
- _calculateAll(data) {
224
- this.contourMipmap = new ContourMipmap(data, this.width, this.height);
225
- this._calculateContours();
226
- this._bufferData = this._createBufferData();
227
- this.program.setBufferData(this._bufferData);
228
-
229
- this.globe.DrawRender();
230
- this._ready = true;
231
- }
232
-
233
- _calculateContours() {
234
- const { isobars } = this;
235
- for (const isobar of isobars) {
236
- const { threshold } = isobar;
237
- const lines = this._calculateIntersections(threshold);
238
- isobar.lines = lines;
239
- }
240
- }
241
-
242
-
243
- _isobarsCheckAndComplete(isobars) {
244
- window.isobars = 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
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ var __importDefault = (this && this.__importDefault) || function (mod) {
36
+ return (mod && mod.__esModule) ? mod : { "default": mod };
37
+ };
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ exports.IsobarRasterToVector = void 0;
40
+ const util_1 = require("../../util");
41
+ const quadtreecontours_1 = __importStar(require("./quadtreecontours"));
42
+ const objectarraylabels_1 = __importDefault(require("./objectarraylabels"));
43
+ const typecheck_1 = require("../../util/check/typecheck");
44
+ class IsobarRasterToVector {
45
+ /**
46
+ * @typedef {Object} IsobarData
47
+ * @property {number} threshold
48
+ * @property {[number, number, number]} color | rgb color
49
+ * @property {string} label
50
+ *
51
+ * @param {*} id
52
+ * @param {Array<IsobarData>} isabors
53
+ * @param {number} width
54
+ * @param {number} height
55
+ * @param {Object} options
56
+ * @param {boolean} options.xFlip
57
+ * @param {boolean} options.yFlip
58
+ * @param {boolean} options.isOn
59
+ * @param {boolean} options.isLabelsOn
60
+ * @param {Object} options.labelStyle
61
+ */
62
+ 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 } = {}) {
63
+ this.id = id;
64
+ this._isobarsCheckAndComplete(isobars);
65
+ this.isobars = isobars;
66
+ this.contourMipmap = null;
67
+ this.width = width;
68
+ this.height = height;
69
+ this.xFlip = xFlip;
70
+ this.yFlip = yFlip;
71
+ this.bbox = [minLon, minLat, maxLon, maxLat];
72
+ this.dataManager = dataManager;
73
+ this._transformationMethod = getTransformationMethod(xFlip, yFlip, width, height, minLon, minLat, maxLon, maxLat);
74
+ this._isOn = isOn;
75
+ this._isLabelsOn = isLabelsOn;
76
+ this._labelsLayer = null;
77
+ this._labelsLayerId = id + '_isobar-labels';
78
+ this._lineStrignRanges = [];
79
+ this._transpos = new Float32Array(3);
80
+ this._maxMipmapLevel = maxMipmapLevel;
81
+ this._labelStyle = labelStyle;
82
+ // this._transformationMethod = null;
83
+ }
84
+ // API
85
+ setData(data, on = false) {
86
+ if (!data)
87
+ return;
88
+ this._data = data;
89
+ if (on)
90
+ this._isOn = true;
91
+ if (this._isOn)
92
+ this._calculateAll(data);
93
+ }
94
+ on() {
95
+ this._isOn = true;
96
+ if (this._data)
97
+ this._calculateAll(this._data);
98
+ }
99
+ off() {
100
+ this._isOn = false;
101
+ this.clean();
102
+ }
103
+ clean() {
104
+ this.flush();
105
+ this.globe.DrawRender();
106
+ }
107
+ setFlip(xFlip, yFlip) {
108
+ (0, typecheck_1.isBoolean)(xFlip);
109
+ (0, typecheck_1.isBoolean)(yFlip);
110
+ if (this.xFlip === xFlip && this.yFlip === yFlip)
111
+ return;
112
+ this.xFlip = xFlip;
113
+ this.yFlip = yFlip;
114
+ const [minLon, minLat, maxLon, maxLat] = this.bbox;
115
+ const { width, height } = this;
116
+ this._transformationMethod = getTransformationMethod(xFlip, yFlip, width, height, minLon, minLat, maxLon, maxLat);
117
+ this._calculateLines();
118
+ this.globe.DrawRender();
119
+ }
120
+ setBoundingBox([minLon, minLat, maxLon, maxLat]) {
121
+ this.bbox = [minLon, minLat, maxLon, maxLat];
122
+ const { width, height, xFlip, yFlip } = this;
123
+ this._transformationMethod = getTransformationMethod(xFlip, yFlip, width, height, minLon, minLat, maxLon, maxLat);
124
+ this._calculateLines();
125
+ this.globe.DrawRender();
126
+ }
127
+ setIsLabelsOn(isLabelsOn) {
128
+ (0, typecheck_1.isBoolean)(isLabelsOn);
129
+ if (this._isLabelsOn === isLabelsOn)
130
+ return;
131
+ this._isLabelsOn = isLabelsOn;
132
+ if (!isLabelsOn) {
133
+ this._labelsLayer.removeFromMap();
134
+ }
135
+ else {
136
+ if (this._labelsLayer === null)
137
+ this._createLabelsLayer();
138
+ this._labelsLayer.addToMap();
139
+ this._createBufferData();
140
+ }
141
+ }
142
+ getIsobars() {
143
+ return this.isobars;
144
+ }
145
+ setIsobars(isobars) {
146
+ this._isobarsCheckAndComplete(isobars);
147
+ this.isobars = isobars;
148
+ this._calculateLines();
149
+ this.globe.DrawRender();
150
+ }
151
+ setWidthHeight(width, height) {
152
+ this.width = width;
153
+ this.height = height;
154
+ const { xFlip, yFlip } = this;
155
+ const [minLon, minLat, maxLon, maxLat] = this.bbox;
156
+ this._transformationMethod = getTransformationMethod(xFlip, yFlip, width, height, minLon, minLat, maxLon, maxLat);
157
+ this._calculateLines();
158
+ this.globe.DrawRender();
159
+ }
160
+ getLabelStyle() {
161
+ return this._labelsLayer.getLabelStyle();
162
+ }
163
+ setOpacity(opacity) {
164
+ (0, typecheck_1.opacityCheck)(opacity);
165
+ this.program.setOpacity(opacity);
166
+ }
167
+ setLabelStyle(style) {
168
+ this._labelStyle = style;
169
+ if (this._labelsLayer)
170
+ this._labelsLayer.setLabelStyle(style);
171
+ const lastState = this._isLabelsOn;
172
+ this.setIsLabelsOn(false);
173
+ this.setIsLabelsOn(lastState);
174
+ if (lastState)
175
+ this._createBufferData();
176
+ }
177
+ setMaxMipmapLevel(maxMipmapLevel = null) {
178
+ this._maxMipmapLevel = maxMipmapLevel;
179
+ this._calculateLines();
180
+ this.globe.DrawRender();
181
+ }
182
+ flush() {
183
+ this.program.setBufferData(new Float32Array(0));
184
+ this._lineStrignRanges = [];
185
+ if (this._isLabelsOn)
186
+ this._labelsLayer.flush();
187
+ }
188
+ //
189
+ // implicit methods
190
+ init(globe, gl) {
191
+ this.gl = gl;
192
+ this.globe = globe;
193
+ this.program = new util_1.ShapesOnGlobeProgram(gl, globe, 'line_strip');
194
+ if (this._isLabelsOn) {
195
+ this._createLabelsLayer();
196
+ this._labelsLayer.addToMap();
197
+ }
198
+ this.dataManager.register(this.id, (ratio, t1, t2) => {
199
+ if (!t1 || !t2) {
200
+ this.clean();
201
+ return;
202
+ }
203
+ const data = dataMixer(t1, t2, ratio);
204
+ if (this._isOn)
205
+ this.setData(data);
206
+ });
207
+ }
208
+ resize(width, height) {
209
+ this.program.resize(width, height);
210
+ }
211
+ draw3D(projMatrix, modelviewMatrix, transPos) {
212
+ if (!this._ready)
213
+ return;
214
+ this._drawContour(projMatrix, modelviewMatrix, transPos);
215
+ }
216
+ _calculateLines() {
217
+ this._calculateContours();
218
+ this._bufferData = this._createBufferData();
219
+ this.program.setBufferData(this._bufferData);
220
+ }
221
+ _drawContour(projMatrix, modelviewMatrix, transPos) {
222
+ this.program.draw(projMatrix, modelviewMatrix, transPos, this._lineStrignRanges);
223
+ }
224
+ _calculateIntersections(threshold) {
225
+ const { _transformationMethod } = this;
226
+ const lines = this.contourMipmap.contour([threshold], { maxMipmapLevel: this._maxMipmapLevel }).map(coords => {
227
+ return coords.map(([x, y]) => _transformationMethod(x, y));
228
+ });
229
+ return lines;
230
+ }
231
+ _calculateAll(data) {
232
+ this.contourMipmap = new quadtreecontours_1.default(data, this.width, this.height);
233
+ this._calculateContours();
234
+ this._bufferData = this._createBufferData();
235
+ this.program.setBufferData(this._bufferData);
236
+ this.globe.DrawRender();
237
+ this._ready = true;
238
+ }
239
+ _calculateContours() {
240
+ const { isobars } = this;
241
+ for (const isobar of isobars) {
242
+ const { threshold } = isobar;
243
+ const lines = this._calculateIntersections(threshold);
244
+ isobar.lines = lines;
245
+ }
246
+ }
247
+ _isobarsCheckAndComplete(isobars) {
248
+ window.isobars = isobars;
249
+ if (!Array.isArray(isobars))
250
+ throw new Error("isobars must be an array");
251
+ if (isobars.length === 0)
252
+ throw new Error("isobars must contain at least one element");
253
+ for (const isobar of isobars) {
254
+ if (!isobar || typeof isobar !== 'object')
255
+ throw new Error("isobar must be an object");
256
+ if (typeof isobar.threshold !== 'number')
257
+ throw new Error("isobar.threshold must be a number");
258
+ if (isobar.color) {
259
+ if (!Array.isArray(isobar.color) || isobar.color.length !== 3)
260
+ throw new Error("isobar.color must be an array with 3 elements");
261
+ for (const color of isobar.color) {
262
+ if (color < 0 || color > 1)
263
+ throw new Error("isobar.color elements must be between 0 and 1");
264
+ }
265
+ }
266
+ if (!isobar.color)
267
+ isobar.color = [1, 1, 1];
268
+ }
269
+ }
270
+ _createBufferData() {
271
+ const { isobars } = this;
272
+ const pointCount = isobars.reduce((acc, { lines }) => acc + lines.reduce((acc, line) => acc + line.length, 0), 0);
273
+ const bufferData = new Float32Array(pointCount * 6);
274
+ let index = 0;
275
+ let pointCounter = 0;
276
+ this._lineStrignRanges = [];
277
+ // gather label data label
278
+ const labelPoints = {
279
+ coords: [],
280
+ coordsZ: [],
281
+ attribs: []
282
+ };
283
+ const { coords, coordsZ, attribs } = labelPoints;
284
+ let fidCounter = 0;
285
+ for (const { lines, color, threshold } of isobars) {
286
+ for (const line of lines) {
287
+ let startIndex = pointCounter;
288
+ for (const [x, y] of line) {
289
+ const pixXY = (0, util_1.latLongToPixelXY)(y, x);
290
+ bufferData[index++] = pixXY.x;
291
+ bufferData[index++] = pixXY.y;
292
+ bufferData[index++] = color[0];
293
+ bufferData[index++] = color[1];
294
+ bufferData[index++] = color[2];
295
+ bufferData[index++] = 1.0;
296
+ pointCounter++;
297
+ }
298
+ coords.push(line[0][0], line[0][1]);
299
+ coordsZ.push(0);
300
+ attribs.push({ value: threshold, fid: fidCounter++ });
301
+ this._lineStrignRanges.push([startIndex, pointCounter - startIndex]);
302
+ }
303
+ }
304
+ if (this._isLabelsOn)
305
+ this._labelsLayer.setData(labelPoints);
306
+ return bufferData;
307
+ }
308
+ _createLabelsLayer() {
309
+ this._labelsLayer = new objectarraylabels_1.default(this._labelsLayerId, this.globe, this._labelStyle);
310
+ }
311
+ setGeometry() {
312
+ this.program.setGeometry();
313
+ }
314
+ free() {
315
+ this.flush();
316
+ this.program.free();
317
+ if (this._isLabelsOn)
318
+ this._labelsLayer.removeFromMap();
319
+ this.dataManager.unregister(this.id);
320
+ }
321
+ }
322
+ exports.IsobarRasterToVector = IsobarRasterToVector;
323
+ const getTransformationMethod = (xFlip, yFlip, width, height, minX, minY, maxX, maxY) => {
324
+ const { scaleX, scaleY } = (0, quadtreecontours_1.scaleParameters)(minX, minY, maxX, maxY, width, height);
325
+ if (xFlip && yFlip)
326
+ return (x, y) => [maxX - x * scaleX, maxY - y * scaleY];
327
+ if (xFlip && !yFlip)
328
+ return (x, y) => [maxX - x * scaleX, minY + y * scaleY];
329
+ if (!xFlip && yFlip)
330
+ return (x, y) => [minX + x * scaleX, maxY - y * scaleY];
331
+ return (x, y) => [minX + x * scaleX, minY + y * scaleY];
332
+ };
333
+ function dataMixer(data1, data2, ratio) {
334
+ if (!data1 || !data2)
335
+ return null;
336
+ if (data1.length !== data2.length)
337
+ throw new Error("Data length mismatch");
338
+ const data = new Float32Array(data1.length);
339
+ for (let i = 0; i < data1.length; i++) {
340
+ data[i] = data1[i] * (1 - ratio) + data2[i] * ratio;
341
+ }
342
+ return data;
343
+ }