@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
@@ -0,0 +1,252 @@
1
+ import { CSZMode } from "@pirireis/webglobe";
2
+ import { isTextFont, opacityCheck } from "../util/check/typecheck";
3
+
4
+ interface TextFont {
5
+ name: string;
6
+ textColor: string;
7
+ hollowColor: string;
8
+ size: number;
9
+ hollow: boolean;
10
+ bold: boolean;
11
+ italic: boolean;
12
+ position?: string;
13
+ }
14
+
15
+ interface Style {
16
+ textFont: TextFont;
17
+ opacity: number;
18
+ zMode: CSZMode;
19
+ }
20
+
21
+ interface Coordinates {
22
+ long: number;
23
+ lat: number;
24
+ }
25
+
26
+ interface ZoomAdaptorResult {
27
+ opacityMultiplier: number;
28
+ sizeMultiplier: number;
29
+ }
30
+
31
+ interface TextItem {
32
+ long: number;
33
+ lat: number;
34
+ text: string;
35
+ opacity: number | null;
36
+ angle: number | null;
37
+ zPayload: any;
38
+ position: string;
39
+ }
40
+
41
+ interface Globe {
42
+ DrawRender(): void;
43
+ api_GetCurrentGeometry(): number;
44
+ api_GetCurrentLODWithDecimal(): number;
45
+ api_GetScreenPointFromGeo(coords: { long: number; lat: number; z: number }, isMSL: boolean): { x: number | null; y: number | null };
46
+ api_DrawContextTextMultiLine(text: string, textFont: TextFont, opacity: number, position: { x: number; y: number }, angleIsOn: boolean, angle: number | null): void;
47
+ }
48
+
49
+ type TextAdaptor = (item: any, id: number, container: any[], properties?: any) => string | null;
50
+ type CoordinatesAdaptor = (item: any, id: number, container: any[], properties?: any) => Coordinates | null;
51
+ type KeyAdaptor = (item: any, id?: number, container?: any[], properties?: any) => string;
52
+ type OpacityAdaptor = (item: any, id: number, container: any[], properties?: any) => number;
53
+ type AngleAdaptor = (item: any, id: number, container: any[], properties?: any) => number | null;
54
+ type PositionAdaptor = (item: any, id: number, container: any[], properties?: any) => string;
55
+ type ZoomLevelAdaptor = (zoomLevel: number) => (item: any) => ZoomAdaptorResult;
56
+
57
+ interface ConstructorOptions {
58
+ style?: Style;
59
+ xOffset?: number;
60
+ yOffset?: number;
61
+ doDraw?: boolean;
62
+ textAdaptor?: TextAdaptor | null;
63
+ coordinatesAdaptor?: CoordinatesAdaptor | null;
64
+ keyAdaptor?: KeyAdaptor | null;
65
+ opacityAdaptor?: OpacityAdaptor | null;
66
+ angleAdaptor?: AngleAdaptor | null;
67
+ angleOnSphere?: boolean;
68
+ positionAdaptor?: PositionAdaptor;
69
+ zoomLevelAdaptor?: ZoomLevelAdaptor;
70
+ }
71
+
72
+ /**
73
+ * TODOs:
74
+ * 1) update all if initials change (propably need a context and a callback to iterate over zPayload)
75
+ * 2) expose a mechanic to update text on zoom change
76
+ * 3) extend the mechanic on 2 to other events
77
+ *
78
+ * TODO: key check and raise error if doesnt exist
79
+ */
80
+
81
+ export class ContextTextWriter3 {
82
+ private globe: Globe;
83
+ private itemMap: Map<string, TextItem>;
84
+ // @ts-ignore
85
+ private style: Style;
86
+ private doDraw: boolean;
87
+ private textAdaptor: TextAdaptor | null;
88
+ private coordinatesAdaptor: CoordinatesAdaptor | null;
89
+ private keyAdaptor: KeyAdaptor | null;
90
+ private zoomLevelAdaptor: ZoomLevelAdaptor;
91
+ private positionAdaptor: PositionAdaptor;
92
+ private opacityAdaptor: OpacityAdaptor;
93
+ private angleOnSphere: boolean;
94
+ private angleAdaptor: AngleAdaptor;
95
+ private angleAdaptorIsOn: boolean;
96
+ private xOffset: number;
97
+ private yOffset: number;
98
+
99
+ constructor(globe: Globe, {
100
+ style = {
101
+ textFont: {
102
+ name: 'Arial',
103
+ textColor: '#FFFFFF', // beyaz
104
+ hollowColor: '#000000', // siyah
105
+ size: 12, // piksel
106
+ hollow: true,
107
+ bold: true,
108
+ italic: false,
109
+ },
110
+ opacity: 1.0,
111
+ zMode: CSZMode.Z_GROUND_PERVERTEX,
112
+ },
113
+ xOffset = 0,
114
+ yOffset = 0,
115
+ doDraw = true,
116
+ textAdaptor = null,
117
+ coordinatesAdaptor = null,
118
+ keyAdaptor = null,
119
+ opacityAdaptor = null,
120
+ angleAdaptor = null,
121
+ angleOnSphere = false,
122
+ positionAdaptor = (item: any, i: number, container: any[], properties?: any): string => "left",
123
+ zoomLevelAdaptor = (zoomLevel: number) => (item: any): ZoomAdaptorResult => {
124
+ return {
125
+ opacityMultiplier: 1,
126
+ sizeMultiplier: 1
127
+ }
128
+ }
129
+ }: ConstructorOptions = {}) {
130
+ this.globe = globe;
131
+ this.itemMap = new Map<string, TextItem>();
132
+ this.setStyle(style);
133
+ this.doDraw = doDraw;
134
+ this._checkParameterTypes(textAdaptor, coordinatesAdaptor, keyAdaptor, opacityAdaptor, angleAdaptor, xOffset, yOffset);
135
+
136
+ this.textAdaptor = textAdaptor;
137
+ this.coordinatesAdaptor = coordinatesAdaptor;
138
+ this.keyAdaptor = keyAdaptor;
139
+
140
+ this.zoomLevelAdaptor = zoomLevelAdaptor;
141
+ this.positionAdaptor = positionAdaptor;
142
+ this.opacityAdaptor = opacityAdaptor ? opacityAdaptor : () => 1;
143
+ this.angleOnSphere = angleOnSphere;
144
+ if (angleAdaptor) {
145
+ this.angleAdaptor = angleAdaptor
146
+ this.angleAdaptorIsOn = true;
147
+ } else {
148
+ this.angleAdaptor = () => null
149
+ this.angleAdaptorIsOn = false
150
+ }
151
+
152
+ this.xOffset = xOffset;
153
+ this.yOffset = yOffset;
154
+ }
155
+
156
+ private _checkParameterTypes(textAdaptor: TextAdaptor | null, coordinatesAdaptor: CoordinatesAdaptor | null, keyAdaptor: KeyAdaptor | null, opacityAdaptor: OpacityAdaptor | null, angleAdaptor: AngleAdaptor | null, xOffset: number, yOffset: number): void {
157
+ if (textAdaptor !== null) if (!(textAdaptor instanceof Function)) throw new Error("textAdaptor is not an instance of a Function");
158
+ if (coordinatesAdaptor !== null) if (!(coordinatesAdaptor instanceof Function)) throw new Error("coordinatesAdaptor is not an instance of a Function");
159
+ if (keyAdaptor !== null) if (!(keyAdaptor instanceof Function)) throw new Error("keyAdaptor is not an instance of a Function");
160
+ if (opacityAdaptor !== null) if (!(opacityAdaptor instanceof Function)) throw new Error("opacityAdaptor is not an instance of a Function");
161
+ if (angleAdaptor !== null) if (!(angleAdaptor instanceof Function)) throw new Error("angleAdaptor is not an instance of a Function");
162
+ if (typeof xOffset !== "number") throw new Error("xOffset type is not a number");
163
+ if (typeof yOffset !== "number") throw new Error("yOffset type is not a number");
164
+ }
165
+
166
+ setKeyAdaptor(adaptor: KeyAdaptor): void {
167
+ this.keyAdaptor = adaptor;
168
+ }
169
+
170
+ setDoDraw(bool: boolean): void {
171
+ this.doDraw = bool;
172
+ this.globe.DrawRender();
173
+ }
174
+
175
+ setStyle(style: Style): void {
176
+ isTextFont(style.textFont);
177
+ opacityCheck(style.opacity); //TODO: use shallow copy
178
+ this.style = style;
179
+ this.globe.DrawRender();
180
+ }
181
+
182
+ setOpacity(opacity: number): void {
183
+ this.style.opacity = opacity;
184
+ this.globe.DrawRender();
185
+ }
186
+
187
+ draw(): void {
188
+ if (!this.doDraw) return;
189
+ const { globe, style, itemMap, xOffset, yOffset } = this;
190
+ const { textFont, opacity: opacity_ } = style;
191
+ const textSize = textFont.size;
192
+ const is3D = globe.api_GetCurrentGeometry() === 0;
193
+ const angleIsOn = is3D ? (this.angleAdaptorIsOn && this.angleOnSphere) : (this.angleAdaptorIsOn)
194
+ const zoomLevel = globe.api_GetCurrentLODWithDecimal();
195
+ const zoomAdaptor = this.zoomLevelAdaptor(zoomLevel);
196
+ for (const item of itemMap.values()) {
197
+ const { lat, long, text, opacity = null, angle = null, zPayload, position } = item;
198
+ const { x, y } = globe.api_GetScreenPointFromGeo(
199
+ {
200
+ long: long,
201
+ lat: lat,
202
+ z: 0,
203
+ },
204
+ style.zMode === CSZMode.Z_MSL,
205
+ );
206
+ const { opacityMultiplier, sizeMultiplier } = zoomAdaptor(zPayload);
207
+ const o = (opacity === null ? opacity_ : opacity * opacity_) * opacityMultiplier;
208
+ textFont.size = sizeMultiplier * textSize;
209
+ textFont.position = position;
210
+ if (x !== null && y !== null) globe.api_DrawContextTextMultiLine(text, textFont, o, { x: x + xOffset, y: y - yOffset }, angleIsOn, angle);
211
+ }
212
+ textFont.size = textSize;
213
+ }
214
+
215
+ insertTextBulk(container: any[], properties?: any): void {
216
+ container.forEach((v, i, c) => {
217
+ this.insertText(v, i, c, properties);
218
+ });
219
+ }
220
+
221
+ deleteTextBulk(keys: string[]): void {
222
+ for (const key of keys) {
223
+ this.itemMap.delete(key);
224
+ }
225
+ }
226
+
227
+ insertText(item: any, id: number, container: any[], properties?: any): void {
228
+ const key = this.keyAdaptor!(item, id, container, properties)
229
+ const coords = this.coordinatesAdaptor!(item, id, container, properties)
230
+ if (coords == null) {
231
+ this.itemMap.delete(key);
232
+ return;
233
+ }
234
+ const text = this.textAdaptor!(item, id, container, properties)
235
+ if (text == null) {
236
+ this.itemMap.delete(key);
237
+ return
238
+ };
239
+ const opacity = this.opacityAdaptor(item, id, container, properties);
240
+ const angle = this.angleAdaptor(item, id, container, properties);
241
+ const position = this.positionAdaptor(item, id, container, properties);
242
+ this.itemMap.set(key, { long: coords.long, lat: coords.lat, text, opacity, angle, zPayload: item, position });
243
+ }
244
+
245
+ clear(): void {
246
+ this.itemMap.clear();
247
+ }
248
+
249
+ free(): void {
250
+ this.itemMap = null as any;
251
+ }
252
+ }
@@ -1,146 +1,231 @@
1
- // @ts-ignore
2
- import { CSZMode } from "@pirireis/webglobe";
3
- import { isTextFont, opacityCheck } from "../util/check/typecheck";
4
- /**
5
- * TODOs:
6
- * 1) update all if initials change (propably need a context and a callback to iterate over zPayload)
7
- * 2) expose a mechanic to update text on zoom change
8
- * 3) extend the mechanic on 2 to other events
9
- *
10
- * TODO: key check and raise error if doesnt exist
11
- */
12
- const defaultStyle = {
13
- textFont: {
14
- name: 'Arial',
15
- textColor: '#FFFFFF', // beyaz
16
- hollowColor: '#000000', // siyah
17
- size: 12, // piksel
18
- hollow: true,
19
- bold: false,
20
- italic: false,
21
- },
22
- opacity: 1.0,
23
- zMode: CSZMode.Z_GROUND_PERVERTEX,
24
- };
25
- // xOffset = 0,
26
- // yOffset = 0,
27
- // doDraw = true,
28
- // textAdapter = null,
29
- // coordinatesAdapter = null,
30
- // keyAdapter = null,
31
- // opacityAdapter = null,
32
- // angleAdapter = null,
33
- // angleOnSphere = false,
34
- // positionAdapter = (item: any, i: number, container: any[], properties?: any): string => "left",
35
- export class ContextTextWriter4 {
36
- globe;
37
- itemMap;
38
- style;
39
- doDraw;
40
- textAdapter;
41
- deleteAdapter;
42
- zoomLevelAdapter;
43
- xOffset;
44
- yOffset;
45
- angleOptions;
46
- constructor(globe, textAdapter, deleteAdapter, zoomLevelAdapter = (zoomLevel) => (item) => {
47
- return {
48
- opacityMultiplier: 1,
49
- sizeMultiplier: 1
50
- };
51
- }, style = defaultStyle, angleOptions = {
52
- angleOnSphere: false,
53
- angleIsOn: false
54
- }, doDraw = true, offset = { x: 0, y: 0 }) {
55
- this.globe = globe;
56
- this.itemMap = new Map();
57
- isTextFont(style.textFont);
58
- opacityCheck(style.opacity);
59
- this.style = { ...style, textFont: { ...style.textFont } };
60
- this.angleOptions = angleOptions;
61
- this.doDraw = doDraw;
62
- this.angleOptions = angleOptions;
63
- this.textAdapter = textAdapter;
64
- this.deleteAdapter = deleteAdapter;
65
- this.zoomLevelAdapter = zoomLevelAdapter;
66
- this.xOffset = offset.x;
67
- this.yOffset = offset.y;
68
- }
69
- setDoDraw(bool) {
70
- this.doDraw = bool;
71
- this.globe.DrawRender();
72
- }
73
- setStyle(style) {
74
- isTextFont(style.textFont);
75
- opacityCheck(style.opacity);
76
- this.style = { ...style, textFont: { ...style.textFont } };
77
- this.globe.DrawRender();
78
- }
79
- setOpacity(opacity) {
80
- this.style.opacity = opacity;
81
- this.globe.DrawRender();
82
- }
83
- draw() {
84
- if (!this.doDraw)
85
- return;
86
- const { globe, style, itemMap, xOffset, yOffset } = this;
87
- const { textFont, opacity: opacity_ } = style;
88
- const textSize = textFont.size;
89
- const is3D = globe.api_GetCurrentGeometry() === 0;
90
- const angleIsOn = is3D ? (this.angleOptions.angleIsOn && this.angleOptions.angleOnSphere) : (this.angleOptions.angleIsOn);
91
- const zoomLevel = globe.api_GetCurrentLODWithDecimal();
92
- const zoomAdapter = this.zoomLevelAdapter(zoomLevel);
93
- for (const item of itemMap.values()) {
94
- const { lat, long, text, opacity = null, angle = null, position } = item;
95
- const { opacityMultiplier, sizeMultiplier } = zoomAdapter(item);
96
- if (sizeMultiplier <= 0 || opacityMultiplier <= 0)
97
- continue;
98
- const o = (opacity === null ? opacity_ : opacity * opacity_) * opacityMultiplier;
99
- const { x, y } = globe.api_GetScreenPointFromGeo({
100
- long: long,
101
- lat: lat,
102
- z: 0,
103
- }, style.zMode === CSZMode.Z_MSL);
104
- textFont.size = sizeMultiplier * textSize;
105
- textFont.position = position;
106
- if (x !== null && y !== null) {
107
- globe.api_DrawContextTextMultiLine(text, textFont, o, { x: x + xOffset, y: y - yOffset }, angleIsOn, angle);
108
- }
109
- }
110
- textFont.size = textSize;
111
- }
112
- insertText(data) {
113
- const textDatas = this.textAdapter(data);
114
- for (const textData of textDatas) {
115
- this.itemMap.set(textData.key, textData);
116
- }
117
- }
118
- insertTextBulk(datas) {
119
- for (const data of datas) {
120
- this.insertText(data);
121
- }
122
- }
123
- deleteText(data) {
124
- const keys = this.deleteAdapter(data);
125
- for (const key of keys) {
126
- if (this.itemMap.has(key)) {
127
- this.itemMap.delete(key);
128
- }
129
- }
130
- }
131
- deleteTextBulk(datas) {
132
- for (const data of datas) {
133
- this.deleteText(data);
134
- }
135
- }
136
- setOffsets(x, y) {
137
- this.xOffset = x;
138
- this.yOffset = y;
139
- }
140
- clear() {
141
- this.itemMap.clear();
142
- }
143
- free() {
144
- this.itemMap = null;
145
- }
146
- }
1
+ // @ts-ignore
2
+ import { CSZMode } from "@pirireis/webglobe";
3
+ import { isTextFont, opacityCheck } from "../util/check/typecheck";
4
+
5
+ interface TextFont {
6
+ name: string;
7
+ textColor: string;
8
+ hollowColor: string;
9
+ size: number;
10
+ hollow: boolean;
11
+ bold: boolean;
12
+ italic: boolean;
13
+ position?: string;
14
+ }
15
+
16
+ interface Style {
17
+ textFont: TextFont;
18
+ opacity: number;
19
+ zMode: CSZMode;
20
+ }
21
+
22
+
23
+ interface ZoomAdapterResult {
24
+ opacityMultiplier: number;
25
+ sizeMultiplier: number;
26
+ }
27
+
28
+ export interface TextItem {
29
+ key: string;
30
+ long: number;
31
+ lat: number;
32
+ text: string;
33
+ opacity: number | null;
34
+ angle: number | null;
35
+ position: string;
36
+ }
37
+
38
+ interface Globe {
39
+ DrawRender(): void;
40
+ api_GetCurrentGeometry(): number;
41
+ api_GetCurrentLODWithDecimal(): number;
42
+ api_GetScreenPointFromGeo(coords: { long: number; lat: number; z: number }, isMSL: boolean): { x: number | null; y: number | null };
43
+ api_DrawContextTextMultiLine(text: string, textFont: TextFont, opacity: number, position: { x: number; y: number }, angleIsOn: boolean, angle: number | null): void;
44
+ }
45
+
46
+ export type TextAdapter = (data: any) => TextItem[]
47
+ export type DeleteAdapter = (data: any) => string[]
48
+ export type ZoomLevelAdapter = (zoomLevel: number) => (item: any) => ZoomAdapterResult;
49
+
50
+ /**
51
+ * TODOs:
52
+ * 1) update all if initials change (propably need a context and a callback to iterate over zPayload)
53
+ * 2) expose a mechanic to update text on zoom change
54
+ * 3) extend the mechanic on 2 to other events
55
+ *
56
+ * TODO: key check and raise error if doesnt exist
57
+ */
58
+
59
+
60
+
61
+ const defaultStyle = {
62
+ textFont: {
63
+ name: 'Arial',
64
+ textColor: '#FFFFFF', // beyaz
65
+ hollowColor: '#000000', // siyah
66
+ size: 12, // piksel
67
+ hollow: true,
68
+ bold: false,
69
+ italic: false,
70
+ },
71
+ opacity: 1.0,
72
+ zMode: CSZMode.Z_GROUND_PERVERTEX,
73
+ }
74
+ // xOffset = 0,
75
+ // yOffset = 0,
76
+ // doDraw = true,
77
+ // textAdapter = null,
78
+ // coordinatesAdapter = null,
79
+ // keyAdapter = null,
80
+ // opacityAdapter = null,
81
+ // angleAdapter = null,
82
+ // angleOnSphere = false,
83
+ // positionAdapter = (item: any, i: number, container: any[], properties?: any): string => "left",
84
+
85
+
86
+ export class ContextTextWriter4 {
87
+ private globe: Globe;
88
+ private itemMap: Map<string, TextItem>;
89
+ private style: Style;
90
+ private doDraw: boolean;
91
+ private textAdapter: TextAdapter;
92
+ private deleteAdapter: DeleteAdapter;
93
+ private zoomLevelAdapter: ZoomLevelAdapter;
94
+ private xOffset: number;
95
+ private yOffset: number;
96
+
97
+ private angleOptions: {
98
+ angleOnSphere: boolean;
99
+ angleIsOn: boolean;
100
+ }
101
+
102
+ constructor(globe: Globe,
103
+ textAdapter: TextAdapter,
104
+ deleteAdapter: DeleteAdapter,
105
+ zoomLevelAdapter = (zoomLevel: number) => (item: any): ZoomAdapterResult => {
106
+ return {
107
+ opacityMultiplier: 1,
108
+ sizeMultiplier: 1
109
+ }
110
+ },
111
+ style = defaultStyle,
112
+ angleOptions = {
113
+ angleOnSphere: false,
114
+ angleIsOn: false
115
+ },
116
+ doDraw = true,
117
+ offset = { x: 0, y: 0 }
118
+ ) {
119
+ this.globe = globe;
120
+ this.itemMap = new Map<string, TextItem>();
121
+ isTextFont(style.textFont);
122
+ opacityCheck(style.opacity);
123
+ this.style = { ...style, textFont: { ...style.textFont } };
124
+ this.angleOptions = angleOptions;
125
+ this.doDraw = doDraw;
126
+ this.angleOptions = angleOptions;
127
+ this.textAdapter = textAdapter;
128
+ this.deleteAdapter = deleteAdapter;
129
+ this.zoomLevelAdapter = zoomLevelAdapter;
130
+ this.xOffset = offset.x;
131
+ this.yOffset = offset.y;
132
+ }
133
+
134
+
135
+ setDoDraw(bool: boolean): void {
136
+ this.doDraw = bool;
137
+ this.globe.DrawRender();
138
+ }
139
+
140
+ setStyle(style: Style): void {
141
+ isTextFont(style.textFont);
142
+ opacityCheck(style.opacity);
143
+ this.style = { ...style, textFont: { ...style.textFont } };
144
+ this.globe.DrawRender();
145
+ }
146
+
147
+ setOpacity(opacity: number): void {
148
+ this.style.opacity = opacity;
149
+ this.globe.DrawRender();
150
+ }
151
+
152
+ draw(): void {
153
+ if (!this.doDraw) return;
154
+ const { globe, style, itemMap, xOffset, yOffset } = this;
155
+ const { textFont, opacity: opacity_ } = style;
156
+ const textSize = textFont.size;
157
+ const is3D = globe.api_GetCurrentGeometry() === 0;
158
+ const angleIsOn = is3D ? (this.angleOptions.angleIsOn && this.angleOptions.angleOnSphere) : (this.angleOptions.angleIsOn)
159
+ const zoomLevel = globe.api_GetCurrentLODWithDecimal();
160
+ const zoomAdapter = this.zoomLevelAdapter(zoomLevel);
161
+ for (const item of itemMap.values()) {
162
+ const { lat, long, text, opacity = null, angle = null, position } = item;
163
+ const { opacityMultiplier, sizeMultiplier } = zoomAdapter(item);
164
+ if (sizeMultiplier <= 0 || opacityMultiplier <= 0) continue;
165
+ const o = (opacity === null ? opacity_ : opacity * opacity_) * opacityMultiplier;
166
+ const { x, y } = globe.api_GetScreenPointFromGeo(
167
+ {
168
+ long: long,
169
+ lat: lat,
170
+ z: 0,
171
+ },
172
+ style.zMode === CSZMode.Z_MSL,
173
+ );
174
+ textFont.size = sizeMultiplier * textSize;
175
+ textFont.position = position;
176
+ if (x !== null && y !== null) {
177
+ globe.api_DrawContextTextMultiLine(text, textFont, o, { x: x + xOffset, y: y - yOffset }, angleIsOn, angle)
178
+ }
179
+ }
180
+ textFont.size = textSize;
181
+ }
182
+
183
+
184
+
185
+ insertText(data: any): void {
186
+
187
+ const textDatas = this.textAdapter(data)
188
+ for (const textData of textDatas) {
189
+ this.itemMap.set(textData.key, textData);
190
+ }
191
+ }
192
+
193
+
194
+ insertTextBulk(datas: any[]): void {
195
+ for (const data of datas) {
196
+ this.insertText(data);
197
+ }
198
+ }
199
+
200
+
201
+
202
+ deleteText(data: any): void {
203
+ const keys = this.deleteAdapter(data);
204
+ for (const key of keys) {
205
+ if (this.itemMap.has(key)) {
206
+ this.itemMap.delete(key);
207
+ }
208
+ }
209
+ }
210
+
211
+ deleteTextBulk(datas: any[]): void {
212
+ for (const data of datas) {
213
+ this.deleteText(data);
214
+ }
215
+ }
216
+
217
+
218
+
219
+ setOffsets(x: number, y: number): void {
220
+ this.xOffset = x;
221
+ this.yOffset = y;
222
+ }
223
+
224
+ clear(): void {
225
+ this.itemMap.clear();
226
+ }
227
+
228
+ free(): void {
229
+ this.itemMap = null as any;
230
+ }
231
+ }