@pirireis/webglobeplugins 0.9.6 → 0.9.8

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 (304) hide show
  1. package/{Math → dist/Math}/angle-calculation.js +15 -14
  2. package/dist/Math/arc.js +65 -0
  3. package/{Math → dist/Math}/bounds/line-bbox.js +188 -225
  4. package/dist/Math/constants.js +9 -0
  5. package/{Math/frustum/camera.ts → dist/Math/frustum/camera.js} +24 -32
  6. package/{Math/frustum/from-globeinfo.ts → dist/Math/frustum/from-globeinfo.js} +48 -63
  7. package/dist/Math/frustum/types.js +2 -0
  8. package/{Math/globe-util/horizon-plane.ts → dist/Math/globe-util/horizon-plane.js} +112 -137
  9. package/dist/Math/index.js +1 -0
  10. package/dist/Math/juction/arc-plane.js +83 -0
  11. package/dist/Math/juction/line-sphere.js +25 -0
  12. package/{Math/juction/plane-plane.ts → dist/Math/juction/plane-plane.js} +58 -66
  13. package/dist/Math/line.js +56 -0
  14. package/dist/Math/matrix4.js +1 -0
  15. package/{Math → dist/Math}/methods.js +201 -237
  16. package/dist/Math/plane.js +60 -0
  17. package/{Math/quaternion.ts → dist/Math/quaternion.js} +104 -120
  18. package/dist/Math/types.js +2 -0
  19. package/dist/Math/utils.js +4 -0
  20. package/{Math/vec3.ts → dist/Math/vec3.js} +126 -155
  21. package/dist/algorithms/search-binary.js +19 -0
  22. package/dist/altitude-locator/adaptors.js +1 -0
  23. package/{altitude-locator → dist/altitude-locator}/draw-subset-obj.js +18 -27
  24. package/dist/altitude-locator/keymethod.js +1 -0
  25. package/{altitude-locator → dist/altitude-locator}/plugin.js +341 -439
  26. package/{altitude-locator → dist/altitude-locator}/types.js +23 -26
  27. package/{arrowfield → dist/arrowfield}/adaptor.js +14 -11
  28. package/dist/arrowfield/index.js +10 -0
  29. package/{arrowfield → dist/arrowfield}/plugin.js +86 -128
  30. package/dist/bearing-line/index.js +8 -0
  31. package/{bearing-line → dist/bearing-line}/plugin.js +449 -512
  32. package/{circle-line-chain → dist/circle-line-chain}/chain-list-map.js +205 -221
  33. package/dist/circle-line-chain/init.js +1 -0
  34. package/{circle-line-chain → dist/circle-line-chain}/plugin.js +424 -469
  35. package/dist/circle-line-chain/util.js +5 -0
  36. package/{compass-rose → dist/compass-rose}/compass-rose-padding-flat.js +225 -266
  37. package/{compass-rose → dist/compass-rose}/compass-text-writer.js +153 -173
  38. package/dist/compass-rose/index.js +7 -0
  39. package/{compassrose → dist/compassrose}/compassrose.js +296 -341
  40. package/dist/compassrose/index.js +8 -0
  41. package/dist/globe-types.js +1 -0
  42. package/dist/heatwave/index.js +10 -0
  43. package/{heatwave → dist/heatwave}/isobar/objectarraylabels.js +202 -247
  44. package/{heatwave → dist/heatwave}/isobar/plugin.js +343 -340
  45. package/{heatwave → dist/heatwave}/isobar/quadtreecontours.js +300 -336
  46. package/{heatwave → dist/heatwave}/plugins/heatwaveglobeshell.js +206 -258
  47. package/dist/index.js +58 -0
  48. package/{jest.config.js → dist/jest.config.js} +7 -6
  49. package/{partialrings → dist/partialrings}/buffer-manager.js +81 -89
  50. package/dist/partialrings/index.js +41 -0
  51. package/{partialrings → dist/partialrings}/plugin.js +135 -160
  52. package/{partialrings → dist/partialrings}/program.js +204 -242
  53. package/{pin → dist/pin}/pin-object-array.js +305 -381
  54. package/{pin → dist/pin}/pin-point-totem.js +60 -77
  55. package/{point-heat-map → dist/point-heat-map}/adaptors/timetracksplugin-format-to-this.js +66 -78
  56. package/dist/point-heat-map/index.js +1 -0
  57. package/{point-heat-map → dist/point-heat-map}/plugin-webworker.js +126 -151
  58. package/{point-heat-map → dist/point-heat-map}/point-to-heat-map-flow.js +127 -150
  59. package/dist/point-tracks/key-methods.js +5 -0
  60. package/{point-tracks → dist/point-tracks}/plugin.js +338 -394
  61. package/dist/programs/arrowfield/index.js +7 -0
  62. package/{programs → dist/programs}/arrowfield/logic.js +144 -173
  63. package/{programs → dist/programs}/arrowfield/object.js +66 -89
  64. package/{programs → dist/programs}/data2legend/density-to-legend.js +76 -90
  65. package/{programs → dist/programs}/data2legend/point-to-density-texture.js +76 -90
  66. package/dist/programs/float2legendwithratio/index.js +8 -0
  67. package/{programs → dist/programs}/float2legendwithratio/logic.js +122 -145
  68. package/{programs → dist/programs}/float2legendwithratio/object.js +110 -141
  69. package/{programs → dist/programs}/globe-util/is-globe-moved.js +21 -27
  70. package/dist/programs/globeshell/index.js +8 -0
  71. package/dist/programs/globeshell/noise/noises.js +1 -0
  72. package/dist/programs/globeshell/wiggle/index.js +8 -0
  73. package/{programs → dist/programs}/globeshell/wiggle/logic.js +246 -272
  74. package/{programs → dist/programs}/globeshell/wiggle/object.js +72 -93
  75. package/dist/programs/helpers/blender/index.js +1 -0
  76. package/{programs → dist/programs}/helpers/blender/program.js +61 -73
  77. package/dist/programs/helpers/fadeaway/index.js +7 -0
  78. package/{programs → dist/programs}/helpers/fadeaway/logic.js +49 -53
  79. package/dist/programs/helpers/fadeaway/object.js +20 -0
  80. package/dist/programs/helpers/index.js +8 -0
  81. package/dist/programs/index.js +58 -0
  82. package/dist/programs/interface.js +1 -0
  83. package/{programs → dist/programs}/line-on-globe/angled-line.js +125 -155
  84. package/{programs → dist/programs}/line-on-globe/circle-accurate-3d.js +95 -121
  85. package/{programs → dist/programs}/line-on-globe/circle-accurate-flat.js +158 -204
  86. package/{programs → dist/programs}/line-on-globe/circle-accurate.js +117 -141
  87. package/{programs → dist/programs}/line-on-globe/circle.js +111 -135
  88. package/{programs → dist/programs}/line-on-globe/degree-padding-around-circle-3d.js +111 -140
  89. package/dist/programs/line-on-globe/index.js +1 -0
  90. package/{programs → dist/programs}/line-on-globe/lines-color-instanced-flat.js +91 -106
  91. package/{programs/line-on-globe/linestrip.ts → dist/programs/line-on-globe/linestrip.js} +108 -165
  92. package/{programs → dist/programs}/line-on-globe/naive-accurate-flexible.js +127 -171
  93. package/{programs → dist/programs}/line-on-globe/to-the-surface.js +83 -101
  94. package/dist/programs/line-on-globe/util.js +8 -0
  95. package/{programs → dist/programs}/picking/pickable-renderer.js +107 -135
  96. package/{programs → dist/programs}/point-on-globe/element-globe-surface-glow.js +101 -127
  97. package/{programs → dist/programs}/point-on-globe/element-point-glow.js +88 -119
  98. package/{programs → dist/programs}/point-on-globe/square-pixel-point.js +126 -141
  99. package/{programs/programcache.ts → dist/programs/programcache.js} +131 -131
  100. package/{programs → dist/programs}/rings/distancering/circleflatprogram.js +115 -95
  101. package/{programs → dist/programs}/rings/distancering/circlepaddingfreeangleprogram.js +320 -329
  102. package/{programs → dist/programs}/rings/distancering/circlepaddysharedbuffer.js +357 -420
  103. package/dist/programs/rings/distancering/index.js +14 -0
  104. package/{programs → dist/programs}/rings/distancering/paddyflatprogram.js +120 -94
  105. package/{programs → dist/programs}/rings/distancering/paddyflatprogram2d.js +122 -98
  106. package/{programs → dist/programs}/rings/distancering/paddyflatprogram3d.js +120 -94
  107. package/dist/programs/rings/distancering/shader.js +1 -0
  108. package/dist/programs/rings/index.js +17 -0
  109. package/{programs → dist/programs}/rings/partial-ring/piece-of-pie.js +181 -221
  110. package/{programs → dist/programs}/totems/camerauniformblock.js +147 -184
  111. package/{programs → dist/programs}/totems/canvas-webglobe-info.js +102 -128
  112. package/{programs → dist/programs}/totems/gpu-selection-uniform-block.js +104 -128
  113. package/dist/programs/totems/index.js +40 -0
  114. package/dist/programs/two-d/pixel-circle.js +1 -0
  115. package/{programs → dist/programs}/two-d/pixel-padding-for-compass.js +101 -113
  116. package/{programs → dist/programs}/util.js +17 -20
  117. package/dist/programs/vectorfields/index.js +23 -0
  118. package/{programs → dist/programs}/vectorfields/logics/drawrectangleparticles.js +65 -83
  119. package/dist/programs/vectorfields/logics/index.js +12 -0
  120. package/{programs → dist/programs}/vectorfields/logics/pixelbased.js +84 -103
  121. package/{programs → dist/programs}/vectorfields/logics/ubo.js +55 -56
  122. package/{programs → dist/programs}/vectorfields/pingpongbuffermanager.js +76 -80
  123. package/dist/rangerings/enum.js +5 -0
  124. package/dist/rangerings/index.js +15 -0
  125. package/{rangerings → dist/rangerings}/plugin.js +560 -649
  126. package/{rangerings → dist/rangerings}/rangeringangletext.js +329 -368
  127. package/{rangerings → dist/rangerings}/ring-account.js +117 -129
  128. package/{shaders → dist/shaders}/fragment-toy/firework.js +5 -2
  129. package/{shaders → dist/shaders}/fragment-toy/singularity.js +5 -5
  130. package/{shape-on-terrain/arc/naive/plugin.ts → dist/shape-on-terrain/arc/naive/plugin.js} +252 -304
  131. package/{timetracks → dist/timetracks}/adaptors-line-strip.js +71 -80
  132. package/{timetracks → dist/timetracks}/adaptors.js +122 -133
  133. package/dist/timetracks/index.js +19 -0
  134. package/{timetracks → dist/timetracks}/plugin-line-strip.js +250 -295
  135. package/{timetracks → dist/timetracks}/plugin.js +258 -304
  136. package/{timetracks → dist/timetracks}/program-line-strip.js +416 -493
  137. package/{timetracks → dist/timetracks}/program.js +464 -542
  138. package/{timetracks → dist/timetracks}/programpoint-line-strip.js +101 -122
  139. package/{timetracks → dist/timetracks}/programpoint.js +101 -122
  140. package/{types.ts → dist/types.js} +15 -17
  141. package/{util → dist/util}/account/bufferoffsetmanager.js +179 -209
  142. package/dist/util/account/index.js +23 -0
  143. package/{util/account/single-attribute-buffer-management/buffer-manager.ts → dist/util/account/single-attribute-buffer-management/buffer-manager.js} +108 -119
  144. package/{util/account/single-attribute-buffer-management/buffer-orchestrator.ts → dist/util/account/single-attribute-buffer-management/buffer-orchestrator.js} +150 -173
  145. package/dist/util/account/single-attribute-buffer-management/index.js +9 -0
  146. package/{util/account/single-attribute-buffer-management/object-store.ts → dist/util/account/single-attribute-buffer-management/object-store.js} +51 -65
  147. package/dist/util/account/single-attribute-buffer-management/types.js +2 -0
  148. package/{util → dist/util}/account/util.js +22 -22
  149. package/dist/util/algorithms/index.js +1 -0
  150. package/{util → dist/util}/algorithms/search-binary.js +28 -26
  151. package/dist/util/check/get.js +18 -0
  152. package/dist/util/check/index.js +1 -0
  153. package/dist/util/check/typecheck.js +49 -0
  154. package/{util → dist/util}/geometry/index.js +51 -53
  155. package/{util/gl-util/buffer/attribute-loader.ts → dist/util/gl-util/buffer/attribute-loader.js} +69 -85
  156. package/dist/util/gl-util/buffer/index.js +6 -0
  157. package/dist/util/gl-util/buffer/types.js +1 -0
  158. package/dist/util/gl-util/draw-options/methods.js +38 -0
  159. package/dist/util/gl-util/draw-options/types.js +15 -0
  160. package/{util/gl-util/uniform-block/manager.ts → dist/util/gl-util/uniform-block/manager.js} +156 -187
  161. package/dist/util/gl-util/uniform-block/shader.js +1 -0
  162. package/dist/util/gl-util/uniform-block/types.js +8 -0
  163. package/{util → dist/util}/heatwavedatamanager/datamanager.js +152 -168
  164. package/dist/util/heatwavedatamanager/index.js +10 -0
  165. package/{util → dist/util}/heatwavedatamanager/pointcoordinatesdatacalculator.js +122 -133
  166. package/{util → dist/util}/heatwavedatamanager/pointcoordsmeta.js +20 -22
  167. package/dist/util/index.js +57 -0
  168. package/dist/util/interpolation/index.js +1 -0
  169. package/dist/util/interpolation/timetrack/index.js +5 -0
  170. package/{util → dist/util}/interpolation/timetrack/timetrack-interpolator.js +79 -88
  171. package/{util → dist/util}/interpolation/timetrack/web-worker-str.js +5 -2
  172. package/{util → dist/util}/interpolation/timetrack/web-worker.js +48 -51
  173. package/{util → dist/util}/jshelpers/data-filler.js +20 -19
  174. package/{util → dist/util}/jshelpers/equality.js +20 -17
  175. package/dist/util/jshelpers/index.js +37 -0
  176. package/{util → dist/util}/jshelpers/timefilters.js +32 -32
  177. package/{util → dist/util}/picking/fence.js +46 -46
  178. package/{util → dist/util}/picking/picker-displayer.js +139 -177
  179. package/{util → dist/util}/programs/draw-texture-on-canvas.js +69 -82
  180. package/dist/util/programs/index.js +17 -0
  181. package/{util → dist/util}/programs/shapesonglobe.js +174 -206
  182. package/{util → dist/util}/programs/supersampletotextures.js +103 -132
  183. package/{util → dist/util}/programs/texturetoglobe.js +133 -154
  184. package/{util/shaderfunctions/geometrytransformations.ts → dist/util/shaderfunctions/geometrytransformations.js} +68 -116
  185. package/dist/util/shaderfunctions/index.js +18 -0
  186. package/{util → dist/util}/shaderfunctions/nodata.js +5 -4
  187. package/{util → dist/util}/shaderfunctions/noisefunctions.js +9 -10
  188. package/{util/surface-line-data/arc-bboxes.ts → dist/util/surface-line-data/arc-bboxes.js} +25 -42
  189. package/{util → dist/util}/surface-line-data/arcs-to-cuts.js +50 -74
  190. package/dist/util/surface-line-data/cut-arc.js +1 -0
  191. package/{util/surface-line-data/flow.ts → dist/util/surface-line-data/flow.js} +28 -52
  192. package/dist/util/surface-line-data/rbush-manager.js +1 -0
  193. package/dist/util/surface-line-data/types.js +1 -0
  194. package/dist/util/surface-line-data/web-worker.js +1 -0
  195. package/dist/util/webglobe/gldefaultstates.js +7 -0
  196. package/dist/util/webglobe/index.js +18 -0
  197. package/{util → dist/util}/webglobe/rasteroverlay.js +78 -96
  198. package/{util/webglobjectbuilders.ts → dist/util/webglobjectbuilders.js} +388 -456
  199. package/{util → dist/util}/webglobjectbuilders1.js +237 -271
  200. package/{waveparticles → dist/waveparticles}/adaptor.js +17 -16
  201. package/dist/waveparticles/index.js +10 -0
  202. package/{waveparticles → dist/waveparticles}/plugin.js +266 -313
  203. package/{wind → dist/wind}/imagetovectorfieldandmagnitude.js +35 -39
  204. package/dist/wind/index.js +14 -0
  205. package/{wind → dist/wind}/plugin.js +681 -812
  206. package/{wind → dist/wind}/vectorfieldimage.js +25 -27
  207. package/{write-text → dist/write-text}/attached-text-writer.js +91 -105
  208. package/{write-text → dist/write-text}/context-text.js +98 -125
  209. package/{write-text → dist/write-text}/context-text3.js +155 -178
  210. package/dist/write-text/index.js +5 -0
  211. package/{write-text → dist/write-text}/writer-plugin.js +8 -7
  212. package/package.json +5 -2
  213. package/Math/arc.ts +0 -76
  214. package/Math/constants.ts +0 -11
  215. package/Math/frustum/types.ts +0 -11
  216. package/Math/index.js +0 -0
  217. package/Math/juction/arc-plane.ts +0 -114
  218. package/Math/juction/line-sphere.ts +0 -30
  219. package/Math/line.ts +0 -70
  220. package/Math/matrix4.ts +0 -0
  221. package/Math/plane.ts +0 -86
  222. package/Math/roadmap.md +0 -10
  223. package/Math/types.ts +0 -45
  224. package/Math/utils.js +0 -3
  225. package/algorithms/search-binary.js +0 -14
  226. package/altitude-locator/adaptors.js +0 -0
  227. package/altitude-locator/keymethod.js +0 -0
  228. package/arrowfield/index.js +0 -3
  229. package/bearing-line/index.js +0 -2
  230. package/circle-line-chain/init.js +0 -0
  231. package/circle-line-chain/readme.md +0 -57
  232. package/circle-line-chain/util.js +0 -1
  233. package/compass-rose/index.js +0 -3
  234. package/compassrose/index.js +0 -2
  235. package/depth-locator/readme.md +0 -26
  236. package/globe-types.ts +0 -13
  237. package/heatwave/index.js +0 -4
  238. package/partialrings/goals.md +0 -17
  239. package/partialrings/index.js +0 -3
  240. package/point-heat-map/index.js +0 -0
  241. package/point-heat-map/readme.md +0 -15
  242. package/point-tracks/key-methods.js +0 -3
  243. package/programs/arrowfield/index.js +0 -2
  244. package/programs/float2legendwithratio/index.js +0 -3
  245. package/programs/globeshell/index.js +0 -2
  246. package/programs/globeshell/noise/noises.js +0 -0
  247. package/programs/globeshell/wiggle/index.js +0 -6
  248. package/programs/helpers/blender/index.js +0 -0
  249. package/programs/helpers/fadeaway/index.js +0 -3
  250. package/programs/helpers/fadeaway/object.js +0 -20
  251. package/programs/helpers/index.js +0 -2
  252. package/programs/index.js +0 -21
  253. package/programs/interface.ts +0 -7
  254. package/programs/line-on-globe/index.js +0 -0
  255. package/programs/line-on-globe/util.js +0 -8
  256. package/programs/rings/distancering/index.js +0 -5
  257. package/programs/rings/distancering/shader.js +0 -0
  258. package/programs/rings/index.js +0 -1
  259. package/programs/totems/camerauniformblock.d.ts +0 -48
  260. package/programs/totems/index.ts +0 -2
  261. package/programs/two-d/pixel-circle.js +0 -0
  262. package/programs/vectorfields/index.js +0 -3
  263. package/programs/vectorfields/logics/index.js +0 -5
  264. package/publish.bat +0 -60
  265. package/rangerings/enum.js +0 -3
  266. package/rangerings/index.js +0 -5
  267. package/shape-on-terrain/goal.md +0 -12
  268. package/tests/Math/junction/arc-plane.test.ts +0 -133
  269. package/tests/Math/junction/plane-plane.test.ts +0 -82
  270. package/tests/Math/plane.test.ts +0 -43
  271. package/tests/Math/vec3.test.ts +0 -14
  272. package/timetracks/index.js +0 -6
  273. package/timetracks/readme.md +0 -1
  274. package/tsconfig.json +0 -22
  275. package/util/account/index.js +0 -6
  276. package/util/account/single-attribute-buffer-management/index.ts +0 -13
  277. package/util/account/single-attribute-buffer-management/types.ts +0 -39
  278. package/util/algorithms/index.js +0 -0
  279. package/util/check/get.js +0 -13
  280. package/util/check/index.js +0 -0
  281. package/util/check/typecheck.js +0 -39
  282. package/util/gl-util/buffer/index.ts +0 -6
  283. package/util/gl-util/buffer/types.ts +0 -13
  284. package/util/gl-util/draw-options/methods.ts +0 -66
  285. package/util/gl-util/draw-options/types.ts +0 -28
  286. package/util/gl-util/uniform-block/roadmap.md +0 -70
  287. package/util/gl-util/uniform-block/shader.js +0 -0
  288. package/util/gl-util/uniform-block/types.ts +0 -27
  289. package/util/heatwavedatamanager/index.js +0 -3
  290. package/util/index.js +0 -13
  291. package/util/interpolation/index.js +0 -0
  292. package/util/interpolation/timetrack/index.js +0 -9
  293. package/util/jshelpers/index.js +0 -1
  294. package/util/programs/index.js +0 -1
  295. package/util/shaderfunctions/index.js +0 -2
  296. package/util/surface-line-data/cut-arc.js +0 -0
  297. package/util/surface-line-data/rbush-manager.js +0 -0
  298. package/util/surface-line-data/types.ts +0 -27
  299. package/util/surface-line-data/web-worker.js +0 -0
  300. package/util/webglobe/gldefaultstates.js +0 -5
  301. package/util/webglobe/index.js +0 -2
  302. package/waveparticles/index.js +0 -3
  303. package/wind/index.js +0 -5
  304. package/write-text/index.js +0 -1
@@ -0,0 +1,7 @@
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
+ const object_1 = __importDefault(require("./object"));
7
+ exports.default = object_1.default;
@@ -1,7 +1,8 @@
1
- import { createProgram } from "../../util";
2
- import { globeProgramCache } from "../programcache";
3
- import { CameraUniformBlockTotem } from "../totems";
4
-
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const util_1 = require("../../util");
4
+ const programcache_1 = require("../programcache");
5
+ const totems_1 = require("../totems");
5
6
  const arrowVertexShader = `#version 300 es
6
7
  #define R 6378.137
7
8
  #define PI 3.1415926535897932384626433832795
@@ -107,9 +108,7 @@ void main() {
107
108
  v_color = u_color;
108
109
  gl_PointSize = 4.0;
109
110
  }
110
- `;
111
-
112
-
111
+ `;
113
112
  const arrowFragmentShader = `#version 300 es
114
113
  precision highp float;
115
114
  in vec4 v_color;
@@ -118,169 +117,141 @@ out vec4 outColor;
118
117
  void main() {
119
118
  outColor = v_color;
120
119
  }
121
- `;
122
-
123
-
124
- export default class ArrowFieldLogic {
125
-
126
- constructor() {
127
- this.gl = null;
128
- this.globe = null;
129
- this.cameraUniformBlockTotem = null;
130
- this.program = null;
131
- this.cameraBlockBindingPoint = 0;
132
- this.arrayBlockBindingPoint = 1;
133
- }
134
-
135
- init(globe, gl) {
136
- this.gl = gl;
137
- this.globe = globe;
138
- this.cameraUniformBlockTotem = globeProgramCache.getProgram(globe, CameraUniformBlockTotem);
139
- this.program = this._createProgram();
140
- }
141
-
142
- _createProgram() {
143
- const gl = this.gl;
144
- const program = createProgram(gl, arrowVertexShader, arrowFragmentShader);
145
-
146
- const cameraBlockIndex = gl.getUniformBlockIndex(program, "CameraBlock");
147
- gl.uniformBlockBinding(program, cameraBlockIndex, this.cameraBlockBindingPoint);
148
-
149
-
150
-
151
- const arrowBlockIndex = gl.getUniformBlockIndex(program, "ArrowBlock");
152
- gl.uniformBlockBinding(program, arrowBlockIndex, this.arrayBlockBindingPoint);
153
-
154
- this.textureLocations = {
155
- rotationLocation: gl.getUniformLocation(program, "rotation"),
156
- }
157
-
158
- return program;
159
- }
160
-
161
- getArrowBlockBufferManager() {
162
- return new ArrowBlockBufferManager(this.gl, this.arrayBlockBindingPoint);
163
- }
164
-
165
- // initial load type is static.
166
- // after that, it is dynamic.
167
- getTextureManager(width, height) {
168
- return new TextureManager(this.gl, width, height, this.textureLocations);
169
- }
170
-
171
- draw(arrowBlockManager, textureManager, instanceCount) {
172
- const { gl, cameraBlockBindingPoint, cameraUniformBlockTotem } = this;
173
- gl.useProgram(this.program);
174
- arrowBlockManager.bind();
175
- textureManager.activate();
176
- cameraUniformBlockTotem.bind(cameraBlockBindingPoint);
177
- gl.drawArraysInstanced(gl.LINES, 0, 6, instanceCount);
178
- // gl.drawArraysInstanced(gl.POINTS, 0, 4, instanceCount);
179
- cameraUniformBlockTotem.unbind(cameraBlockBindingPoint);
180
- arrowBlockManager.unbind();
181
- }
182
-
183
- free() {
184
- const { gl, program } = this;
185
- gl.deleteProgram(program);
186
- globeProgramCache.releaseProgram(this.globe, CameraUniformBlockTotem);
187
- }
188
- }
189
-
190
-
191
- class ArrowBlockBufferManager {
192
- constructor(gl, bindingPoint) {
193
- this.gl = gl;
194
- this.bindingPoint = bindingPoint;
195
- this.ubo = gl.createBuffer();
196
- gl.bindBuffer(gl.UNIFORM_BUFFER, this.ubo);
197
- // 4 + 2+ 2 + 2 + 1 +1 +1 +1+1= 15 ~= 16
198
- gl.bufferData(gl.UNIFORM_BUFFER, 56, gl.DYNAMIC_DRAW);
199
- gl.bindBuffer(gl.UNIFORM_BUFFER, null);
200
- }
201
-
202
- update({
203
- color = null,
204
- bboxOffsetRad = null,
205
- bboxSizeRad = null,
206
- resolution = null,
207
- tailLengthRatio = null,
208
- wingLengthRatio = null,
209
- height = null,
210
- opacity = null,
211
- noDataValue = null,
212
- } = {}) {
213
- const { gl, ubo } = this;
214
- gl.bindBuffer(gl.UNIFORM_BUFFER, ubo);
215
- if (color !== null) gl.bufferSubData(gl.UNIFORM_BUFFER, 0, new Float32Array(color));
216
- if (opacity !== null) gl.bufferSubData(gl.UNIFORM_BUFFER, 12, new Float32Array([opacity]));
217
- if (bboxOffsetRad !== null) gl.bufferSubData(gl.UNIFORM_BUFFER, 16, new Float32Array(bboxOffsetRad));
218
- if (bboxSizeRad !== null) gl.bufferSubData(gl.UNIFORM_BUFFER, 24, new Float32Array(bboxSizeRad));
219
- if (resolution !== null) gl.bufferSubData(gl.UNIFORM_BUFFER, 32, new Float32Array(resolution));
220
- if (tailLengthRatio !== null) gl.bufferSubData(gl.UNIFORM_BUFFER, 40, new Float32Array([tailLengthRatio]));
221
- if (wingLengthRatio !== null) gl.bufferSubData(gl.UNIFORM_BUFFER, 44, new Float32Array([wingLengthRatio]));
222
- if (height !== null) gl.bufferSubData(gl.UNIFORM_BUFFER, 48, new Float32Array([height]));
223
- if (noDataValue !== null) gl.bufferSubData(gl.UNIFORM_BUFFER, 52, new Float32Array([noDataValue]));
224
- gl.bindBuffer(gl.UNIFORM_BUFFER, null);
225
- }
226
-
227
- bind() {
228
- const { gl, ubo, bindingPoint } = this;
229
- gl.bindBufferBase(gl.UNIFORM_BUFFER, bindingPoint, ubo);
230
- }
231
-
232
- unbind() {
233
- const { gl, bindingPoint } = this;
234
- gl.bindBufferBase(gl.UNIFORM_BUFFER, bindingPoint, null);
235
- }
236
-
237
- free() {
238
- const { gl, ubo } = this;
239
- gl.deleteBuffer(ubo);
240
- }
241
- }
242
-
243
- class TextureManager {
244
-
245
- constructor(gl, width, height, { rotationLocation }) {
246
- this.gl = gl;
247
- this.width = width;
248
- this.height = height;
249
- this.rotationLocation = rotationLocation;
250
- this.rotationTexture = this._createFloatTexture();
251
- }
252
-
253
- _createFloatTexture() {
254
- const { gl, width, height } = this;
255
- const texture = gl.createTexture();
256
- gl.bindTexture(gl.TEXTURE_2D, texture);
257
- gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST);
258
- gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST);
259
- gl.texImage2D(gl.TEXTURE_2D, 0, gl.R32F, width, height, 0, gl.RED, gl.FLOAT, null);
260
- gl.bindTexture(gl.TEXTURE_2D, null);
261
- return texture;
262
- }
263
-
264
- setData(rotation) {
265
- const { gl, rotationTexture, width, height } = this;
266
- // gl flip y axis
267
- gl.pixelStorei(gl.UNPACK_FLIP_Y_WEBGL, true);
268
- gl.bindTexture(gl.TEXTURE_2D, rotationTexture);
269
- gl.texImage2D(gl.TEXTURE_2D, 0, gl.R32F, width, height, 0, gl.RED, gl.FLOAT, rotation);
270
- gl.bindTexture(gl.TEXTURE_2D, null);
271
- gl.pixelStorei(gl.UNPACK_FLIP_Y_WEBGL, false);
272
- }
273
-
274
- activate() {
275
- const { gl, rotationTexture } = this;
276
-
277
- gl.activeTexture(gl.TEXTURE0);
278
- gl.bindTexture(gl.TEXTURE_2D, rotationTexture);
279
- gl.uniform1i(this.rotationLocation, 0);
280
- }
281
-
282
- free() {
283
- const { gl, rotationTexture } = this;
284
- gl.deleteTexture(rotationTexture);
285
- }
286
- }
120
+ `;
121
+ class ArrowFieldLogic {
122
+ constructor() {
123
+ this.gl = null;
124
+ this.globe = null;
125
+ this.cameraUniformBlockTotem = null;
126
+ this.program = null;
127
+ this.cameraBlockBindingPoint = 0;
128
+ this.arrayBlockBindingPoint = 1;
129
+ }
130
+ init(globe, gl) {
131
+ this.gl = gl;
132
+ this.globe = globe;
133
+ this.cameraUniformBlockTotem = programcache_1.globeProgramCache.getProgram(globe, totems_1.CameraUniformBlockTotem);
134
+ this.program = this._createProgram();
135
+ }
136
+ _createProgram() {
137
+ const gl = this.gl;
138
+ const program = (0, util_1.createProgram)(gl, arrowVertexShader, arrowFragmentShader);
139
+ const cameraBlockIndex = gl.getUniformBlockIndex(program, "CameraBlock");
140
+ gl.uniformBlockBinding(program, cameraBlockIndex, this.cameraBlockBindingPoint);
141
+ const arrowBlockIndex = gl.getUniformBlockIndex(program, "ArrowBlock");
142
+ gl.uniformBlockBinding(program, arrowBlockIndex, this.arrayBlockBindingPoint);
143
+ this.textureLocations = {
144
+ rotationLocation: gl.getUniformLocation(program, "rotation"),
145
+ };
146
+ return program;
147
+ }
148
+ getArrowBlockBufferManager() {
149
+ return new ArrowBlockBufferManager(this.gl, this.arrayBlockBindingPoint);
150
+ }
151
+ // initial load type is static.
152
+ // after that, it is dynamic.
153
+ getTextureManager(width, height) {
154
+ return new TextureManager(this.gl, width, height, this.textureLocations);
155
+ }
156
+ draw(arrowBlockManager, textureManager, instanceCount) {
157
+ const { gl, cameraBlockBindingPoint, cameraUniformBlockTotem } = this;
158
+ gl.useProgram(this.program);
159
+ arrowBlockManager.bind();
160
+ textureManager.activate();
161
+ cameraUniformBlockTotem.bind(cameraBlockBindingPoint);
162
+ gl.drawArraysInstanced(gl.LINES, 0, 6, instanceCount);
163
+ // gl.drawArraysInstanced(gl.POINTS, 0, 4, instanceCount);
164
+ cameraUniformBlockTotem.unbind(cameraBlockBindingPoint);
165
+ arrowBlockManager.unbind();
166
+ }
167
+ free() {
168
+ const { gl, program } = this;
169
+ gl.deleteProgram(program);
170
+ programcache_1.globeProgramCache.releaseProgram(this.globe, totems_1.CameraUniformBlockTotem);
171
+ }
172
+ }
173
+ exports.default = ArrowFieldLogic;
174
+ class ArrowBlockBufferManager {
175
+ constructor(gl, bindingPoint) {
176
+ this.gl = gl;
177
+ this.bindingPoint = bindingPoint;
178
+ this.ubo = gl.createBuffer();
179
+ gl.bindBuffer(gl.UNIFORM_BUFFER, this.ubo);
180
+ // 4 + 2+ 2 + 2 + 1 +1 +1 +1+1= 15 ~= 16
181
+ gl.bufferData(gl.UNIFORM_BUFFER, 56, gl.DYNAMIC_DRAW);
182
+ gl.bindBuffer(gl.UNIFORM_BUFFER, null);
183
+ }
184
+ update({ color = null, bboxOffsetRad = null, bboxSizeRad = null, resolution = null, tailLengthRatio = null, wingLengthRatio = null, height = null, opacity = null, noDataValue = null, } = {}) {
185
+ const { gl, ubo } = this;
186
+ gl.bindBuffer(gl.UNIFORM_BUFFER, ubo);
187
+ if (color !== null)
188
+ gl.bufferSubData(gl.UNIFORM_BUFFER, 0, new Float32Array(color));
189
+ if (opacity !== null)
190
+ gl.bufferSubData(gl.UNIFORM_BUFFER, 12, new Float32Array([opacity]));
191
+ if (bboxOffsetRad !== null)
192
+ gl.bufferSubData(gl.UNIFORM_BUFFER, 16, new Float32Array(bboxOffsetRad));
193
+ if (bboxSizeRad !== null)
194
+ gl.bufferSubData(gl.UNIFORM_BUFFER, 24, new Float32Array(bboxSizeRad));
195
+ if (resolution !== null)
196
+ gl.bufferSubData(gl.UNIFORM_BUFFER, 32, new Float32Array(resolution));
197
+ if (tailLengthRatio !== null)
198
+ gl.bufferSubData(gl.UNIFORM_BUFFER, 40, new Float32Array([tailLengthRatio]));
199
+ if (wingLengthRatio !== null)
200
+ gl.bufferSubData(gl.UNIFORM_BUFFER, 44, new Float32Array([wingLengthRatio]));
201
+ if (height !== null)
202
+ gl.bufferSubData(gl.UNIFORM_BUFFER, 48, new Float32Array([height]));
203
+ if (noDataValue !== null)
204
+ gl.bufferSubData(gl.UNIFORM_BUFFER, 52, new Float32Array([noDataValue]));
205
+ gl.bindBuffer(gl.UNIFORM_BUFFER, null);
206
+ }
207
+ bind() {
208
+ const { gl, ubo, bindingPoint } = this;
209
+ gl.bindBufferBase(gl.UNIFORM_BUFFER, bindingPoint, ubo);
210
+ }
211
+ unbind() {
212
+ const { gl, bindingPoint } = this;
213
+ gl.bindBufferBase(gl.UNIFORM_BUFFER, bindingPoint, null);
214
+ }
215
+ free() {
216
+ const { gl, ubo } = this;
217
+ gl.deleteBuffer(ubo);
218
+ }
219
+ }
220
+ class TextureManager {
221
+ constructor(gl, width, height, { rotationLocation }) {
222
+ this.gl = gl;
223
+ this.width = width;
224
+ this.height = height;
225
+ this.rotationLocation = rotationLocation;
226
+ this.rotationTexture = this._createFloatTexture();
227
+ }
228
+ _createFloatTexture() {
229
+ const { gl, width, height } = this;
230
+ const texture = gl.createTexture();
231
+ gl.bindTexture(gl.TEXTURE_2D, texture);
232
+ gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST);
233
+ gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST);
234
+ gl.texImage2D(gl.TEXTURE_2D, 0, gl.R32F, width, height, 0, gl.RED, gl.FLOAT, null);
235
+ gl.bindTexture(gl.TEXTURE_2D, null);
236
+ return texture;
237
+ }
238
+ setData(rotation) {
239
+ const { gl, rotationTexture, width, height } = this;
240
+ // gl flip y axis
241
+ gl.pixelStorei(gl.UNPACK_FLIP_Y_WEBGL, true);
242
+ gl.bindTexture(gl.TEXTURE_2D, rotationTexture);
243
+ gl.texImage2D(gl.TEXTURE_2D, 0, gl.R32F, width, height, 0, gl.RED, gl.FLOAT, rotation);
244
+ gl.bindTexture(gl.TEXTURE_2D, null);
245
+ gl.pixelStorei(gl.UNPACK_FLIP_Y_WEBGL, false);
246
+ }
247
+ activate() {
248
+ const { gl, rotationTexture } = this;
249
+ gl.activeTexture(gl.TEXTURE0);
250
+ gl.bindTexture(gl.TEXTURE_2D, rotationTexture);
251
+ gl.uniform1i(this.rotationLocation, 0);
252
+ }
253
+ free() {
254
+ const { gl, rotationTexture } = this;
255
+ gl.deleteTexture(rotationTexture);
256
+ }
257
+ }
@@ -1,89 +1,66 @@
1
- // this contains vao, drawCount, ArrowBufferBlock, vao,
2
- // how to, where to set instanced parameters
3
- // the vectorfield buffer should be managed outside, since it can be static or dynamic.
4
-
5
- import Logic from './logic';
6
- import { globeProgramCache } from '../programcache';
7
- import { longlatbbox2normalbbox } from "../util";
8
-
9
- export default class ArrowField {
10
- constructor(gl, globe, {
11
- minLon = -180,
12
- maxLon = 180,
13
- minLat = -90,
14
- maxLat = 90,
15
- height = 0,
16
- opacity = 1,
17
- color = [0.04, 0.2, 0.8],
18
- targetWidth = 100,
19
- targetHeight = 100,
20
- dataWidth = null,
21
- dataHeight = null,
22
- tailLengthRatio = 1,
23
- wingLengthRatio = 0.5,
24
- noDataValue = null,
25
- // maxMagnitude = null
26
- } = {}) {
27
- this.gl = gl;
28
- this.globe = globe;
29
-
30
- this.program = globeProgramCache.getProgram(globe, Logic);
31
- this.arrowBlockManager = this.program.getArrowBlockBufferManager();
32
- this.instanceCount = targetWidth * targetHeight;
33
- this.arrowBlockManager.update({ resolution: [targetWidth, targetHeight] });
34
- this.textureManager = this.program.getTextureManager(dataWidth, dataHeight);
35
- this.setBBox({ minLon, maxLon, minLat, maxLat });
36
- this.update({ height, opacity, color, tailLengthRatio, wingLengthRatio, noDataValue });
37
- }
38
-
39
-
40
- setBBox({ minLon = -180, maxLon = 180, minLat = -90, maxLat = 90 } = {}) {
41
- this.bbox = { minLon, maxLon, minLat, maxLat };
42
- const { bboxSizeRad, bboxOffsetRad } = longlatbbox2normalbbox(this.bbox);
43
- this.arrowBlockManager.update({ bboxSizeRad, bboxOffsetRad });
44
- this.globe.DrawRender();
45
- }
46
-
47
-
48
- update({ height, opacity, color, resolution, tailLengthRatio, wingLengthRatio, noDataValue } = {}) {
49
- if (resolution) {
50
- this.instanceCount = resolution[0] * resolution[1];
51
- }
52
- this.arrowBlockManager.update({
53
- color,
54
- resolution,
55
- height,
56
- opacity,
57
- tailLengthRatio,
58
- wingLengthRatio,
59
- noDataValue,
60
- });
61
- this.globe.DrawRender();
62
- }
63
-
64
- setTargetResolution(width, height) {
65
- this.instanceCount = width * height;
66
- this.arrowBlockManager.update({ resolution: [width, height] });
67
-
68
- this.globe.DrawRender();
69
- }
70
-
71
- draw() {
72
- const { program, arrowBlockManager, textureManager, instanceCount } = this;
73
- program.draw(arrowBlockManager, textureManager, instanceCount);
74
- }
75
-
76
-
77
- setData(rotation) {
78
- this.textureManager.setData(rotation);
79
- this.globe.DrawRender();
80
- }
81
-
82
-
83
- free() {
84
- this.arrowBlockManager.free();
85
- this.textureManager.free();
86
- globeProgramCache.releaseProgram(this.gl, Logic);
87
- }
88
- }
89
-
1
+ "use strict";
2
+ // this contains vao, drawCount, ArrowBufferBlock, vao,
3
+ // how to, where to set instanced parameters
4
+ // the vectorfield buffer should be managed outside, since it can be static or dynamic.
5
+ var __importDefault = (this && this.__importDefault) || function (mod) {
6
+ return (mod && mod.__esModule) ? mod : { "default": mod };
7
+ };
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ const logic_1 = __importDefault(require("./logic"));
10
+ const programcache_1 = require("../programcache");
11
+ const util_1 = require("../util");
12
+ class ArrowField {
13
+ constructor(gl, globe, { minLon = -180, maxLon = 180, minLat = -90, maxLat = 90, height = 0, opacity = 1, color = [0.04, 0.2, 0.8], targetWidth = 100, targetHeight = 100, dataWidth = null, dataHeight = null, tailLengthRatio = 1, wingLengthRatio = 0.5, noDataValue = null,
14
+ // maxMagnitude = null
15
+ } = {}) {
16
+ this.gl = gl;
17
+ this.globe = globe;
18
+ this.program = programcache_1.globeProgramCache.getProgram(globe, logic_1.default);
19
+ this.arrowBlockManager = this.program.getArrowBlockBufferManager();
20
+ this.instanceCount = targetWidth * targetHeight;
21
+ this.arrowBlockManager.update({ resolution: [targetWidth, targetHeight] });
22
+ this.textureManager = this.program.getTextureManager(dataWidth, dataHeight);
23
+ this.setBBox({ minLon, maxLon, minLat, maxLat });
24
+ this.update({ height, opacity, color, tailLengthRatio, wingLengthRatio, noDataValue });
25
+ }
26
+ setBBox({ minLon = -180, maxLon = 180, minLat = -90, maxLat = 90 } = {}) {
27
+ this.bbox = { minLon, maxLon, minLat, maxLat };
28
+ const { bboxSizeRad, bboxOffsetRad } = (0, util_1.longlatbbox2normalbbox)(this.bbox);
29
+ this.arrowBlockManager.update({ bboxSizeRad, bboxOffsetRad });
30
+ this.globe.DrawRender();
31
+ }
32
+ update({ height, opacity, color, resolution, tailLengthRatio, wingLengthRatio, noDataValue } = {}) {
33
+ if (resolution) {
34
+ this.instanceCount = resolution[0] * resolution[1];
35
+ }
36
+ this.arrowBlockManager.update({
37
+ color,
38
+ resolution,
39
+ height,
40
+ opacity,
41
+ tailLengthRatio,
42
+ wingLengthRatio,
43
+ noDataValue,
44
+ });
45
+ this.globe.DrawRender();
46
+ }
47
+ setTargetResolution(width, height) {
48
+ this.instanceCount = width * height;
49
+ this.arrowBlockManager.update({ resolution: [width, height] });
50
+ this.globe.DrawRender();
51
+ }
52
+ draw() {
53
+ const { program, arrowBlockManager, textureManager, instanceCount } = this;
54
+ program.draw(arrowBlockManager, textureManager, instanceCount);
55
+ }
56
+ setData(rotation) {
57
+ this.textureManager.setData(rotation);
58
+ this.globe.DrawRender();
59
+ }
60
+ free() {
61
+ this.arrowBlockManager.free();
62
+ this.textureManager.free();
63
+ programcache_1.globeProgramCache.releaseProgram(this.gl, logic_1.default);
64
+ }
65
+ }
66
+ exports.default = ArrowField;