@pirireis/webglobeplugins 1.0.2 → 1.0.3

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 (259) hide show
  1. package/Math/{angle-calculation.ts → angle-calculation.js} +14 -18
  2. package/Math/{arc-cdf-points.ts → arc-cdf-points.js} +272 -329
  3. package/Math/{arc-generate-points-exponantial.ts → arc-generate-points-exponantial.js} +254 -299
  4. package/Math/{arc.ts → arc.js} +292 -421
  5. package/Math/bounds/line-bbox.js +186 -225
  6. package/Math/{circle-cdf-points.ts → circle-cdf-points.js} +78 -143
  7. package/Math/{circle.ts → circle.js} +33 -49
  8. package/Math/{constants.ts → constants.js} +4 -12
  9. package/Math/contour/{quadtreecontours.ts → quadtreecontours.js} +300 -371
  10. package/Math/contour/quadtreecontours1.js +298 -336
  11. package/Math/{finite-line-2d.ts → finite-line-2d.js} +58 -68
  12. package/Math/{haversine.ts → haversine.js} +22 -33
  13. package/Math/index.js +1 -0
  14. package/Math/juction/{arc-plane.ts → arc-plane.js} +143 -203
  15. package/Math/juction/{line-sphere.ts → line-sphere.js} +22 -32
  16. package/Math/juction/{plane-plane.ts → plane-plane.js} +53 -62
  17. package/Math/{line.ts → line.js} +52 -84
  18. package/Math/matrix4.js +1 -0
  19. package/Math/{methods.ts → methods.js} +126 -182
  20. package/Math/{plane.ts → plane.js} +56 -92
  21. package/Math/{quaternion.ts → quaternion.js} +106 -128
  22. package/Math/templete-shapes/{grid-visually-equal.ts → grid-visually-equal.js} +65 -118
  23. package/Math/tessellation/constants.js +1 -0
  24. package/Math/tessellation/{methods.ts → methods.js} +49 -79
  25. package/Math/tessellation/{nearest-value-padding.ts → nearest-value-padding.js} +112 -147
  26. package/Math/tessellation/{spherical-triangle-area.ts → spherical-triangle-area.js} +99 -127
  27. package/Math/tessellation/{tile-merger.ts → tile-merger.js} +429 -578
  28. package/Math/tessellation/{triangle-tessellation.ts → triangle-tessellation.js} +386 -533
  29. package/Math/tessellation/types.js +1 -0
  30. package/Math/types.js +1 -0
  31. package/Math/utils.js +2 -3
  32. package/Math/{vec3.ts → vec3.js} +155 -227
  33. package/Math/{xyz-tile.ts → xyz-tile.js} +18 -26
  34. package/algorithms/search-binary.js +16 -14
  35. package/altitude-locator/adaptors.js +1 -0
  36. package/altitude-locator/keymethod.js +1 -0
  37. package/altitude-locator/plugin.js +344 -445
  38. package/altitude-locator/types.js +21 -26
  39. package/compass-rose/compass-rose-padding-flat.js +230 -274
  40. package/compass-rose/{compass-text-writer.ts → compass-text-writer.js} +155 -210
  41. package/compass-rose/index.js +3 -3
  42. package/{constants.ts → constants.js} +6 -8
  43. package/heatwave/datamanager.js +149 -168
  44. package/heatwave/heatwave.js +206 -261
  45. package/heatwave/index.js +5 -5
  46. package/heatwave/isobar.js +303 -340
  47. package/heatwave/{texture-point-sampler.ts → texture-point-sampler.js} +187 -220
  48. package/investigation-tools/draw/tiles/adapters.js +67 -0
  49. package/investigation-tools/draw/tiles/{tiles.ts → tiles.js} +128 -162
  50. package/jest.config.js +7 -6
  51. package/package.json +1 -1
  52. package/pin/pin-object-array1.js +300 -381
  53. package/pin/pin-point-totem1.js +60 -77
  54. package/programs/arrowfield/arrow-field.js +60 -89
  55. package/programs/arrowfield/logic.js +141 -173
  56. package/programs/data2legend/density-to-legend.js +68 -86
  57. package/programs/data2legend/point-to-density-texture.js +67 -84
  58. package/programs/float2legendwithratio/index.js +2 -3
  59. package/programs/float2legendwithratio/logic.js +118 -144
  60. package/programs/float2legendwithratio/object.js +104 -141
  61. package/programs/helpers/blender.js +58 -73
  62. package/programs/helpers/{fadeaway.ts → fadeaway.js} +60 -73
  63. package/programs/index.js +20 -19
  64. package/programs/line-on-globe/circle-accurate-3d.js +85 -112
  65. package/programs/line-on-globe/circle-accurate-flat.js +148 -200
  66. package/programs/line-on-globe/degree-padding-around-circle-3d.js +102 -134
  67. package/programs/line-on-globe/index.js +1 -0
  68. package/programs/line-on-globe/lines-color-instanced-flat.js +80 -99
  69. package/programs/line-on-globe/linestrip/data.js +4 -0
  70. package/programs/line-on-globe/linestrip/{linestrip.ts → linestrip.js} +93 -152
  71. package/programs/line-on-globe/{naive-accurate-flexible.ts → naive-accurate-flexible.js} +126 -175
  72. package/programs/line-on-globe/util.js +5 -8
  73. package/programs/picking/pickable-polygon-renderer.js +98 -129
  74. package/programs/picking/pickable-renderer.js +98 -130
  75. package/programs/point-on-globe/element-globe-surface-glow.js +93 -122
  76. package/programs/point-on-globe/element-point-glow.js +80 -114
  77. package/programs/point-on-globe/square-pixel-point.js +121 -139
  78. package/programs/polygon-on-globe/{texture-dem-triangles.ts → texture-dem-triangles.js} +163 -207
  79. package/programs/{programcache.ts → programcache.js} +126 -134
  80. package/programs/rings/index.js +1 -1
  81. package/programs/rings/partial-ring/{piece-of-pie.ts → piece-of-pie.js} +152 -222
  82. package/programs/totems/camera-totem-attactment-interface.js +1 -0
  83. package/programs/totems/{camerauniformblock.ts → camerauniformblock.js} +225 -310
  84. package/programs/totems/{canvas-webglobe-info.ts → canvas-webglobe-info.js} +132 -147
  85. package/programs/totems/{dem-textures-manager.ts → dem-textures-manager.js} +257 -360
  86. package/programs/totems/{globe-changes.ts → globe-changes.js} +59 -79
  87. package/programs/totems/gpu-selection-uniform-block.js +99 -127
  88. package/programs/totems/{index.ts → index.js} +2 -2
  89. package/programs/two-d/pixel-padding-for-compass.js +87 -101
  90. package/programs/util.js +14 -19
  91. package/programs/vectorfields/logics/{constants.ts → constants.js} +4 -5
  92. package/programs/vectorfields/logics/{drawrectangleparticles.ts → drawrectangleparticles.js} +80 -115
  93. package/programs/vectorfields/logics/index.js +2 -4
  94. package/programs/vectorfields/logics/particle-ubo.js +16 -0
  95. package/programs/vectorfields/logics/{pixelbased.ts → pixelbased.js} +86 -115
  96. package/programs/vectorfields/logics/ubo.js +51 -57
  97. package/programs/vectorfields/{pingpongbuffermanager.ts → pingpongbuffermanager.js} +99 -113
  98. package/range-tools-on-terrain/bearing-line/{adapters.ts → adapters.js} +114 -154
  99. package/range-tools-on-terrain/bearing-line/{plugin.ts → plugin.js} +457 -569
  100. package/range-tools-on-terrain/bearing-line/types.js +1 -0
  101. package/range-tools-on-terrain/circle-line-chain/{adapters.ts → adapters.js} +85 -104
  102. package/range-tools-on-terrain/circle-line-chain/{chain-list-map.ts → chain-list-map.js} +382 -446
  103. package/range-tools-on-terrain/circle-line-chain/{plugin.ts → plugin.js} +464 -607
  104. package/range-tools-on-terrain/circle-line-chain/types.js +1 -0
  105. package/range-tools-on-terrain/range-ring/{adapters.ts → adapters.js} +93 -114
  106. package/range-tools-on-terrain/range-ring/{enum.ts → enum.js} +2 -2
  107. package/range-tools-on-terrain/range-ring/{plugin.ts → plugin.js} +377 -444
  108. package/range-tools-on-terrain/range-ring/rangeringangletext.js +331 -0
  109. package/range-tools-on-terrain/range-ring/types.js +9 -0
  110. package/semiplugins/interface.js +1 -0
  111. package/semiplugins/lightweight/{line-plugin.ts → line-plugin.js} +221 -342
  112. package/semiplugins/lightweight/{piece-of-pie-plugin.ts → piece-of-pie-plugin.js} +200 -275
  113. package/semiplugins/shape-on-terrain/{arc-plugin.ts → arc-plugin.js} +481 -616
  114. package/semiplugins/shape-on-terrain/{circle-plugin.ts → circle-plugin.js} +444 -588
  115. package/semiplugins/shape-on-terrain/{padding-1-degree.ts → padding-1-degree.js} +539 -713
  116. package/semiplugins/shape-on-terrain/terrain-polygon/{adapters.ts → adapters.js} +55 -69
  117. package/semiplugins/shape-on-terrain/terrain-polygon/data/{cache.ts → cache.js} +102 -149
  118. package/semiplugins/shape-on-terrain/terrain-polygon/data/{index-polygon-map.ts → index-polygon-map.js} +45 -58
  119. package/semiplugins/shape-on-terrain/terrain-polygon/data/{manager.ts → manager.js} +4 -4
  120. package/semiplugins/shape-on-terrain/terrain-polygon/data/master-worker.js +177 -196
  121. package/semiplugins/shape-on-terrain/terrain-polygon/data/{polygon-to-triangles.ts → polygon-to-triangles.js} +100 -144
  122. package/semiplugins/shape-on-terrain/terrain-polygon/data/{random.ts → random.js} +121 -165
  123. package/semiplugins/shape-on-terrain/terrain-polygon/data/types.js +1 -0
  124. package/semiplugins/shape-on-terrain/terrain-polygon/data/{worker-contact.ts → worker-contact.js} +63 -81
  125. package/semiplugins/shape-on-terrain/terrain-polygon/data/worker.js +125 -146
  126. package/semiplugins/shape-on-terrain/terrain-polygon/{terrain-polygon.ts → terrain-polygon.js} +219 -265
  127. package/semiplugins/shape-on-terrain/terrain-polygon/types.js +8 -0
  128. package/semiplugins/shell/bbox-renderer/index.js +2 -0
  129. package/semiplugins/shell/bbox-renderer/{logic.ts → logic.js} +209 -273
  130. package/semiplugins/shell/bbox-renderer/object.js +75 -0
  131. package/semiplugins/type.js +1 -0
  132. package/semiplugins/utility/{container-plugin.ts → container-plugin.js} +94 -126
  133. package/semiplugins/utility/{object-pass-container-plugin.ts → object-pass-container-plugin.js} +80 -101
  134. package/shaders/fragment-toy/firework.js +1 -1
  135. package/shaders/fragment-toy/singularity.js +2 -5
  136. package/tracks/point-heat-map/adaptors/timetracksplugin-format-to-this.js +63 -78
  137. package/tracks/point-heat-map/index.js +1 -0
  138. package/tracks/point-heat-map/plugin-webworker.js +121 -148
  139. package/tracks/point-heat-map/point-to-heat-map-flow.js +121 -150
  140. package/tracks/point-tracks/key-methods.js +2 -3
  141. package/tracks/point-tracks/plugin.js +401 -487
  142. package/tracks/timetracks/adaptors-line-strip.js +65 -79
  143. package/tracks/timetracks/plugin-line-strip.js +240 -295
  144. package/tracks/timetracks/program-line-strip.js +411 -495
  145. package/tracks/timetracks/programpoint-line-strip.js +109 -137
  146. package/types.js +19 -0
  147. package/util/account/bufferoffsetmanager.js +176 -209
  148. package/util/account/create-buffermap-orchastration.js +39 -0
  149. package/util/account/index.js +3 -6
  150. package/util/account/single-attribute-buffer-management/{buffer-manager.ts → buffer-manager.js} +119 -151
  151. package/util/account/single-attribute-buffer-management/{buffer-orchestrator.ts → buffer-orchestrator.js} +212 -238
  152. package/util/account/single-attribute-buffer-management/{buffer-orchestrator1.ts → buffer-orchestrator1.js} +159 -184
  153. package/util/account/single-attribute-buffer-management/{index.ts → index.js} +4 -11
  154. package/util/account/single-attribute-buffer-management/{object-store.ts → object-store.js} +55 -76
  155. package/util/account/single-attribute-buffer-management/types.js +1 -0
  156. package/util/account/util.js +18 -22
  157. package/util/algorithms/index.js +1 -0
  158. package/util/algorithms/search-binary.js +25 -26
  159. package/util/build-strategy/{static-dynamic.ts → static-dynamic.js} +41 -50
  160. package/util/check/index.js +1 -0
  161. package/util/check/typecheck.js +66 -0
  162. package/util/{frame-counter-trigger.ts → frame-counter-trigger.js} +84 -99
  163. package/util/geometry/{index.ts → index.js} +121 -155
  164. package/util/gl-util/buffer/{attribute-loader.ts → attribute-loader.js} +62 -84
  165. package/util/gl-util/buffer/{index.ts → index.js} +3 -6
  166. package/util/gl-util/draw-options/{methods.ts → methods.js} +32 -47
  167. package/util/gl-util/uniform-block/{manager.ts → manager.js} +200 -232
  168. package/util/{globe-default-gl-states.ts → globe-default-gl-states.js} +4 -5
  169. package/util/{helper-methods.ts → helper-methods.js} +8 -9
  170. package/util/index.js +10 -9
  171. package/util/interpolation/index.js +1 -0
  172. package/util/interpolation/timetrack/index.js +2 -9
  173. package/util/interpolation/timetrack/timetrack-interpolator.js +79 -94
  174. package/util/interpolation/timetrack/web-worker.js +46 -51
  175. package/util/picking/{fence.ts → fence.js} +43 -47
  176. package/util/picking/{picker-displayer.ts → picker-displayer.js} +176 -226
  177. package/util/programs/draw-from-pixel-coords.js +164 -201
  178. package/util/programs/{draw-texture-on-canvas.ts → draw-texture-on-canvas.js} +69 -91
  179. package/util/programs/supersampletotextures.js +97 -130
  180. package/util/programs/texturetoglobe.js +128 -153
  181. package/util/shaderfunctions/{geometrytransformations.ts → geometrytransformations.js} +44 -106
  182. package/util/shaderfunctions/index.js +2 -2
  183. package/util/shaderfunctions/nodata.js +2 -4
  184. package/util/shaderfunctions/noisefunctions.js +7 -10
  185. package/util/{webglobjectbuilders.ts → webglobjectbuilders.js} +358 -446
  186. package/vectorfield/arrowfield/adaptor.js +11 -11
  187. package/vectorfield/arrowfield/index.js +3 -3
  188. package/vectorfield/arrowfield/plugin.js +83 -128
  189. package/vectorfield/waveparticles/adaptor.js +15 -16
  190. package/vectorfield/waveparticles/index.js +3 -3
  191. package/vectorfield/waveparticles/{plugin.ts → plugin.js} +415 -506
  192. package/vectorfield/wind/adapters/{image-to-fields.ts → image-to-fields.js} +61 -74
  193. package/vectorfield/wind/adapters/types.js +1 -0
  194. package/vectorfield/wind/{imagetovectorfieldandmagnitude.ts → imagetovectorfieldandmagnitude.js} +53 -78
  195. package/vectorfield/wind/index.js +5 -5
  196. package/vectorfield/wind/{plugin-persistant copy.ts → plugin-persistant copy.js } +364 -461
  197. package/vectorfield/wind/{plugin-persistant.ts → plugin-persistant.js} +375 -483
  198. package/vectorfield/wind/plugin.js +685 -883
  199. package/vectorfield/wind/vectorfieldimage.js +23 -27
  200. package/write-text/{context-text-bulk.ts → context-text-bulk.js} +200 -285
  201. package/write-text/context-text3.js +167 -0
  202. package/write-text/{context-text4.ts → context-text4.js} +146 -231
  203. package/write-text/context-textDELETE.js +94 -125
  204. package/write-text/objectarraylabels/{index.ts → index.js} +2 -2
  205. package/write-text/objectarraylabels/objectarraylabels.js +200 -247
  206. package/Math/matrix4.ts +0 -0
  207. package/Math/mesh/mapbox-delaunay.d.ts +0 -74
  208. package/Math/roadmap.md +0 -10
  209. package/Math/tessellation/constants.ts +0 -1
  210. package/Math/tessellation/roadmap.md +0 -48
  211. package/Math/tessellation/types.ts +0 -1
  212. package/Math/types.ts +0 -68
  213. package/investigation-tools/draw/tiles/adapters.ts +0 -133
  214. package/programs/line-on-globe/linestrip/data.ts +0 -29
  215. package/programs/polygon-on-globe/roadmap.md +0 -8
  216. package/programs/totems/camera-totem-attactment-interface.ts +0 -4
  217. package/programs/vectorfields/logics/particle-ubo.ts +0 -23
  218. package/publish.bat +0 -62
  219. package/range-tools-on-terrain/bearing-line/types.ts +0 -65
  220. package/range-tools-on-terrain/circle-line-chain/types.ts +0 -43
  221. package/range-tools-on-terrain/range-ring/rangeringangletext.ts +0 -396
  222. package/range-tools-on-terrain/range-ring/types.ts +0 -30
  223. package/semiplugins/interface.ts +0 -14
  224. package/semiplugins/shape-on-terrain/goal.md +0 -12
  225. package/semiplugins/shape-on-terrain/terrain-polygon/data/cache-shortcuts.md +0 -20
  226. package/semiplugins/shape-on-terrain/terrain-polygon/data/master-worker.ts +0 -209
  227. package/semiplugins/shape-on-terrain/terrain-polygon/data/readme.md +0 -5
  228. package/semiplugins/shape-on-terrain/terrain-polygon/data/types.ts +0 -37
  229. package/semiplugins/shape-on-terrain/terrain-polygon/notes.md +0 -90
  230. package/semiplugins/shape-on-terrain/terrain-polygon/types.ts +0 -69
  231. package/semiplugins/shell/bbox-renderer/index.ts +0 -2
  232. package/semiplugins/shell/bbox-renderer/object.ts +0 -129
  233. package/semiplugins/type.ts +0 -8
  234. package/terrain-plugin.mmd +0 -83
  235. package/tests/Math/arc-sampling-test.js +0 -367
  236. package/tests/Math/arc-sampling-test.ts +0 -429
  237. package/tests/Math/arc.test.ts +0 -77
  238. package/tests/Math/junction/arc-limit.test.ts +0 -7
  239. package/tests/Math/junction/arc-plane-points.test.ts +0 -196
  240. package/tests/Math/junction/arc-plane.test.ts +0 -172
  241. package/tests/Math/junction/line-sphere.test.ts +0 -127
  242. package/tests/Math/junction/plane-plane.test.ts +0 -91
  243. package/tests/Math/plane-test.ts +0 -17
  244. package/tests/Math/plane.test.ts +0 -43
  245. package/tests/Math/vec3.test.ts +0 -33
  246. package/tracks/point-heat-map/readme.md +0 -15
  247. package/tracks/timetracks/readme.md +0 -1
  248. package/tsconfig.json +0 -22
  249. package/types/@pirireis/webglobe.d.ts +0 -102
  250. package/types/delaunator.d.ts +0 -40
  251. package/types/earcut.d.ts +0 -11
  252. package/types/rbush.d.ts +0 -57
  253. package/types.ts +0 -319
  254. package/util/account/create-buffermap-orchastration.ts +0 -85
  255. package/util/account/single-attribute-buffer-management/types.ts +0 -43
  256. package/util/check/typecheck.ts +0 -74
  257. package/vectorfield/wind/adapters/types.ts +0 -12
  258. package/write-text/context-text3.ts +0 -252
  259. package/write-text/objectarraylabels/objectarraylabels.d.ts +0 -72
@@ -1,148 +1,121 @@
1
- import { PointHeatmapFlow } from "./point-to-heat-map-flow";
2
- import { createWorker } from "../../util/interpolation/timetrack/index";
3
- import { createTexture, getColorRampModed } from "../../util/webglobjectbuilders";
4
- import { opacityCheck, constraintFloat } from "../../util/check/typecheck";
5
-
6
- class PointHeatmapPlugin {
7
-
8
- constructor(id, { opacity = 1.0, pointSize = 5.0, onInterpolationComplete = () => { } } = {}) {
9
- this.id = id;
10
- this.globe = null;
11
- this.gl = null;
12
- this.densityToLegendProgram = null;
13
- this._time = null;
14
-
15
- this._opacity = opacity;
16
- this._pointSize = pointSize;
17
- this._legendTexture = null;
18
-
19
- this._throttleListener = null;
20
- this._timeTracksAreSet = false;
21
- this.timeTrackInterpolationWorker = createWorker();
22
- this.timeTrackInterpolationWorker.onmessage = (e) => {
23
- if (e.data.error) {
24
- throw new Error(e.data.error);
25
- }
26
- if (e.data === true) {
27
- onInterpolationComplete();
28
- }
29
- if (e.data instanceof Float32Array) {
30
- this.flow.setData(e.data);
31
- this._throttleListener = null;
32
- onInterpolationComplete();
33
- }
34
- }
35
- }
36
-
37
- // globe interaction
38
-
39
- init(globe, gl) {
40
- this.globe = globe;
41
- this.gl = gl;
42
- this.flow = new PointHeatmapFlow(globe);
43
- this.setGeometry();
44
- this.resize();
45
- }
46
-
47
-
48
- setPointSize(pointSize) {
49
- constraintFloat(pointSize, 1);
50
- this._pointSize = pointSize;
51
- this.globe.DrawRender();
52
- }
53
-
54
-
55
- /**
56
- * @param {Array<string>}
57
- * @param {string} mode "interpolated" | "discrete"
58
- */
59
-
60
- setColorRamp(values, thresholds, mode = "interpolated") {
61
- const gl = this.gl
62
- if (this.gl === null) {
63
- throw new Error('Plugin not initialized');
64
- };
65
- const rampData = getColorRampModed(values, thresholds, mode);
66
- const texture = createTexture(gl, gl.LINEAR, rampData, 256, 1);
67
- if (this._legendTexture) {
68
- this.gl.deleteTexture(this._legendTexture);
69
- }
70
- this._legendTexture = texture;
71
- this.globe.DrawRender();
72
- }
73
-
74
-
75
- setTime(time) {
76
- // TODO: WORK ON THIS
77
- this._time = time;
78
- if (this.isReady() && this._throttleListener === null) {
79
- if (this._isFreed) return;
80
- this._throttleListener = setTimeout(() => {
81
- this.timeTrackInterpolationWorker?.postMessage({ time: this._time });
82
- }, 0);
83
- }
84
- }
85
-
86
-
87
- setTimetracks(timeTracks) {
88
- this._timeTracksAreSet = true;
89
- this.timeTrackInterpolationWorker.postMessage({ timeTracks });
90
- if (this._time !== null) {
91
- this.setTime(this._time);
92
- }
93
- this.globe.DrawRender();
94
- }
95
-
96
-
97
- setOpacity(opacity) {
98
- opacityCheck(opacity);
99
- this._opacity = opacity;
100
- this.globe.DrawRender();
101
- }
102
-
103
-
104
-
105
- setGeometry() {
106
- const geometry = this.globe.api_GetCurrentGeometry();
107
- this.timeTrackInterpolationWorker.postMessage({ geometry });
108
- if (this._time !== null) {
109
- this.setTime(this._time);
110
- }
111
- }
112
-
113
-
114
- draw3D() {
115
- if (this.isReady()) {
116
- this.flow.draw(this._legendTexture, this._pointSize, this._opacity);
117
- }
118
- }
119
-
120
-
121
- resize() {
122
- this.flow.resize();
123
- if (this._time !== null) {
124
- this.setTime(this._time);
125
- }
126
- }
127
-
128
-
129
- isReady() {
130
- return (this.gl !== null && this._legendTexture !== null && this._timeTracksAreSet);
131
- }
132
-
133
- free() {
134
- if (this._isFreed) return;
135
- this.gl.deleteTexture(this._legendTexture);
136
- this.flow.free();
137
- this.flow = null;
138
- this.gl = null;
139
- this._isFreed = true;
140
- this._legendTexture = null;
141
- this.timeTrackInterpolationWorker.terminate();
142
- this.timeTrackInterpolationWorker = null;
143
- }
144
- }
145
-
146
-
147
- export { PointHeatmapPlugin };
148
-
1
+ import { PointHeatmapFlow } from "./point-to-heat-map-flow";
2
+ import { createWorker } from "../../util/interpolation/timetrack/index";
3
+ import { createTexture, getColorRampModed } from "../../util/webglobjectbuilders";
4
+ import { opacityCheck, constraintFloat } from "../../util/check/typecheck";
5
+ class PointHeatmapPlugin {
6
+ constructor(id, { opacity = 1.0, pointSize = 5.0, onInterpolationComplete = () => { } } = {}) {
7
+ this.id = id;
8
+ this.globe = null;
9
+ this.gl = null;
10
+ this.densityToLegendProgram = null;
11
+ this._time = null;
12
+ this._opacity = opacity;
13
+ this._pointSize = pointSize;
14
+ this._legendTexture = null;
15
+ this._throttleListener = null;
16
+ this._timeTracksAreSet = false;
17
+ this.timeTrackInterpolationWorker = createWorker();
18
+ this.timeTrackInterpolationWorker.onmessage = (e) => {
19
+ if (e.data.error) {
20
+ throw new Error(e.data.error);
21
+ }
22
+ if (e.data === true) {
23
+ onInterpolationComplete();
24
+ }
25
+ if (e.data instanceof Float32Array) {
26
+ this.flow.setData(e.data);
27
+ this._throttleListener = null;
28
+ onInterpolationComplete();
29
+ }
30
+ };
31
+ }
32
+ // globe interaction
33
+ init(globe, gl) {
34
+ this.globe = globe;
35
+ this.gl = gl;
36
+ this.flow = new PointHeatmapFlow(globe);
37
+ this.setGeometry();
38
+ this.resize();
39
+ }
40
+ setPointSize(pointSize) {
41
+ constraintFloat(pointSize, 1);
42
+ this._pointSize = pointSize;
43
+ this.globe.DrawRender();
44
+ }
45
+ /**
46
+ * @param {Array<string>}
47
+ * @param {string} mode "interpolated" | "discrete"
48
+ */
49
+ setColorRamp(values, thresholds, mode = "interpolated") {
50
+ const gl = this.gl;
51
+ if (this.gl === null) {
52
+ throw new Error('Plugin not initialized');
53
+ }
54
+ ;
55
+ const rampData = getColorRampModed(values, thresholds, mode);
56
+ const texture = createTexture(gl, gl.LINEAR, rampData, 256, 1);
57
+ if (this._legendTexture) {
58
+ this.gl.deleteTexture(this._legendTexture);
59
+ }
60
+ this._legendTexture = texture;
61
+ this.globe.DrawRender();
62
+ }
63
+ setTime(time) {
64
+ // TODO: WORK ON THIS
65
+ this._time = time;
66
+ if (this.isReady() && this._throttleListener === null) {
67
+ if (this._isFreed)
68
+ return;
69
+ this._throttleListener = setTimeout(() => {
70
+ this.timeTrackInterpolationWorker?.postMessage({ time: this._time });
71
+ }, 0);
72
+ }
73
+ }
74
+ setTimetracks(timeTracks) {
75
+ this._timeTracksAreSet = true;
76
+ this.timeTrackInterpolationWorker.postMessage({ timeTracks });
77
+ if (this._time !== null) {
78
+ this.setTime(this._time);
79
+ }
80
+ this.globe.DrawRender();
81
+ }
82
+ setOpacity(opacity) {
83
+ opacityCheck(opacity);
84
+ this._opacity = opacity;
85
+ this.globe.DrawRender();
86
+ }
87
+ setGeometry() {
88
+ const geometry = this.globe.api_GetCurrentGeometry();
89
+ this.timeTrackInterpolationWorker.postMessage({ geometry });
90
+ if (this._time !== null) {
91
+ this.setTime(this._time);
92
+ }
93
+ }
94
+ draw3D() {
95
+ if (this.isReady()) {
96
+ this.flow.draw(this._legendTexture, this._pointSize, this._opacity);
97
+ }
98
+ }
99
+ resize() {
100
+ this.flow.resize();
101
+ if (this._time !== null) {
102
+ this.setTime(this._time);
103
+ }
104
+ }
105
+ isReady() {
106
+ return (this.gl !== null && this._legendTexture !== null && this._timeTracksAreSet);
107
+ }
108
+ free() {
109
+ if (this._isFreed)
110
+ return;
111
+ this.gl.deleteTexture(this._legendTexture);
112
+ this.flow.free();
113
+ this.flow = null;
114
+ this.gl = null;
115
+ this._isFreed = true;
116
+ this._legendTexture = null;
117
+ this.timeTrackInterpolationWorker.terminate();
118
+ this.timeTrackInterpolationWorker = null;
119
+ }
120
+ }
121
+ export { PointHeatmapPlugin };
@@ -1,150 +1,121 @@
1
- import { densityToLegendProgramCache } from "../../programs/data2legend/density-to-legend";
2
- import { pointToDensityTextureCache } from "../../programs/data2legend/point-to-density-texture";
3
- // import { textureOnCanvasProgramCache } from "../../util/programs/draw-texture-on-canvas";
4
- import { defaultblendfunction } from "../../util/globe-default-gl-states";
5
- class PointHeatmapFlow {
6
-
7
- constructor(globe) {
8
- this.globe = null;
9
- this.gl = null;
10
- this.program = null;
11
- this.densityToLegendProgram = null;
12
- this.globe = globe;
13
- this.gl = globe.gl;
14
- this.pointToDensityProgram = pointToDensityTextureCache.get(globe);
15
- this.densityToLegendProgram = densityToLegendProgramCache.get(globe);
16
- // this.testTextureProgram = textureOnCanvasProgramCache.get(globe.gl);
17
- this._lookInfo = globe.api_GetCurrentLookInfo();
18
- const { gl } = this;
19
-
20
- this.buffer = gl.createBuffer();
21
- this.vao2D = this.pointToDensityProgram.createVAO(this.buffer, 2);
22
- this.vao3D = this.pointToDensityProgram.createVAO(this.buffer, 3);
23
-
24
- // framebuffer and texture
25
- this.framebuffer = gl.createFramebuffer();
26
- this.densityTexture = this._createDensityTexture();
27
- this._bindTextureToFramebuffer();
28
-
29
- }
30
-
31
- _bindTextureToFramebuffer() {
32
- const { gl, densityTexture, framebuffer } = this;
33
- gl.bindFramebuffer(gl.FRAMEBUFFER, framebuffer);
34
- gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, densityTexture, 0);
35
- gl.bindFramebuffer(gl.FRAMEBUFFER, null);
36
- }
37
-
38
-
39
- draw(legendTexture, pointSize, opacity = 1.0) {
40
- const { gl, globe, framebuffer } = this;
41
- if (this._drawDensityRequired || this._isVisionChanged()) {
42
- gl.bindFramebuffer(gl.FRAMEBUFFER, framebuffer);
43
- gl.clearColor(0, 0, 0, 0);
44
- gl.viewport(
45
- 0, 0,
46
- Math.floor(globe.api_ScrW()), Math.floor(globe.api_ScrH())
47
- );
48
- gl.clear(gl.COLOR_BUFFER_BIT);
49
- this._drawDensity(pointSize);
50
- gl.bindFramebuffer(gl.FRAMEBUFFER, null);
51
- }
52
- defaultblendfunction(gl);
53
- this._drawLegend(legendTexture, opacity);
54
- }
55
-
56
-
57
- resize() {
58
- const { gl, densityTexture } = this;
59
- gl.deleteTexture(densityTexture);
60
- this.densityTexture = this._createDensityTexture();
61
- this._bindTextureToFramebuffer();
62
- this._drawDensityRequired = true;
63
- }
64
-
65
-
66
- // USER API
67
-
68
- /**
69
- * @param {Float32Array} data
70
- * @format [x, y, z, height] x,y,z is normalized 3d cartesian coordinates. Height in kilometers. Set 6378.137 for ground level.
71
- */
72
- setData(data) {
73
- const { gl, buffer } = this;
74
- gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
75
- gl.bufferData(gl.ARRAY_BUFFER, data, gl.STATIC_DRAW);
76
- // use program
77
- this.dataLength = data.length;
78
- this._drawDensityRequired = true;
79
- this.globe.DrawRender();
80
- }
81
-
82
- // implicit Methods
83
-
84
- _createDensityTexture() {
85
- const { gl, globe } = this;
86
- const width = Math.floor(globe.api_ScrW())
87
- const height = Math.floor(globe.api_ScrH());
88
- const texture = gl.createTexture();
89
- gl.bindTexture(gl.TEXTURE_2D, texture);
90
- gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, width, height, 0, gl.RGBA, gl.UNSIGNED_BYTE, null);
91
- gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);
92
- gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);
93
- gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);
94
- gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);
95
- return texture;
96
- }
97
-
98
-
99
- _drawDensity(pointSize) {
100
- const { gl, globe, pointToDensityProgram, vao2D, vao3D, dataLength } = this;
101
- const is3D = globe.api_GetCurrentGeometry() === 0;
102
- const vao = is3D ? vao3D : vao2D;
103
- const length = dataLength / (is3D ? 3 : 2);
104
- gl.blendEquation(gl.FUNC_ADD);
105
- gl.blendFuncSeparate(gl.SRC_ALPHA, gl.ONE, gl.SRC_ALPHA, gl.ONE);
106
- pointToDensityProgram.draw(vao, length, pointSize);
107
-
108
- this._drawDensityRequired = false;
109
- }
110
-
111
-
112
- _drawLegend(legendTexture, opacity) {
113
- const { densityToLegendProgram, densityTexture } = this;
114
- densityToLegendProgram.draw(densityTexture, legendTexture, opacity);
115
- }
116
-
117
-
118
- _isVisionChanged() {
119
- const currentLookInfo = this.globe.api_GetCurrentLookInfo();
120
- const _lookInfo = this._lookInfo;
121
- if (
122
- currentLookInfo.CenterLong !== _lookInfo.CenterLong ||
123
- currentLookInfo.CenterLat !== _lookInfo.CenterLat ||
124
- currentLookInfo.Distance !== _lookInfo.Distance ||
125
- currentLookInfo.Tilt !== _lookInfo.Tilt ||
126
- currentLookInfo.NorthAng !== _lookInfo.NorthAng
127
- ) {
128
- this._lookInfo = currentLookInfo;
129
- return true;
130
- }
131
- return false;
132
- }
133
-
134
-
135
- free() {
136
- if (this._isFreed) return;
137
- this._isFreed = true;
138
- densityToLegendProgramCache.release(this.globe);
139
- pointToDensityTextureCache.release(this.globe);
140
- // textureOnCanvasProgramCache.release(this.gl);
141
- this.gl.deleteTexture(this.densityTexture);
142
- this.gl.deleteFramebuffer(this.framebuffer);
143
- this.gl.deleteBuffer(this.buffer);
144
- this.gl.deleteVertexArray(this.vao2D);
145
- this.gl.deleteVertexArray(this.vao3D);
146
- }
147
- }
148
-
149
-
150
- export { PointHeatmapFlow };
1
+ import { densityToLegendProgramCache } from "../../programs/data2legend/density-to-legend";
2
+ import { pointToDensityTextureCache } from "../../programs/data2legend/point-to-density-texture";
3
+ // import { textureOnCanvasProgramCache } from "../../util/programs/draw-texture-on-canvas";
4
+ import { defaultblendfunction } from "../../util/globe-default-gl-states";
5
+ class PointHeatmapFlow {
6
+ constructor(globe) {
7
+ this.globe = null;
8
+ this.gl = null;
9
+ this.program = null;
10
+ this.densityToLegendProgram = null;
11
+ this.globe = globe;
12
+ this.gl = globe.gl;
13
+ this.pointToDensityProgram = pointToDensityTextureCache.get(globe);
14
+ this.densityToLegendProgram = densityToLegendProgramCache.get(globe);
15
+ // this.testTextureProgram = textureOnCanvasProgramCache.get(globe.gl);
16
+ this._lookInfo = globe.api_GetCurrentLookInfo();
17
+ const { gl } = this;
18
+ this.buffer = gl.createBuffer();
19
+ this.vao2D = this.pointToDensityProgram.createVAO(this.buffer, 2);
20
+ this.vao3D = this.pointToDensityProgram.createVAO(this.buffer, 3);
21
+ // framebuffer and texture
22
+ this.framebuffer = gl.createFramebuffer();
23
+ this.densityTexture = this._createDensityTexture();
24
+ this._bindTextureToFramebuffer();
25
+ }
26
+ _bindTextureToFramebuffer() {
27
+ const { gl, densityTexture, framebuffer } = this;
28
+ gl.bindFramebuffer(gl.FRAMEBUFFER, framebuffer);
29
+ gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, densityTexture, 0);
30
+ gl.bindFramebuffer(gl.FRAMEBUFFER, null);
31
+ }
32
+ draw(legendTexture, pointSize, opacity = 1.0) {
33
+ const { gl, globe, framebuffer } = this;
34
+ if (this._drawDensityRequired || this._isVisionChanged()) {
35
+ gl.bindFramebuffer(gl.FRAMEBUFFER, framebuffer);
36
+ gl.clearColor(0, 0, 0, 0);
37
+ gl.viewport(0, 0, Math.floor(globe.api_ScrW()), Math.floor(globe.api_ScrH()));
38
+ gl.clear(gl.COLOR_BUFFER_BIT);
39
+ this._drawDensity(pointSize);
40
+ gl.bindFramebuffer(gl.FRAMEBUFFER, null);
41
+ }
42
+ defaultblendfunction(gl);
43
+ this._drawLegend(legendTexture, opacity);
44
+ }
45
+ resize() {
46
+ const { gl, densityTexture } = this;
47
+ gl.deleteTexture(densityTexture);
48
+ this.densityTexture = this._createDensityTexture();
49
+ this._bindTextureToFramebuffer();
50
+ this._drawDensityRequired = true;
51
+ }
52
+ // USER API
53
+ /**
54
+ * @param {Float32Array} data
55
+ * @format [x, y, z, height] x,y,z is normalized 3d cartesian coordinates. Height in kilometers. Set 6378.137 for ground level.
56
+ */
57
+ setData(data) {
58
+ const { gl, buffer } = this;
59
+ gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
60
+ gl.bufferData(gl.ARRAY_BUFFER, data, gl.STATIC_DRAW);
61
+ // use program
62
+ this.dataLength = data.length;
63
+ this._drawDensityRequired = true;
64
+ this.globe.DrawRender();
65
+ }
66
+ // implicit Methods
67
+ _createDensityTexture() {
68
+ const { gl, globe } = this;
69
+ const width = Math.floor(globe.api_ScrW());
70
+ const height = Math.floor(globe.api_ScrH());
71
+ const texture = gl.createTexture();
72
+ gl.bindTexture(gl.TEXTURE_2D, texture);
73
+ gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, width, height, 0, gl.RGBA, gl.UNSIGNED_BYTE, null);
74
+ gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);
75
+ gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);
76
+ gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);
77
+ gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);
78
+ return texture;
79
+ }
80
+ _drawDensity(pointSize) {
81
+ const { gl, globe, pointToDensityProgram, vao2D, vao3D, dataLength } = this;
82
+ const is3D = globe.api_GetCurrentGeometry() === 0;
83
+ const vao = is3D ? vao3D : vao2D;
84
+ const length = dataLength / (is3D ? 3 : 2);
85
+ gl.blendEquation(gl.FUNC_ADD);
86
+ gl.blendFuncSeparate(gl.SRC_ALPHA, gl.ONE, gl.SRC_ALPHA, gl.ONE);
87
+ pointToDensityProgram.draw(vao, length, pointSize);
88
+ this._drawDensityRequired = false;
89
+ }
90
+ _drawLegend(legendTexture, opacity) {
91
+ const { densityToLegendProgram, densityTexture } = this;
92
+ densityToLegendProgram.draw(densityTexture, legendTexture, opacity);
93
+ }
94
+ _isVisionChanged() {
95
+ const currentLookInfo = this.globe.api_GetCurrentLookInfo();
96
+ const _lookInfo = this._lookInfo;
97
+ if (currentLookInfo.CenterLong !== _lookInfo.CenterLong ||
98
+ currentLookInfo.CenterLat !== _lookInfo.CenterLat ||
99
+ currentLookInfo.Distance !== _lookInfo.Distance ||
100
+ currentLookInfo.Tilt !== _lookInfo.Tilt ||
101
+ currentLookInfo.NorthAng !== _lookInfo.NorthAng) {
102
+ this._lookInfo = currentLookInfo;
103
+ return true;
104
+ }
105
+ return false;
106
+ }
107
+ free() {
108
+ if (this._isFreed)
109
+ return;
110
+ this._isFreed = true;
111
+ densityToLegendProgramCache.release(this.globe);
112
+ pointToDensityTextureCache.release(this.globe);
113
+ // textureOnCanvasProgramCache.release(this.gl);
114
+ this.gl.deleteTexture(this.densityTexture);
115
+ this.gl.deleteFramebuffer(this.framebuffer);
116
+ this.gl.deleteBuffer(this.buffer);
117
+ this.gl.deleteVertexArray(this.vao2D);
118
+ this.gl.deleteVertexArray(this.vao3D);
119
+ }
120
+ }
121
+ export { PointHeatmapFlow };
@@ -1,3 +1,2 @@
1
- const pointKeyMeyhod = (trackId, pointID) => `${trackId}-${pointID}`;
2
-
3
- export { pointKeyMeyhod };
1
+ const pointKeyMeyhod = (trackId, pointID) => `${trackId}-${pointID}`;
2
+ export { pointKeyMeyhod };