@pirireis/webglobeplugins 1.0.2 → 1.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (259) hide show
  1. package/Math/{angle-calculation.ts → angle-calculation.js} +14 -18
  2. package/Math/{arc-cdf-points.ts → arc-cdf-points.js} +272 -329
  3. package/Math/{arc-generate-points-exponantial.ts → arc-generate-points-exponantial.js} +254 -299
  4. package/Math/{arc.ts → arc.js} +292 -421
  5. package/Math/bounds/line-bbox.js +186 -225
  6. package/Math/{circle-cdf-points.ts → circle-cdf-points.js} +78 -143
  7. package/Math/{circle.ts → circle.js} +33 -49
  8. package/Math/{constants.ts → constants.js} +4 -12
  9. package/Math/contour/{quadtreecontours.ts → quadtreecontours.js} +300 -371
  10. package/Math/contour/quadtreecontours1.js +298 -336
  11. package/Math/{finite-line-2d.ts → finite-line-2d.js} +58 -68
  12. package/Math/{haversine.ts → haversine.js} +22 -33
  13. package/Math/index.js +1 -0
  14. package/Math/juction/{arc-plane.ts → arc-plane.js} +143 -203
  15. package/Math/juction/{line-sphere.ts → line-sphere.js} +22 -32
  16. package/Math/juction/{plane-plane.ts → plane-plane.js} +53 -62
  17. package/Math/{line.ts → line.js} +52 -84
  18. package/Math/matrix4.js +1 -0
  19. package/Math/{methods.ts → methods.js} +126 -182
  20. package/Math/{plane.ts → plane.js} +56 -92
  21. package/Math/{quaternion.ts → quaternion.js} +106 -128
  22. package/Math/templete-shapes/{grid-visually-equal.ts → grid-visually-equal.js} +65 -118
  23. package/Math/tessellation/constants.js +1 -0
  24. package/Math/tessellation/{methods.ts → methods.js} +49 -79
  25. package/Math/tessellation/{nearest-value-padding.ts → nearest-value-padding.js} +112 -147
  26. package/Math/tessellation/{spherical-triangle-area.ts → spherical-triangle-area.js} +99 -127
  27. package/Math/tessellation/{tile-merger.ts → tile-merger.js} +429 -578
  28. package/Math/tessellation/{triangle-tessellation.ts → triangle-tessellation.js} +386 -533
  29. package/Math/tessellation/types.js +1 -0
  30. package/Math/types.js +1 -0
  31. package/Math/utils.js +2 -3
  32. package/Math/{vec3.ts → vec3.js} +155 -227
  33. package/Math/{xyz-tile.ts → xyz-tile.js} +18 -26
  34. package/algorithms/search-binary.js +16 -14
  35. package/altitude-locator/adaptors.js +1 -0
  36. package/altitude-locator/keymethod.js +1 -0
  37. package/altitude-locator/plugin.js +344 -445
  38. package/altitude-locator/types.js +21 -26
  39. package/compass-rose/compass-rose-padding-flat.js +230 -274
  40. package/compass-rose/{compass-text-writer.ts → compass-text-writer.js} +155 -210
  41. package/compass-rose/index.js +3 -3
  42. package/{constants.ts → constants.js} +6 -8
  43. package/heatwave/datamanager.js +149 -168
  44. package/heatwave/heatwave.js +206 -261
  45. package/heatwave/index.js +5 -5
  46. package/heatwave/isobar.js +303 -340
  47. package/heatwave/{texture-point-sampler.ts → texture-point-sampler.js} +187 -220
  48. package/investigation-tools/draw/tiles/adapters.js +67 -0
  49. package/investigation-tools/draw/tiles/{tiles.ts → tiles.js} +128 -162
  50. package/jest.config.js +7 -6
  51. package/package.json +1 -1
  52. package/pin/pin-object-array1.js +300 -381
  53. package/pin/pin-point-totem1.js +60 -77
  54. package/programs/arrowfield/arrow-field.js +60 -89
  55. package/programs/arrowfield/logic.js +141 -173
  56. package/programs/data2legend/density-to-legend.js +68 -86
  57. package/programs/data2legend/point-to-density-texture.js +67 -84
  58. package/programs/float2legendwithratio/index.js +2 -3
  59. package/programs/float2legendwithratio/logic.js +118 -144
  60. package/programs/float2legendwithratio/object.js +104 -141
  61. package/programs/helpers/blender.js +58 -73
  62. package/programs/helpers/{fadeaway.ts → fadeaway.js} +60 -73
  63. package/programs/index.js +20 -19
  64. package/programs/line-on-globe/circle-accurate-3d.js +85 -112
  65. package/programs/line-on-globe/circle-accurate-flat.js +148 -200
  66. package/programs/line-on-globe/degree-padding-around-circle-3d.js +102 -134
  67. package/programs/line-on-globe/index.js +1 -0
  68. package/programs/line-on-globe/lines-color-instanced-flat.js +80 -99
  69. package/programs/line-on-globe/linestrip/data.js +4 -0
  70. package/programs/line-on-globe/linestrip/{linestrip.ts → linestrip.js} +93 -152
  71. package/programs/line-on-globe/{naive-accurate-flexible.ts → naive-accurate-flexible.js} +126 -175
  72. package/programs/line-on-globe/util.js +5 -8
  73. package/programs/picking/pickable-polygon-renderer.js +98 -129
  74. package/programs/picking/pickable-renderer.js +98 -130
  75. package/programs/point-on-globe/element-globe-surface-glow.js +93 -122
  76. package/programs/point-on-globe/element-point-glow.js +80 -114
  77. package/programs/point-on-globe/square-pixel-point.js +121 -139
  78. package/programs/polygon-on-globe/{texture-dem-triangles.ts → texture-dem-triangles.js} +163 -207
  79. package/programs/{programcache.ts → programcache.js} +126 -134
  80. package/programs/rings/index.js +1 -1
  81. package/programs/rings/partial-ring/{piece-of-pie.ts → piece-of-pie.js} +152 -222
  82. package/programs/totems/camera-totem-attactment-interface.js +1 -0
  83. package/programs/totems/{camerauniformblock.ts → camerauniformblock.js} +225 -310
  84. package/programs/totems/{canvas-webglobe-info.ts → canvas-webglobe-info.js} +132 -147
  85. package/programs/totems/{dem-textures-manager.ts → dem-textures-manager.js} +257 -360
  86. package/programs/totems/{globe-changes.ts → globe-changes.js} +59 -79
  87. package/programs/totems/gpu-selection-uniform-block.js +99 -127
  88. package/programs/totems/{index.ts → index.js} +2 -2
  89. package/programs/two-d/pixel-padding-for-compass.js +87 -101
  90. package/programs/util.js +14 -19
  91. package/programs/vectorfields/logics/{constants.ts → constants.js} +4 -5
  92. package/programs/vectorfields/logics/{drawrectangleparticles.ts → drawrectangleparticles.js} +80 -115
  93. package/programs/vectorfields/logics/index.js +2 -4
  94. package/programs/vectorfields/logics/particle-ubo.js +16 -0
  95. package/programs/vectorfields/logics/{pixelbased.ts → pixelbased.js} +86 -115
  96. package/programs/vectorfields/logics/ubo.js +51 -57
  97. package/programs/vectorfields/{pingpongbuffermanager.ts → pingpongbuffermanager.js} +99 -113
  98. package/range-tools-on-terrain/bearing-line/{adapters.ts → adapters.js} +114 -154
  99. package/range-tools-on-terrain/bearing-line/{plugin.ts → plugin.js} +457 -569
  100. package/range-tools-on-terrain/bearing-line/types.js +1 -0
  101. package/range-tools-on-terrain/circle-line-chain/{adapters.ts → adapters.js} +85 -104
  102. package/range-tools-on-terrain/circle-line-chain/{chain-list-map.ts → chain-list-map.js} +382 -446
  103. package/range-tools-on-terrain/circle-line-chain/{plugin.ts → plugin.js} +464 -607
  104. package/range-tools-on-terrain/circle-line-chain/types.js +1 -0
  105. package/range-tools-on-terrain/range-ring/{adapters.ts → adapters.js} +93 -114
  106. package/range-tools-on-terrain/range-ring/{enum.ts → enum.js} +2 -2
  107. package/range-tools-on-terrain/range-ring/{plugin.ts → plugin.js} +377 -444
  108. package/range-tools-on-terrain/range-ring/rangeringangletext.js +331 -0
  109. package/range-tools-on-terrain/range-ring/types.js +9 -0
  110. package/semiplugins/interface.js +1 -0
  111. package/semiplugins/lightweight/{line-plugin.ts → line-plugin.js} +221 -342
  112. package/semiplugins/lightweight/{piece-of-pie-plugin.ts → piece-of-pie-plugin.js} +200 -275
  113. package/semiplugins/shape-on-terrain/{arc-plugin.ts → arc-plugin.js} +481 -616
  114. package/semiplugins/shape-on-terrain/{circle-plugin.ts → circle-plugin.js} +444 -588
  115. package/semiplugins/shape-on-terrain/{padding-1-degree.ts → padding-1-degree.js} +539 -713
  116. package/semiplugins/shape-on-terrain/terrain-polygon/{adapters.ts → adapters.js} +55 -69
  117. package/semiplugins/shape-on-terrain/terrain-polygon/data/{cache.ts → cache.js} +102 -149
  118. package/semiplugins/shape-on-terrain/terrain-polygon/data/{index-polygon-map.ts → index-polygon-map.js} +45 -58
  119. package/semiplugins/shape-on-terrain/terrain-polygon/data/{manager.ts → manager.js} +4 -4
  120. package/semiplugins/shape-on-terrain/terrain-polygon/data/master-worker.js +177 -196
  121. package/semiplugins/shape-on-terrain/terrain-polygon/data/{polygon-to-triangles.ts → polygon-to-triangles.js} +100 -144
  122. package/semiplugins/shape-on-terrain/terrain-polygon/data/{random.ts → random.js} +121 -165
  123. package/semiplugins/shape-on-terrain/terrain-polygon/data/types.js +1 -0
  124. package/semiplugins/shape-on-terrain/terrain-polygon/data/{worker-contact.ts → worker-contact.js} +63 -81
  125. package/semiplugins/shape-on-terrain/terrain-polygon/data/worker.js +125 -146
  126. package/semiplugins/shape-on-terrain/terrain-polygon/{terrain-polygon.ts → terrain-polygon.js} +219 -265
  127. package/semiplugins/shape-on-terrain/terrain-polygon/types.js +8 -0
  128. package/semiplugins/shell/bbox-renderer/index.js +2 -0
  129. package/semiplugins/shell/bbox-renderer/{logic.ts → logic.js} +209 -273
  130. package/semiplugins/shell/bbox-renderer/object.js +75 -0
  131. package/semiplugins/type.js +1 -0
  132. package/semiplugins/utility/{container-plugin.ts → container-plugin.js} +94 -126
  133. package/semiplugins/utility/{object-pass-container-plugin.ts → object-pass-container-plugin.js} +80 -101
  134. package/shaders/fragment-toy/firework.js +1 -1
  135. package/shaders/fragment-toy/singularity.js +2 -5
  136. package/tracks/point-heat-map/adaptors/timetracksplugin-format-to-this.js +63 -78
  137. package/tracks/point-heat-map/index.js +1 -0
  138. package/tracks/point-heat-map/plugin-webworker.js +121 -148
  139. package/tracks/point-heat-map/point-to-heat-map-flow.js +121 -150
  140. package/tracks/point-tracks/key-methods.js +2 -3
  141. package/tracks/point-tracks/plugin.js +401 -487
  142. package/tracks/timetracks/adaptors-line-strip.js +65 -79
  143. package/tracks/timetracks/plugin-line-strip.js +240 -295
  144. package/tracks/timetracks/program-line-strip.js +411 -495
  145. package/tracks/timetracks/programpoint-line-strip.js +109 -137
  146. package/types.js +19 -0
  147. package/util/account/bufferoffsetmanager.js +176 -209
  148. package/util/account/create-buffermap-orchastration.js +39 -0
  149. package/util/account/index.js +3 -6
  150. package/util/account/single-attribute-buffer-management/{buffer-manager.ts → buffer-manager.js} +119 -151
  151. package/util/account/single-attribute-buffer-management/{buffer-orchestrator.ts → buffer-orchestrator.js} +212 -238
  152. package/util/account/single-attribute-buffer-management/{buffer-orchestrator1.ts → buffer-orchestrator1.js} +159 -184
  153. package/util/account/single-attribute-buffer-management/{index.ts → index.js} +4 -11
  154. package/util/account/single-attribute-buffer-management/{object-store.ts → object-store.js} +55 -76
  155. package/util/account/single-attribute-buffer-management/types.js +1 -0
  156. package/util/account/util.js +18 -22
  157. package/util/algorithms/index.js +1 -0
  158. package/util/algorithms/search-binary.js +25 -26
  159. package/util/build-strategy/{static-dynamic.ts → static-dynamic.js} +41 -50
  160. package/util/check/index.js +1 -0
  161. package/util/check/typecheck.js +66 -0
  162. package/util/{frame-counter-trigger.ts → frame-counter-trigger.js} +84 -99
  163. package/util/geometry/{index.ts → index.js} +121 -155
  164. package/util/gl-util/buffer/{attribute-loader.ts → attribute-loader.js} +62 -84
  165. package/util/gl-util/buffer/{index.ts → index.js} +3 -6
  166. package/util/gl-util/draw-options/{methods.ts → methods.js} +32 -47
  167. package/util/gl-util/uniform-block/{manager.ts → manager.js} +200 -232
  168. package/util/{globe-default-gl-states.ts → globe-default-gl-states.js} +4 -5
  169. package/util/{helper-methods.ts → helper-methods.js} +8 -9
  170. package/util/index.js +10 -9
  171. package/util/interpolation/index.js +1 -0
  172. package/util/interpolation/timetrack/index.js +2 -9
  173. package/util/interpolation/timetrack/timetrack-interpolator.js +79 -94
  174. package/util/interpolation/timetrack/web-worker.js +46 -51
  175. package/util/picking/{fence.ts → fence.js} +43 -47
  176. package/util/picking/{picker-displayer.ts → picker-displayer.js} +176 -226
  177. package/util/programs/draw-from-pixel-coords.js +164 -201
  178. package/util/programs/{draw-texture-on-canvas.ts → draw-texture-on-canvas.js} +69 -91
  179. package/util/programs/supersampletotextures.js +97 -130
  180. package/util/programs/texturetoglobe.js +128 -153
  181. package/util/shaderfunctions/{geometrytransformations.ts → geometrytransformations.js} +44 -106
  182. package/util/shaderfunctions/index.js +2 -2
  183. package/util/shaderfunctions/nodata.js +2 -4
  184. package/util/shaderfunctions/noisefunctions.js +7 -10
  185. package/util/{webglobjectbuilders.ts → webglobjectbuilders.js} +358 -446
  186. package/vectorfield/arrowfield/adaptor.js +11 -11
  187. package/vectorfield/arrowfield/index.js +3 -3
  188. package/vectorfield/arrowfield/plugin.js +83 -128
  189. package/vectorfield/waveparticles/adaptor.js +15 -16
  190. package/vectorfield/waveparticles/index.js +3 -3
  191. package/vectorfield/waveparticles/{plugin.ts → plugin.js} +415 -506
  192. package/vectorfield/wind/adapters/{image-to-fields.ts → image-to-fields.js} +61 -74
  193. package/vectorfield/wind/adapters/types.js +1 -0
  194. package/vectorfield/wind/{imagetovectorfieldandmagnitude.ts → imagetovectorfieldandmagnitude.js} +53 -78
  195. package/vectorfield/wind/index.js +5 -5
  196. package/vectorfield/wind/{plugin-persistant copy.ts → plugin-persistant copy.js } +364 -461
  197. package/vectorfield/wind/{plugin-persistant.ts → plugin-persistant.js} +375 -483
  198. package/vectorfield/wind/plugin.js +685 -883
  199. package/vectorfield/wind/vectorfieldimage.js +23 -27
  200. package/write-text/{context-text-bulk.ts → context-text-bulk.js} +200 -285
  201. package/write-text/context-text3.js +167 -0
  202. package/write-text/{context-text4.ts → context-text4.js} +146 -231
  203. package/write-text/context-textDELETE.js +94 -125
  204. package/write-text/objectarraylabels/{index.ts → index.js} +2 -2
  205. package/write-text/objectarraylabels/objectarraylabels.js +200 -247
  206. package/Math/matrix4.ts +0 -0
  207. package/Math/mesh/mapbox-delaunay.d.ts +0 -74
  208. package/Math/roadmap.md +0 -10
  209. package/Math/tessellation/constants.ts +0 -1
  210. package/Math/tessellation/roadmap.md +0 -48
  211. package/Math/tessellation/types.ts +0 -1
  212. package/Math/types.ts +0 -68
  213. package/investigation-tools/draw/tiles/adapters.ts +0 -133
  214. package/programs/line-on-globe/linestrip/data.ts +0 -29
  215. package/programs/polygon-on-globe/roadmap.md +0 -8
  216. package/programs/totems/camera-totem-attactment-interface.ts +0 -4
  217. package/programs/vectorfields/logics/particle-ubo.ts +0 -23
  218. package/publish.bat +0 -62
  219. package/range-tools-on-terrain/bearing-line/types.ts +0 -65
  220. package/range-tools-on-terrain/circle-line-chain/types.ts +0 -43
  221. package/range-tools-on-terrain/range-ring/rangeringangletext.ts +0 -396
  222. package/range-tools-on-terrain/range-ring/types.ts +0 -30
  223. package/semiplugins/interface.ts +0 -14
  224. package/semiplugins/shape-on-terrain/goal.md +0 -12
  225. package/semiplugins/shape-on-terrain/terrain-polygon/data/cache-shortcuts.md +0 -20
  226. package/semiplugins/shape-on-terrain/terrain-polygon/data/master-worker.ts +0 -209
  227. package/semiplugins/shape-on-terrain/terrain-polygon/data/readme.md +0 -5
  228. package/semiplugins/shape-on-terrain/terrain-polygon/data/types.ts +0 -37
  229. package/semiplugins/shape-on-terrain/terrain-polygon/notes.md +0 -90
  230. package/semiplugins/shape-on-terrain/terrain-polygon/types.ts +0 -69
  231. package/semiplugins/shell/bbox-renderer/index.ts +0 -2
  232. package/semiplugins/shell/bbox-renderer/object.ts +0 -129
  233. package/semiplugins/type.ts +0 -8
  234. package/terrain-plugin.mmd +0 -83
  235. package/tests/Math/arc-sampling-test.js +0 -367
  236. package/tests/Math/arc-sampling-test.ts +0 -429
  237. package/tests/Math/arc.test.ts +0 -77
  238. package/tests/Math/junction/arc-limit.test.ts +0 -7
  239. package/tests/Math/junction/arc-plane-points.test.ts +0 -196
  240. package/tests/Math/junction/arc-plane.test.ts +0 -172
  241. package/tests/Math/junction/line-sphere.test.ts +0 -127
  242. package/tests/Math/junction/plane-plane.test.ts +0 -91
  243. package/tests/Math/plane-test.ts +0 -17
  244. package/tests/Math/plane.test.ts +0 -43
  245. package/tests/Math/vec3.test.ts +0 -33
  246. package/tracks/point-heat-map/readme.md +0 -15
  247. package/tracks/timetracks/readme.md +0 -1
  248. package/tsconfig.json +0 -22
  249. package/types/@pirireis/webglobe.d.ts +0 -102
  250. package/types/delaunator.d.ts +0 -40
  251. package/types/earcut.d.ts +0 -11
  252. package/types/rbush.d.ts +0 -57
  253. package/types.ts +0 -319
  254. package/util/account/create-buffermap-orchastration.ts +0 -85
  255. package/util/account/single-attribute-buffer-management/types.ts +0 -43
  256. package/util/check/typecheck.ts +0 -74
  257. package/vectorfield/wind/adapters/types.ts +0 -12
  258. package/write-text/context-text3.ts +0 -252
  259. package/write-text/objectarraylabels/objectarraylabels.d.ts +0 -72
@@ -1,295 +1,240 @@
1
- /**
2
- * Author: Toprak Nihat Deniz Ozturk
3
- */
4
-
5
-
6
-
7
- import TrackGlowLineProgram from './program-line-strip';
8
- import PointProgram from './programpoint-line-strip';
9
-
10
- /**
11
- * @typedef {Float32Array} TimeTrackMultiColorData | A linestring is representation, let A{a1, a2, a3}, B{b1, b2} be the points of the line.
12
- * TimeTrackMultiColorData is [
13
- * a1x, a1y, a1z, a1time, a1r, a1g, a1b, a1time, a3time,
14
- * a2x, a2y, a2z, a2time, a2r, a2g, a2b, a1time, a3time,
15
- * a3x, a3y, a3z, a3time, a3r, a3g, a3b, a1time, a3time,
16
- * NaN, NaN, NaN, NaN, NaN, NaN, NaN, NaN, NaN,
17
- * b1x, b1y, b1z, b1time, b1r, b1g, b1b, b1time, b2time,
18
- * b2x, b2y, b2z, b2time, b2r, b2g, b2b, BstartTime, BendTime
19
- * ]
20
- * there is a cutting point between A and B
21
- *
22
- * x, y is xy coordinates are in between 0, +1 for -180 to +180 longitude and -90 to +90 latitude
23
- * z is height in meters
24
- */
25
-
26
-
27
-
28
-
29
-
30
- /**
31
- * Access following methods through `plugin.program.` :
32
- * * setGamma
33
- * * setExposure
34
- * * setAlphaThreshold
35
- * * setWeights
36
- * * setHeadPercentage
37
- * * setRouteAlpha
38
- * * setFinalAlphaRatio
39
-
40
- uses float32array in a * {@link TimeTrackMultiColorData} format
41
-
42
- */
43
- export default class TimeTrackMultiColorPlugin {
44
- /**
45
- * @param {String} id
46
- * @param {Object} options
47
- * @param {TimeTrackMultiColorData} options.data {@link TimeTrackMultiColorData}
48
- * @param {number} options.headPercentage 0 ~ 1
49
- * @param {number} options.routeAlpha 0 ~ 1
50
- * @param {Array.<Number>} options.weights [w1, w2, w3, w4, w5]
51
- * @param {number} options.alphaThreshold 0 ~ 1
52
- * @param {number} options.exposure 0 ~ inf
53
- * @param {number} options.gamma 0 ~ inf
54
- * @param {number} options.finalAlphaRatio 0 ~ 1
55
- * @param {number} pointOptions.opacity 0 ~ 1
56
- * @param {number} pointOptions.pointSize 0 ~ inf
57
- * @param {boolean} pointOptions.isOn true | false
58
- */
59
- constructor(id, options = {}, { opacity = 1.0, pointSize = 1, isOn = false } = {}) {
60
- this.id = id;
61
-
62
- this.globe = null;
63
- this.gl = null;
64
- this.program = null;
65
- this._headTime = 0;
66
- this._tailTime = 0;
67
-
68
- this._data = options.data || null;
69
- this._options = options;
70
- this._pointOptions = { opacity, pointSize, isOn };
71
- this.program = null;
72
-
73
- this._transporArr = new Float32Array(3);
74
-
75
- this._ready = false;
76
-
77
- this.pointProgram = null;
78
-
79
- this._attrBuffer = null;
80
- }
81
-
82
- // ----------------------------------
83
- // --- user methods ---
84
- // ----------------------------------
85
-
86
- setHeadAndTailTime(headTime, tailTime) {
87
- this._headTime = headTime;
88
- this._tailTime = tailTime;
89
- // console.log("setHeadAndTailTime", headTime, tailTime);
90
- this.pointProgram?.setHeadTime(headTime);
91
- this.globe.DrawRender();
92
- }
93
-
94
- setBlurWeights(weights) {
95
- this.program.setBlurWeights(weights);
96
- this.globe.DrawRender();
97
- }
98
-
99
- setHeadPercentage(headPercentage) {
100
- this.program.setHeadPercentage(headPercentage);
101
- this.globe.DrawRender();
102
- }
103
-
104
- setRouteAlpha(routeAlpha) {
105
- this.program.setRouteAlpha(routeAlpha);
106
- this.globe.DrawRender();
107
- }
108
-
109
- setFinalAlphaRatio(finalAlphaRatio) {
110
- this.program.setFinalAlphaRatio(finalAlphaRatio);
111
- this.globe.DrawRender();
112
- }
113
-
114
- setGamma(gamma) {
115
- this.program.setGamma(gamma);
116
- this.globe.DrawRender();
117
- }
118
-
119
- setExposure(exposure) {
120
- this.program.setExposure(exposure);
121
- this.globe.DrawRender();
122
- }
123
-
124
- setBlurRepetition(repetition) {
125
- this.program.setBlurRepetition(repetition);
126
- this.globe.DrawRender();
127
- }
128
-
129
-
130
-
131
- // ---------------point program setters-------------------
132
-
133
- setPointOpacity(opacity) {
134
- this._pointOptions.opacity = opacity;
135
- if (this.pointProgram) {
136
- this.pointProgram.setOpacity(opacity);
137
- this.globe.DrawRender();
138
- }
139
- }
140
-
141
- setPointSize(size) {
142
- this._pointOptions.pointSize = size;
143
- if (this.pointProgram) {
144
- this.pointProgram.setPointSize(size);
145
- this.globe.DrawRender();
146
- }
147
- }
148
-
149
- pointSwitch(isOn) {
150
- if (isOn && !this.pointProgram) {
151
- this.pointProgram = this._createPointProgram();
152
- } else {
153
- this._deletePointProgram();
154
- }
155
-
156
- }
157
-
158
- // ------------------------------------------------------------
159
-
160
- _createPointProgram() {
161
- const { gl } = this;
162
- const program = new PointProgram(gl, this.globe, this._attrBuffer, this._pointOptions);
163
- program.setDrawCount(this._totalSize);
164
- return program;
165
- }
166
-
167
- _deletePointProgram() {
168
- if (this.pointProgram) this.pointProgram.free();
169
- this.pointProgram = null;
170
- }
171
-
172
- // -------------------------------------------------------------
173
-
174
- isReady() {
175
- return this._ready;
176
- }
177
-
178
- /**
179
- * @param {TimeTrackMultiColorData} data {@link TimeTrackMultiColorData}
180
- * Check Class constructor
181
- */
182
- setData(data) {
183
- if (this.gl) {
184
- this._ready = false;
185
- this.setDataAsFloat32Array(data);
186
- this._ready = true;
187
- } else {
188
- this._data = data;
189
- this._ready = false;
190
- }
191
- }
192
-
193
- /**
194
- * @param {TimeTrackMultiColorData} data {@link TimeTrackMultiColorData}
195
- * @param {number} totalSize | if not provided, it is calculated from float32Array.length / 9. Use if you want to draw first n points.
196
- */
197
- setDataAsFloat32Array(data, totalSize = null) {
198
-
199
- const { gl, _attrBuffer } = this;
200
- gl.bindBuffer(gl.ARRAY_BUFFER, _attrBuffer);
201
- gl.bufferData(gl.ARRAY_BUFFER, data, gl.STATIC_DRAW);
202
- gl.bindBuffer(gl.ARRAY_BUFFER, null);
203
-
204
-
205
- // this.program.setInBuffer(data);
206
-
207
- // this.pointProgram.setData(data);
208
- if (totalSize) {
209
- this._totalSize = totalSize;
210
- } else {
211
- this._totalSize = data.length / 9;
212
- }
213
- this.program.setTotalLength(this._totalSize);
214
- this.pointProgram?.setDrawCount(this._totalSize / 2);
215
-
216
- this._ready = true;
217
- }
218
-
219
- // ------------------------------
220
- // --- globe Methods ---
221
- // ------------------------------
222
-
223
- draw3D(projMatrix, modelviewMatrix, transPos) {
224
- if (!this._ready) return;
225
- const { _headTime, _tailTime, program, _transporArr, globe } = this;
226
- this.pointProgram?.draw();
227
-
228
- _transporArr.set([transPos.x, transPos.y, transPos.z], 0);
229
- const geomType = globe.api_GetCurrentGeometry();
230
- if (geomType === 0) {
231
- program.draw(_headTime, _tailTime, projMatrix, modelviewMatrix, _transporArr);
232
- } else if (geomType === 1) {
233
- const { width, height } = globe.api_GetCurrentWorldWH();
234
- program.draw(_headTime, _tailTime, projMatrix, modelviewMatrix, _transporArr,
235
- [width, height]);
236
- } else {
237
- console.error("Unknown geometry type", geomType);
238
- }
239
- }
240
-
241
- resize(width, height) {
242
- const { program, globe } = this;
243
- width = width || globe.api_ScrW();
244
- height = height || globe.api_ScrH();
245
- program.resize(width, height);
246
- }
247
-
248
-
249
- init(globe, gl) {
250
- this.globe = globe;
251
- this.gl = gl;
252
- this._attrBuffer = gl.createBuffer();
253
- this.program = new TrackGlowLineProgram(gl, this._attrBuffer, globe.api_ScrW(), globe.api_ScrH(), this._options);
254
- if (this._pointOptions?.isOn) this.pointProgram = new PointProgram(gl, globe, this._attrBuffer);
255
-
256
- // this.pointProgram.setAttrBuffer(_attrBuffer);
257
- this.setGeometry();
258
- if (this._data) {
259
- this._ready = true;
260
- this.setDataAsFloat32Array(this._data);
261
-
262
- this._data = null;
263
- }
264
- this.resize();
265
- }
266
-
267
-
268
- free() {
269
- const { gl, _attrBuffer } = this;
270
- this.program.free();
271
- gl.deleteBuffer(_attrBuffer);
272
- }
273
-
274
-
275
- setGeometry() {
276
- const { globe, program } = this;
277
- program.setIs3D(globe.api_GetCurrentGeometry() === 0);
278
- }
279
-
280
- // ----------------------------------
281
- // --- implicit methods ---
282
- // ----------------------------------
283
-
284
-
285
- _latLongToPixelXY(latitude, longitude) {
286
- return {
287
- x: (longitude + 180) / 360,
288
- y: (90 - latitude) / 180
289
- };
290
- }
291
- }
292
-
293
-
294
-
295
-
1
+ /**
2
+ * Author: Toprak Nihat Deniz Ozturk
3
+ */
4
+ import TrackGlowLineProgram from './program-line-strip';
5
+ import PointProgram from './programpoint-line-strip';
6
+ /**
7
+ * @typedef {Float32Array} TimeTrackMultiColorData | A linestring is representation, let A{a1, a2, a3}, B{b1, b2} be the points of the line.
8
+ * TimeTrackMultiColorData is [
9
+ * a1x, a1y, a1z, a1time, a1r, a1g, a1b, a1time, a3time,
10
+ * a2x, a2y, a2z, a2time, a2r, a2g, a2b, a1time, a3time,
11
+ * a3x, a3y, a3z, a3time, a3r, a3g, a3b, a1time, a3time,
12
+ * NaN, NaN, NaN, NaN, NaN, NaN, NaN, NaN, NaN,
13
+ * b1x, b1y, b1z, b1time, b1r, b1g, b1b, b1time, b2time,
14
+ * b2x, b2y, b2z, b2time, b2r, b2g, b2b, BstartTime, BendTime
15
+ * ]
16
+ * there is a cutting point between A and B
17
+ *
18
+ * x, y is xy coordinates are in between 0, +1 for -180 to +180 longitude and -90 to +90 latitude
19
+ * z is height in meters
20
+ */
21
+ /**
22
+ * Access following methods through `plugin.program.` :
23
+ * * setGamma
24
+ * * setExposure
25
+ * * setAlphaThreshold
26
+ * * setWeights
27
+ * * setHeadPercentage
28
+ * * setRouteAlpha
29
+ * * setFinalAlphaRatio
30
+
31
+ uses float32array in a * {@link TimeTrackMultiColorData} format
32
+
33
+ */
34
+ export default class TimeTrackMultiColorPlugin {
35
+ /**
36
+ * @param {String} id
37
+ * @param {Object} options
38
+ * @param {TimeTrackMultiColorData} options.data {@link TimeTrackMultiColorData}
39
+ * @param {number} options.headPercentage 0 ~ 1
40
+ * @param {number} options.routeAlpha 0 ~ 1
41
+ * @param {Array.<Number>} options.weights [w1, w2, w3, w4, w5]
42
+ * @param {number} options.alphaThreshold 0 ~ 1
43
+ * @param {number} options.exposure 0 ~ inf
44
+ * @param {number} options.gamma 0 ~ inf
45
+ * @param {number} options.finalAlphaRatio 0 ~ 1
46
+ * @param {number} pointOptions.opacity 0 ~ 1
47
+ * @param {number} pointOptions.pointSize 0 ~ inf
48
+ * @param {boolean} pointOptions.isOn true | false
49
+ */
50
+ constructor(id, options = {}, { opacity = 1.0, pointSize = 1, isOn = false } = {}) {
51
+ this.id = id;
52
+ this.globe = null;
53
+ this.gl = null;
54
+ this.program = null;
55
+ this._headTime = 0;
56
+ this._tailTime = 0;
57
+ this._data = options.data || null;
58
+ this._options = options;
59
+ this._pointOptions = { opacity, pointSize, isOn };
60
+ this.program = null;
61
+ this._transporArr = new Float32Array(3);
62
+ this._ready = false;
63
+ this.pointProgram = null;
64
+ this._attrBuffer = null;
65
+ }
66
+ // ----------------------------------
67
+ // --- user methods ---
68
+ // ----------------------------------
69
+ setHeadAndTailTime(headTime, tailTime) {
70
+ this._headTime = headTime;
71
+ this._tailTime = tailTime;
72
+ // console.log("setHeadAndTailTime", headTime, tailTime);
73
+ this.pointProgram?.setHeadTime(headTime);
74
+ this.globe.DrawRender();
75
+ }
76
+ setBlurWeights(weights) {
77
+ this.program.setBlurWeights(weights);
78
+ this.globe.DrawRender();
79
+ }
80
+ setHeadPercentage(headPercentage) {
81
+ this.program.setHeadPercentage(headPercentage);
82
+ this.globe.DrawRender();
83
+ }
84
+ setRouteAlpha(routeAlpha) {
85
+ this.program.setRouteAlpha(routeAlpha);
86
+ this.globe.DrawRender();
87
+ }
88
+ setFinalAlphaRatio(finalAlphaRatio) {
89
+ this.program.setFinalAlphaRatio(finalAlphaRatio);
90
+ this.globe.DrawRender();
91
+ }
92
+ setGamma(gamma) {
93
+ this.program.setGamma(gamma);
94
+ this.globe.DrawRender();
95
+ }
96
+ setExposure(exposure) {
97
+ this.program.setExposure(exposure);
98
+ this.globe.DrawRender();
99
+ }
100
+ setBlurRepetition(repetition) {
101
+ this.program.setBlurRepetition(repetition);
102
+ this.globe.DrawRender();
103
+ }
104
+ // ---------------point program setters-------------------
105
+ setPointOpacity(opacity) {
106
+ this._pointOptions.opacity = opacity;
107
+ if (this.pointProgram) {
108
+ this.pointProgram.setOpacity(opacity);
109
+ this.globe.DrawRender();
110
+ }
111
+ }
112
+ setPointSize(size) {
113
+ this._pointOptions.pointSize = size;
114
+ if (this.pointProgram) {
115
+ this.pointProgram.setPointSize(size);
116
+ this.globe.DrawRender();
117
+ }
118
+ }
119
+ pointSwitch(isOn) {
120
+ if (isOn && !this.pointProgram) {
121
+ this.pointProgram = this._createPointProgram();
122
+ }
123
+ else {
124
+ this._deletePointProgram();
125
+ }
126
+ }
127
+ // ------------------------------------------------------------
128
+ _createPointProgram() {
129
+ const { gl } = this;
130
+ const program = new PointProgram(gl, this.globe, this._attrBuffer, this._pointOptions);
131
+ program.setDrawCount(this._totalSize);
132
+ return program;
133
+ }
134
+ _deletePointProgram() {
135
+ if (this.pointProgram)
136
+ this.pointProgram.free();
137
+ this.pointProgram = null;
138
+ }
139
+ // -------------------------------------------------------------
140
+ isReady() {
141
+ return this._ready;
142
+ }
143
+ /**
144
+ * @param {TimeTrackMultiColorData} data {@link TimeTrackMultiColorData}
145
+ * Check Class constructor
146
+ */
147
+ setData(data) {
148
+ if (this.gl) {
149
+ this._ready = false;
150
+ this.setDataAsFloat32Array(data);
151
+ this._ready = true;
152
+ }
153
+ else {
154
+ this._data = data;
155
+ this._ready = false;
156
+ }
157
+ }
158
+ /**
159
+ * @param {TimeTrackMultiColorData} data {@link TimeTrackMultiColorData}
160
+ * @param {number} totalSize | if not provided, it is calculated from float32Array.length / 9. Use if you want to draw first n points.
161
+ */
162
+ setDataAsFloat32Array(data, totalSize = null) {
163
+ const { gl, _attrBuffer } = this;
164
+ gl.bindBuffer(gl.ARRAY_BUFFER, _attrBuffer);
165
+ gl.bufferData(gl.ARRAY_BUFFER, data, gl.STATIC_DRAW);
166
+ gl.bindBuffer(gl.ARRAY_BUFFER, null);
167
+ // this.program.setInBuffer(data);
168
+ // this.pointProgram.setData(data);
169
+ if (totalSize) {
170
+ this._totalSize = totalSize;
171
+ }
172
+ else {
173
+ this._totalSize = data.length / 9;
174
+ }
175
+ this.program.setTotalLength(this._totalSize);
176
+ this.pointProgram?.setDrawCount(this._totalSize / 2);
177
+ this._ready = true;
178
+ }
179
+ // ------------------------------
180
+ // --- globe Methods ---
181
+ // ------------------------------
182
+ draw3D(projMatrix, modelviewMatrix, transPos) {
183
+ if (!this._ready)
184
+ return;
185
+ const { _headTime, _tailTime, program, _transporArr, globe } = this;
186
+ this.pointProgram?.draw();
187
+ _transporArr.set([transPos.x, transPos.y, transPos.z], 0);
188
+ const geomType = globe.api_GetCurrentGeometry();
189
+ if (geomType === 0) {
190
+ program.draw(_headTime, _tailTime, projMatrix, modelviewMatrix, _transporArr);
191
+ }
192
+ else if (geomType === 1) {
193
+ const { width, height } = globe.api_GetCurrentWorldWH();
194
+ program.draw(_headTime, _tailTime, projMatrix, modelviewMatrix, _transporArr, [width, height]);
195
+ }
196
+ else {
197
+ console.error("Unknown geometry type", geomType);
198
+ }
199
+ }
200
+ resize(width, height) {
201
+ const { program, globe } = this;
202
+ width = width || globe.api_ScrW();
203
+ height = height || globe.api_ScrH();
204
+ program.resize(width, height);
205
+ }
206
+ init(globe, gl) {
207
+ this.globe = globe;
208
+ this.gl = gl;
209
+ this._attrBuffer = gl.createBuffer();
210
+ this.program = new TrackGlowLineProgram(gl, this._attrBuffer, globe.api_ScrW(), globe.api_ScrH(), this._options);
211
+ if (this._pointOptions?.isOn)
212
+ this.pointProgram = new PointProgram(gl, globe, this._attrBuffer);
213
+ // this.pointProgram.setAttrBuffer(_attrBuffer);
214
+ this.setGeometry();
215
+ if (this._data) {
216
+ this._ready = true;
217
+ this.setDataAsFloat32Array(this._data);
218
+ this._data = null;
219
+ }
220
+ this.resize();
221
+ }
222
+ free() {
223
+ const { gl, _attrBuffer } = this;
224
+ this.program.free();
225
+ gl.deleteBuffer(_attrBuffer);
226
+ }
227
+ setGeometry() {
228
+ const { globe, program } = this;
229
+ program.setIs3D(globe.api_GetCurrentGeometry() === 0);
230
+ }
231
+ // ----------------------------------
232
+ // --- implicit methods ---
233
+ // ----------------------------------
234
+ _latLongToPixelXY(latitude, longitude) {
235
+ return {
236
+ x: (longitude + 180) / 360,
237
+ y: (90 - latitude) / 180
238
+ };
239
+ }
240
+ }