@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
@@ -1,43 +1,32 @@
1
- import { createProgram, shaderfunctions } from "../util";
2
- import { CameraUniformBlockTotem, CameraUniformBlockString, noRegisterGlobeProgramCache, globeProgramCache } from "../programs";
3
- import BufferManager from "./buffer-manager";
4
- import {
5
- POLE,
6
- PI,
7
- longLatRadToMercator,
8
- mercatorXYToGLPosition,
9
- longLatRadToCartesian3D,
10
- circleLimpFromLongLatRadCenterCartesian3D,
11
- circleLimpFromLongLatRadCenterMercatorRealDistance,
12
- cartesian3DToGLPosition
13
-
14
-
15
- } from "../util/shaderfunctions/geometrytransformations";
16
-
17
-
18
- /**
19
- * TODO:
20
- * 1. Triangle face looks at screen. if rotation angle is positive the last vertex must be the faintest.
21
- *
22
- */
23
-
24
- const drawModeMap = Object.freeze({
25
- LINE_STRIP: 0,
26
- TRIANGLE_FAN: 1,
27
- });
28
-
29
-
30
-
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.programCache = exports.Logic = exports.ITEM_SIZE = void 0;
7
+ const util_1 = require("../util");
8
+ const programs_1 = require("../programs");
9
+ const buffer_manager_1 = __importDefault(require("./buffer-manager"));
10
+ const geometrytransformations_1 = require("../util/shaderfunctions/geometrytransformations");
11
+ /**
12
+ * TODO:
13
+ * 1. Triangle face looks at screen. if rotation angle is positive the last vertex must be the faintest.
14
+ *
15
+ */
16
+ const drawModeMap = Object.freeze({
17
+ LINE_STRIP: 0,
18
+ TRIANGLE_FAN: 1,
19
+ });
31
20
  const vertexShaderSource = `#version 300 es
32
21
 
33
- ${CameraUniformBlockString}
34
- ${PI}
35
- ${longLatRadToMercator}
36
- ${mercatorXYToGLPosition}
37
- ${longLatRadToCartesian3D}
38
- ${circleLimpFromLongLatRadCenterCartesian3D}
39
- ${circleLimpFromLongLatRadCenterMercatorRealDistance}
40
- ${cartesian3DToGLPosition}
22
+ ${programs_1.CameraUniformBlockString}
23
+ ${geometrytransformations_1.PI}
24
+ ${geometrytransformations_1.longLatRadToMercator}
25
+ ${geometrytransformations_1.mercatorXYToGLPosition}
26
+ ${geometrytransformations_1.longLatRadToCartesian3D}
27
+ ${geometrytransformations_1.circleLimpFromLongLatRadCenterCartesian3D}
28
+ ${geometrytransformations_1.circleLimpFromLongLatRadCenterMercatorRealDistance}
29
+ ${geometrytransformations_1.cartesian3DToGLPosition}
41
30
 
42
31
  uniform float edge_count;
43
32
  uniform int draw_mode; // %2 => 0: LINE_STRIP, 1: TRIANGLE_FAN
@@ -105,10 +94,8 @@ void main() {
105
94
  }
106
95
 
107
96
  gl_PointSize = 10.0;
108
- }`;
109
-
110
-
111
- const fragmentShaderSource = `#version 300 es` + POLE + PI + `
97
+ }`;
98
+ const fragmentShaderSource = `#version 300 es` + geometrytransformations_1.POLE + geometrytransformations_1.PI + `
112
99
  precision highp float;
113
100
  // flat in int vid;
114
101
  in vec4 v_color;
@@ -122,203 +109,178 @@ void main() {
122
109
  // if ( mod(v_angle * v_phase, PI / 90.0 ) < (PI / 180.0)) { discard; }
123
110
  if ( v_pos.x < -POLE || v_pos.x > POLE || v_pos.y < -POLE || v_pos.y > POLE ) { discard; }
124
111
  outColor = v_color;
125
- }`;
126
-
127
- export const ITEM_SIZE = 10;
128
-
129
- export class Logic {
130
-
131
- constructor(globe) {
132
- this.globe = globe;
133
- this.gl = globe.gl;
134
- this._lastMode = 0;
135
- this._lastEdgeCount = 64;
136
- this._lastAlphaMultiplier = 1.0;
137
-
138
- this.program = createProgram(this.gl, vertexShaderSource, fragmentShaderSource);
139
- const { gl, program } = this;
140
- { // set attributes locations
141
- gl.bindAttribLocation(program, 0, 'center');
142
- gl.bindAttribLocation(program, 1, 'start_angle');
143
- gl.bindAttribLocation(program, 2, 'tail_angle');
144
- gl.bindAttribLocation(program, 3, 'color');
145
- gl.bindAttribLocation(program, 4, 'radius');
146
- gl.bindAttribLocation(program, 5, 'color_mode');
147
- // vao
148
- // instanced draw read 1
149
- }
150
- { // Uniforms
151
- this._edgeCountLocation = gl.getUniformLocation(program, 'edge_count');
152
- this._draw_modeLocation = gl.getUniformLocation(program, 'draw_mode');
153
- this._plugin_alpha_multiplierLocation = gl.getUniformLocation(program, 'plugin_alpha_multiplier');
154
- const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
155
- gl.useProgram(program);
156
- gl.uniform1i(this._draw_modeLocation, this._lastMode);
157
- gl.uniform1f(this._edgeCountLocation, this._lastEdgeCount);
158
- gl.uniform1f(this._plugin_alpha_multiplierLocation, 1.0);
159
-
160
- this.cameraBlockBindingPoint = 0;
161
- this.cameraBlockTotem = globeProgramCache.getProgram(globe, CameraUniformBlockTotem);
162
- const cameraBlockIndex = gl.getUniformBlockIndex(program, "CameraUniformBlock");
163
- gl.uniformBlockBinding(program, cameraBlockIndex, this.cameraBlockBindingPoint);
164
-
165
- gl.useProgram(currentProgram);
166
- }
167
-
168
- }
169
-
170
-
171
-
172
- draw(length, vao, edgeCount, alphaMultiplier, drawMode) {
173
- const { gl, program, cameraBlockTotem, cameraBlockBindingPoint } = this
174
-
175
- // gl.disable(gl.DEPTH_TEST);
176
- gl.useProgram(program);
177
- if (drawMode !== this._lastMode) {
178
- gl.uniform1i(this._draw_modeLocation, drawModeMap[drawMode]);
179
- this._lastMode = drawMode;
180
- }
181
- if (edgeCount !== this._lastEdgeCount) {
182
- gl.uniform1f(this._edgeCountLocation, edgeCount);
183
- this._lastEdgeCount = edgeCount;
184
- }
185
- if (alphaMultiplier !== this._lastAlphaMultiplier) {
186
- gl.uniform1f(this._plugin_alpha_multiplierLocation, alphaMultiplier);
187
- this._lastAlphaMultiplier = alphaMultiplier;
188
- }
189
- const overdraw = drawModeMap[drawMode];
190
- cameraBlockTotem.bind(cameraBlockBindingPoint);
191
- gl.bindVertexArray(vao);
192
- gl.drawArraysInstanced(gl[drawMode], 0, edgeCount + overdraw, length);
193
- cameraBlockTotem.unbind(cameraBlockBindingPoint);
194
- gl.bindVertexArray(null);
195
- // gl.enable(gl.DEPTH_TEST);
196
- }
197
-
198
-
199
- free() {
200
- noRegisterGlobeProgramCache.releaseProgram(this.globe, CameraUniformBlockTotem);
201
- this.gl.deleteProgram(this.program);
202
- this.program = null;
203
- }
204
-
205
-
206
- getVaoBuffer() {
207
- const { gl } = this;
208
- const vao = gl.createVertexArray();
209
- const buffer = gl.createBuffer();
210
- gl.bindVertexArray(vao);
211
- gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
212
-
213
- const stride = ITEM_SIZE * 4;
214
- let offset = 0;
215
- gl.enableVertexAttribArray(0);
216
- gl.vertexAttribPointer(0, 2, gl.FLOAT, false, stride, offset);
217
- offset += 2 * 4;
218
- gl.enableVertexAttribArray(1);
219
- gl.vertexAttribPointer(1, 1, gl.FLOAT, false, stride, offset);
220
- offset += 1 * 4;
221
- gl.enableVertexAttribArray(2);
222
- gl.vertexAttribPointer(2, 1, gl.FLOAT, false, stride, offset);
223
- offset += 1 * 4;
224
- gl.enableVertexAttribArray(3);
225
- gl.vertexAttribPointer(3, 4, gl.FLOAT, false, stride, offset);
226
- offset += 4 * 4;
227
- gl.enableVertexAttribArray(4);
228
- gl.vertexAttribPointer(4, 1, gl.FLOAT, false, stride, offset);
229
- offset += 1 * 4;
230
- gl.enableVertexAttribArray(5);
231
- gl.vertexAttribPointer(5, 1, gl.FLOAT, false, stride, offset);
232
-
233
- gl.vertexAttribDivisor(0, 1);
234
- gl.vertexAttribDivisor(1, 1);
235
- gl.vertexAttribDivisor(2, 1);
236
- gl.vertexAttribDivisor(3, 1);
237
- gl.vertexAttribDivisor(4, 1);
238
- gl.vertexAttribDivisor(5, 1);
239
- gl.bindVertexArray(null);
240
- gl.bindBuffer(gl.ARRAY_BUFFER, null);
241
-
242
- return {
243
- vao,
244
- buffer,
245
- }
246
- }
247
-
248
- /**
249
- * in vec2 center; // long, lat in radian
250
- in float start_angle; // the start of partial circle from bearing point
251
- in float tail_angle; // the rotation of the partial circle
252
- in vec4 color;
253
- in float radius; // in meter
254
- in float color_mode; // 0.0: constant, 1.0: fading, 2.0: hide
255
- */
256
-
257
- createVAO(centerObj, startAngleObj, tailAngleObj, colorObj, radiusObj, colorModeObj) {
258
-
259
- const { gl } = this;
260
- const vao = gl.createVertexArray();
261
- gl.bindVertexArray(vao);
262
-
263
- {
264
- const { buffer, stride, offset } = centerObj;
265
- gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
266
- gl.enableVertexAttribArray(0);
267
- gl.vertexAttribPointer(0, 2, gl.FLOAT, false, stride, offset);
268
- gl.vertexAttribDivisor(0, 1);
269
- }
270
-
271
- {
272
- const { buffer, stride, offset } = startAngleObj;
273
- gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
274
- gl.enableVertexAttribArray(1);
275
- gl.vertexAttribPointer(1, 1, gl.FLOAT, false, stride, offset);
276
- gl.vertexAttribDivisor(1, 1);
277
- }
278
- {
279
- const { buffer, stride, offset } = tailAngleObj;
280
- gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
281
- gl.enableVertexAttribArray(2);
282
- gl.vertexAttribPointer(2, 1, gl.FLOAT, false, stride, offset);
283
- gl.vertexAttribDivisor(2, 1);
284
- }
285
- {
286
- const { buffer, stride, offset } = colorObj;
287
- gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
288
- gl.enableVertexAttribArray(3);
289
- gl.vertexAttribPointer(3, 4, gl.FLOAT, false, stride, offset);
290
- gl.vertexAttribDivisor(3, 1);
291
- }
292
- {
293
- const { buffer, stride, offset } = radiusObj;
294
- gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
295
- gl.enableVertexAttribArray(4);
296
- gl.vertexAttribPointer(4, 1, gl.FLOAT, false, stride, offset);
297
- gl.vertexAttribDivisor(4, 1);
298
- }
299
- {
300
- const { buffer, stride, offset } = colorModeObj;
301
- gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
302
- gl.enableVertexAttribArray(5);
303
- gl.vertexAttribPointer(5, 1, gl.FLOAT, false, stride, offset);
304
- gl.vertexAttribDivisor(5, 1);
305
- }
306
- gl.bindVertexArray(null);
307
- gl.bindBuffer(gl.ARRAY_BUFFER, null);
308
- return vao;
309
- }
310
-
311
-
312
- getBufferManagerAndVao({ capacity = 10, bufferType = "DYNAMIC_DRAW" } = {}) {
313
- const { vao, buffer } = this.getVaoBuffer();
314
- return {
315
- bufferManager: new BufferManager(this.globe, this.gl, buffer, { capacity, bufferType }),
316
- vao
317
- };
318
- }
319
- }
320
-
321
- export const programCache = Object.freeze({
322
- get: (globe) => noRegisterGlobeProgramCache.getProgram(globe, Logic),
323
- release: (globe) => noRegisterGlobeProgramCache.releaseProgram(globe, Logic)
324
- });
112
+ }`;
113
+ exports.ITEM_SIZE = 10;
114
+ class Logic {
115
+ constructor(globe) {
116
+ this.globe = globe;
117
+ this.gl = globe.gl;
118
+ this._lastMode = 0;
119
+ this._lastEdgeCount = 64;
120
+ this._lastAlphaMultiplier = 1.0;
121
+ this.program = (0, util_1.createProgram)(this.gl, vertexShaderSource, fragmentShaderSource);
122
+ const { gl, program } = this;
123
+ { // set attributes locations
124
+ gl.bindAttribLocation(program, 0, 'center');
125
+ gl.bindAttribLocation(program, 1, 'start_angle');
126
+ gl.bindAttribLocation(program, 2, 'tail_angle');
127
+ gl.bindAttribLocation(program, 3, 'color');
128
+ gl.bindAttribLocation(program, 4, 'radius');
129
+ gl.bindAttribLocation(program, 5, 'color_mode');
130
+ // vao
131
+ // instanced draw read 1
132
+ }
133
+ { // Uniforms
134
+ this._edgeCountLocation = gl.getUniformLocation(program, 'edge_count');
135
+ this._draw_modeLocation = gl.getUniformLocation(program, 'draw_mode');
136
+ this._plugin_alpha_multiplierLocation = gl.getUniformLocation(program, 'plugin_alpha_multiplier');
137
+ const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
138
+ gl.useProgram(program);
139
+ gl.uniform1i(this._draw_modeLocation, this._lastMode);
140
+ gl.uniform1f(this._edgeCountLocation, this._lastEdgeCount);
141
+ gl.uniform1f(this._plugin_alpha_multiplierLocation, 1.0);
142
+ this.cameraBlockBindingPoint = 0;
143
+ this.cameraBlockTotem = programs_1.globeProgramCache.getProgram(globe, programs_1.CameraUniformBlockTotem);
144
+ const cameraBlockIndex = gl.getUniformBlockIndex(program, "CameraUniformBlock");
145
+ gl.uniformBlockBinding(program, cameraBlockIndex, this.cameraBlockBindingPoint);
146
+ gl.useProgram(currentProgram);
147
+ }
148
+ }
149
+ draw(length, vao, edgeCount, alphaMultiplier, drawMode) {
150
+ const { gl, program, cameraBlockTotem, cameraBlockBindingPoint } = this;
151
+ // gl.disable(gl.DEPTH_TEST);
152
+ gl.useProgram(program);
153
+ if (drawMode !== this._lastMode) {
154
+ gl.uniform1i(this._draw_modeLocation, drawModeMap[drawMode]);
155
+ this._lastMode = drawMode;
156
+ }
157
+ if (edgeCount !== this._lastEdgeCount) {
158
+ gl.uniform1f(this._edgeCountLocation, edgeCount);
159
+ this._lastEdgeCount = edgeCount;
160
+ }
161
+ if (alphaMultiplier !== this._lastAlphaMultiplier) {
162
+ gl.uniform1f(this._plugin_alpha_multiplierLocation, alphaMultiplier);
163
+ this._lastAlphaMultiplier = alphaMultiplier;
164
+ }
165
+ const overdraw = drawModeMap[drawMode];
166
+ cameraBlockTotem.bind(cameraBlockBindingPoint);
167
+ gl.bindVertexArray(vao);
168
+ gl.drawArraysInstanced(gl[drawMode], 0, edgeCount + overdraw, length);
169
+ cameraBlockTotem.unbind(cameraBlockBindingPoint);
170
+ gl.bindVertexArray(null);
171
+ // gl.enable(gl.DEPTH_TEST);
172
+ }
173
+ free() {
174
+ programs_1.noRegisterGlobeProgramCache.releaseProgram(this.globe, programs_1.CameraUniformBlockTotem);
175
+ this.gl.deleteProgram(this.program);
176
+ this.program = null;
177
+ }
178
+ getVaoBuffer() {
179
+ const { gl } = this;
180
+ const vao = gl.createVertexArray();
181
+ const buffer = gl.createBuffer();
182
+ gl.bindVertexArray(vao);
183
+ gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
184
+ const stride = exports.ITEM_SIZE * 4;
185
+ let offset = 0;
186
+ gl.enableVertexAttribArray(0);
187
+ gl.vertexAttribPointer(0, 2, gl.FLOAT, false, stride, offset);
188
+ offset += 2 * 4;
189
+ gl.enableVertexAttribArray(1);
190
+ gl.vertexAttribPointer(1, 1, gl.FLOAT, false, stride, offset);
191
+ offset += 1 * 4;
192
+ gl.enableVertexAttribArray(2);
193
+ gl.vertexAttribPointer(2, 1, gl.FLOAT, false, stride, offset);
194
+ offset += 1 * 4;
195
+ gl.enableVertexAttribArray(3);
196
+ gl.vertexAttribPointer(3, 4, gl.FLOAT, false, stride, offset);
197
+ offset += 4 * 4;
198
+ gl.enableVertexAttribArray(4);
199
+ gl.vertexAttribPointer(4, 1, gl.FLOAT, false, stride, offset);
200
+ offset += 1 * 4;
201
+ gl.enableVertexAttribArray(5);
202
+ gl.vertexAttribPointer(5, 1, gl.FLOAT, false, stride, offset);
203
+ gl.vertexAttribDivisor(0, 1);
204
+ gl.vertexAttribDivisor(1, 1);
205
+ gl.vertexAttribDivisor(2, 1);
206
+ gl.vertexAttribDivisor(3, 1);
207
+ gl.vertexAttribDivisor(4, 1);
208
+ gl.vertexAttribDivisor(5, 1);
209
+ gl.bindVertexArray(null);
210
+ gl.bindBuffer(gl.ARRAY_BUFFER, null);
211
+ return {
212
+ vao,
213
+ buffer,
214
+ };
215
+ }
216
+ /**
217
+ * in vec2 center; // long, lat in radian
218
+ in float start_angle; // the start of partial circle from bearing point
219
+ in float tail_angle; // the rotation of the partial circle
220
+ in vec4 color;
221
+ in float radius; // in meter
222
+ in float color_mode; // 0.0: constant, 1.0: fading, 2.0: hide
223
+ */
224
+ createVAO(centerObj, startAngleObj, tailAngleObj, colorObj, radiusObj, colorModeObj) {
225
+ const { gl } = this;
226
+ const vao = gl.createVertexArray();
227
+ gl.bindVertexArray(vao);
228
+ {
229
+ const { buffer, stride, offset } = centerObj;
230
+ gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
231
+ gl.enableVertexAttribArray(0);
232
+ gl.vertexAttribPointer(0, 2, gl.FLOAT, false, stride, offset);
233
+ gl.vertexAttribDivisor(0, 1);
234
+ }
235
+ {
236
+ const { buffer, stride, offset } = startAngleObj;
237
+ gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
238
+ gl.enableVertexAttribArray(1);
239
+ gl.vertexAttribPointer(1, 1, gl.FLOAT, false, stride, offset);
240
+ gl.vertexAttribDivisor(1, 1);
241
+ }
242
+ {
243
+ const { buffer, stride, offset } = tailAngleObj;
244
+ gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
245
+ gl.enableVertexAttribArray(2);
246
+ gl.vertexAttribPointer(2, 1, gl.FLOAT, false, stride, offset);
247
+ gl.vertexAttribDivisor(2, 1);
248
+ }
249
+ {
250
+ const { buffer, stride, offset } = colorObj;
251
+ gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
252
+ gl.enableVertexAttribArray(3);
253
+ gl.vertexAttribPointer(3, 4, gl.FLOAT, false, stride, offset);
254
+ gl.vertexAttribDivisor(3, 1);
255
+ }
256
+ {
257
+ const { buffer, stride, offset } = radiusObj;
258
+ gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
259
+ gl.enableVertexAttribArray(4);
260
+ gl.vertexAttribPointer(4, 1, gl.FLOAT, false, stride, offset);
261
+ gl.vertexAttribDivisor(4, 1);
262
+ }
263
+ {
264
+ const { buffer, stride, offset } = colorModeObj;
265
+ gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
266
+ gl.enableVertexAttribArray(5);
267
+ gl.vertexAttribPointer(5, 1, gl.FLOAT, false, stride, offset);
268
+ gl.vertexAttribDivisor(5, 1);
269
+ }
270
+ gl.bindVertexArray(null);
271
+ gl.bindBuffer(gl.ARRAY_BUFFER, null);
272
+ return vao;
273
+ }
274
+ getBufferManagerAndVao({ capacity = 10, bufferType = "DYNAMIC_DRAW" } = {}) {
275
+ const { vao, buffer } = this.getVaoBuffer();
276
+ return {
277
+ bufferManager: new buffer_manager_1.default(this.globe, this.gl, buffer, { capacity, bufferType }),
278
+ vao
279
+ };
280
+ }
281
+ }
282
+ exports.Logic = Logic;
283
+ exports.programCache = Object.freeze({
284
+ get: (globe) => programs_1.noRegisterGlobeProgramCache.getProgram(globe, Logic),
285
+ release: (globe) => programs_1.noRegisterGlobeProgramCache.releaseProgram(globe, Logic)
286
+ });