@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,258 +1,206 @@
1
- import { getColorRampModed, DataManager, PointCoordinatesDataCalculator } from "../../util";
2
-
3
- import { GlobeShellWiggle, Float2LegendWithRatio } from "../../programs";
4
-
5
- import { opacityCheck } from "../../util/check/typecheck";
6
-
7
- /**
8
- * @param id : string
9
- * @param dataManager : DataManager
10
- * @param colorRampData : {values: string[], thresholds: number[], mode: string}
11
- * @param dataWidthHeight : {width: number, height: number}
12
- * @param options : {bbox: number[], minMaxEdges: {min: number, max: number}, escapeValue: number, resolution: number[], meshPartition: number[]}
13
- */
14
- export default class HeatWaveGlobeShellPlugin {
15
- constructor(id, dataManager, colorRampData, dataWidthHeight,
16
- {
17
- bbox = [-180, -90, 180, 90],
18
- minMaxEdges = { min: -99999, max: 99999 },
19
- escapeValue = 99999,
20
- resolution = [2056, 2056],
21
- yFlip = true,
22
- } = {}) {
23
- this.id = id;
24
- this.dataManager = dataManager;
25
- this._dataWidthHeight = dataWidthHeight;
26
-
27
- this._isOn = true;
28
- this._bbox = bbox
29
- this._minMaxEdges = minMaxEdges;
30
- this._escapeValue = escapeValue
31
- this._resolution = resolution;
32
-
33
- this._colorRampData = colorRampData; // holds until init
34
- this._yFlip = yFlip;
35
- this._lastTexture0data = null;
36
- this._lastTexture1data = null;
37
-
38
- // output of heatProgram is written to ._coloredHeatTexture
39
- this._frameBuffer = null
40
- this._coloredHeatTexture = null;
41
- this.enabled = false;
42
- this.isAble = false;
43
- }
44
-
45
-
46
- setHeight(height) {
47
- this.globeShell.setHeight(height);
48
- }
49
-
50
-
51
- drawHeat() {
52
- const gl = this.gl;
53
- gl.bindFramebuffer(gl.FRAMEBUFFER, this._frameBuffer);
54
- gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, this._coloredHeatTexture, 0);
55
- gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);
56
- const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
57
- const currentWidth = gl.canvas.width;
58
- const currentHeight = gl.canvas.height;
59
- gl.viewport(0, 0, ...this._resolution);
60
- this.heatProgram.draw()
61
- gl.viewport(0, 0, currentWidth, currentHeight);
62
- gl.bindFramebuffer(gl.FRAMEBUFFER, null);
63
- gl.useProgram(currentProgram);
64
- this.globe.DrawRender();
65
- }
66
-
67
-
68
- setEscapeValue(escapeValue) {
69
- this._escapeValue = escapeValue;
70
- this.heatProgram.setEscapeValue(escapeValue);
71
- }
72
-
73
-
74
- _createPointCoordinatesDataCalculator() {
75
- this.coordinatesDataCalculator = new PointCoordinatesDataCalculator(this._bbox, this._dataWidthHeight.width, this._dataWidthHeight.height);
76
- this.dataManager.register(this._coordinatesDataCalculatorID(), this.coordinatesDataCalculator.updateData.bind(this.coordinatesDataCalculator));
77
- }
78
-
79
-
80
- _coordinatesDataCalculatorID() {
81
- return this.id + "_coordinatesDataCalculator";
82
- }
83
-
84
-
85
- updateTime(time) {
86
- this.dataManager.updateTime(time);
87
- this.globe.DrawRender();
88
- }
89
-
90
- setWiggle({ wiggleInKm = null, wiggleSpeed = null } = {}) {
91
- this.globeShell.setWiggle({ wiggleInKm, wiggleSpeed });
92
- }
93
-
94
-
95
- setMinMaxEdges(min = null, max = null) {
96
- if (min) this._minMaxEdges.min = min;
97
- if (max) this._minMaxEdges.max = max;
98
- this.heatProgram.setMinMaxEdges(this._minMaxEdges.min, this._minMaxEdges.max);
99
- this.drawHeat();
100
- }
101
-
102
-
103
- setBBox(minLon, minLat, maxLon, maxLat) {
104
- this._bbox = [minLon, minLat, maxLon, maxLat];
105
- this.globeShell.setBBox({ minLon, minLat, maxLon, maxLat });
106
- this.drawHeat();
107
- }
108
-
109
-
110
- getPointCoordinatesDataCalculator() {
111
- if (!this.coordinatesDataCalculator) this._createPointCoordinatesDataCalculator();
112
- return this.coordinatesDataCalculator;
113
- }
114
-
115
-
116
- /**
117
- * @param {*} values n + 1 number of color hex values without alpha channel. Ex: ["#ff0000", "#00ff00", "#0000ff"]
118
- * @param {*} thresholds n number of thresholds. Ex: [0, 10, 20]
119
- * @param {*} mode "discrete" or "interpolated"
120
- *
121
- * There are maximum 256 pixels in the color ramp.
122
- * The first values array is minimum edge value which is the first pixel, the second comes one pixel after the first.
123
- */
124
- setColorRamp(values, thresholds, mode = "interpolated") {
125
- const lowest = thresholds[0];
126
- const highest = thresholds[thresholds.length - 1];
127
- const range = highest - lowest;
128
- const clampedThresholds = thresholds.map((t) => (t - lowest) / range);
129
- const colors = getColorRampModed(values, clampedThresholds, mode);
130
- this.heatProgram.setColorRampTextureData(colors, 256);
131
- this.heatProgram.setColorRampRange(lowest, highest);
132
- this.drawHeat();
133
- }
134
-
135
-
136
- off() {
137
- this._isOn = false;
138
- }
139
-
140
-
141
- on() {
142
- this._isOn = true;
143
- }
144
-
145
-
146
- _updateData(ratio, textureData0 = null, textureData1 = null) {
147
- if (!textureData0 || !textureData1) {
148
- if (this._disCarded) return;
149
- this.heatProgram.discard();
150
- this.drawHeat();
151
- this._disCarded = true;
152
- return;
153
- };
154
- this.heatProgram.setBlendRatio(ratio);
155
- if (this._lastTexture0data !== textureData0 || this._lastTexture1data !== textureData1) {
156
- this._disCarded = false;
157
- this._lastTexture0data = textureData0;
158
- this._lastTexture1data = textureData1;
159
- this.heatProgram.setFloatTextureData(textureData0, textureData1, this._dataWidthHeight.width, this._dataWidthHeight.height, this._yFlip);
160
- }
161
- this.drawHeat();
162
- }
163
-
164
-
165
- setDataWidthHeight(width, height) {
166
- this._dataWidthHeight = { width, height };
167
- this.heatProgram.setDataWidthHeight(width, height);
168
- this.setGeometry();
169
- }
170
-
171
-
172
- draw3D() {
173
- if (!this._isOn) return;
174
- // if (!this.isAble) return;
175
- this.gl.disable(this.gl.DEPTH_TEST);
176
- this.globeShell.draw();
177
- this.gl.enable(this.gl.DEPTH_TEST);
178
- }
179
-
180
-
181
- setOpacity(opacity) {
182
- opacityCheck(opacity);
183
- this.globeShell.setOpacity(opacity);
184
- }
185
-
186
-
187
- _setAfterInit() {
188
- const [minLon, minLat, maxLon, maxLat] = this._bbox;
189
- this.globeShell.setBBox({ minLon, minLat, maxLon, maxLat });
190
- this.setColorRamp(this._colorRampData.values, this._colorRampData.thresholds, this._colorRampData.mode);
191
- delete this._colorRampData;
192
- this.setMinMaxEdges(this._minMaxEdges.min, this._minMaxEdges.max);
193
- this.setEscapeValue(this._escapeValue);
194
- }
195
-
196
-
197
- _init(globe, gl) {
198
- this.globeShell = new GlobeShellWiggle(gl, globe, {
199
- minLon: this._bbox[0],
200
- minLat: this._bbox[1],
201
- maxLon: this._bbox[2],
202
- maxLat: this._bbox[3],
203
- color: [1.0, 0.1, 0.4, 0.2],
204
- height: 0,
205
- wiggleInKM: 2,
206
- eastWestTied: false,
207
- displayMesh: false
208
- });
209
- this.heatProgram = new Float2LegendWithRatio(gl);
210
- this._frameBuffer = gl.createFramebuffer();
211
-
212
- this.dataManager.register(this.id, (ratio, t1, t2) => this._updateData(ratio, t1, t2));
213
- this.setResolution(this._resolution[0], this._resolution[1]);
214
- }
215
-
216
-
217
-
218
- init(globe, gl) {
219
- this.globe = globe;
220
- this.gl = gl;
221
- this._init(globe, gl);
222
- this._setAfterInit();
223
- }
224
-
225
- setGeometry() {
226
- // globeShell has an implicit program, registered and sets its own geometry.
227
- return;
228
- }
229
-
230
-
231
- // sets Density of middle texture which is used with framebuffers
232
- setResolution(width, height) {
233
- const gl = this.gl;
234
- this._resolution = [width, height];
235
- this._coloredHeatTexture = gl.createTexture();
236
- gl.bindTexture(gl.TEXTURE_2D, this._coloredHeatTexture);
237
- gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, width, height, 0, gl.RGBA, gl.UNSIGNED_BYTE, null);
238
- gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);
239
- gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);
240
- gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);
241
- gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);
242
- gl.bindTexture(gl.TEXTURE_2D, null);
243
- this.globeShell.setTexture(this._coloredHeatTexture);
244
- }
245
-
246
-
247
- free() {
248
- if (this.coordinatesDataCalculator) {
249
- this.dataManager.unregister(this._coordinatesDataCalculatorID());
250
- this.coordinatesDataCalculator = null;
251
- }
252
- this.dataManager.unregister(this.id);
253
- this.globeShell.free();
254
- this.heatProgram.free();
255
- }
256
-
257
-
258
- }
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const util_1 = require("../../util");
4
+ const programs_1 = require("../../programs");
5
+ const typecheck_1 = require("../../util/check/typecheck");
6
+ /**
7
+ * @param id : string
8
+ * @param dataManager : DataManager
9
+ * @param colorRampData : {values: string[], thresholds: number[], mode: string}
10
+ * @param dataWidthHeight : {width: number, height: number}
11
+ * @param options : {bbox: number[], minMaxEdges: {min: number, max: number}, escapeValue: number, resolution: number[], meshPartition: number[]}
12
+ */
13
+ class HeatWaveGlobeShellPlugin {
14
+ constructor(id, dataManager, colorRampData, dataWidthHeight, { bbox = [-180, -90, 180, 90], minMaxEdges = { min: -99999, max: 99999 }, escapeValue = 99999, resolution = [2056, 2056], yFlip = true, } = {}) {
15
+ this.id = id;
16
+ this.dataManager = dataManager;
17
+ this._dataWidthHeight = dataWidthHeight;
18
+ this._isOn = true;
19
+ this._bbox = bbox;
20
+ this._minMaxEdges = minMaxEdges;
21
+ this._escapeValue = escapeValue;
22
+ this._resolution = resolution;
23
+ this._colorRampData = colorRampData; // holds until init
24
+ this._yFlip = yFlip;
25
+ this._lastTexture0data = null;
26
+ this._lastTexture1data = null;
27
+ // output of heatProgram is written to ._coloredHeatTexture
28
+ this._frameBuffer = null;
29
+ this._coloredHeatTexture = null;
30
+ this.enabled = false;
31
+ this.isAble = false;
32
+ }
33
+ setHeight(height) {
34
+ this.globeShell.setHeight(height);
35
+ }
36
+ drawHeat() {
37
+ const gl = this.gl;
38
+ gl.bindFramebuffer(gl.FRAMEBUFFER, this._frameBuffer);
39
+ gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, this._coloredHeatTexture, 0);
40
+ gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);
41
+ const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
42
+ const currentWidth = gl.canvas.width;
43
+ const currentHeight = gl.canvas.height;
44
+ gl.viewport(0, 0, ...this._resolution);
45
+ this.heatProgram.draw();
46
+ gl.viewport(0, 0, currentWidth, currentHeight);
47
+ gl.bindFramebuffer(gl.FRAMEBUFFER, null);
48
+ gl.useProgram(currentProgram);
49
+ this.globe.DrawRender();
50
+ }
51
+ setEscapeValue(escapeValue) {
52
+ this._escapeValue = escapeValue;
53
+ this.heatProgram.setEscapeValue(escapeValue);
54
+ }
55
+ _createPointCoordinatesDataCalculator() {
56
+ this.coordinatesDataCalculator = new util_1.PointCoordinatesDataCalculator(this._bbox, this._dataWidthHeight.width, this._dataWidthHeight.height);
57
+ this.dataManager.register(this._coordinatesDataCalculatorID(), this.coordinatesDataCalculator.updateData.bind(this.coordinatesDataCalculator));
58
+ }
59
+ _coordinatesDataCalculatorID() {
60
+ return this.id + "_coordinatesDataCalculator";
61
+ }
62
+ updateTime(time) {
63
+ this.dataManager.updateTime(time);
64
+ this.globe.DrawRender();
65
+ }
66
+ setWiggle({ wiggleInKm = null, wiggleSpeed = null } = {}) {
67
+ this.globeShell.setWiggle({ wiggleInKm, wiggleSpeed });
68
+ }
69
+ setMinMaxEdges(min = null, max = null) {
70
+ if (min)
71
+ this._minMaxEdges.min = min;
72
+ if (max)
73
+ this._minMaxEdges.max = max;
74
+ this.heatProgram.setMinMaxEdges(this._minMaxEdges.min, this._minMaxEdges.max);
75
+ this.drawHeat();
76
+ }
77
+ setBBox(minLon, minLat, maxLon, maxLat) {
78
+ this._bbox = [minLon, minLat, maxLon, maxLat];
79
+ this.globeShell.setBBox({ minLon, minLat, maxLon, maxLat });
80
+ this.drawHeat();
81
+ }
82
+ getPointCoordinatesDataCalculator() {
83
+ if (!this.coordinatesDataCalculator)
84
+ this._createPointCoordinatesDataCalculator();
85
+ return this.coordinatesDataCalculator;
86
+ }
87
+ /**
88
+ * @param {*} values n + 1 number of color hex values without alpha channel. Ex: ["#ff0000", "#00ff00", "#0000ff"]
89
+ * @param {*} thresholds n number of thresholds. Ex: [0, 10, 20]
90
+ * @param {*} mode "discrete" or "interpolated"
91
+ *
92
+ * There are maximum 256 pixels in the color ramp.
93
+ * The first values array is minimum edge value which is the first pixel, the second comes one pixel after the first.
94
+ */
95
+ setColorRamp(values, thresholds, mode = "interpolated") {
96
+ const lowest = thresholds[0];
97
+ const highest = thresholds[thresholds.length - 1];
98
+ const range = highest - lowest;
99
+ const clampedThresholds = thresholds.map((t) => (t - lowest) / range);
100
+ const colors = (0, util_1.getColorRampModed)(values, clampedThresholds, mode);
101
+ this.heatProgram.setColorRampTextureData(colors, 256);
102
+ this.heatProgram.setColorRampRange(lowest, highest);
103
+ this.drawHeat();
104
+ }
105
+ off() {
106
+ this._isOn = false;
107
+ }
108
+ on() {
109
+ this._isOn = true;
110
+ }
111
+ _updateData(ratio, textureData0 = null, textureData1 = null) {
112
+ if (!textureData0 || !textureData1) {
113
+ if (this._disCarded)
114
+ return;
115
+ this.heatProgram.discard();
116
+ this.drawHeat();
117
+ this._disCarded = true;
118
+ return;
119
+ }
120
+ ;
121
+ this.heatProgram.setBlendRatio(ratio);
122
+ if (this._lastTexture0data !== textureData0 || this._lastTexture1data !== textureData1) {
123
+ this._disCarded = false;
124
+ this._lastTexture0data = textureData0;
125
+ this._lastTexture1data = textureData1;
126
+ this.heatProgram.setFloatTextureData(textureData0, textureData1, this._dataWidthHeight.width, this._dataWidthHeight.height, this._yFlip);
127
+ }
128
+ this.drawHeat();
129
+ }
130
+ setDataWidthHeight(width, height) {
131
+ this._dataWidthHeight = { width, height };
132
+ this.heatProgram.setDataWidthHeight(width, height);
133
+ this.setGeometry();
134
+ }
135
+ draw3D() {
136
+ if (!this._isOn)
137
+ return;
138
+ // if (!this.isAble) return;
139
+ this.gl.disable(this.gl.DEPTH_TEST);
140
+ this.globeShell.draw();
141
+ this.gl.enable(this.gl.DEPTH_TEST);
142
+ }
143
+ setOpacity(opacity) {
144
+ (0, typecheck_1.opacityCheck)(opacity);
145
+ this.globeShell.setOpacity(opacity);
146
+ }
147
+ _setAfterInit() {
148
+ const [minLon, minLat, maxLon, maxLat] = this._bbox;
149
+ this.globeShell.setBBox({ minLon, minLat, maxLon, maxLat });
150
+ this.setColorRamp(this._colorRampData.values, this._colorRampData.thresholds, this._colorRampData.mode);
151
+ delete this._colorRampData;
152
+ this.setMinMaxEdges(this._minMaxEdges.min, this._minMaxEdges.max);
153
+ this.setEscapeValue(this._escapeValue);
154
+ }
155
+ _init(globe, gl) {
156
+ this.globeShell = new programs_1.GlobeShellWiggle(gl, globe, {
157
+ minLon: this._bbox[0],
158
+ minLat: this._bbox[1],
159
+ maxLon: this._bbox[2],
160
+ maxLat: this._bbox[3],
161
+ color: [1.0, 0.1, 0.4, 0.2],
162
+ height: 0,
163
+ wiggleInKM: 2,
164
+ eastWestTied: false,
165
+ displayMesh: false
166
+ });
167
+ this.heatProgram = new programs_1.Float2LegendWithRatio(gl);
168
+ this._frameBuffer = gl.createFramebuffer();
169
+ this.dataManager.register(this.id, (ratio, t1, t2) => this._updateData(ratio, t1, t2));
170
+ this.setResolution(this._resolution[0], this._resolution[1]);
171
+ }
172
+ init(globe, gl) {
173
+ this.globe = globe;
174
+ this.gl = gl;
175
+ this._init(globe, gl);
176
+ this._setAfterInit();
177
+ }
178
+ setGeometry() {
179
+ // globeShell has an implicit program, registered and sets its own geometry.
180
+ return;
181
+ }
182
+ // sets Density of middle texture which is used with framebuffers
183
+ setResolution(width, height) {
184
+ const gl = this.gl;
185
+ this._resolution = [width, height];
186
+ this._coloredHeatTexture = gl.createTexture();
187
+ gl.bindTexture(gl.TEXTURE_2D, this._coloredHeatTexture);
188
+ gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, width, height, 0, gl.RGBA, gl.UNSIGNED_BYTE, null);
189
+ gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);
190
+ gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);
191
+ gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);
192
+ gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);
193
+ gl.bindTexture(gl.TEXTURE_2D, null);
194
+ this.globeShell.setTexture(this._coloredHeatTexture);
195
+ }
196
+ free() {
197
+ if (this.coordinatesDataCalculator) {
198
+ this.dataManager.unregister(this._coordinatesDataCalculatorID());
199
+ this.coordinatesDataCalculator = null;
200
+ }
201
+ this.dataManager.unregister(this.id);
202
+ this.globeShell.free();
203
+ this.heatProgram.free();
204
+ }
205
+ }
206
+ exports.default = HeatWaveGlobeShellPlugin;
package/dist/index.js ADDED
@@ -0,0 +1,58 @@
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
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.pointheatmap = exports.partialring = exports.arrowfield = exports.programs = exports.util = exports.heatwave = exports.compassrose = exports.rangerings = exports.timetracks = exports.waveparticles = exports.wind = void 0;
37
+ const wind = __importStar(require("./wind"));
38
+ exports.wind = wind;
39
+ const waveparticles = __importStar(require("./waveparticles"));
40
+ exports.waveparticles = waveparticles;
41
+ const timetracks = __importStar(require("./timetracks"));
42
+ exports.timetracks = timetracks;
43
+ const arrowfield = __importStar(require("./arrowfield"));
44
+ exports.arrowfield = arrowfield;
45
+ const rangerings = __importStar(require("./rangerings"));
46
+ exports.rangerings = rangerings;
47
+ const partialring = __importStar(require("./partialrings"));
48
+ exports.partialring = partialring;
49
+ const compassrose = __importStar(require("./compassrose"));
50
+ exports.compassrose = compassrose;
51
+ const heatwave = __importStar(require("./heatwave"));
52
+ exports.heatwave = heatwave;
53
+ const util = __importStar(require("./util"));
54
+ exports.util = util;
55
+ const programs = __importStar(require("./programs"));
56
+ exports.programs = programs;
57
+ const pointheatmap = __importStar(require("./point-heat-map"));
58
+ exports.pointheatmap = pointheatmap;
@@ -1,6 +1,7 @@
1
- module.exports = {
2
- preset: 'ts-jest',
3
- testEnvironment: 'node',
4
- testMatch: ['**/tests/**/*.test.ts'],
5
- moduleFileExtensions: ['ts', 'js'],
6
- }
1
+ "use strict";
2
+ module.exports = {
3
+ preset: 'ts-jest',
4
+ testEnvironment: 'node',
5
+ testMatch: ['**/tests/**/*.test.ts'],
6
+ moduleFileExtensions: ['ts', 'js'],
7
+ };