@pirireis/webglobeplugins 0.17.0 → 1.0.2

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 (274) hide show
  1. package/Math/{angle-calculation.js → angle-calculation.ts} +18 -14
  2. package/Math/{arc-cdf-points.js → arc-cdf-points.ts} +329 -272
  3. package/Math/{arc-generate-points-exponantial.js → arc-generate-points-exponantial.ts} +299 -254
  4. package/Math/{arc.js → arc.ts} +421 -292
  5. package/Math/bounds/line-bbox.js +225 -186
  6. package/Math/{circle-cdf-points.js → circle-cdf-points.ts} +143 -78
  7. package/Math/{circle.js → circle.ts} +49 -33
  8. package/Math/{constants.js → constants.ts} +12 -4
  9. package/Math/contour/{quadtreecontours.js → quadtreecontours.ts} +371 -300
  10. package/Math/contour/quadtreecontours1.js +336 -298
  11. package/Math/{finite-line-2d.js → finite-line-2d.ts} +68 -58
  12. package/Math/haversine.ts +33 -0
  13. package/Math/index.js +0 -1
  14. package/Math/juction/{arc-plane.js → arc-plane.ts} +203 -143
  15. package/Math/juction/{line-sphere.js → line-sphere.ts} +32 -22
  16. package/Math/juction/{plane-plane.js → plane-plane.ts} +62 -53
  17. package/Math/{line.js → line.ts} +84 -52
  18. package/Math/matrix4.ts +0 -0
  19. package/Math/mesh/mapbox-delaunay.d.ts +74 -0
  20. package/Math/{methods.js → methods.ts} +182 -107
  21. package/Math/{plane.js → plane.ts} +92 -56
  22. package/Math/{quaternion.js → quaternion.ts} +128 -106
  23. package/Math/roadmap.md +10 -0
  24. package/Math/templete-shapes/{grid-visually-equal.js → grid-visually-equal.ts} +118 -65
  25. package/Math/tessellation/constants.ts +1 -0
  26. package/Math/tessellation/methods.ts +79 -0
  27. package/Math/tessellation/nearest-value-padding.ts +147 -0
  28. package/Math/tessellation/roadmap.md +48 -0
  29. package/Math/tessellation/spherical-triangle-area.ts +127 -0
  30. package/Math/tessellation/tile-merger.ts +578 -0
  31. package/Math/tessellation/triangle-tessellation.ts +533 -0
  32. package/Math/tessellation/types.ts +1 -0
  33. package/Math/types.ts +68 -0
  34. package/Math/utils.js +3 -2
  35. package/Math/{vec3.js → vec3.ts} +227 -151
  36. package/Math/xyz-tile.ts +26 -0
  37. package/algorithms/search-binary.js +14 -16
  38. package/altitude-locator/adaptors.js +0 -1
  39. package/altitude-locator/keymethod.js +0 -1
  40. package/altitude-locator/plugin.js +445 -345
  41. package/altitude-locator/types.js +26 -21
  42. package/compass-rose/compass-rose-padding-flat.js +274 -230
  43. package/compass-rose/{compass-text-writer.js → compass-text-writer.ts} +210 -155
  44. package/compass-rose/index.js +3 -3
  45. package/{constants.js → constants.ts} +8 -6
  46. package/heatwave/datamanager.js +168 -149
  47. package/heatwave/heatwave.js +261 -206
  48. package/heatwave/index.js +5 -5
  49. package/heatwave/isobar.js +340 -303
  50. package/heatwave/{texture-point-sampler.js → texture-point-sampler.ts} +220 -187
  51. package/investigation-tools/draw/tiles/adapters.ts +133 -0
  52. package/investigation-tools/draw/tiles/tiles.ts +162 -0
  53. package/jest.config.js +6 -7
  54. package/package.json +1 -1
  55. package/pin/pin-object-array1.js +381 -300
  56. package/pin/pin-point-totem1.js +77 -60
  57. package/programs/arrowfield/arrow-field.js +89 -60
  58. package/programs/arrowfield/logic.js +173 -141
  59. package/programs/data2legend/density-to-legend.js +86 -68
  60. package/programs/data2legend/point-to-density-texture.js +84 -67
  61. package/programs/float2legendwithratio/index.js +3 -2
  62. package/programs/float2legendwithratio/logic.js +144 -118
  63. package/programs/float2legendwithratio/object.js +141 -104
  64. package/programs/helpers/blender.js +73 -58
  65. package/programs/helpers/{fadeaway.js → fadeaway.ts} +73 -55
  66. package/programs/index.js +19 -20
  67. package/programs/line-on-globe/circle-accurate-3d.js +112 -85
  68. package/programs/line-on-globe/circle-accurate-flat.js +200 -148
  69. package/programs/line-on-globe/degree-padding-around-circle-3d.js +134 -102
  70. package/programs/line-on-globe/index.js +0 -1
  71. package/programs/line-on-globe/lines-color-instanced-flat.js +99 -80
  72. package/programs/line-on-globe/linestrip/data.ts +29 -0
  73. package/programs/line-on-globe/linestrip/{linestrip.js → linestrip.ts} +152 -93
  74. package/programs/line-on-globe/{naive-accurate-flexible.js → naive-accurate-flexible.ts} +175 -126
  75. package/programs/line-on-globe/util.js +8 -5
  76. package/programs/picking/pickable-polygon-renderer.js +129 -98
  77. package/programs/picking/pickable-renderer.js +130 -98
  78. package/programs/point-on-globe/element-globe-surface-glow.js +122 -93
  79. package/programs/point-on-globe/element-point-glow.js +114 -80
  80. package/programs/point-on-globe/square-pixel-point.js +139 -120
  81. package/programs/polygon-on-globe/roadmap.md +8 -0
  82. package/programs/polygon-on-globe/texture-dem-triangles.ts +290 -0
  83. package/programs/{programcache.js → programcache.ts} +134 -126
  84. package/programs/rings/index.js +1 -1
  85. package/programs/rings/partial-ring/{piece-of-pie.js → piece-of-pie.ts} +222 -152
  86. package/programs/totems/camera-totem-attactment-interface.ts +4 -0
  87. package/programs/totems/{camerauniformblock.js → camerauniformblock.ts} +326 -230
  88. package/programs/totems/{canvas-webglobe-info.js → canvas-webglobe-info.ts} +147 -132
  89. package/programs/totems/dem-textures-manager.ts +368 -0
  90. package/programs/totems/{globe-changes.js → globe-changes.ts} +79 -59
  91. package/programs/totems/gpu-selection-uniform-block.js +127 -99
  92. package/programs/totems/{index.js → index.ts} +2 -2
  93. package/programs/two-d/pixel-padding-for-compass.js +101 -87
  94. package/programs/util.js +19 -14
  95. package/programs/vectorfields/logics/{constants.js → constants.ts} +5 -4
  96. package/programs/vectorfields/logics/drawrectangleparticles.ts +182 -0
  97. package/programs/vectorfields/logics/index.js +4 -2
  98. package/programs/vectorfields/logics/particle-ubo.ts +23 -0
  99. package/programs/vectorfields/logics/{pixelbased.js → pixelbased.ts} +119 -84
  100. package/programs/vectorfields/logics/ubo.js +57 -51
  101. package/programs/vectorfields/{pingpongbuffermanager.js → pingpongbuffermanager.ts} +113 -73
  102. package/publish.bat +62 -0
  103. package/range-tools-on-terrain/bearing-line/{adapters.js → adapters.ts} +154 -114
  104. package/range-tools-on-terrain/bearing-line/{plugin.js → plugin.ts} +569 -457
  105. package/range-tools-on-terrain/bearing-line/types.ts +65 -0
  106. package/range-tools-on-terrain/circle-line-chain/{adapters.js → adapters.ts} +104 -85
  107. package/range-tools-on-terrain/circle-line-chain/{chain-list-map.js → chain-list-map.ts} +446 -382
  108. package/range-tools-on-terrain/circle-line-chain/{plugin.js → plugin.ts} +607 -464
  109. package/range-tools-on-terrain/circle-line-chain/types.ts +43 -0
  110. package/range-tools-on-terrain/range-ring/{adapters.js → adapters.ts} +114 -93
  111. package/range-tools-on-terrain/range-ring/{enum.js → enum.ts} +2 -2
  112. package/range-tools-on-terrain/range-ring/{plugin.js → plugin.ts} +444 -377
  113. package/range-tools-on-terrain/range-ring/rangeringangletext.ts +396 -0
  114. package/range-tools-on-terrain/range-ring/types.ts +30 -0
  115. package/semiplugins/interface.ts +14 -0
  116. package/semiplugins/lightweight/{line-plugin.js → line-plugin.ts} +342 -221
  117. package/semiplugins/lightweight/{piece-of-pie-plugin.js → piece-of-pie-plugin.ts} +275 -200
  118. package/semiplugins/shape-on-terrain/{arc-plugin.js → arc-plugin.ts} +616 -472
  119. package/semiplugins/shape-on-terrain/{circle-plugin.js → circle-plugin.ts} +588 -444
  120. package/semiplugins/shape-on-terrain/goal.md +12 -0
  121. package/semiplugins/shape-on-terrain/{padding-1-degree.js → padding-1-degree.ts} +713 -539
  122. package/semiplugins/shape-on-terrain/terrain-polygon/adapters.ts +69 -0
  123. package/semiplugins/shape-on-terrain/terrain-polygon/data/cache-shortcuts.md +20 -0
  124. package/semiplugins/shape-on-terrain/terrain-polygon/data/cache.ts +149 -0
  125. package/semiplugins/shape-on-terrain/terrain-polygon/data/index-polygon-map.ts +58 -0
  126. package/semiplugins/shape-on-terrain/terrain-polygon/data/manager.ts +4 -0
  127. package/semiplugins/shape-on-terrain/terrain-polygon/data/master-worker.js +196 -0
  128. package/semiplugins/shape-on-terrain/terrain-polygon/data/master-worker.ts +209 -0
  129. package/semiplugins/shape-on-terrain/terrain-polygon/data/polygon-to-triangles.ts +144 -0
  130. package/semiplugins/shape-on-terrain/terrain-polygon/data/random.ts +165 -0
  131. package/semiplugins/shape-on-terrain/terrain-polygon/data/readme.md +5 -0
  132. package/semiplugins/shape-on-terrain/terrain-polygon/data/types.ts +37 -0
  133. package/semiplugins/shape-on-terrain/terrain-polygon/data/worker-contact.ts +81 -0
  134. package/semiplugins/shape-on-terrain/terrain-polygon/data/worker.js +146 -0
  135. package/semiplugins/shape-on-terrain/terrain-polygon/notes.md +90 -0
  136. package/semiplugins/shape-on-terrain/terrain-polygon/terrain-polygon.ts +265 -0
  137. package/semiplugins/shape-on-terrain/terrain-polygon/types.ts +69 -0
  138. package/semiplugins/shell/bbox-renderer/index.ts +2 -0
  139. package/semiplugins/shell/bbox-renderer/{logic.js → logic.ts} +273 -249
  140. package/semiplugins/shell/bbox-renderer/object.ts +129 -0
  141. package/semiplugins/type.ts +8 -0
  142. package/semiplugins/utility/{container-plugin.js → container-plugin.ts} +126 -94
  143. package/semiplugins/utility/{object-pass-container-plugin.js → object-pass-container-plugin.ts} +101 -80
  144. package/shaders/fragment-toy/firework.js +1 -1
  145. package/shaders/fragment-toy/singularity.js +5 -2
  146. package/terrain-plugin.mmd +83 -0
  147. package/tests/Math/arc-sampling-test.js +367 -0
  148. package/tests/Math/arc-sampling-test.ts +429 -0
  149. package/tests/Math/arc.test.ts +77 -0
  150. package/tests/Math/junction/arc-limit.test.ts +7 -0
  151. package/tests/Math/junction/arc-plane-points.test.ts +196 -0
  152. package/tests/Math/junction/arc-plane.test.ts +172 -0
  153. package/tests/Math/junction/line-sphere.test.ts +127 -0
  154. package/tests/Math/junction/plane-plane.test.ts +91 -0
  155. package/tests/Math/plane-test.ts +17 -0
  156. package/tests/Math/plane.test.ts +43 -0
  157. package/tests/Math/vec3.test.ts +33 -0
  158. package/tracks/point-heat-map/adaptors/timetracksplugin-format-to-this.js +78 -63
  159. package/tracks/point-heat-map/index.js +0 -1
  160. package/tracks/point-heat-map/plugin-webworker.js +148 -121
  161. package/tracks/point-heat-map/point-to-heat-map-flow.js +150 -121
  162. package/tracks/point-heat-map/readme.md +15 -0
  163. package/tracks/point-tracks/key-methods.js +3 -2
  164. package/tracks/point-tracks/plugin.js +487 -393
  165. package/tracks/timetracks/adaptors-line-strip.js +79 -65
  166. package/tracks/timetracks/plugin-line-strip.js +295 -240
  167. package/tracks/timetracks/program-line-strip.js +495 -411
  168. package/tracks/timetracks/programpoint-line-strip.js +137 -109
  169. package/tracks/timetracks/readme.md +1 -0
  170. package/tsconfig.json +22 -0
  171. package/types/@pirireis/webglobe.d.ts +102 -0
  172. package/types/delaunator.d.ts +40 -0
  173. package/types/earcut.d.ts +11 -0
  174. package/types/rbush.d.ts +57 -0
  175. package/types.ts +319 -0
  176. package/util/account/bufferoffsetmanager.js +209 -176
  177. package/util/account/create-buffermap-orchastration.ts +85 -0
  178. package/util/account/index.js +6 -3
  179. package/util/account/single-attribute-buffer-management/{buffer-manager.js → buffer-manager.ts} +151 -117
  180. package/util/account/single-attribute-buffer-management/{buffer-orchestrator.js → buffer-orchestrator.ts} +238 -212
  181. package/util/account/single-attribute-buffer-management/{buffer-orchestrator1.js → buffer-orchestrator1.ts} +184 -159
  182. package/util/account/single-attribute-buffer-management/{index.js → index.ts} +11 -4
  183. package/util/account/single-attribute-buffer-management/{object-store.js → object-store.ts} +76 -55
  184. package/util/account/single-attribute-buffer-management/types.ts +43 -0
  185. package/util/account/util.js +22 -18
  186. package/util/algorithms/index.js +0 -1
  187. package/util/algorithms/search-binary.js +26 -25
  188. package/util/build-strategy/{static-dynamic.js → static-dynamic.ts} +50 -41
  189. package/util/check/index.js +0 -1
  190. package/util/check/typecheck.ts +74 -0
  191. package/util/{frame-counter-trigger.js → frame-counter-trigger.ts} +99 -84
  192. package/util/geometry/{index.js → index.ts} +155 -121
  193. package/util/gl-util/buffer/{attribute-loader.js → attribute-loader.ts} +84 -62
  194. package/util/gl-util/buffer/{index.js → index.ts} +6 -3
  195. package/util/gl-util/draw-options/{methods.js → methods.ts} +47 -32
  196. package/util/gl-util/uniform-block/{manager.js → manager.ts} +232 -190
  197. package/util/{webglobe/gldefaultstates.js → globe-default-gl-states.ts} +5 -4
  198. package/util/helper-methods.ts +9 -0
  199. package/util/index.js +9 -10
  200. package/util/interpolation/index.js +0 -1
  201. package/util/interpolation/timetrack/index.js +9 -2
  202. package/util/interpolation/timetrack/timetrack-interpolator.js +94 -79
  203. package/util/interpolation/timetrack/web-worker.js +51 -46
  204. package/util/picking/{fence.js → fence.ts} +47 -41
  205. package/util/picking/picker-displayer.ts +226 -0
  206. package/util/programs/draw-from-pixel-coords.js +201 -164
  207. package/util/programs/{draw-texture-on-canvas.js → draw-texture-on-canvas.ts} +92 -67
  208. package/util/programs/supersampletotextures.js +130 -97
  209. package/util/programs/texturetoglobe.js +153 -128
  210. package/util/shaderfunctions/{geometrytransformations.js → geometrytransformations.ts} +169 -41
  211. package/util/shaderfunctions/index.js +2 -2
  212. package/util/shaderfunctions/nodata.js +4 -2
  213. package/util/shaderfunctions/noisefunctions.js +10 -7
  214. package/util/{webglobjectbuilders.js → webglobjectbuilders.ts} +446 -358
  215. package/vectorfield/arrowfield/adaptor.js +11 -11
  216. package/vectorfield/arrowfield/index.js +3 -3
  217. package/vectorfield/arrowfield/plugin.js +128 -83
  218. package/vectorfield/waveparticles/adaptor.js +16 -15
  219. package/vectorfield/waveparticles/index.js +3 -3
  220. package/vectorfield/waveparticles/plugin.ts +506 -0
  221. package/vectorfield/wind/adapters/image-to-fields.ts +74 -0
  222. package/vectorfield/wind/adapters/types.ts +12 -0
  223. package/vectorfield/wind/{imagetovectorfieldandmagnitude.js → imagetovectorfieldandmagnitude.ts} +78 -56
  224. package/vectorfield/wind/index.js +5 -5
  225. package/vectorfield/wind/plugin-persistant copy.ts +461 -0
  226. package/vectorfield/wind/plugin-persistant.ts +483 -0
  227. package/vectorfield/wind/plugin.js +883 -671
  228. package/vectorfield/wind/vectorfieldimage.js +27 -23
  229. package/write-text/{context-text-bulk.js → context-text-bulk.ts} +285 -200
  230. package/write-text/context-text3.ts +252 -0
  231. package/write-text/{context-text4.js → context-text4.ts} +231 -145
  232. package/write-text/context-textDELETE.js +125 -94
  233. package/write-text/objectarraylabels/{index.js → index.ts} +2 -2
  234. package/write-text/objectarraylabels/objectarraylabels.d.ts +72 -0
  235. package/write-text/objectarraylabels/objectarraylabels.js +247 -200
  236. package/Math/matrix4.js +0 -1
  237. package/Math/tessellation/earcut/adapters.js +0 -37
  238. package/Math/tessellation/hybrid-triangle-tessellation-meta.js +0 -123
  239. package/Math/tessellation/methods.js +0 -46
  240. package/Math/tessellation/shred-input.js +0 -18
  241. package/Math/tessellation/tile-merger.js +0 -56
  242. package/Math/tessellation/tiler.js +0 -50
  243. package/Math/tessellation/triangle-tessellation-meta.js +0 -516
  244. package/Math/tessellation/triangle-tessellation.js +0 -14
  245. package/Math/tessellation/types.js +0 -1
  246. package/Math/tessellation/zoom-catch.js +0 -1
  247. package/Math/types.js +0 -1
  248. package/programs/line-on-globe/linestrip/data.js +0 -4
  249. package/programs/polygon-on-globe/partial-tesselation.js +0 -1
  250. package/programs/polygon-on-globe/texture-dem-triangle-test-plugin-triangle.js +0 -204
  251. package/programs/polygon-on-globe/texture-dem-triangle-test-plugin.js +0 -118
  252. package/programs/polygon-on-globe/texture-dem-triangles.js +0 -236
  253. package/programs/vectorfields/logics/drawrectangleparticles.js +0 -112
  254. package/programs/vectorfields/logics/ubo-new.js +0 -25
  255. package/range-tools-on-terrain/bearing-line/types.js +0 -1
  256. package/range-tools-on-terrain/circle-line-chain/types.js +0 -1
  257. package/range-tools-on-terrain/range-ring/rangeringangletext.js +0 -331
  258. package/range-tools-on-terrain/range-ring/types.js +0 -9
  259. package/semiplugins/interface.js +0 -1
  260. package/semiplugins/shape-on-terrain/terrain-cover/texture-dem-cover.js +0 -1
  261. package/semiplugins/shell/bbox-renderer/index.js +0 -2
  262. package/semiplugins/shell/bbox-renderer/object.js +0 -65
  263. package/semiplugins/type.js +0 -1
  264. package/types.js +0 -19
  265. package/util/account/create-buffermap-orchastration.js +0 -39
  266. package/util/account/single-attribute-buffer-management/types.js +0 -1
  267. package/util/check/typecheck.js +0 -66
  268. package/util/gl-util/uniform-block/types.js +0 -1
  269. package/util/picking/picker-displayer.js +0 -134
  270. package/util/webglobe/index.js +0 -2
  271. package/util/webglobe/rasteroverlay.js +0 -76
  272. package/vectorfield/waveparticles/plugin.js +0 -290
  273. package/write-text/attached-text-writer.js +0 -95
  274. package/write-text/context-text3.js +0 -167
@@ -1,221 +1,342 @@
1
- import { LineOnGlobeCache } from "../../programs/line-on-globe/naive-accurate-flexible";
2
- import { BufferOrchestrator } from "../../util/account/single-attribute-buffer-management/buffer-orchestrator";
3
- import { BufferManager } from "../../util/account/single-attribute-buffer-management/buffer-manager";
4
- import { sphereCoord } from "../../util/geometry/index";
5
- import { constraintFloat } from "../../util/check/typecheck";
6
- export class LinePlugin {
7
- id;
8
- globe = null;
9
- gl = null;
10
- program = null;
11
- vao = null;
12
- _options;
13
- _uboHandler = null;
14
- bufferOrchestrator;
15
- bufferManagersMap = new Map();
16
- _freed = false;
17
- constructor(id, { flatViewOn = true, globeViewOn = true, variativeColorsOn = false, defaultColor = [1, 1, 1, 1], dashedLineOpacityVariativeOn = false, dashedLineRatioVariativeOn = false, bufferType = "DYNAMIC_DRAW", opacity = 1.0, initialCapacity = 10 } = {}) {
18
- this.id = id;
19
- this._options = {
20
- flatViewOn: flatViewOn ?? true,
21
- globeViewOn: globeViewOn ?? true,
22
- variativeColorsOn: variativeColorsOn ?? false,
23
- defaultColor: defaultColor ?? [1, 1, 1, 1],
24
- dashedLineOpacityVariativeOn: dashedLineOpacityVariativeOn ?? false,
25
- dashedLineRatioVariativeOn: dashedLineRatioVariativeOn ?? false,
26
- bufferType: bufferType ?? "DYNAMIC_DRAW",
27
- opacity: opacity ?? 1.0,
28
- initialCapacity: initialCapacity ?? 10
29
- };
30
- this.bufferOrchestrator = new BufferOrchestrator({ capacity: initialCapacity ?? 10 });
31
- }
32
- init(globe, gl) {
33
- this.globe = globe;
34
- this.gl = gl;
35
- this.program = LineOnGlobeCache.get(globe);
36
- this._uboHandler = this.program.createUBO();
37
- this.setDefaultColor(this._options.defaultColor);
38
- this._fillManagerMap();
39
- this.vao = this.program.createVAO(...this._createSelectBufferNames().map((key) => {
40
- if (key === null) {
41
- return null;
42
- }
43
- const bufferManagerComp = this.bufferManagersMap.get(key);
44
- if (bufferManagerComp === undefined) {
45
- throw new Error(`Buffer key ${key} does not exist in bufferManagersMap`);
46
- }
47
- const { bufferManager } = bufferManagerComp;
48
- return {
49
- stride: 0,
50
- offset: 0,
51
- buffer: bufferManager.buffer
52
- };
53
- }));
54
- }
55
- // PLUGIN INTERFACE METHODS
56
- increaseSpace(amount) {
57
- if (this._freed) {
58
- console.warn("Plugin is freed, cannot increase space");
59
- return;
60
- }
61
- if (this.globe === null) {
62
- console.warn("Globe is not initialized.");
63
- return;
64
- }
65
- if (typeof amount !== "number" || amount <= 0) {
66
- console.warn("Invalid amount, must be a positive number");
67
- return;
68
- }
69
- this.bufferOrchestrator.ensureSpace(amount, this.bufferManagersMap);
70
- }
71
- insertBulk(items) {
72
- const { bufferOrchestrator, bufferManagersMap, globe } = this;
73
- if (!bufferOrchestrator || !globe) {
74
- throw new Error("Buffer orchestrator or globe is not initialized.");
75
- }
76
- bufferOrchestrator.insertBulk(items, bufferManagersMap);
77
- this.globe?.DrawRender();
78
- }
79
- deleteBulk(keys) {
80
- const { bufferOrchestrator, bufferManagersMap, globe } = this;
81
- if (!bufferOrchestrator || !globe) {
82
- throw new Error("Buffer orchestrator or globe is not initialized.");
83
- }
84
- bufferOrchestrator.deleteBulk(keys, bufferManagersMap);
85
- this.globe?.DrawRender();
86
- }
87
- setPluginOpacity(opacity, drawRender = false) {
88
- constraintFloat(opacity, 0, 1);
89
- this._options.opacity = opacity;
90
- if (drawRender) {
91
- this.globe?.DrawRender();
92
- }
93
- }
94
- setPluginDashedLineRatio(ratio) {
95
- constraintFloat(ratio, 0, 1);
96
- this._uboHandler?.updateSingle("dashed_line_ratio", new Float32Array([ratio]));
97
- this.globe?.DrawRender();
98
- }
99
- setPluginDashLineOpacity(opacity) {
100
- constraintFloat(opacity, 0, 1);
101
- this._options.dashedLineOpacityVariativeOn = true;
102
- this._options.defaultColor[3] = opacity; // Update the default color's alpha channel
103
- this.globe?.DrawRender();
104
- }
105
- setDefaultColor(color, drawRender = false) {
106
- if (!this.globe || !this.gl) {
107
- console.warn("Globe or WebGL context is not initialized.");
108
- return;
109
- }
110
- this._options.defaultColor = color;
111
- this._uboHandler?.updateSingle("u_color", new Float32Array(color));
112
- if (drawRender) {
113
- this.globe.DrawRender();
114
- }
115
- }
116
- updateCoordinates(items) {
117
- throw new Error("Method not implemented.");
118
- }
119
- // GLOBE INTERACTION METHODS
120
- draw3D() {
121
- if (this._freed) {
122
- console.warn("Plugin has been freed, cannot draw.");
123
- }
124
- ;
125
- if (!this.globe || !this.gl || !this.program || !this.vao) {
126
- throw new Error("Globe, GL context or program is not initialized.");
127
- }
128
- const { bufferOrchestrator, _options, _uboHandler, vao } = this;
129
- if (!bufferOrchestrator || !bufferOrchestrator || !_uboHandler) {
130
- throw new Error("Buffer orchestrator is not initialized.");
131
- }
132
- const { flatViewOn, globeViewOn, opacity } = _options;
133
- const drawOptions = {
134
- drawRange: {
135
- first: 0,
136
- count: bufferOrchestrator.length
137
- }
138
- };
139
- this.gl.disable(this.gl.DEPTH_TEST); // Disable depth test for lines
140
- const currentGeometry = this.globe.api_GetCurrentGeometry();
141
- if (currentGeometry === 0 && globeViewOn) {
142
- // @ts-ignore
143
- this.program.draw(vao, drawOptions, opacity, _uboHandler);
144
- }
145
- else if (currentGeometry === 1 && flatViewOn) {
146
- // @ts-ignore
147
- this.program.draw(vao, drawOptions, opacity, _uboHandler);
148
- }
149
- this.gl.enable(this.gl.DEPTH_TEST); // Re-enable depth test after drawing
150
- }
151
- free() {
152
- if (this._freed)
153
- return;
154
- // TODO: FILL
155
- this.bufferManagersMap.forEach((manager) => {
156
- manager.bufferManager.free();
157
- });
158
- this._uboHandler?.free();
159
- LineOnGlobeCache.release(this.globe);
160
- this._freed = true;
161
- }
162
- // IMPLICIT INTERFACE METHODS
163
- _fillManagerMap() {
164
- const globe = this.globe;
165
- const { flatViewOn, globeViewOn, variativeColorsOn, dashedLineOpacityVariativeOn, dashedLineRatioVariativeOn, bufferType = "DYNAMIC_DRAW" } = this._options;
166
- const m = this.bufferManagersMap;
167
- if (flatViewOn) {
168
- m.set("start_position", {
169
- bufferManager: new BufferManager(globe.gl, 2, { bufferType, initialCapacity: this._options.initialCapacity }),
170
- adaptor: (item) => {
171
- const result = new Float32Array(globe.api_GetMercator2DPoint(item.start[0], item.start[1]));
172
- return result;
173
- }
174
- });
175
- m.set("end_position", {
176
- bufferManager: new BufferManager(globe.gl, 2, { bufferType, initialCapacity: this._options.initialCapacity }),
177
- adaptor: (item) => new Float32Array(globe.api_GetMercator2DPoint(item.end[0], item.end[1]))
178
- });
179
- }
180
- if (globeViewOn) {
181
- m.set("start_position_3d", {
182
- bufferManager: new BufferManager(globe.gl, 3, { bufferType, initialCapacity: this._options.initialCapacity }),
183
- adaptor: (item) => sphereCoord(item.start[0], item.start[1], globe, item.start_altitude || 0)
184
- });
185
- m.set("end_position_3d", {
186
- bufferManager: new BufferManager(globe.gl, 3, { bufferType, initialCapacity: this._options.initialCapacity }),
187
- adaptor: (item) => sphereCoord(item.end[0], item.end[1], globe, item.end_altitude || 0)
188
- });
189
- }
190
- if (variativeColorsOn) {
191
- m.set("color", {
192
- bufferManager: new BufferManager(globe.gl, 4, { bufferType, initialCapacity: this._options.initialCapacity }),
193
- adaptor: (item) => new Float32Array(item.color !== undefined ? item.color : [-1, -1, -1, -1])
194
- });
195
- }
196
- if (dashedLineOpacityVariativeOn) {
197
- m.set("dashed_line_opacity", {
198
- bufferManager: new BufferManager(globe.gl, 1, { bufferType, initialCapacity: this._options.initialCapacity }),
199
- adaptor: (item) => new Float32Array(item.dashed_line_opacity !== undefined ? [item.dashed_line_opacity] : [-1])
200
- });
201
- }
202
- if (dashedLineRatioVariativeOn) {
203
- m.set("dashed_line_ratio", {
204
- bufferManager: new BufferManager(globe.gl, 1, { bufferType, initialCapacity: this._options.initialCapacity }),
205
- adaptor: (item) => new Float32Array(item.dashed_line_ratio !== undefined ? [item.dashed_line_ratio] : [-1])
206
- });
207
- }
208
- }
209
- _createSelectBufferNames() {
210
- const { flatViewOn, globeViewOn, variativeColorsOn, dashedLineOpacityVariativeOn, dashedLineRatioVariativeOn } = this._options;
211
- return [
212
- flatViewOn ? "start_position" : null,
213
- globeViewOn ? "start_position_3d" : null,
214
- flatViewOn ? "end_position" : null,
215
- globeViewOn ? "end_position_3d" : null,
216
- dashedLineOpacityVariativeOn ? "dashed_line_opacity" : null,
217
- dashedLineRatioVariativeOn ? "dashed_line_ratio" : null,
218
- variativeColorsOn ? "color" : null
219
- ];
220
- }
221
- }
1
+ import { SemiPluginInterface } from "../interface";
2
+ import { LineOnGlobeCache } from "../../programs/line-on-globe/naive-accurate-flexible";
3
+ import { PluginStyleOptions } from "../type";
4
+ import { Globe, ProgramInterface, PluginInterface, Color, BUFFER_TYPE, LongLatRadian } from "../../types";
5
+
6
+
7
+
8
+ import { BufferOrchestrator } from "../../util/account/single-attribute-buffer-management/buffer-orchestrator";
9
+ import { BufferManager } from "../../util/account/single-attribute-buffer-management/buffer-manager";
10
+ import { BufferManagersMap } from "../../util/account/single-attribute-buffer-management/types";
11
+
12
+ import { UBOHandler } from "../../types";
13
+
14
+ import { sphereCoord } from "../../util/geometry/index";
15
+ import { constraintFloat } from "../../util/check/typecheck";
16
+ import { BufferAndReadInfo } from "../../types";
17
+
18
+ /**
19
+ * This plugin is lightweight. Processes and memories minimal data. Sacrifices details.
20
+ * Only two points to draw a line in 2D and an Arc in 3D.
21
+ * The 3D arc does not fit the terrain!
22
+ * The 2D line is straight, not great circle projection
23
+ */
24
+
25
+ export type LineInput = {
26
+ key: string; // Unique key for the line
27
+ start: LongLatRadian; // Start position
28
+ start_altitude?: number; // Start altitude, default is 0
29
+ end: LongLatRadian; // End position
30
+ end_altitude?: number; // End altitude, default is 0
31
+ color?: Color; // Color of the line
32
+ dashed_line_opacity?: number; // Proportion of the opacity of the dashed line
33
+ dashed_line_ratio?: number; // Ratio of the dashed line
34
+ }
35
+
36
+ export type LinePluginOptions = PluginStyleOptions & {
37
+
38
+ flatViewOn: boolean; // If true, the line will be drawn in flat view.
39
+ globeViewOn: boolean; // If true, the line will be drawn in globe view.
40
+ variativeColorsOn: boolean; // If true, the color will be variative based on the circle's radius.
41
+ defaultColor: Color; // Default color of the line.
42
+ dashedLineOpacityVariativeOn: boolean; // If true, the line will be dashed.
43
+ dashedLineRatioVariativeOn: boolean; // If true, the dashed line ratio will be variative based on the circle's radius.
44
+ bufferType: BUFFER_TYPE; // Buffer draw type, default is DYNAMIC_DRAW
45
+ opacity: number; // Opacity of the line, default is 1.0
46
+ initialCapacity: number;
47
+
48
+ }
49
+
50
+ export class LinePlugin implements PluginInterface, SemiPluginInterface {
51
+ id: string;
52
+ globe: Globe | null = null;
53
+ private gl: WebGL2RenderingContext | null = null;
54
+ private program: ProgramInterface | null = null;
55
+ private vao: WebGLVertexArrayObject | null = null;
56
+ private _options: LinePluginOptions;
57
+ private _uboHandler: UBOHandler | null = null;
58
+ private bufferOrchestrator: BufferOrchestrator;
59
+ private bufferManagersMap: BufferManagersMap = new Map();
60
+ private _freed: boolean = false;
61
+
62
+ constructor(id: string, {
63
+ flatViewOn = true,
64
+ globeViewOn = true,
65
+ variativeColorsOn = false,
66
+ defaultColor = [1, 1, 1, 1],
67
+ dashedLineOpacityVariativeOn = false,
68
+ dashedLineRatioVariativeOn = false,
69
+ bufferType = "DYNAMIC_DRAW",
70
+ opacity = 1.0,
71
+ initialCapacity = 10
72
+ }: Partial<LinePluginOptions> = {}) {
73
+ this.id = id;
74
+ this._options = {
75
+ flatViewOn: flatViewOn ?? true,
76
+ globeViewOn: globeViewOn ?? true,
77
+ variativeColorsOn: variativeColorsOn ?? false,
78
+ defaultColor: defaultColor ?? [1, 1, 1, 1],
79
+ dashedLineOpacityVariativeOn: dashedLineOpacityVariativeOn ?? false,
80
+ dashedLineRatioVariativeOn: dashedLineRatioVariativeOn ?? false,
81
+ bufferType: bufferType ?? "DYNAMIC_DRAW",
82
+ opacity: opacity ?? 1.0,
83
+ initialCapacity: initialCapacity ?? 10
84
+ };
85
+ this.bufferOrchestrator = new BufferOrchestrator({ capacity: initialCapacity ?? 10 });
86
+ }
87
+
88
+
89
+ init(globe: Globe, gl: WebGL2RenderingContext): void {
90
+ this.globe = globe;
91
+ this.gl = gl;
92
+
93
+ this.program = LineOnGlobeCache.get(globe) as ProgramInterface;
94
+
95
+ this._uboHandler = this.program.createUBO() as UBOHandler;
96
+ this.setDefaultColor(this._options.defaultColor);
97
+
98
+
99
+ this._fillManagerMap();
100
+
101
+
102
+ this.vao = this.program.createVAO(
103
+ ...this._createSelectBufferNames().map((key) => {
104
+ if (key === null) {
105
+ return null;
106
+ }
107
+ const bufferManagerComp = this.bufferManagersMap.get(key);
108
+ if (bufferManagerComp === undefined) {
109
+ throw new Error(`Buffer key ${key} does not exist in bufferManagersMap`);
110
+ }
111
+ const { bufferManager } = bufferManagerComp;
112
+ return {
113
+ stride: 0,
114
+ offset: 0,
115
+ buffer: bufferManager.buffer as WebGLBuffer
116
+ } as BufferAndReadInfo;
117
+ })
118
+ );
119
+
120
+ }
121
+
122
+ // PLUGIN INTERFACE METHODS
123
+
124
+
125
+
126
+ increaseSpace(amount: number): void {
127
+ if (this._freed) {
128
+ console.warn("Plugin is freed, cannot increase space");
129
+ return;
130
+ }
131
+ if (this.globe === null) {
132
+ console.warn("Globe is not initialized.");
133
+ return;
134
+ }
135
+ if (typeof amount !== "number" || amount <= 0) {
136
+ console.warn("Invalid amount, must be a positive number");
137
+ return;
138
+ }
139
+ this.bufferOrchestrator.ensureSpace(amount, this.bufferManagersMap!);
140
+ }
141
+
142
+
143
+ insertBulk(items: Array<LineInput>): void {
144
+ const { bufferOrchestrator, bufferManagersMap, globe } = this;
145
+ if (!bufferOrchestrator || !globe) {
146
+ throw new Error("Buffer orchestrator or globe is not initialized.");
147
+ }
148
+ bufferOrchestrator.insertBulk(items, bufferManagersMap);
149
+ this.globe?.DrawRender();
150
+ }
151
+
152
+ deleteBulk(keys: Array<string>): void {
153
+ const { bufferOrchestrator, bufferManagersMap, globe } = this;
154
+ if (!bufferOrchestrator || !globe) {
155
+ throw new Error("Buffer orchestrator or globe is not initialized.");
156
+ }
157
+ bufferOrchestrator.deleteBulk(keys, bufferManagersMap);
158
+ this.globe?.DrawRender();
159
+ }
160
+
161
+
162
+ setPluginOpacity(opacity: number, drawRender: boolean = false): void {
163
+ constraintFloat(opacity, 0, 1);
164
+ this._options.opacity = opacity;
165
+ if (drawRender) {
166
+ this.globe?.DrawRender();
167
+ }
168
+ }
169
+
170
+ setPluginDashedLineRatio(ratio: number): void {
171
+ constraintFloat(ratio, 0, 1);
172
+ this._uboHandler?.updateSingle("dashed_line_ratio", new Float32Array([ratio]));
173
+ this.globe?.DrawRender();
174
+ }
175
+
176
+ setPluginDashLineOpacity(opacity: number): void {
177
+ constraintFloat(opacity, 0, 1);
178
+ this._options.dashedLineOpacityVariativeOn = true;
179
+ this._options.defaultColor[3] = opacity; // Update the default color's alpha channel
180
+ this.globe?.DrawRender();
181
+ }
182
+
183
+
184
+
185
+ setDefaultColor(color: Color, drawRender: boolean = false): void {
186
+ if (!this.globe || !this.gl) {
187
+ console.warn("Globe or WebGL context is not initialized.");
188
+ return;
189
+ }
190
+ this._options.defaultColor = color;
191
+ this._uboHandler?.updateSingle("u_color", new Float32Array(color));
192
+ if (drawRender) {
193
+ this.globe.DrawRender();
194
+ }
195
+ }
196
+
197
+
198
+
199
+ updateCoordinates(items: Pick<LineInput, "key" | "start" | "end">[]): void {
200
+ throw new Error("Method not implemented.");
201
+ }
202
+ // GLOBE INTERACTION METHODS
203
+
204
+ draw3D(): void {
205
+ if (this._freed) {
206
+ console.warn("Plugin has been freed, cannot draw.");
207
+ };
208
+
209
+ if (!this.globe || !this.gl || !this.program || !this.vao) {
210
+ throw new Error("Globe, GL context or program is not initialized.");
211
+ }
212
+
213
+ const { bufferOrchestrator, _options, _uboHandler, vao } = this;
214
+ if (!bufferOrchestrator || !bufferOrchestrator || !_uboHandler) {
215
+ throw new Error("Buffer orchestrator is not initialized.");
216
+ }
217
+
218
+ const { flatViewOn, globeViewOn, opacity } = _options;
219
+
220
+ const drawOptions = {
221
+ drawRange: {
222
+ first: 0,
223
+ count: bufferOrchestrator.length
224
+ }
225
+ }
226
+ this.gl.disable(this.gl.DEPTH_TEST); // Disable depth test for lines
227
+ const currentGeometry = this.globe.api_GetCurrentGeometry();
228
+ if (currentGeometry === 0 && globeViewOn) {
229
+ // @ts-ignore
230
+ this.program.draw(vao, drawOptions, opacity, _uboHandler)
231
+ } else if (currentGeometry === 1 && flatViewOn) {
232
+ // @ts-ignore
233
+ this.program.draw(vao, drawOptions, opacity, _uboHandler);
234
+ }
235
+ this.gl.enable(this.gl.DEPTH_TEST); // Re-enable depth test after drawing
236
+ }
237
+
238
+
239
+ free(): void {
240
+ if (this._freed) return;
241
+ // TODO: FILL
242
+
243
+ this.bufferManagersMap.forEach((manager) => {
244
+ manager.bufferManager.free();
245
+ });
246
+ this._uboHandler?.free();
247
+ LineOnGlobeCache.release(this.globe as Globe);
248
+ this._freed = true;
249
+ }
250
+
251
+
252
+
253
+ // IMPLICIT INTERFACE METHODS
254
+
255
+ _fillManagerMap(): void {
256
+ const globe = this.globe as Globe;
257
+
258
+ const {
259
+ flatViewOn,
260
+ globeViewOn,
261
+ variativeColorsOn,
262
+ dashedLineOpacityVariativeOn,
263
+ dashedLineRatioVariativeOn,
264
+ bufferType = "DYNAMIC_DRAW"
265
+ } = this._options;
266
+
267
+ const m = this.bufferManagersMap;
268
+
269
+ if (flatViewOn) {
270
+ m.set("start_position",
271
+ {
272
+ bufferManager: new BufferManager(globe.gl, 2, { bufferType, initialCapacity: this._options.initialCapacity }),
273
+ adaptor: (item: LineInput) => {
274
+ const result = new Float32Array(globe.api_GetMercator2DPoint(item.start[0], item.start[1]))
275
+ return result;
276
+ }
277
+ });
278
+ m.set("end_position", {
279
+ bufferManager: new BufferManager(globe.gl, 2, { bufferType, initialCapacity: this._options.initialCapacity }),
280
+ adaptor: (item: LineInput) => new Float32Array(globe.api_GetMercator2DPoint(item.end[0], item.end[1]))
281
+ });
282
+ }
283
+
284
+ if (globeViewOn) {
285
+ m.set("start_position_3d", {
286
+ bufferManager: new BufferManager(globe.gl, 3, { bufferType, initialCapacity: this._options.initialCapacity }),
287
+ adaptor: (item: LineInput) => sphereCoord(item.start[0], item.start[1], globe, item.start_altitude || 0)
288
+ });
289
+
290
+ m.set("end_position_3d", {
291
+ bufferManager: new BufferManager(globe.gl, 3, { bufferType, initialCapacity: this._options.initialCapacity }),
292
+ adaptor: (item: LineInput) => sphereCoord(item.end[0], item.end[1], globe, item.end_altitude || 0)
293
+
294
+ });
295
+ }
296
+
297
+ if (variativeColorsOn) {
298
+ m.set("color", {
299
+ bufferManager: new BufferManager(globe.gl, 4, { bufferType, initialCapacity: this._options.initialCapacity }),
300
+ adaptor: (item: LineInput) => new Float32Array(item.color !== undefined ? item.color : [-1, -1, -1, -1])
301
+ });
302
+ }
303
+
304
+ if (dashedLineOpacityVariativeOn) {
305
+ m.set("dashed_line_opacity", {
306
+ bufferManager: new BufferManager(globe.gl, 1, { bufferType, initialCapacity: this._options.initialCapacity }),
307
+ adaptor: (item: LineInput) => new Float32Array(item.dashed_line_opacity !== undefined ? [item.dashed_line_opacity] : [-1])
308
+ });
309
+ }
310
+
311
+ if (dashedLineRatioVariativeOn) {
312
+ m.set("dashed_line_ratio", {
313
+ bufferManager: new BufferManager(globe.gl, 1, { bufferType, initialCapacity: this._options.initialCapacity }),
314
+ adaptor: (item: LineInput) => new Float32Array(item.dashed_line_ratio !== undefined ? [item.dashed_line_ratio] : [-1])
315
+ });
316
+ }
317
+
318
+ }
319
+
320
+
321
+ _createSelectBufferNames(): Array<string | null> {
322
+ const {
323
+ flatViewOn,
324
+ globeViewOn,
325
+ variativeColorsOn,
326
+ dashedLineOpacityVariativeOn,
327
+ dashedLineRatioVariativeOn
328
+ } = this._options;
329
+
330
+ return [
331
+ flatViewOn ? "start_position" : null,
332
+ globeViewOn ? "start_position_3d" : null,
333
+ flatViewOn ? "end_position" : null,
334
+ globeViewOn ? "end_position_3d" : null,
335
+ dashedLineOpacityVariativeOn ? "dashed_line_opacity" : null,
336
+ dashedLineRatioVariativeOn ? "dashed_line_ratio" : null,
337
+ variativeColorsOn ? "color" : null
338
+ ]
339
+ }
340
+
341
+ }
342
+