@pirireis/webglobeplugins 0.9.9 → 0.9.10

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 (211) hide show
  1. package/Math/angle-calculation.js +15 -0
  2. package/Math/arc.js +65 -0
  3. package/Math/bounds/line-bbox.js +188 -0
  4. package/Math/constants.js +9 -0
  5. package/Math/frustum/camera.js +24 -0
  6. package/Math/frustum/from-globeinfo.js +48 -0
  7. package/Math/frustum/types.js +2 -0
  8. package/Math/globe-util/horizon-plane.js +112 -0
  9. package/Math/index.js +1 -0
  10. package/Math/juction/arc-plane.js +83 -0
  11. package/Math/juction/line-sphere.js +25 -0
  12. package/Math/juction/plane-plane.js +58 -0
  13. package/Math/line.js +56 -0
  14. package/Math/matrix4.js +1 -0
  15. package/Math/methods.js +201 -0
  16. package/Math/plane.js +60 -0
  17. package/Math/quaternion.js +104 -0
  18. package/Math/types.js +2 -0
  19. package/Math/utils.js +4 -0
  20. package/Math/vec3.js +126 -0
  21. package/algorithms/search-binary.js +19 -0
  22. package/altitude-locator/adaptors.js +1 -0
  23. package/altitude-locator/draw-subset-obj.js +18 -0
  24. package/altitude-locator/keymethod.js +1 -0
  25. package/altitude-locator/plugin.js +341 -0
  26. package/altitude-locator/types.js +23 -0
  27. package/arrowfield/adaptor.js +14 -0
  28. package/arrowfield/index.js +10 -0
  29. package/arrowfield/plugin.js +86 -0
  30. package/bearing-line/index.js +8 -0
  31. package/bearing-line/plugin.js +449 -0
  32. package/circle-line-chain/chain-list-map.js +205 -0
  33. package/circle-line-chain/init.js +1 -0
  34. package/circle-line-chain/plugin.js +424 -0
  35. package/circle-line-chain/util.js +5 -0
  36. package/compass-rose/compass-rose-padding-flat.js +225 -0
  37. package/compass-rose/compass-text-writer.js +153 -0
  38. package/compass-rose/index.js +7 -0
  39. package/compassrose/compassrose.js +296 -0
  40. package/compassrose/index.js +8 -0
  41. package/globe-types.js +1 -0
  42. package/heatwave/index.js +10 -0
  43. package/heatwave/isobar/objectarraylabels.js +202 -0
  44. package/heatwave/isobar/plugin.js +343 -0
  45. package/heatwave/isobar/quadtreecontours.js +300 -0
  46. package/heatwave/plugins/heatwaveglobeshell.js +206 -0
  47. package/jest.config.js +7 -0
  48. package/package.json +4 -4
  49. package/partialrings/buffer-manager.js +81 -0
  50. package/partialrings/index.js +41 -0
  51. package/partialrings/plugin.js +135 -0
  52. package/partialrings/program.js +286 -0
  53. package/pin/pin-object-array.js +305 -0
  54. package/pin/pin-point-totem.js +60 -0
  55. package/point-heat-map/adaptors/timetracksplugin-format-to-this.js +66 -0
  56. package/point-heat-map/index.js +1 -0
  57. package/point-heat-map/plugin-webworker.js +126 -0
  58. package/point-heat-map/point-to-heat-map-flow.js +127 -0
  59. package/point-tracks/key-methods.js +5 -0
  60. package/point-tracks/plugin.js +338 -0
  61. package/programs/arrowfield/index.js +7 -0
  62. package/programs/arrowfield/logic.js +257 -0
  63. package/programs/arrowfield/object.js +66 -0
  64. package/programs/data2legend/density-to-legend.js +101 -0
  65. package/programs/data2legend/point-to-density-texture.js +100 -0
  66. package/programs/float2legendwithratio/index.js +8 -0
  67. package/programs/float2legendwithratio/logic.js +171 -0
  68. package/programs/float2legendwithratio/object.js +110 -0
  69. package/programs/globe-util/is-globe-moved.js +21 -0
  70. package/programs/globeshell/index.js +8 -0
  71. package/programs/globeshell/noise/noises.js +1 -0
  72. package/programs/globeshell/wiggle/index.js +8 -0
  73. package/programs/globeshell/wiggle/logic.js +345 -0
  74. package/programs/globeshell/wiggle/object.js +72 -0
  75. package/programs/helpers/blender/index.js +1 -0
  76. package/programs/helpers/blender/program.js +79 -0
  77. package/programs/helpers/fadeaway/index.js +7 -0
  78. package/programs/helpers/fadeaway/logic.js +72 -0
  79. package/programs/helpers/fadeaway/object.js +20 -0
  80. package/programs/helpers/index.js +8 -0
  81. package/programs/index.js +58 -0
  82. package/programs/interface.js +1 -0
  83. package/programs/line-on-globe/angled-line.js +176 -0
  84. package/programs/line-on-globe/circle-accurate-3d.js +141 -0
  85. package/programs/line-on-globe/circle-accurate-flat.js +216 -0
  86. package/programs/line-on-globe/circle-accurate.js +178 -0
  87. package/programs/line-on-globe/circle.js +167 -0
  88. package/programs/line-on-globe/degree-padding-around-circle-3d.js +159 -0
  89. package/programs/line-on-globe/index.js +1 -0
  90. package/programs/line-on-globe/lines-color-instanced-flat.js +136 -0
  91. package/programs/line-on-globe/linestrip.js +171 -0
  92. package/programs/line-on-globe/naive-accurate-flexible.js +195 -0
  93. package/programs/line-on-globe/to-the-surface.js +111 -0
  94. package/programs/line-on-globe/util.js +8 -0
  95. package/programs/picking/pickable-renderer.js +188 -0
  96. package/programs/point-on-globe/element-globe-surface-glow.js +142 -0
  97. package/programs/point-on-globe/element-point-glow.js +153 -0
  98. package/programs/point-on-globe/square-pixel-point.js +174 -0
  99. package/programs/programcache.js +131 -0
  100. package/programs/rings/distancering/circleflatprogram.js +156 -0
  101. package/programs/rings/distancering/circlepaddingfreeangleprogram.js +369 -0
  102. package/programs/rings/distancering/circlepaddysharedbuffer.js +357 -0
  103. package/programs/rings/distancering/index.js +14 -0
  104. package/programs/rings/distancering/paddyflatprogram.js +172 -0
  105. package/programs/rings/distancering/paddyflatprogram2d.js +174 -0
  106. package/programs/rings/distancering/paddyflatprogram3d.js +172 -0
  107. package/programs/rings/distancering/shader.js +1 -0
  108. package/programs/rings/index.js +17 -0
  109. package/programs/rings/partial-ring/piece-of-pie.js +275 -0
  110. package/programs/totems/camerauniformblock.js +160 -0
  111. package/programs/totems/canvas-webglobe-info.js +110 -0
  112. package/programs/totems/gpu-selection-uniform-block.js +108 -0
  113. package/programs/totems/index.js +40 -0
  114. package/programs/two-d/pixel-circle.js +1 -0
  115. package/programs/two-d/pixel-padding-for-compass.js +162 -0
  116. package/programs/util.js +17 -0
  117. package/programs/vectorfields/index.js +23 -0
  118. package/programs/vectorfields/logics/drawrectangleparticles.js +107 -0
  119. package/programs/vectorfields/logics/index.js +12 -0
  120. package/programs/vectorfields/logics/pixelbased.js +142 -0
  121. package/programs/vectorfields/logics/ubo.js +63 -0
  122. package/programs/vectorfields/pingpongbuffermanager.js +76 -0
  123. package/rangerings/enum.js +5 -0
  124. package/rangerings/index.js +15 -0
  125. package/rangerings/plugin.js +560 -0
  126. package/rangerings/rangeringangletext.js +329 -0
  127. package/rangerings/ring-account.js +117 -0
  128. package/shaders/fragment-toy/firework.js +58 -0
  129. package/shaders/fragment-toy/singularity.js +59 -0
  130. package/shape-on-terrain/arc/naive/plugin.js +252 -0
  131. package/timetracks/adaptors-line-strip.js +71 -0
  132. package/timetracks/adaptors.js +122 -0
  133. package/timetracks/index.js +19 -0
  134. package/timetracks/plugin-line-strip.js +250 -0
  135. package/timetracks/plugin.js +258 -0
  136. package/timetracks/program-line-strip.js +611 -0
  137. package/timetracks/program.js +772 -0
  138. package/timetracks/programpoint-line-strip.js +154 -0
  139. package/timetracks/programpoint.js +147 -0
  140. package/types.js +15 -0
  141. package/util/account/bufferoffsetmanager.js +179 -0
  142. package/util/account/index.js +23 -0
  143. package/util/account/single-attribute-buffer-management/buffer-manager.js +108 -0
  144. package/util/account/single-attribute-buffer-management/buffer-orchestrator.js +150 -0
  145. package/util/account/single-attribute-buffer-management/index.js +9 -0
  146. package/util/account/single-attribute-buffer-management/object-store.js +51 -0
  147. package/util/account/single-attribute-buffer-management/types.js +2 -0
  148. package/util/account/util.js +22 -0
  149. package/util/algorithms/index.js +1 -0
  150. package/util/algorithms/search-binary.js +28 -0
  151. package/util/check/get.js +18 -0
  152. package/util/check/index.js +1 -0
  153. package/util/check/typecheck.js +49 -0
  154. package/util/geometry/index.js +51 -0
  155. package/util/gl-util/buffer/attribute-loader.js +69 -0
  156. package/util/gl-util/buffer/index.js +6 -0
  157. package/util/gl-util/buffer/types.js +1 -0
  158. package/util/gl-util/draw-options/methods.js +38 -0
  159. package/util/gl-util/draw-options/types.js +15 -0
  160. package/util/gl-util/uniform-block/manager.js +156 -0
  161. package/util/gl-util/uniform-block/shader.js +1 -0
  162. package/util/gl-util/uniform-block/types.js +8 -0
  163. package/util/heatwavedatamanager/datamanager.js +152 -0
  164. package/util/heatwavedatamanager/index.js +10 -0
  165. package/util/heatwavedatamanager/pointcoordinatesdatacalculator.js +122 -0
  166. package/util/heatwavedatamanager/pointcoordsmeta.js +20 -0
  167. package/util/index.js +57 -0
  168. package/util/interpolation/index.js +1 -0
  169. package/util/interpolation/timetrack/index.js +5 -0
  170. package/util/interpolation/timetrack/timetrack-interpolator.js +79 -0
  171. package/util/interpolation/timetrack/web-worker-str.js +183 -0
  172. package/util/interpolation/timetrack/web-worker.js +48 -0
  173. package/util/jshelpers/data-filler.js +20 -0
  174. package/util/jshelpers/equality.js +20 -0
  175. package/util/jshelpers/index.js +37 -0
  176. package/util/jshelpers/timefilters.js +32 -0
  177. package/util/picking/fence.js +46 -0
  178. package/util/picking/picker-displayer.js +139 -0
  179. package/util/programs/draw-texture-on-canvas.js +89 -0
  180. package/util/programs/index.js +17 -0
  181. package/util/programs/shapesonglobe.js +214 -0
  182. package/util/programs/supersampletotextures.js +113 -0
  183. package/util/programs/texturetoglobe.js +182 -0
  184. package/util/shaderfunctions/geometrytransformations.js +340 -0
  185. package/util/shaderfunctions/index.js +18 -0
  186. package/util/shaderfunctions/nodata.js +11 -0
  187. package/util/shaderfunctions/noisefunctions.js +43 -0
  188. package/util/surface-line-data/arc-bboxes.js +25 -0
  189. package/util/surface-line-data/arcs-to-cuts.js +50 -0
  190. package/util/surface-line-data/cut-arc.js +1 -0
  191. package/util/surface-line-data/flow.js +28 -0
  192. package/util/surface-line-data/rbush-manager.js +1 -0
  193. package/util/surface-line-data/types.js +1 -0
  194. package/util/surface-line-data/web-worker.js +1 -0
  195. package/util/webglobe/gldefaultstates.js +7 -0
  196. package/util/webglobe/index.js +18 -0
  197. package/util/webglobe/rasteroverlay.js +78 -0
  198. package/util/webglobjectbuilders.js +388 -0
  199. package/util/webglobjectbuilders1.js +237 -0
  200. package/waveparticles/adaptor.js +17 -0
  201. package/waveparticles/index.js +10 -0
  202. package/waveparticles/plugin.js +266 -0
  203. package/wind/imagetovectorfieldandmagnitude.js +35 -0
  204. package/wind/index.js +14 -0
  205. package/wind/plugin.js +926 -0
  206. package/wind/vectorfieldimage.js +25 -0
  207. package/write-text/attached-text-writer.js +91 -0
  208. package/write-text/context-text.js +98 -0
  209. package/write-text/context-text3.js +155 -0
  210. package/write-text/index.js +5 -0
  211. package/write-text/writer-plugin.js +8 -0
@@ -0,0 +1,341 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PointGlowLineToEarthPlugin = void 0;
4
+ require("./types.js");
5
+ const pickable_renderer_js_1 = require("../programs/picking/pickable-renderer.js");
6
+ const element_point_glow_js_1 = require("../programs/point-on-globe/element-point-glow.js");
7
+ const element_globe_surface_glow_js_1 = require("../programs/point-on-globe/element-globe-surface-glow.js");
8
+ const naive_accurate_flexible_js_1 = require("../programs/line-on-globe/naive-accurate-flexible.js");
9
+ const account_1 = require("../util/account");
10
+ const picker_displayer_js_1 = require("../util/picking/picker-displayer.js");
11
+ const methods_js_1 = require("../Math/methods.js");
12
+ const typecheck_js_1 = require("../util/check/typecheck.js");
13
+ const attribute_loader_1 = require("../util/gl-util/buffer/attribute-loader");
14
+ const camerauniformblock_js_1 = require("../programs/totems/camerauniformblock.js");
15
+ /**
16
+ * is used with depth we can create a line from surface to the point.
17
+ */
18
+ const glowOverSize = 1.35; // 1.25 is the default value in the shader
19
+ class PointGlowLineToEarthPlugin {
20
+ constructor({ isGlowPointOn = true, isGlowSurfaceOn = true }) {
21
+ this.globe = null;
22
+ this.gl = null;
23
+ this._pickableWrapper = {};
24
+ this._glowPointWrapper = {};
25
+ this._glowSurfaceWrapper = {};
26
+ this._lineProgramWrapper = {};
27
+ this._modes = {
28
+ isGlowPointOn,
29
+ isGlowSurfaceOn
30
+ };
31
+ this._hoveredObjectId = null;
32
+ this._lastWH = { w: 0, h: 0 };
33
+ this._opacity = 1.0;
34
+ this._hoverAgentParams = {
35
+ timePass: 0,
36
+ timeGap: 150,
37
+ stillPicking: false
38
+ };
39
+ this._cameraBlockTotem = null;
40
+ this._tickPhase = 0;
41
+ this._parametersChanged = false;
42
+ }
43
+ init(globe, gl) {
44
+ this.globe = globe;
45
+ this.gl = gl;
46
+ this._init();
47
+ this._cameraBlockTotem = camerauniformblock_js_1.CameraUniformBlockTotemCache.get(this.globe);
48
+ }
49
+ _init() {
50
+ const { globe, gl, _pickableWrapper, _glowPointWrapper, _glowSurfaceWrapper, _lineProgramWrapper } = this;
51
+ const bufferType = "STATIC_DRAW";
52
+ const initialCapacity = 50;
53
+ this._bufferOrchestrator = new account_1.BufferOrchestrator({ initialCapacity });
54
+ this._bufferManagersMap = new Map([
55
+ ['pos3D', {
56
+ bufferManager: new account_1.BufferManager(gl, 6, { bufferType, initialCapacity }),
57
+ adaptor: (item) => new Float32Array([...(0, methods_js_1.wgs84ToCartesian3d)(item.long, item.lat, item.altitude / 1000), ...(0, methods_js_1.wgs84ToCartesian3d)(item.long, item.lat, 0 / 1000)])
58
+ }],
59
+ ['pos2D', {
60
+ bufferManager: new account_1.BufferManager(gl, 2, { bufferType, initialCapacity }),
61
+ adaptor: (item) => new Float32Array((0, methods_js_1.wgs84ToMercator)(item.long, item.lat))
62
+ }],
63
+ ['rgba', {
64
+ bufferManager: new account_1.BufferManager(gl, 8, { bufferType, initialCapacity }),
65
+ adaptor: (item) => new Float32Array([...item.color, ...item.color])
66
+ }],
67
+ ['size', {
68
+ bufferManager: new account_1.BufferManager(gl, 1, { bufferType, initialCapacity }),
69
+ adaptor: (item) => new Float32Array([item.size])
70
+ }],
71
+ ]);
72
+ _pickableWrapper.program = pickable_renderer_js_1.PickableRendererProgramCache.get(globe);
73
+ _glowPointWrapper.program = element_point_glow_js_1.ElementPointGlowProgramCache.get(globe);
74
+ _lineProgramWrapper.program = naive_accurate_flexible_js_1.LineOnGlobeCache.get(globe);
75
+ this._pickerDisplayer = new picker_displayer_js_1.PickerDisplayer(globe);
76
+ const obj = (key) => key === null ? null : (0, attribute_loader_1.createBufferAndReadInfo)(this._bufferManagersMap.get(key).bufferManager.buffer);
77
+ _pickableWrapper.vao = _pickableWrapper.program.createVAO((0, attribute_loader_1.createBufferAndReadInfo)(this._bufferManagersMap.get('pos3D').bufferManager.buffer, 6 * 4, 0), (0, attribute_loader_1.createBufferAndReadInfo)(this._bufferManagersMap.get('pos2D').bufferManager.buffer), (0, attribute_loader_1.createBufferAndReadInfo)(this._bufferManagersMap.get('rgba').bufferManager.buffer, 8 * 4, 0), (0, attribute_loader_1.createBufferAndReadInfo)(this._bufferManagersMap.get('size').bufferManager.buffer));
78
+ _pickableWrapper.vaoLine = _pickableWrapper.program.createVAO(...['pos3D', 'pos2D', 'rgba', null].map(obj));
79
+ _pickableWrapper.vaoHoverPoint = _pickableWrapper.program.createVAO((0, attribute_loader_1.createBufferAndReadInfo)(this._bufferManagersMap.get('pos3D').bufferManager.buffer, 6 * 4, 0), (0, attribute_loader_1.createBufferAndReadInfo)(this._bufferManagersMap.get('pos2D').bufferManager.buffer), null, (0, attribute_loader_1.createBufferAndReadInfo)(this._bufferManagersMap.get('size').bufferManager.buffer));
80
+ _pickableWrapper.vaoHoverLine = _pickableWrapper.program.createVAO(...['pos3D', 'pos2D', null, null].map(obj));
81
+ _glowPointWrapper.vao = _glowPointWrapper.program.createVAO((0, attribute_loader_1.createBufferAndReadInfo)(this._bufferManagersMap.get('pos3D').bufferManager.buffer, 6 * 4, 0), (0, attribute_loader_1.createBufferAndReadInfo)(this._bufferManagersMap.get('pos2D').bufferManager.buffer), null, (0, attribute_loader_1.createBufferAndReadInfo)(this._bufferManagersMap.get('size').bufferManager.buffer));
82
+ // _lineProgramWrapper.vao = _lineProgramWrapper.program.createVAO(
83
+ // ...[null, 'pos3D', null, 'reverse3D', null, null, "rgba"].map(obj)
84
+ // );
85
+ // _pickableWrapper.vaoRev = _pickableWrapper.program.createVAO(
86
+ // ...['reverse3D', 'pos2D', 'rgba', 'size'].map(obj)
87
+ // );
88
+ _pickableWrapper.ubo = _pickableWrapper.program.createUBO();
89
+ _pickableWrapper.ubo.update(new Map([
90
+ ["u_rgba", [1, 1, 1, 1]],
91
+ ["u_opacity", [1.0]],
92
+ ["u_size_multiplier", [1.0]],
93
+ ["u_size", [1.0]],
94
+ ["u_is_circle", [1.0]],
95
+ ["u_dash_opacity_multiplier", [0.75]],
96
+ ["u_dash_phase", [1.57]],
97
+ ["u_dash_count", [0.5]],
98
+ ["u_is_circle", [1.0]]
99
+ ]));
100
+ _pickableWrapper.uboLine = _pickableWrapper.program.createUBO();
101
+ _pickableWrapper.uboLine.update(new Map([
102
+ ["u_rgba", [1, 1, 1, 1]],
103
+ ["u_opacity", [1.0]],
104
+ ["u_size_multiplier", [1.0]],
105
+ ["u_size", [1.0]],
106
+ ["u_draw_mode", [1.0]], // 0.0 for default, 1.0 for line
107
+ ["u_dash_phase", [1.0]],
108
+ ["u_dash_count", [1.0]],
109
+ ["u_dash_opacity_multiplier", [1.0]],
110
+ ["u_is_circle", [0.0]]
111
+ ]));
112
+ _pickableWrapper.uboLineGlow = _pickableWrapper.program.createUBO();
113
+ _pickableWrapper.uboLineGlow.update(new Map([
114
+ ["u_rgba", [1, 1, 1, 1]],
115
+ ["u_opacity", [1.0]],
116
+ ["u_size_multiplier", [1.0]],
117
+ ["u_size", [1.0]],
118
+ ["u_draw_mode", [1]], // 0.0 for default, 1.0 for line
119
+ ["u_dash_phase", [0.0]],
120
+ ["u_dash_count", [5.0]],
121
+ ["u_dash_opacity_multiplier", [0.5]],
122
+ ["u_is_circle", [0.0]]
123
+ ]));
124
+ // _pickableWrapper._phase = 1;
125
+ // _pickableWrapper.phaseTick = () => {
126
+ // _pickableWrapper._phase -= 0.003;
127
+ // if (_pickableWrapper._phase < 0) {
128
+ // _pickableWrapper._phase = 1;
129
+ // }
130
+ // _pickableWrapper.uboLineGlow.update(new Map([["u_dash_phase", [_pickableWrapper._phase]]]));
131
+ // }
132
+ _glowPointWrapper.ubo = _glowPointWrapper.program.createUBO();
133
+ _glowPointWrapper.ubo.update(new Map([
134
+ ["u_size", new Float32Array([30.0])],
135
+ ["u_size_multiplier", new Float32Array([glowOverSize])],
136
+ ]));
137
+ // _glowPointWrapper._phase = 0;
138
+ // _glowPointWrapper.phaseTick = () => {
139
+ // _glowPointWrapper._phase += 0.0175;
140
+ // if (_glowPointWrapper._phase < 0) {
141
+ // _glowPointWrapper._phase = 1;
142
+ // }
143
+ // _glowPointWrapper.ubo.update(new Map([["u_phase", [_glowPointWrapper._phase]]]));
144
+ // }
145
+ }
146
+ /**
147
+ *
148
+ * @param {Array<PointGlowData>} data
149
+ */
150
+ insertBulk(data) {
151
+ const { _bufferManagersMap, _bufferOrchestrator, globe } = this;
152
+ _bufferOrchestrator.insertBulk(data, _bufferManagersMap);
153
+ this._changed();
154
+ }
155
+ setPointSizeMultiplier(sizeMultiplier) {
156
+ (0, typecheck_js_1.constraintFloat)(sizeMultiplier, 0.1, null);
157
+ this._pickableWrapper.ubo.update(new Map([["u_size_multiplier", [sizeMultiplier]]]));
158
+ this._glowPointWrapper.ubo.update(new Map([["u_size_multiplier", [sizeMultiplier * 1.25]]]));
159
+ this._changed();
160
+ }
161
+ /**
162
+ * @param {DrawRange} drawRange if null draws all
163
+ * @returns
164
+ */
165
+ setDrawRange(drawRange = null) {
166
+ this._drawRange = drawRange;
167
+ this._changed();
168
+ }
169
+ /**
170
+ *
171
+ * sophisticated setDrawRange,
172
+ * 3 concepts:
173
+ */
174
+ setGlowIndexes(glowIndexes) {
175
+ const { gl } = this;
176
+ if (!this._elementBuffer) {
177
+ this._elementBuffer = gl.createBuffer();
178
+ }
179
+ // filter glowIndexes with DrawRange
180
+ gl.bindElementArrayBuffer(this._elementBuffer);
181
+ this._parametersChanged = true;
182
+ gl.bufferData(gl.ELEMENT_ARRAY_BUFFER, new Uint32Array(glowIndexes), gl.DYNAMIC_DRAW);
183
+ }
184
+ setOpacity(opacity) {
185
+ (0, typecheck_js_1.opacityCheck)(opacity);
186
+ this._opacity = opacity;
187
+ this._pickableWrapper.ubo.update(new Map([["u_opacity", [opacity]]]));
188
+ this._pickableWrapper.uboLine.update(new Map([["u_opacity", [opacity]]]));
189
+ this._glowPointWrapper.ubo.update(new Map([["u_opacity", [opacity * glowOverSize]]]));
190
+ this._changed();
191
+ }
192
+ draw3D() {
193
+ const { _pickableWrapper, _bufferOrchestrator, _drawRange, _pickerDisplayer } = this;
194
+ const { globe, gl } = this;
195
+ this._hoverAgent();
196
+ this.resize();
197
+ const is3D = globe.api_GetCurrentGeometry() == 0;
198
+ const drawRange = _drawRange || { first: 0, count: _bufferOrchestrator.length };
199
+ const drawOptionsPoint = {
200
+ drawRange,
201
+ };
202
+ this._doDraw(drawOptionsPoint, is3D, drawRange);
203
+ _pickerDisplayer.drawColorTexture();
204
+ if (this._hoveredObjectId === -1) {
205
+ return;
206
+ }
207
+ // hover draw
208
+ gl.disable(gl.DEPTH_TEST);
209
+ const { program, vaoHoverPoint, vaoHoverLine, uboLineGlow } = _pickableWrapper;
210
+ const drawOptionsHoveredPoint = {
211
+ drawRange: {
212
+ first: this._hoveredObjectId,
213
+ count: 1
214
+ },
215
+ };
216
+ // program.draw(vaoHoverPoint, drawptionsHoveredPoint, ubo);
217
+ if (true || this._modes.isGlowPointOn) {
218
+ const { program, vao, ubo } = this._glowPointWrapper;
219
+ // this._glowPointWrapper.phaseTick();
220
+ program.draw(vao, drawOptionsHoveredPoint, ubo);
221
+ }
222
+ else {
223
+ }
224
+ this.globe.DrawRender();
225
+ if (is3D) {
226
+ const drawOptionsHoveredLine = {
227
+ drawRange: {
228
+ first: this._hoveredObjectId * 2,
229
+ count: 2
230
+ },
231
+ drawMode: gl.LINES
232
+ };
233
+ // _pickableWrapper.phaseTick();
234
+ program.draw(vaoHoverLine, drawOptionsHoveredLine, uboLineGlow);
235
+ }
236
+ this._phaseTick();
237
+ gl.enable(gl.DEPTH_TEST);
238
+ }
239
+ _doDraw(drawOptionsPoint, is3D, drawRange) {
240
+ const { gl, _pickableWrapper, _pickerDisplayer } = this;
241
+ const { program, vao, ubo, uboLine, vaoLine } = _pickableWrapper;
242
+ if (this._doesChanged()) {
243
+ _pickerDisplayer.bindFBO();
244
+ _pickerDisplayer.clearTextures();
245
+ gl.enable(gl.DEPTH_TEST);
246
+ program.draw(vao, drawOptionsPoint, ubo);
247
+ }
248
+ if (is3D) {
249
+ const drawOptionsLine = {
250
+ drawRange: {
251
+ first: drawRange.first * 2,
252
+ count: drawRange.count * 2
253
+ },
254
+ drawMode: gl.LINES
255
+ };
256
+ if (this._doesChanged) {
257
+ uboLine.update(new Map([
258
+ ["u_opacity", [0.01]]
259
+ ]));
260
+ program.draw(vaoLine, drawOptionsLine, uboLine);
261
+ }
262
+ gl.bindFramebuffer(gl.FRAMEBUFFER, null);
263
+ uboLine.update(new Map([
264
+ ["u_opacity", [this._opacity]]
265
+ ]));
266
+ program.draw(vaoLine, drawOptionsLine, uboLine);
267
+ }
268
+ }
269
+ getCurrentSelection() {
270
+ return this._hoveredObjectId;
271
+ }
272
+ resize() {
273
+ const w = this.globe.api_ScrW();
274
+ const h = this.globe.api_ScrH();
275
+ if (w === this._lastWH.w && h === this._lastWH.h)
276
+ return;
277
+ this._lastWH.w = w;
278
+ this._lastWH.h = h;
279
+ this._pickerDisplayer.resize();
280
+ this._changed();
281
+ }
282
+ free() {
283
+ const { _pickableWrapper, _glowPointWrapper, _glowSurfaceWrapper, _lineProgramWrapper } = this;
284
+ [_pickableWrapper, _glowPointWrapper, _glowSurfaceWrapper, _lineProgramWrapper].forEach((item) => {
285
+ const { vao, ubo } = item;
286
+ ubo === null || ubo === void 0 ? void 0 : ubo.free();
287
+ this.gl.deleteVertexArray(vao);
288
+ });
289
+ pickable_renderer_js_1.PickableRendererProgramCache.release(this.globe);
290
+ element_point_glow_js_1.ElementPointGlowProgramCache.release(this.globe);
291
+ // ElementGlobeSufaceGlowCache.release(this.globe); // TODO: uncomment when needed
292
+ naive_accurate_flexible_js_1.LineOnGlobeCache.release(this.globe);
293
+ if (this._elementBuffer)
294
+ this.gl.deleteBuffer(this._elementBuffer);
295
+ this._pickerDisplayer.free();
296
+ this._bufferManagersMap.forEach((item) => item.bufferManager.free());
297
+ this._bufferManagersMap.clear();
298
+ camerauniformblock_js_1.CameraUniformBlockTotemCache.release(this.globe);
299
+ }
300
+ _phaseTick() {
301
+ this._tickPhase += 0.003;
302
+ if (this._tickPhase > 1) {
303
+ this._tickPhase = 0;
304
+ }
305
+ this._glowPointWrapper.ubo.update(new Map([["u_phase", [this._tickPhase * 2]]]));
306
+ this._pickableWrapper.uboLineGlow.update(new Map([["u_dash_phase", [1 - this._tickPhase]]]));
307
+ }
308
+ _hoverAgent() {
309
+ const { globe, _hoverAgentParams } = this;
310
+ const pos = globe.api_GetMousePos();
311
+ const currentTime = new Date().getTime();
312
+ if (_hoverAgentParams.stillPicking || _hoverAgentParams.timePass > currentTime) {
313
+ return;
314
+ }
315
+ ;
316
+ _hoverAgentParams.timePass = currentTime + _hoverAgentParams.timeGap;
317
+ const x = pos.canvasX;
318
+ const y = globe.api_ScrH() - pos.canvasY;
319
+ _hoverAgentParams.stillPicking = true;
320
+ this._pickerDisplayer.pickXY(x, y, 1, (idSet) => {
321
+ _hoverAgentParams.stillPicking = false;
322
+ if (idSet.size === 0) {
323
+ this._hoveredObjectId = -1;
324
+ return;
325
+ }
326
+ const index = [...idSet][0];
327
+ if (index !== this._hoveredObjectId) {
328
+ this._hoveredObjectId = index;
329
+ this.globe.DrawRender();
330
+ }
331
+ });
332
+ }
333
+ _doesChanged() {
334
+ return this._cameraBlockTotem.isMoved() || this._parametersChanged; // TODO: implement
335
+ }
336
+ _changed() {
337
+ this._parametersChanged = true;
338
+ this.globe.DrawRender();
339
+ }
340
+ }
341
+ exports.PointGlowLineToEarthPlugin = PointGlowLineToEarthPlugin;
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ require("../types");
4
+ /**
5
+ * @typedef PointGlowData
6
+ * @type {Object}
7
+ * @property {number} key
8
+ * @property {number} latitude
9
+ * @property {number} longitude
10
+ * @property {number} height
11
+ * @property {number} size
12
+ * @property {[number, number, number]} color
13
+ */
14
+ /**
15
+ *
16
+ *
17
+ * drawSubsetOptions
18
+ * @typedef DrawSubsetOptions
19
+ * @type {Object}
20
+ * @property {null|Color} color if provided, it will override the color
21
+ * @property {Opacity} opacity default 1.0
22
+ * @property {DrawRangeIndexParams} drawOptions
23
+ */
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.centigradePlus90ToRadians = centigradePlus90ToRadians;
4
+ function centigradePlus90ToRadians(centigradeArray, noDataValue = -9999) {
5
+ const radiansArray = new Float32Array(centigradeArray.length);
6
+ for (let i = 0; i < centigradeArray.length; i++) {
7
+ if (centigradeArray[i] === noDataValue) {
8
+ radiansArray[i] = noDataValue;
9
+ continue;
10
+ }
11
+ radiansArray[i] = (centigradeArray[i] + 90.0) * Math.PI / 180;
12
+ }
13
+ return radiansArray;
14
+ }
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.centigradePlus90ToRadians = exports.ArrowField = void 0;
7
+ const plugin_1 = __importDefault(require("./plugin"));
8
+ exports.ArrowField = plugin_1.default;
9
+ const adaptor_1 = require("./adaptor");
10
+ Object.defineProperty(exports, "centigradePlus90ToRadians", { enumerable: true, get: function () { return adaptor_1.centigradePlus90ToRadians; } });
@@ -0,0 +1,86 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const programs_1 = require("../programs");
4
+ class ArrowFieldPlugin {
5
+ constructor(id, { minLon = -180, maxLon = 180, minLat = -90, maxLat = 90, height = 0, opacity = 1, tailLengthRatio = 1, wingLengthRatio = 0.5, color = [0.04, 0.2, 0.8], targetWidth = 100, targetHeight = 100, data = null, dataWidth = null, dataHeight = null, maxMagnitude = null, noDataValue = null } = {}) {
6
+ this.id = id;
7
+ this.options = {
8
+ minLon,
9
+ maxLon,
10
+ minLat,
11
+ maxLat,
12
+ height,
13
+ tailLengthRatio,
14
+ wingLengthRatio,
15
+ opacity,
16
+ color,
17
+ data,
18
+ targetHeight,
19
+ targetWidth,
20
+ dataWidth,
21
+ dataHeight,
22
+ maxMagnitude,
23
+ noDataValue
24
+ };
25
+ this.arrowFieldObj = null;
26
+ this._doDraw = true;
27
+ }
28
+ init(globe, gl) {
29
+ this.globe = globe;
30
+ this.gl = gl;
31
+ this.arrowFieldObj = new programs_1.ArrowField(gl, globe, this.options);
32
+ }
33
+ draw3D() {
34
+ if (this._doDraw) {
35
+ const { gl, arrowFieldObj } = this;
36
+ gl.disable(gl.DEPTH_TEST);
37
+ arrowFieldObj.draw();
38
+ gl.enable(gl.DEPTH_TEST);
39
+ }
40
+ }
41
+ free() {
42
+ this.arrowFieldObj.free();
43
+ this.arrowFieldObj = null;
44
+ }
45
+ // user interaction methods
46
+ on() {
47
+ this._doDraw = true;
48
+ }
49
+ off() {
50
+ this._doDraw = false;
51
+ }
52
+ setBBox({ minLon = -180, maxLon = 180, minLat = -90, maxLat = 90 } = {}) {
53
+ this.arrowFieldObj.setBBox({ minLon, maxLon, minLat, maxLat });
54
+ }
55
+ setHeight(height) {
56
+ this.arrowFieldObj.update({ height });
57
+ }
58
+ setColor(color) {
59
+ this.arrowFieldObj.update({ color });
60
+ }
61
+ setOpacity(opacity) {
62
+ this.arrowFieldObj.update({ opacity });
63
+ }
64
+ setTailLengthRatio(tailLengthRatio) {
65
+ this.arrowFieldObj.update({ tailLengthRatio });
66
+ }
67
+ setWingLengthRatio(wingLengthRatio) {
68
+ this.arrowFieldObj.update({ wingLengthRatio });
69
+ }
70
+ setDataResolution(dataWidth, dataHeight) {
71
+ this.arrowFieldObj.update({ dataWidth, dataHeight });
72
+ }
73
+ setTargetResolution(targetWidth, targetHeight) {
74
+ this.arrowFieldObj.update({ resolution: [targetWidth, targetHeight] });
75
+ }
76
+ setMaxMagnitude(maxMagnitude) {
77
+ this.arrowFieldObj.update({ maxMagnitude });
78
+ }
79
+ setNoDataValue(noDataValue) {
80
+ this.arrowFieldObj.update({ noDataValue });
81
+ }
82
+ setData(rotationData) {
83
+ this.arrowFieldObj.setData(rotationData);
84
+ }
85
+ }
86
+ exports.default = ArrowFieldPlugin;
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.BearingLinePlugin = void 0;
7
+ const plugin_1 = __importDefault(require("./plugin"));
8
+ exports.BearingLinePlugin = plugin_1.default;