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