@pirireis/webglobeplugins 0.17.1 → 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 (272) 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 -113
  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.js → tiles.ts} +162 -128
  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 -481
  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 -394
  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 -685
  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 -146
  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 -298
  242. package/Math/tessellation/tiler.js +0 -50
  243. package/Math/tessellation/triangle-tessellation-meta.js +0 -523
  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/investigation-tools/draw/tiles/adapters.js +0 -67
  249. package/programs/line-on-globe/linestrip/data.js +0 -4
  250. package/programs/polygon-on-globe/texture-dem-triangle-test-plugin-triangle.js +0 -328
  251. package/programs/polygon-on-globe/texture-dem-triangles.js +0 -268
  252. package/programs/vectorfields/logics/drawrectangleparticles.js +0 -114
  253. package/programs/vectorfields/logics/drawrectangleparticles1.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/vectorfield/waveparticles/plugin.js +0 -290
  272. package/write-text/context-text3.js +0 -167
@@ -1,457 +1,569 @@
1
- import { ContextTextWriter3 } from "../../write-text/context-text3";
2
- import { flatLinesInputAdapter, flatLinesBearingInputAdapter, bearingLineToCircleInputAdapter, bearingLineToArcInputAdapter, bearingLineToBearingArcInputAdapter, bearingLineToPieceOfPieInputAdapter, pieceOfPieOpacityAdaptor } from "./adapters";
3
- import { CircleOnTerrainPlugin } from "../../semiplugins/shape-on-terrain/circle-plugin";
4
- import { PieceOfPiePlugin } from "../../semiplugins/lightweight/piece-of-pie-plugin";
5
- import { ArcOnTerrainPlugin } from "../../semiplugins/shape-on-terrain/arc-plugin";
6
- import { LinePlugin } from "../../semiplugins/lightweight/line-plugin";
7
- export class BearingLinePlugin {
8
- id;
9
- globe = null;
10
- circlePlugin;
11
- arcPlugin;
12
- arcPluginBL;
13
- pieceOfPiePlugin;
14
- linePlugin;
15
- linePluginBL;
16
- _freed = false;
17
- _opacities = {
18
- general: 1,
19
- circle: 1,
20
- arc: 1,
21
- pie: 1,
22
- bearing: 1
23
- };
24
- _textWritersMap = new Map();
25
- _textDataPreAdaptor = (item) => item;
26
- drawOptions = {
27
- drawVRM: true,
28
- drawBearingLine: true,
29
- drawAngleRing: true,
30
- drawText: true,
31
- flatRealLineOn: true, // This is a new option to control flat real line drawing
32
- flatStraightLineOn: true // This is a new option to control flat straight line drawing
33
- };
34
- _memory = new Map();
35
- _semiPluginsOptions = {
36
- circleOnTerrainOptions: {
37
- defaultColor: [1, 1, 1, 0.5],
38
- defaultHeightFromGroundIn3D: 30.0,
39
- variativeColorsOn: false,
40
- isMSL: false
41
- },
42
- arcOnTerrainOptions: {
43
- defaultHeightFromGroundIn3D: 30.0,
44
- variativeColorsOn: false,
45
- defaultColor: [1, 1, 1, 0.5],
46
- globeViewOn: true,
47
- flatViewOn: false,
48
- isMSL: false
49
- },
50
- lineOptions: {
51
- flatViewOn: true,
52
- globeViewOn: true,
53
- variativeColorsOn: false,
54
- defaultColor: [1, 1, 1, 0.5],
55
- },
56
- pieceOfPieOptions: {
57
- defaultColor: [1, 1, 1, 0.5],
58
- variativeColorsOn: false,
59
- defaultHeightFromGroundIn3D: 1000.0,
60
- }
61
- };
62
- constructor(id, { textWritersMap, textDataPreAdaptor, opacities, drawOptions, circleOnTerrainOptions = {
63
- defaultColor: [1, 1, 1, 0.5],
64
- defaultHeightFromGroundIn3D: 30.0,
65
- variativeColorsOn: false,
66
- }, arcOnTerrainOptions = {
67
- globeViewOn: true,
68
- flatViewOn: false,
69
- defaultColor: [1, 1, 1, 0.5],
70
- defaultHeightFromGroundIn3D: 30.0,
71
- variativeColorsOn: false,
72
- }, lineOptions = {
73
- flatViewOn: true,
74
- globeViewOn: false,
75
- variativeColorsOn: false,
76
- defaultColor: [1, 1, 1, 0.5],
77
- }, pieceOfPieOptions = {
78
- defaultColor: [1, 1, 1, 0.5],
79
- variativeColorsOn: false,
80
- defaultHeightFromGroundIn3D: 1000.0,
81
- } } = {}) {
82
- this.id = id;
83
- if (!(textWritersMap instanceof Map))
84
- throw new Error("textWritersMap is not an instance of Map");
85
- textWritersMap.forEach((v) => {
86
- if (!(v instanceof ContextTextWriter3))
87
- throw new Error("textWritersMap element is not an instance of ContextTextWriter3");
88
- });
89
- if (circleOnTerrainOptions) {
90
- this._semiPluginsOptions.circleOnTerrainOptions = {
91
- ...this._semiPluginsOptions.circleOnTerrainOptions,
92
- ...circleOnTerrainOptions
93
- };
94
- }
95
- if (arcOnTerrainOptions) {
96
- this._semiPluginsOptions.arcOnTerrainOptions = {
97
- ...this._semiPluginsOptions.arcOnTerrainOptions,
98
- ...arcOnTerrainOptions
99
- };
100
- }
101
- if (lineOptions) {
102
- this._semiPluginsOptions.lineOptions = {
103
- ...this._semiPluginsOptions.lineOptions,
104
- ...lineOptions
105
- };
106
- }
107
- if (pieceOfPieOptions)
108
- this._semiPluginsOptions.pieceOfPieOptions = {
109
- ...this._semiPluginsOptions.pieceOfPieOptions,
110
- ...pieceOfPieOptions
111
- };
112
- this._textWritersMap = textWritersMap || new Map();
113
- this._textWritersMap.forEach((writer) => writer.setKeyAdaptor((item) => item.key));
114
- this._textDataPreAdaptor = textDataPreAdaptor || ((item) => item);
115
- this.circlePlugin = new CircleOnTerrainPlugin(id + "_circle", this._semiPluginsOptions.circleOnTerrainOptions);
116
- this.arcPlugin = new ArcOnTerrainPlugin(id + "_arc", {
117
- ...this._semiPluginsOptions.arcOnTerrainOptions,
118
- });
119
- this.arcPluginBL = new ArcOnTerrainPlugin(id + "_arcBL", {
120
- ...this._semiPluginsOptions.arcOnTerrainOptions,
121
- });
122
- this.pieceOfPiePlugin = new PieceOfPiePlugin(id + "_pieceOfPie", {
123
- bufferType: "DYNAMIC_DRAW",
124
- ...this._semiPluginsOptions.pieceOfPieOptions
125
- });
126
- this.linePlugin = new LinePlugin(id + "_line", {
127
- bufferType: "DYNAMIC_DRAW",
128
- ...this._semiPluginsOptions.lineOptions
129
- });
130
- this.linePluginBL = new LinePlugin(id + "_lineBL", {
131
- ...this._semiPluginsOptions.lineOptions // flatViewOn: true,
132
- });
133
- if (opacities) {
134
- this._opacities = {
135
- ...this._opacities,
136
- ...opacities,
137
- };
138
- }
139
- if (drawOptions) {
140
- this.drawOptions = {
141
- ...this.drawOptions,
142
- ...drawOptions
143
- };
144
- }
145
- }
146
- setDefaultSemiPluginColor(semiPluginName, color) {
147
- if (this._freed) {
148
- throw new Error("Plugin has been freed, cannot set default semi plugin color.");
149
- }
150
- if (!this.globe) {
151
- throw new Error("Globe is not set, cannot set default semi plugin color.");
152
- }
153
- if (semiPluginName === "ALL") {
154
- this.circlePlugin.setDefaultColor(color);
155
- this.arcPlugin.setDefaultColor(color);
156
- this.arcPluginBL.setDefaultColor(color);
157
- this.linePlugin.setDefaultColor(color);
158
- this.linePluginBL.setDefaultColor(color);
159
- this.pieceOfPiePlugin.setDefaultColor(color);
160
- return;
161
- }
162
- switch (semiPluginName) {
163
- case "circleOnTerrain":
164
- this.circlePlugin.setDefaultColor(color);
165
- break;
166
- case "arcOnTerrain":
167
- this.arcPlugin.setDefaultColor(color);
168
- break;
169
- case "line":
170
- this.linePlugin.setDefaultColor(color);
171
- break;
172
- case "pieceOfPie":
173
- this.pieceOfPiePlugin.setDefaultColor(color);
174
- break;
175
- default:
176
- throw new Error(`Unknown semi plugin name: ${semiPluginName}`);
177
- }
178
- }
179
- setDoDrawVRM(drawVRM) {
180
- if (this._freed) {
181
- throw new Error("Plugin has been freed, cannot set draw VRM.");
182
- }
183
- if (!this.globe) {
184
- throw new Error("Globe is not set, cannot set draw VRM.");
185
- }
186
- this.drawOptions.drawVRM = drawVRM;
187
- this.globe.DrawRender();
188
- }
189
- setDoDrawText(drawText) {
190
- if (this._freed) {
191
- throw new Error("Plugin has been freed, cannot set draw text.");
192
- }
193
- if (!this.globe) {
194
- throw new Error("Globe is not set, cannot set draw text.");
195
- }
196
- this.drawOptions.drawText = drawText;
197
- this.globe.DrawRender();
198
- }
199
- setDoDrawBearingLine(drawBearingLine) {
200
- if (this._freed) {
201
- throw new Error("Plugin has been freed, cannot set draw bearing line.");
202
- }
203
- if (!this.globe) {
204
- throw new Error("Globe is not set, cannot set draw bearing line.");
205
- }
206
- this.drawOptions.drawBearingLine = drawBearingLine;
207
- this.globe.DrawRender();
208
- }
209
- setDoDrawAngleRing(drawAngleRing) {
210
- if (this._freed) {
211
- throw new Error("Plugin has been freed, cannot set draw angle ring.");
212
- }
213
- if (!this.globe) {
214
- throw new Error("Globe is not set, cannot set draw angle ring.");
215
- }
216
- this.drawOptions.drawAngleRing = drawAngleRing;
217
- this.globe.DrawRender();
218
- }
219
- updatePartial(items, { textWriterIDs } = {}) {
220
- if (this._freed) {
221
- throw new Error("Plugin has been freed, cannot update item.");
222
- }
223
- if (!this.globe) {
224
- throw new Error("Globe is not set, cannot update item.");
225
- }
226
- const fixedItems = [];
227
- for (const item of items) {
228
- if (!this._memory.has(item.key)) {
229
- throw new Error(`Item with key ${item.key} not found in memory.`);
230
- }
231
- fixedItems.push(this.__memorizeItem(item));
232
- }
233
- this._build(fixedItems, { textWriterIDs });
234
- }
235
- setDrawOptions(drawOptions) {
236
- if (this._freed) {
237
- throw new Error("Plugin has been freed, cannot set draw options.");
238
- }
239
- if (!this.globe) {
240
- throw new Error("Globe is not set, cannot set draw options.");
241
- }
242
- this.drawOptions = {
243
- ...this.drawOptions,
244
- ...drawOptions
245
- };
246
- this.globe.DrawRender();
247
- }
248
- updateCoordinatesBulk(items, { textWriterIDs } = {}) {
249
- if (this._freed) {
250
- throw new Error("Plugin has been freed, cannot update coordinates.");
251
- }
252
- if (!this.globe) {
253
- throw new Error("Globe is not set, cannot update coordinates.");
254
- }
255
- const fixedItems = [];
256
- for (const item of items) {
257
- if (!this._memory.has(item.key)) {
258
- throw new Error(`Item with key ${item.key} not found in memory.`);
259
- }
260
- else {
261
- fixedItems.push(this.__memorizeItem(item));
262
- }
263
- }
264
- this._build(fixedItems, { textWriterIDs });
265
- }
266
- setOpacities(opacities) {
267
- if (this._freed) {
268
- throw new Error("Plugin has been freed, cannot set opacities.");
269
- }
270
- if (!this.globe) {
271
- throw new Error("Globe is not set, cannot set opacities.");
272
- }
273
- this._opacities = {
274
- ...this._opacities,
275
- ...opacities,
276
- };
277
- this.globe.DrawRender();
278
- }
279
- insertBulk(items, { textWriterIDs } = {}) {
280
- this._build(items, { textWriterIDs });
281
- }
282
- deleteBulk(keys) {
283
- if (this._freed) {
284
- throw new Error("Plugin has been freed, cannot delete items.");
285
- }
286
- if (!this.globe) {
287
- throw new Error("Globe is not set, cannot delete items.");
288
- }
289
- if (!this.circlePlugin || !this.arcPlugin) {
290
- throw new Error("Circle and Arc plugins are not initialized.");
291
- }
292
- this.circlePlugin.deleteBulk(keys);
293
- this.arcPlugin.deleteBulk(keys);
294
- this.arcPluginBL.deleteBulk(keys);
295
- this.pieceOfPiePlugin.deleteBulk(keys);
296
- this.linePlugin.deleteBulk(keys);
297
- this.linePluginBL.deleteBulk(keys);
298
- this.__deleteTexts(keys);
299
- this.globe.DrawRender();
300
- }
301
- updateText(textWriterIDs, itemKeys = null) {
302
- if (this._freed) {
303
- throw new Error("Plugin has been freed, cannot update text.");
304
- }
305
- const items = itemKeys ? itemKeys.map(key => this._memory.get(key)).filter(Boolean) : Array.from(this._memory.values());
306
- this.__insertTexts(items, textWriterIDs);
307
- }
308
- _calculateRadiusFromBearingLine(bearingLine) {
309
- const { long, lat, endLong, endLat } = bearingLine;
310
- // @ts-ignore
311
- bearingLine.radius = this.globe.Math.GetDist2D(long, lat, endLong, endLat);
312
- }
313
- __deleteTexts(keys) {
314
- if (this._freed) {
315
- throw new Error("Plugin has been freed, cannot delete texts.");
316
- }
317
- if (!this.globe) {
318
- throw new Error("Globe is not set, cannot delete texts.");
319
- }
320
- for (const textWriter of this._textWritersMap.values()) {
321
- textWriter.deleteTextBulk(keys);
322
- }
323
- keys.forEach(key => {
324
- this._memory.delete(key);
325
- });
326
- }
327
- __insertTexts(items, textWriterIDs = []) {
328
- if (this._freed) {
329
- throw new Error("Plugin has been freed, cannot insert texts.");
330
- }
331
- if (!this.globe) {
332
- throw new Error("Globe is not set, cannot insert texts.");
333
- }
334
- if (textWriterIDs.length === 0) {
335
- textWriterIDs = Array.from(this._textWritersMap.keys());
336
- }
337
- // check textWriterIDs
338
- for (const textWriterID of textWriterIDs) {
339
- const textWriter = this._textWritersMap.get(textWriterID);
340
- if (!textWriter) {
341
- throw new Error(`Text writer with ID ${textWriterID} not found.`);
342
- }
343
- }
344
- for (const textWriterID of textWriterIDs) {
345
- const textWriter = this._textWritersMap.get(textWriterID);
346
- if (textWriter) {
347
- textWriter.insertTextBulk(items.map(x => this._textDataPreAdaptor(x)), textWriterID);
348
- }
349
- }
350
- }
351
- __memorizeItem(item) {
352
- const oldItem = this._memory.get(item.key);
353
- let newItem = oldItem ? { ...oldItem, ...item } : item;
354
- this._memory.set(item.key, newItem);
355
- return newItem;
356
- }
357
- _build(items, { textWriterIDs } = {}) {
358
- if (this._freed) {
359
- throw new Error("Plugin has been freed, cannot update coordinates.");
360
- }
361
- if (!this.globe) {
362
- throw new Error("Globe is not set, cannot update coordinates.");
363
- }
364
- if (!this.circlePlugin || !this.arcPlugin) {
365
- throw new Error("Circle and Arc plugins are not initialized.");
366
- }
367
- items.forEach(item => {
368
- this._calculateRadiusFromBearingLine(item);
369
- });
370
- const processedItems = items.map((item) => this.__memorizeItem(item));
371
- // @ts-ignore
372
- const circleInputs = processedItems.map(bearingLineToCircleInputAdapter(this.globe));
373
- this.circlePlugin.insertBulk(circleInputs);
374
- const arcInputs = processedItems.map(bearingLineToArcInputAdapter);
375
- this.arcPlugin.insertBulk(arcInputs);
376
- // @ts-ignore
377
- const bearingArcInputs = processedItems.map((x) => bearingLineToBearingArcInputAdapter(this.globe, x));
378
- this.arcPluginBL.insertBulk(bearingArcInputs);
379
- this.__insertTexts(processedItems, textWriterIDs);
380
- // @ts-ignore
381
- const pieceOfPieInputs = processedItems.map((x) => bearingLineToPieceOfPieInputAdapter(this.globe, x));
382
- this.pieceOfPiePlugin.insertBulk(pieceOfPieInputs);
383
- // line inputs
384
- const lineInputs = processedItems.map(flatLinesInputAdapter);
385
- this.linePlugin.insertBulk(lineInputs);
386
- const lineInputsBL = processedItems.map(flatLinesBearingInputAdapter);
387
- this.linePluginBL.insertBulk(lineInputsBL);
388
- // @ts-ignore
389
- this.globe.DrawRender();
390
- }
391
- // globe API
392
- init(globe, gl) {
393
- if (this._freed) {
394
- throw new Error("Plugin has been freed, cannot initialize.");
395
- }
396
- this.globe = globe;
397
- this.circlePlugin.init(globe, gl);
398
- this.arcPlugin.init(globe, gl);
399
- this.arcPluginBL.init(globe, gl);
400
- this.linePlugin.init(globe, gl);
401
- this.linePluginBL.init(globe, gl);
402
- this.pieceOfPiePlugin.init(globe, gl);
403
- }
404
- draw3D() {
405
- if (this._freed) {
406
- throw new Error("Plugin has been freed, cannot draw.");
407
- }
408
- if (!this.globe) {
409
- throw new Error("Globe is not set, cannot draw.");
410
- }
411
- if (!this.circlePlugin || !this.arcPlugin) {
412
- throw new Error("Circle and Arc plugins are not initialized.");
413
- }
414
- if (this.drawOptions.drawVRM) {
415
- this.circlePlugin.setPluginOpacity(this._opacities.circle ?? this._opacities.general, false);
416
- this.circlePlugin.draw3D();
417
- }
418
- if (this.drawOptions.drawBearingLine) {
419
- this.arcPluginBL.setPluginOpacity(this._opacities.bearing ?? this._opacities.general, false);
420
- this.arcPluginBL.draw3D();
421
- }
422
- if (this.drawOptions.drawAngleRing) {
423
- const currentLOD = this.globe.api_GetCurrentLODWithDecimal();
424
- const tiltAngle = this.globe.api_GetCurrentLookInfo().Tilt;
425
- const opacity = pieceOfPieOpacityAdaptor(currentLOD, tiltAngle) * (this._opacities.general ?? 1);
426
- if (opacity > 0) {
427
- this.pieceOfPiePlugin.setPluginOpacity(opacity, false);
428
- this.pieceOfPiePlugin.draw3D();
429
- }
430
- }
431
- const currentGeometry = this.globe.api_GetCurrentGeometry();
432
- this.arcPlugin.setPluginOpacity(this._opacities.arc ?? this._opacities.general, false);
433
- this.arcPlugin.draw3D();
434
- if (currentGeometry === 1) {
435
- this.linePlugin.draw3D();
436
- this.linePluginBL.draw3D();
437
- }
438
- for (const textWriter of this._textWritersMap.values()) {
439
- textWriter.draw();
440
- }
441
- }
442
- free() {
443
- if (this._freed) {
444
- throw new Error("Plugin has already been freed.");
445
- }
446
- this._freed = true;
447
- this.globe = null;
448
- this._memory.clear();
449
- this._textWritersMap.clear();
450
- this.circlePlugin.free();
451
- this.arcPlugin.free();
452
- this.arcPluginBL.free();
453
- this.pieceOfPiePlugin.free();
454
- this.linePlugin.free();
455
- this.linePluginBL.free();
456
- }
457
- }
1
+ import { BearingLineInput, Opacities, drawOption } from "./types";
2
+ import { Globe, PluginInterface, Color } from "../../types";
3
+
4
+ import { ContextTextWriter3 } from "../../write-text/context-text3";
5
+ import {
6
+ flatLinesInputAdapter,
7
+ flatLinesBearingInputAdapter,
8
+ bearingLineToCircleInputAdapter,
9
+ bearingLineToArcInputAdapter,
10
+ bearingLineToBearingArcInputAdapter,
11
+ bearingLineToPieceOfPieInputAdapter,
12
+ pieceOfPieOpacityAdaptor
13
+ } from "./adapters";
14
+ import { CircleOnTerrainPlugin, CircleOnTerrainPluginOptions } from "../../semiplugins/shape-on-terrain/circle-plugin";
15
+ import { PieceOfPiePlugin, PieceOfPiePluginOptions } from "../../semiplugins/lightweight/piece-of-pie-plugin";
16
+ import { ArcOnTerrainPlugin, ArcOnTerrainPluginOptions } from "../../semiplugins/shape-on-terrain/arc-plugin";
17
+ import { LinePlugin, LinePluginOptions } from "../../semiplugins/lightweight/line-plugin";
18
+
19
+
20
+ export class BearingLinePlugin implements PluginInterface {
21
+
22
+ id: string;
23
+ globe: Globe | null = null;
24
+ private circlePlugin: CircleOnTerrainPlugin;
25
+ private arcPlugin: ArcOnTerrainPlugin;
26
+ private arcPluginBL: ArcOnTerrainPlugin;
27
+ private pieceOfPiePlugin: PieceOfPiePlugin;
28
+ private linePlugin: LinePlugin;
29
+ private linePluginBL: LinePlugin;
30
+ private _freed: boolean = false;
31
+ private _opacities: Opacities = {
32
+ general: 1,
33
+ circle: 1,
34
+ arc: 1,
35
+ pie: 1,
36
+ bearing: 1
37
+ };
38
+ private _textWritersMap: Map<string, ContextTextWriter3> = new Map();
39
+ private _textDataPreAdaptor: ((item: BearingLineInput) => any) = (item) => item;
40
+ private drawOptions: drawOption = {
41
+ drawVRM: true,
42
+ drawBearingLine: true,
43
+ drawAngleRing: true,
44
+ drawText: true,
45
+ flatRealLineOn: true, // This is a new option to control flat real line drawing
46
+ flatStraightLineOn: true // This is a new option to control flat straight line drawing
47
+ }
48
+ private _memory: Map<string, any> = new Map();
49
+
50
+ private _semiPluginsOptions: {
51
+ circleOnTerrainOptions: Partial<CircleOnTerrainPluginOptions>,
52
+ arcOnTerrainOptions: Partial<ArcOnTerrainPluginOptions>,
53
+ lineOptions: Partial<LinePluginOptions>,
54
+ pieceOfPieOptions: Partial<PieceOfPiePluginOptions>,
55
+
56
+ } = {
57
+ circleOnTerrainOptions: {
58
+ defaultColor: [1, 1, 1, 0.5],
59
+ defaultHeightFromGroundIn3D: 30.0,
60
+ variativeColorsOn: false,
61
+ isMSL: false
62
+ },
63
+ arcOnTerrainOptions: {
64
+ defaultHeightFromGroundIn3D: 30.0,
65
+ variativeColorsOn: false,
66
+ defaultColor: [1, 1, 1, 0.5] as Color,
67
+ globeViewOn: true,
68
+ flatViewOn: false,
69
+ isMSL: false
70
+ },
71
+ lineOptions: {
72
+ flatViewOn: true,
73
+ globeViewOn: true,
74
+ variativeColorsOn: false,
75
+ defaultColor: [1, 1, 1, 0.5],
76
+ },
77
+ pieceOfPieOptions: {
78
+ defaultColor: [1, 1, 1, 0.5],
79
+ variativeColorsOn: false,
80
+ defaultHeightFromGroundIn3D: 1000.0,
81
+ }
82
+ }
83
+
84
+ constructor(id: string,
85
+ {
86
+ textWritersMap,
87
+ textDataPreAdaptor,
88
+ opacities,
89
+ drawOptions,
90
+ circleOnTerrainOptions = {
91
+ defaultColor: [1, 1, 1, 0.5] as Color,
92
+ defaultHeightFromGroundIn3D: 30.0,
93
+ variativeColorsOn: false,
94
+ },
95
+ arcOnTerrainOptions = {
96
+ globeViewOn: true,
97
+ flatViewOn: false,
98
+ defaultColor: [1, 1, 1, 0.5] as Color,
99
+ defaultHeightFromGroundIn3D: 30.0,
100
+ variativeColorsOn: false,
101
+ },
102
+ lineOptions = {
103
+ flatViewOn: true,
104
+ globeViewOn: false,
105
+ variativeColorsOn: false,
106
+ defaultColor: [1, 1, 1, 0.5] as Color,
107
+ },
108
+ pieceOfPieOptions = {
109
+ defaultColor: [1, 1, 1, 0.5] as Color,
110
+ variativeColorsOn: false,
111
+ defaultHeightFromGroundIn3D: 1000.0,
112
+ }
113
+ }: {
114
+ textWritersMap?: Map<string, ContextTextWriter3>,
115
+ textDataPreAdaptor?: (item: BearingLineInput) => any,
116
+ opacities?: Partial<Opacities>,
117
+ drawOptions?: Partial<drawOption>,
118
+ circleOnTerrainOptions?: Partial<CircleOnTerrainPluginOptions>,
119
+ arcOnTerrainOptions?: Partial<ArcOnTerrainPluginOptions>,
120
+ lineOptions?: Partial<LinePluginOptions>,
121
+ pieceOfPieOptions?: Partial<PieceOfPiePluginOptions>,
122
+ } = {}
123
+ ) {
124
+ this.id = id;
125
+ if (!(textWritersMap instanceof Map)) throw new Error("textWritersMap is not an instance of Map");
126
+ textWritersMap.forEach((v) => {
127
+ if (!(v instanceof ContextTextWriter3)) throw new Error("textWritersMap element is not an instance of ContextTextWriter3");
128
+ });
129
+
130
+
131
+ if (circleOnTerrainOptions) {
132
+ this._semiPluginsOptions.circleOnTerrainOptions = {
133
+ ...this._semiPluginsOptions.circleOnTerrainOptions,
134
+ ...circleOnTerrainOptions
135
+ };
136
+ }
137
+ if (arcOnTerrainOptions) {
138
+ this._semiPluginsOptions.arcOnTerrainOptions = {
139
+ ...this._semiPluginsOptions.arcOnTerrainOptions,
140
+ ...arcOnTerrainOptions
141
+ };
142
+ }
143
+ if (lineOptions) {
144
+ this._semiPluginsOptions.lineOptions = {
145
+ ...this._semiPluginsOptions.lineOptions,
146
+ ...lineOptions
147
+ };
148
+ }
149
+ if (pieceOfPieOptions) this._semiPluginsOptions.pieceOfPieOptions = {
150
+ ...this._semiPluginsOptions.pieceOfPieOptions,
151
+ ...pieceOfPieOptions
152
+ };
153
+
154
+
155
+ this._textWritersMap = textWritersMap || new Map();
156
+ this._textWritersMap.forEach((writer) => writer.setKeyAdaptor((item: { key: string }) => item.key));
157
+ this._textDataPreAdaptor = textDataPreAdaptor || ((item) => item);
158
+ this.circlePlugin = new CircleOnTerrainPlugin(id + "_circle",
159
+ this._semiPluginsOptions.circleOnTerrainOptions as CircleOnTerrainPluginOptions
160
+ )
161
+ this.arcPlugin = new ArcOnTerrainPlugin(id + "_arc", {
162
+ ...this._semiPluginsOptions.arcOnTerrainOptions,
163
+ })
164
+ this.arcPluginBL = new ArcOnTerrainPlugin(id + "_arcBL", {
165
+ ...this._semiPluginsOptions.arcOnTerrainOptions,
166
+ })
167
+ this.pieceOfPiePlugin = new PieceOfPiePlugin(id + "_pieceOfPie", {
168
+ bufferType: "DYNAMIC_DRAW",
169
+ ...this._semiPluginsOptions.pieceOfPieOptions
170
+
171
+ });
172
+ this.linePlugin = new LinePlugin(id + "_line", {
173
+ bufferType: "DYNAMIC_DRAW",
174
+ ...this._semiPluginsOptions.lineOptions
175
+ });
176
+ this.linePluginBL = new LinePlugin(id + "_lineBL", {
177
+ ...this._semiPluginsOptions.lineOptions // flatViewOn: true,
178
+ });
179
+ if (opacities) {
180
+ this._opacities = {
181
+ ...this._opacities,
182
+ ...opacities,
183
+ }
184
+ }
185
+ if (drawOptions) {
186
+ this.drawOptions = {
187
+ ...this.drawOptions,
188
+ ...drawOptions
189
+ };
190
+ }
191
+
192
+
193
+ }
194
+
195
+
196
+
197
+ setDefaultSemiPluginColor(
198
+ semiPluginName: "circleOnTerrain" | "arcOnTerrain" | "line" | "pieceOfPie" | "ALL",
199
+ color: Color
200
+ ) {
201
+
202
+
203
+ if (this._freed) {
204
+ throw new Error("Plugin has been freed, cannot set default semi plugin color.");
205
+ }
206
+ if (!this.globe) {
207
+ throw new Error("Globe is not set, cannot set default semi plugin color.");
208
+ }
209
+
210
+ if (semiPluginName === "ALL") {
211
+ this.circlePlugin.setDefaultColor(color);
212
+ this.arcPlugin.setDefaultColor(color);
213
+ this.arcPluginBL.setDefaultColor(color);
214
+ this.linePlugin.setDefaultColor(color);
215
+ this.linePluginBL.setDefaultColor(color);
216
+ this.pieceOfPiePlugin.setDefaultColor(color);
217
+ return;
218
+ }
219
+
220
+ switch (semiPluginName) {
221
+ case "circleOnTerrain":
222
+ this.circlePlugin.setDefaultColor(color);
223
+ break;
224
+ case "arcOnTerrain":
225
+ this.arcPlugin.setDefaultColor(color);
226
+ break;
227
+ case "line":
228
+ this.linePlugin.setDefaultColor(color);
229
+ break;
230
+ case "pieceOfPie":
231
+ this.pieceOfPiePlugin.setDefaultColor(color);
232
+ break;
233
+ default:
234
+ throw new Error(`Unknown semi plugin name: ${semiPluginName}`);
235
+ }
236
+ }
237
+
238
+ setDoDrawVRM(drawVRM: boolean): void {
239
+ if (this._freed) {
240
+ throw new Error("Plugin has been freed, cannot set draw VRM.");
241
+ }
242
+ if (!this.globe) {
243
+ throw new Error("Globe is not set, cannot set draw VRM.");
244
+ }
245
+ this.drawOptions.drawVRM = drawVRM;
246
+ this.globe.DrawRender();
247
+ }
248
+
249
+ setDoDrawText(drawText: boolean): void {
250
+ if (this._freed) {
251
+ throw new Error("Plugin has been freed, cannot set draw text.");
252
+ }
253
+ if (!this.globe) {
254
+ throw new Error("Globe is not set, cannot set draw text.");
255
+ }
256
+ this.drawOptions.drawText = drawText;
257
+ this.globe.DrawRender();
258
+ }
259
+
260
+
261
+ setDoDrawBearingLine(drawBearingLine: boolean): void {
262
+ if (this._freed) {
263
+ throw new Error("Plugin has been freed, cannot set draw bearing line.");
264
+ }
265
+ if (!this.globe) {
266
+ throw new Error("Globe is not set, cannot set draw bearing line.");
267
+ }
268
+ this.drawOptions.drawBearingLine = drawBearingLine;
269
+ this.globe.DrawRender();
270
+ }
271
+
272
+
273
+ setDoDrawAngleRing(drawAngleRing: boolean): void {
274
+ if (this._freed) {
275
+ throw new Error("Plugin has been freed, cannot set draw angle ring.");
276
+ }
277
+ if (!this.globe) {
278
+ throw new Error("Globe is not set, cannot set draw angle ring.");
279
+ }
280
+ this.drawOptions.drawAngleRing = drawAngleRing;
281
+ this.globe.DrawRender();
282
+ }
283
+
284
+
285
+
286
+ updatePartial(items: (Partial<BearingLineInput> & { key: string })[], { textWriterIDs }: { textWriterIDs?: string[] } = {}) {
287
+ if (this._freed) {
288
+ throw new Error("Plugin has been freed, cannot update item.");
289
+ }
290
+ if (!this.globe) {
291
+ throw new Error("Globe is not set, cannot update item.");
292
+ }
293
+ const fixedItems = []
294
+ for (const item of items) {
295
+ if (!this._memory.has(item.key)) {
296
+ throw new Error(`Item with key ${item.key} not found in memory.`);
297
+ }
298
+ fixedItems.push(this.__memorizeItem(item));
299
+ }
300
+ this._build(fixedItems, { textWriterIDs });
301
+ }
302
+
303
+ setDrawOptions(drawOptions: Partial<drawOption>) {
304
+ if (this._freed) {
305
+ throw new Error("Plugin has been freed, cannot set draw options.");
306
+ }
307
+ if (!this.globe) {
308
+ throw new Error("Globe is not set, cannot set draw options.");
309
+ }
310
+ this.drawOptions = {
311
+ ...this.drawOptions,
312
+ ...drawOptions
313
+ };
314
+ this.globe.DrawRender();
315
+ }
316
+
317
+ updateCoordinatesBulk(items: BearingLineInput[], { textWriterIDs }: { textWriterIDs?: string[] } = {}) {
318
+ if (this._freed) {
319
+ throw new Error("Plugin has been freed, cannot update coordinates.");
320
+ }
321
+ if (!this.globe) {
322
+ throw new Error("Globe is not set, cannot update coordinates.");
323
+ }
324
+ const fixedItems = [];
325
+ for (const item of items) {
326
+ if (!this._memory.has(item.key)) {
327
+ throw new Error(`Item with key ${item.key} not found in memory.`);
328
+ } else {
329
+ fixedItems.push(this.__memorizeItem(item));
330
+ }
331
+ }
332
+ this._build(fixedItems, { textWriterIDs });
333
+ }
334
+
335
+
336
+ setOpacities(opacities: Partial<Opacities>) {
337
+ if (this._freed) {
338
+ throw new Error("Plugin has been freed, cannot set opacities.");
339
+ }
340
+ if (!this.globe) {
341
+ throw new Error("Globe is not set, cannot set opacities.");
342
+ }
343
+ this._opacities = {
344
+ ...this._opacities,
345
+ ...opacities,
346
+ };
347
+ this.globe.DrawRender();
348
+ }
349
+
350
+
351
+ insertBulk(items: BearingLineInput[], { textWriterIDs }: { textWriterIDs?: string[] } = {}) {
352
+
353
+ this._build(items, { textWriterIDs });
354
+ }
355
+
356
+ deleteBulk(keys: string[]) {
357
+ if (this._freed) {
358
+ throw new Error("Plugin has been freed, cannot delete items.");
359
+ }
360
+ if (!this.globe) {
361
+ throw new Error("Globe is not set, cannot delete items.");
362
+ }
363
+ if (!this.circlePlugin || !this.arcPlugin) {
364
+ throw new Error("Circle and Arc plugins are not initialized.");
365
+ }
366
+
367
+ this.circlePlugin.deleteBulk(keys);
368
+ this.arcPlugin.deleteBulk(keys);
369
+ this.arcPluginBL.deleteBulk(keys);
370
+ this.pieceOfPiePlugin.deleteBulk(keys);
371
+ this.linePlugin.deleteBulk(keys);
372
+ this.linePluginBL.deleteBulk(keys);
373
+ this.__deleteTexts(keys);
374
+ this.globe.DrawRender();
375
+ }
376
+
377
+
378
+ updateText(textWriterIDs: string[], itemKeys: string[] | null = null) {
379
+ if (this._freed) {
380
+ throw new Error("Plugin has been freed, cannot update text.");
381
+ }
382
+
383
+ const items = itemKeys ? itemKeys.map(key => this._memory.get(key)).filter(Boolean) : Array.from(this._memory.values());
384
+
385
+ this.__insertTexts(
386
+ items,
387
+ textWriterIDs
388
+ );
389
+
390
+ }
391
+
392
+
393
+
394
+ _calculateRadiusFromBearingLine(bearingLine: BearingLineInput): void {
395
+ const { long, lat, endLong, endLat } = bearingLine;
396
+ // @ts-ignore
397
+ bearingLine.radius = this.globe.Math.GetDist2D(long, lat, endLong, endLat);
398
+ }
399
+
400
+ __deleteTexts(keys: string[]) {
401
+ if (this._freed) {
402
+ throw new Error("Plugin has been freed, cannot delete texts.");
403
+ }
404
+ if (!this.globe) {
405
+ throw new Error("Globe is not set, cannot delete texts.");
406
+ }
407
+ for (const textWriter of this._textWritersMap.values()) {
408
+ textWriter.deleteTextBulk(keys);
409
+ }
410
+ keys.forEach(key => {
411
+ this._memory.delete(key);
412
+ });
413
+ }
414
+
415
+
416
+ __insertTexts(items: BearingLineInput[], textWriterIDs: string[] = []) {
417
+ if (this._freed) {
418
+ throw new Error("Plugin has been freed, cannot insert texts.");
419
+ }
420
+ if (!this.globe) {
421
+ throw new Error("Globe is not set, cannot insert texts.");
422
+ }
423
+ if (textWriterIDs.length === 0) {
424
+ textWriterIDs = Array.from(this._textWritersMap.keys());
425
+ }
426
+ // check textWriterIDs
427
+ for (const textWriterID of textWriterIDs) {
428
+ const textWriter = this._textWritersMap.get(textWriterID);
429
+ if (!textWriter) {
430
+ throw new Error(`Text writer with ID ${textWriterID} not found.`);
431
+ }
432
+ }
433
+
434
+
435
+ for (const textWriterID of textWriterIDs) {
436
+ const textWriter = this._textWritersMap.get(textWriterID);
437
+ if (textWriter) {
438
+ textWriter.insertTextBulk(items.map(x => this._textDataPreAdaptor(x)), textWriterID);
439
+ }
440
+ }
441
+ }
442
+
443
+
444
+ __memorizeItem(item: { key: string } & Partial<BearingLineInput>): BearingLineInput {
445
+ const oldItem = this._memory.get(item.key);
446
+ let newItem = oldItem ? { ...oldItem, ...item } : item;
447
+ this._memory.set(item.key, newItem);
448
+ return newItem;
449
+ }
450
+
451
+ _build(items: BearingLineInput[], { textWriterIDs }: { textWriterIDs?: string[] } = {}) {
452
+ if (this._freed) {
453
+ throw new Error("Plugin has been freed, cannot update coordinates.");
454
+
455
+ }
456
+ if (!this.globe) {
457
+ throw new Error("Globe is not set, cannot update coordinates.");
458
+ }
459
+ if (!this.circlePlugin || !this.arcPlugin) {
460
+ throw new Error("Circle and Arc plugins are not initialized.");
461
+ }
462
+ items.forEach(item => {
463
+ this._calculateRadiusFromBearingLine(item);
464
+ });
465
+ const processedItems = items.map((item) => this.__memorizeItem(item));
466
+
467
+ // @ts-ignore
468
+ const circleInputs = processedItems.map(bearingLineToCircleInputAdapter(this.globe)) as CircleInput[];
469
+ this.circlePlugin.insertBulk(circleInputs);
470
+ const arcInputs = processedItems.map(bearingLineToArcInputAdapter);
471
+ this.arcPlugin.insertBulk(arcInputs);
472
+ // @ts-ignore
473
+ const bearingArcInputs = processedItems.map((x) => bearingLineToBearingArcInputAdapter(this.globe, x));
474
+ this.arcPluginBL.insertBulk(bearingArcInputs);
475
+ this.__insertTexts(processedItems, textWriterIDs);
476
+ // @ts-ignore
477
+ const pieceOfPieInputs = processedItems.map((x) => bearingLineToPieceOfPieInputAdapter(this.globe, x));
478
+ this.pieceOfPiePlugin.insertBulk(pieceOfPieInputs);
479
+ // line inputs
480
+ const lineInputs = processedItems.map(flatLinesInputAdapter);
481
+ this.linePlugin.insertBulk(lineInputs);
482
+ const lineInputsBL = processedItems.map(flatLinesBearingInputAdapter);
483
+ this.linePluginBL.insertBulk(lineInputsBL);
484
+ // @ts-ignore
485
+ this.globe.DrawRender();
486
+ }
487
+
488
+ // globe API
489
+
490
+ init(globe: Globe, gl: WebGL2RenderingContext): void {
491
+ if (this._freed) {
492
+ throw new Error("Plugin has been freed, cannot initialize.");
493
+ }
494
+ this.globe = globe;
495
+
496
+ this.circlePlugin.init(globe, gl);
497
+ this.arcPlugin.init(globe, gl);
498
+ this.arcPluginBL.init(globe, gl);
499
+ this.linePlugin.init(globe, gl);
500
+ this.linePluginBL.init(globe, gl);
501
+ this.pieceOfPiePlugin.init(globe, gl);
502
+
503
+ }
504
+
505
+ draw3D(): void {
506
+
507
+ if (this._freed) {
508
+ throw new Error("Plugin has been freed, cannot draw.");
509
+ }
510
+ if (!this.globe) {
511
+ throw new Error("Globe is not set, cannot draw.");
512
+ }
513
+ if (!this.circlePlugin || !this.arcPlugin) {
514
+ throw new Error("Circle and Arc plugins are not initialized.");
515
+ }
516
+
517
+ if (this.drawOptions.drawVRM) {
518
+ this.circlePlugin.setPluginOpacity(this._opacities.circle ?? this._opacities.general, false);
519
+ this.circlePlugin.draw3D();
520
+ }
521
+
522
+
523
+ if (this.drawOptions.drawBearingLine) {
524
+ this.arcPluginBL.setPluginOpacity(this._opacities.bearing ?? this._opacities.general, false);
525
+ this.arcPluginBL.draw3D();
526
+ }
527
+
528
+ if (this.drawOptions.drawAngleRing) {
529
+ const currentLOD = this.globe.api_GetCurrentLODWithDecimal();
530
+ const tiltAngle = this.globe.api_GetCurrentLookInfo().Tilt;
531
+ const opacity = pieceOfPieOpacityAdaptor(currentLOD, tiltAngle) * (this._opacities.general ?? 1);
532
+ if (opacity > 0) {
533
+ this.pieceOfPiePlugin.setPluginOpacity(opacity, false);
534
+ this.pieceOfPiePlugin.draw3D();
535
+ }
536
+ }
537
+
538
+ const currentGeometry = this.globe.api_GetCurrentGeometry();
539
+
540
+ this.arcPlugin.setPluginOpacity(this._opacities.arc ?? this._opacities.general, false);
541
+ this.arcPlugin.draw3D();
542
+
543
+ if (currentGeometry === 1) {
544
+ this.linePlugin.draw3D();
545
+ this.linePluginBL.draw3D();
546
+ }
547
+
548
+ for (const textWriter of this._textWritersMap.values()) {
549
+ textWriter.draw();
550
+ }
551
+ }
552
+
553
+
554
+ free(): void {
555
+ if (this._freed) {
556
+ throw new Error("Plugin has already been freed.");
557
+ }
558
+ this._freed = true;
559
+ this.globe = null;
560
+ this._memory.clear();
561
+ this._textWritersMap.clear();
562
+ this.circlePlugin.free();
563
+ this.arcPlugin.free();
564
+ this.arcPluginBL.free();
565
+ this.pieceOfPiePlugin.free();
566
+ this.linePlugin.free();
567
+ this.linePluginBL.free();
568
+ }
569
+ }