@pirireis/webglobeplugins 0.17.1 → 1.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (272) hide show
  1. package/Math/{angle-calculation.js → angle-calculation.ts} +18 -14
  2. package/Math/{arc-cdf-points.js → arc-cdf-points.ts} +329 -272
  3. package/Math/{arc-generate-points-exponantial.js → arc-generate-points-exponantial.ts} +299 -254
  4. package/Math/{arc.js → arc.ts} +421 -292
  5. package/Math/bounds/line-bbox.js +225 -186
  6. package/Math/{circle-cdf-points.js → circle-cdf-points.ts} +143 -78
  7. package/Math/{circle.js → circle.ts} +49 -33
  8. package/Math/{constants.js → constants.ts} +12 -4
  9. package/Math/contour/{quadtreecontours.js → quadtreecontours.ts} +371 -300
  10. package/Math/contour/quadtreecontours1.js +336 -298
  11. package/Math/{finite-line-2d.js → finite-line-2d.ts} +68 -58
  12. package/Math/haversine.ts +33 -0
  13. package/Math/index.js +0 -1
  14. package/Math/juction/{arc-plane.js → arc-plane.ts} +203 -143
  15. package/Math/juction/{line-sphere.js → line-sphere.ts} +32 -22
  16. package/Math/juction/{plane-plane.js → plane-plane.ts} +62 -53
  17. package/Math/{line.js → line.ts} +84 -52
  18. package/Math/matrix4.ts +0 -0
  19. package/Math/mesh/mapbox-delaunay.d.ts +74 -0
  20. package/Math/{methods.js → methods.ts} +182 -113
  21. package/Math/{plane.js → plane.ts} +92 -56
  22. package/Math/{quaternion.js → quaternion.ts} +128 -106
  23. package/Math/roadmap.md +10 -0
  24. package/Math/templete-shapes/{grid-visually-equal.js → grid-visually-equal.ts} +118 -65
  25. package/Math/tessellation/constants.ts +1 -0
  26. package/Math/tessellation/methods.ts +79 -0
  27. package/Math/tessellation/nearest-value-padding.ts +147 -0
  28. package/Math/tessellation/roadmap.md +48 -0
  29. package/Math/tessellation/spherical-triangle-area.ts +127 -0
  30. package/Math/tessellation/tile-merger.ts +578 -0
  31. package/Math/tessellation/triangle-tessellation.ts +533 -0
  32. package/Math/tessellation/types.ts +1 -0
  33. package/Math/types.ts +68 -0
  34. package/Math/utils.js +3 -2
  35. package/Math/{vec3.js → vec3.ts} +227 -151
  36. package/Math/xyz-tile.ts +26 -0
  37. package/algorithms/search-binary.js +14 -16
  38. package/altitude-locator/adaptors.js +0 -1
  39. package/altitude-locator/keymethod.js +0 -1
  40. package/altitude-locator/plugin.js +445 -345
  41. package/altitude-locator/types.js +26 -21
  42. package/compass-rose/compass-rose-padding-flat.js +274 -230
  43. package/compass-rose/{compass-text-writer.js → compass-text-writer.ts} +210 -155
  44. package/compass-rose/index.js +3 -3
  45. package/{constants.js → constants.ts} +8 -6
  46. package/heatwave/datamanager.js +168 -149
  47. package/heatwave/heatwave.js +261 -206
  48. package/heatwave/index.js +5 -5
  49. package/heatwave/isobar.js +340 -303
  50. package/heatwave/{texture-point-sampler.js → texture-point-sampler.ts} +220 -187
  51. package/investigation-tools/draw/tiles/adapters.ts +133 -0
  52. package/investigation-tools/draw/tiles/{tiles.js → tiles.ts} +162 -128
  53. package/jest.config.js +6 -7
  54. package/package.json +1 -1
  55. package/pin/pin-object-array1.js +381 -300
  56. package/pin/pin-point-totem1.js +77 -60
  57. package/programs/arrowfield/arrow-field.js +89 -60
  58. package/programs/arrowfield/logic.js +173 -141
  59. package/programs/data2legend/density-to-legend.js +86 -68
  60. package/programs/data2legend/point-to-density-texture.js +84 -67
  61. package/programs/float2legendwithratio/index.js +3 -2
  62. package/programs/float2legendwithratio/logic.js +144 -118
  63. package/programs/float2legendwithratio/object.js +141 -104
  64. package/programs/helpers/blender.js +73 -58
  65. package/programs/helpers/{fadeaway.js → fadeaway.ts} +73 -55
  66. package/programs/index.js +19 -20
  67. package/programs/line-on-globe/circle-accurate-3d.js +112 -85
  68. package/programs/line-on-globe/circle-accurate-flat.js +200 -148
  69. package/programs/line-on-globe/degree-padding-around-circle-3d.js +134 -102
  70. package/programs/line-on-globe/index.js +0 -1
  71. package/programs/line-on-globe/lines-color-instanced-flat.js +99 -80
  72. package/programs/line-on-globe/linestrip/data.ts +29 -0
  73. package/programs/line-on-globe/linestrip/{linestrip.js → linestrip.ts} +152 -93
  74. package/programs/line-on-globe/{naive-accurate-flexible.js → naive-accurate-flexible.ts} +175 -126
  75. package/programs/line-on-globe/util.js +8 -5
  76. package/programs/picking/pickable-polygon-renderer.js +129 -98
  77. package/programs/picking/pickable-renderer.js +130 -98
  78. package/programs/point-on-globe/element-globe-surface-glow.js +122 -93
  79. package/programs/point-on-globe/element-point-glow.js +114 -80
  80. package/programs/point-on-globe/square-pixel-point.js +139 -120
  81. package/programs/polygon-on-globe/roadmap.md +8 -0
  82. package/programs/polygon-on-globe/texture-dem-triangles.ts +290 -0
  83. package/programs/{programcache.js → programcache.ts} +134 -126
  84. package/programs/rings/index.js +1 -1
  85. package/programs/rings/partial-ring/{piece-of-pie.js → piece-of-pie.ts} +222 -152
  86. package/programs/totems/camera-totem-attactment-interface.ts +4 -0
  87. package/programs/totems/{camerauniformblock.js → camerauniformblock.ts} +326 -230
  88. package/programs/totems/{canvas-webglobe-info.js → canvas-webglobe-info.ts} +147 -132
  89. package/programs/totems/dem-textures-manager.ts +368 -0
  90. package/programs/totems/{globe-changes.js → globe-changes.ts} +79 -59
  91. package/programs/totems/gpu-selection-uniform-block.js +127 -99
  92. package/programs/totems/{index.js → index.ts} +2 -2
  93. package/programs/two-d/pixel-padding-for-compass.js +101 -87
  94. package/programs/util.js +19 -14
  95. package/programs/vectorfields/logics/{constants.js → constants.ts} +5 -4
  96. package/programs/vectorfields/logics/drawrectangleparticles.ts +182 -0
  97. package/programs/vectorfields/logics/index.js +4 -2
  98. package/programs/vectorfields/logics/particle-ubo.ts +23 -0
  99. package/programs/vectorfields/logics/{pixelbased.js → pixelbased.ts} +119 -84
  100. package/programs/vectorfields/logics/ubo.js +57 -51
  101. package/programs/vectorfields/{pingpongbuffermanager.js → pingpongbuffermanager.ts} +113 -73
  102. package/publish.bat +62 -0
  103. package/range-tools-on-terrain/bearing-line/{adapters.js → adapters.ts} +154 -114
  104. package/range-tools-on-terrain/bearing-line/{plugin.js → plugin.ts} +569 -457
  105. package/range-tools-on-terrain/bearing-line/types.ts +65 -0
  106. package/range-tools-on-terrain/circle-line-chain/{adapters.js → adapters.ts} +104 -85
  107. package/range-tools-on-terrain/circle-line-chain/{chain-list-map.js → chain-list-map.ts} +446 -382
  108. package/range-tools-on-terrain/circle-line-chain/{plugin.js → plugin.ts} +607 -464
  109. package/range-tools-on-terrain/circle-line-chain/types.ts +43 -0
  110. package/range-tools-on-terrain/range-ring/{adapters.js → adapters.ts} +114 -93
  111. package/range-tools-on-terrain/range-ring/{enum.js → enum.ts} +2 -2
  112. package/range-tools-on-terrain/range-ring/{plugin.js → plugin.ts} +444 -377
  113. package/range-tools-on-terrain/range-ring/rangeringangletext.ts +396 -0
  114. package/range-tools-on-terrain/range-ring/types.ts +30 -0
  115. package/semiplugins/interface.ts +14 -0
  116. package/semiplugins/lightweight/{line-plugin.js → line-plugin.ts} +342 -221
  117. package/semiplugins/lightweight/{piece-of-pie-plugin.js → piece-of-pie-plugin.ts} +275 -200
  118. package/semiplugins/shape-on-terrain/{arc-plugin.js → arc-plugin.ts} +616 -481
  119. package/semiplugins/shape-on-terrain/{circle-plugin.js → circle-plugin.ts} +588 -444
  120. package/semiplugins/shape-on-terrain/goal.md +12 -0
  121. package/semiplugins/shape-on-terrain/{padding-1-degree.js → padding-1-degree.ts} +713 -539
  122. package/semiplugins/shape-on-terrain/terrain-polygon/adapters.ts +69 -0
  123. package/semiplugins/shape-on-terrain/terrain-polygon/data/cache-shortcuts.md +20 -0
  124. package/semiplugins/shape-on-terrain/terrain-polygon/data/cache.ts +149 -0
  125. package/semiplugins/shape-on-terrain/terrain-polygon/data/index-polygon-map.ts +58 -0
  126. package/semiplugins/shape-on-terrain/terrain-polygon/data/manager.ts +4 -0
  127. package/semiplugins/shape-on-terrain/terrain-polygon/data/master-worker.js +196 -0
  128. package/semiplugins/shape-on-terrain/terrain-polygon/data/master-worker.ts +209 -0
  129. package/semiplugins/shape-on-terrain/terrain-polygon/data/polygon-to-triangles.ts +144 -0
  130. package/semiplugins/shape-on-terrain/terrain-polygon/data/random.ts +165 -0
  131. package/semiplugins/shape-on-terrain/terrain-polygon/data/readme.md +5 -0
  132. package/semiplugins/shape-on-terrain/terrain-polygon/data/types.ts +37 -0
  133. package/semiplugins/shape-on-terrain/terrain-polygon/data/worker-contact.ts +81 -0
  134. package/semiplugins/shape-on-terrain/terrain-polygon/data/worker.js +146 -0
  135. package/semiplugins/shape-on-terrain/terrain-polygon/notes.md +90 -0
  136. package/semiplugins/shape-on-terrain/terrain-polygon/terrain-polygon.ts +265 -0
  137. package/semiplugins/shape-on-terrain/terrain-polygon/types.ts +69 -0
  138. package/semiplugins/shell/bbox-renderer/index.ts +2 -0
  139. package/semiplugins/shell/bbox-renderer/{logic.js → logic.ts} +273 -249
  140. package/semiplugins/shell/bbox-renderer/object.ts +129 -0
  141. package/semiplugins/type.ts +8 -0
  142. package/semiplugins/utility/{container-plugin.js → container-plugin.ts} +126 -94
  143. package/semiplugins/utility/{object-pass-container-plugin.js → object-pass-container-plugin.ts} +101 -80
  144. package/shaders/fragment-toy/firework.js +1 -1
  145. package/shaders/fragment-toy/singularity.js +5 -2
  146. package/terrain-plugin.mmd +83 -0
  147. package/tests/Math/arc-sampling-test.js +367 -0
  148. package/tests/Math/arc-sampling-test.ts +429 -0
  149. package/tests/Math/arc.test.ts +77 -0
  150. package/tests/Math/junction/arc-limit.test.ts +7 -0
  151. package/tests/Math/junction/arc-plane-points.test.ts +196 -0
  152. package/tests/Math/junction/arc-plane.test.ts +172 -0
  153. package/tests/Math/junction/line-sphere.test.ts +127 -0
  154. package/tests/Math/junction/plane-plane.test.ts +91 -0
  155. package/tests/Math/plane-test.ts +17 -0
  156. package/tests/Math/plane.test.ts +43 -0
  157. package/tests/Math/vec3.test.ts +33 -0
  158. package/tracks/point-heat-map/adaptors/timetracksplugin-format-to-this.js +78 -63
  159. package/tracks/point-heat-map/index.js +0 -1
  160. package/tracks/point-heat-map/plugin-webworker.js +148 -121
  161. package/tracks/point-heat-map/point-to-heat-map-flow.js +150 -121
  162. package/tracks/point-heat-map/readme.md +15 -0
  163. package/tracks/point-tracks/key-methods.js +3 -2
  164. package/tracks/point-tracks/plugin.js +487 -394
  165. package/tracks/timetracks/adaptors-line-strip.js +79 -65
  166. package/tracks/timetracks/plugin-line-strip.js +295 -240
  167. package/tracks/timetracks/program-line-strip.js +495 -411
  168. package/tracks/timetracks/programpoint-line-strip.js +137 -109
  169. package/tracks/timetracks/readme.md +1 -0
  170. package/tsconfig.json +22 -0
  171. package/types/@pirireis/webglobe.d.ts +102 -0
  172. package/types/delaunator.d.ts +40 -0
  173. package/types/earcut.d.ts +11 -0
  174. package/types/rbush.d.ts +57 -0
  175. package/types.ts +319 -0
  176. package/util/account/bufferoffsetmanager.js +209 -176
  177. package/util/account/create-buffermap-orchastration.ts +85 -0
  178. package/util/account/index.js +6 -3
  179. package/util/account/single-attribute-buffer-management/{buffer-manager.js → buffer-manager.ts} +151 -117
  180. package/util/account/single-attribute-buffer-management/{buffer-orchestrator.js → buffer-orchestrator.ts} +238 -212
  181. package/util/account/single-attribute-buffer-management/{buffer-orchestrator1.js → buffer-orchestrator1.ts} +184 -159
  182. package/util/account/single-attribute-buffer-management/{index.js → index.ts} +11 -4
  183. package/util/account/single-attribute-buffer-management/{object-store.js → object-store.ts} +76 -55
  184. package/util/account/single-attribute-buffer-management/types.ts +43 -0
  185. package/util/account/util.js +22 -18
  186. package/util/algorithms/index.js +0 -1
  187. package/util/algorithms/search-binary.js +26 -25
  188. package/util/build-strategy/{static-dynamic.js → static-dynamic.ts} +50 -41
  189. package/util/check/index.js +0 -1
  190. package/util/check/typecheck.ts +74 -0
  191. package/util/{frame-counter-trigger.js → frame-counter-trigger.ts} +99 -84
  192. package/util/geometry/{index.js → index.ts} +155 -121
  193. package/util/gl-util/buffer/{attribute-loader.js → attribute-loader.ts} +84 -62
  194. package/util/gl-util/buffer/{index.js → index.ts} +6 -3
  195. package/util/gl-util/draw-options/{methods.js → methods.ts} +47 -32
  196. package/util/gl-util/uniform-block/{manager.js → manager.ts} +232 -190
  197. package/util/{webglobe/gldefaultstates.js → globe-default-gl-states.ts} +5 -4
  198. package/util/helper-methods.ts +9 -0
  199. package/util/index.js +9 -10
  200. package/util/interpolation/index.js +0 -1
  201. package/util/interpolation/timetrack/index.js +9 -2
  202. package/util/interpolation/timetrack/timetrack-interpolator.js +94 -79
  203. package/util/interpolation/timetrack/web-worker.js +51 -46
  204. package/util/picking/{fence.js → fence.ts} +47 -41
  205. package/util/picking/picker-displayer.ts +226 -0
  206. package/util/programs/draw-from-pixel-coords.js +201 -164
  207. package/util/programs/{draw-texture-on-canvas.js → draw-texture-on-canvas.ts} +92 -67
  208. package/util/programs/supersampletotextures.js +130 -97
  209. package/util/programs/texturetoglobe.js +153 -128
  210. package/util/shaderfunctions/{geometrytransformations.js → geometrytransformations.ts} +169 -41
  211. package/util/shaderfunctions/index.js +2 -2
  212. package/util/shaderfunctions/nodata.js +4 -2
  213. package/util/shaderfunctions/noisefunctions.js +10 -7
  214. package/util/{webglobjectbuilders.js → webglobjectbuilders.ts} +446 -358
  215. package/vectorfield/arrowfield/adaptor.js +11 -11
  216. package/vectorfield/arrowfield/index.js +3 -3
  217. package/vectorfield/arrowfield/plugin.js +128 -83
  218. package/vectorfield/waveparticles/adaptor.js +16 -15
  219. package/vectorfield/waveparticles/index.js +3 -3
  220. package/vectorfield/waveparticles/plugin.ts +506 -0
  221. package/vectorfield/wind/adapters/image-to-fields.ts +74 -0
  222. package/vectorfield/wind/adapters/types.ts +12 -0
  223. package/vectorfield/wind/{imagetovectorfieldandmagnitude.js → imagetovectorfieldandmagnitude.ts} +78 -56
  224. package/vectorfield/wind/index.js +5 -5
  225. package/vectorfield/wind/plugin-persistant copy.ts +461 -0
  226. package/vectorfield/wind/plugin-persistant.ts +483 -0
  227. package/vectorfield/wind/plugin.js +883 -685
  228. package/vectorfield/wind/vectorfieldimage.js +27 -23
  229. package/write-text/{context-text-bulk.js → context-text-bulk.ts} +285 -200
  230. package/write-text/context-text3.ts +252 -0
  231. package/write-text/{context-text4.js → context-text4.ts} +231 -146
  232. package/write-text/context-textDELETE.js +125 -94
  233. package/write-text/objectarraylabels/{index.js → index.ts} +2 -2
  234. package/write-text/objectarraylabels/objectarraylabels.d.ts +72 -0
  235. package/write-text/objectarraylabels/objectarraylabels.js +247 -200
  236. package/Math/matrix4.js +0 -1
  237. package/Math/tessellation/earcut/adapters.js +0 -37
  238. package/Math/tessellation/hybrid-triangle-tessellation-meta.js +0 -123
  239. package/Math/tessellation/methods.js +0 -46
  240. package/Math/tessellation/shred-input.js +0 -18
  241. package/Math/tessellation/tile-merger.js +0 -298
  242. package/Math/tessellation/tiler.js +0 -50
  243. package/Math/tessellation/triangle-tessellation-meta.js +0 -523
  244. package/Math/tessellation/triangle-tessellation.js +0 -14
  245. package/Math/tessellation/types.js +0 -1
  246. package/Math/tessellation/zoom-catch.js +0 -1
  247. package/Math/types.js +0 -1
  248. package/investigation-tools/draw/tiles/adapters.js +0 -67
  249. package/programs/line-on-globe/linestrip/data.js +0 -4
  250. package/programs/polygon-on-globe/texture-dem-triangle-test-plugin-triangle.js +0 -328
  251. package/programs/polygon-on-globe/texture-dem-triangles.js +0 -268
  252. package/programs/vectorfields/logics/drawrectangleparticles.js +0 -114
  253. package/programs/vectorfields/logics/drawrectangleparticles1.js +0 -112
  254. package/programs/vectorfields/logics/ubo-new.js +0 -25
  255. package/range-tools-on-terrain/bearing-line/types.js +0 -1
  256. package/range-tools-on-terrain/circle-line-chain/types.js +0 -1
  257. package/range-tools-on-terrain/range-ring/rangeringangletext.js +0 -331
  258. package/range-tools-on-terrain/range-ring/types.js +0 -9
  259. package/semiplugins/interface.js +0 -1
  260. package/semiplugins/shape-on-terrain/terrain-cover/texture-dem-cover.js +0 -1
  261. package/semiplugins/shell/bbox-renderer/index.js +0 -2
  262. package/semiplugins/shell/bbox-renderer/object.js +0 -65
  263. package/semiplugins/type.js +0 -1
  264. package/types.js +0 -19
  265. package/util/account/create-buffermap-orchastration.js +0 -39
  266. package/util/account/single-attribute-buffer-management/types.js +0 -1
  267. package/util/check/typecheck.js +0 -66
  268. package/util/gl-util/uniform-block/types.js +0 -1
  269. package/util/picking/picker-displayer.js +0 -134
  270. package/util/webglobe/index.js +0 -2
  271. package/vectorfield/waveparticles/plugin.js +0 -290
  272. package/write-text/context-text3.js +0 -167
@@ -1,190 +1,232 @@
1
- const typeSizes = {
2
- 'float': 4,
3
- 'vec2': 8,
4
- 'vec3': 16, // vec3 takes up same space as vec4 due to alignment
5
- 'vec4': 16,
6
- 'mat2': 32, // 2 vec4s (16 * 2)
7
- 'mat3': 48, // 3 vec4s (16 * 3)
8
- 'mat4': 64, // 4 vec4s (16 * 4)
9
- 'int': 4,
10
- 'ivec2': 8,
11
- 'ivec3': 16,
12
- 'ivec4': 16,
13
- 'bool': 4
14
- };
15
- const typeAlignments = {
16
- 'float': 4,
17
- 'vec2': 8,
18
- 'vec3': 16,
19
- 'vec4': 16,
20
- 'mat2': 16, // aligns to vec4 boundary
21
- 'mat3': 16, // aligns to vec4 boundary
22
- 'mat4': 16, // aligns to vec4 boundary
23
- 'int': 4,
24
- 'ivec2': 8,
25
- 'ivec3': 16,
26
- 'ivec4': 16,
27
- 'bool': 4
28
- };
29
- const typeArrayConstructors = {
30
- 'float': Float32Array,
31
- 'vec2': Float32Array,
32
- 'vec3': Float32Array,
33
- 'vec4': Float32Array,
34
- 'mat2': Float32Array,
35
- 'mat3': Float32Array,
36
- 'mat4': Float32Array,
37
- 'int': Int32Array,
38
- 'ivec2': Int32Array,
39
- 'ivec3': Int32Array,
40
- 'ivec4': Int32Array,
41
- 'bool': Float32Array
42
- };
43
- export class UniformBlockManager {
44
- /**
45
- *
46
- * @param {UniformBlockName} blockName
47
- * @param {Array<UniformBlockMember} blockMembers
48
- * @param {string} prefix usage name of block in the shader
49
- */
50
- blockName;
51
- blockMembers;
52
- bindingPoint;
53
- prefix;
54
- offsetMap;
55
- size;
56
- constructor(blockName, blockMembers, bindingPoint, prefix = "") {
57
- this.blockName = blockName;
58
- this.blockMembers = blockMembers;
59
- this.bindingPoint = bindingPoint;
60
- this.prefix = prefix;
61
- this.offsetMap = this.__create_LayoutSTD140_OffsetMap();
62
- this.size = this.__calculateSize();
63
- }
64
- glslCode() {
65
- let code = `layout(std140) uniform ${this.blockName} {`;
66
- for (const member of this.blockMembers) {
67
- const { name, type } = member;
68
- code += `${type} ${this.prefix}${name};`;
69
- }
70
- if (this.prefix) {
71
- code += `} ${this.prefix};`;
72
- }
73
- else {
74
- code += `};`;
75
- }
76
- return code;
77
- }
78
- createUBO(gl, bufferWriteType = "STATIC_DRAW") {
79
- const ubo = gl.createBuffer();
80
- gl.bindBuffer(gl.UNIFORM_BUFFER, ubo);
81
- // @ts-ignore
82
- gl.bufferData(gl.UNIFORM_BUFFER, this.size, gl[bufferWriteType]);
83
- gl.bindBufferBase(gl.UNIFORM_BUFFER, 0, ubo);
84
- for (const member of this.blockMembers) {
85
- const { name, type, value = null } = member;
86
- ;
87
- const offset = this.offsetMap.get(name);
88
- const data = (value === null) ? new typeArrayConstructors[type](typeSizes[type] / 4).fill(NaN) : value;
89
- gl.bufferSubData(gl.UNIFORM_BUFFER, offset, data);
90
- }
91
- gl.bindBuffer(gl.UNIFORM_BUFFER, null);
92
- return {
93
- ubo,
94
- update: (nameValueMap) => this.updateUBO(gl, ubo, nameValueMap),
95
- updateSingle: (key, value) => this.updateUboSingle(gl, ubo, key, value),
96
- bind: () => this.bind(gl, ubo),
97
- unbind: () => this.unbind(gl),
98
- free: () => gl.deleteBuffer(ubo),
99
- };
100
- }
101
- updateUboSingle(gl, ubo, key, value) {
102
- gl.bindBuffer(gl.UNIFORM_BUFFER, ubo);
103
- const offset = this.offsetMap.get(key);
104
- if (offset === undefined) {
105
- throw new Error(`Uniform block member ${key} not found in offset map.\nPossible members: ${Array.from(this.offsetMap.keys()).join(", ")}`);
106
- }
107
- // @ts-ignore
108
- const type = this.blockMembers.find(member => member.name === key).type;
109
- let data;
110
- if (Array.isArray(value)) {
111
- data = new typeArrayConstructors[type](value);
112
- }
113
- else if (typeof value === 'number') {
114
- data = new typeArrayConstructors[type]([value]);
115
- }
116
- else if (value instanceof ArrayBuffer) {
117
- data = new typeArrayConstructors[type](value);
118
- }
119
- else if (ArrayBuffer.isView(value) && !(value instanceof DataView)) {
120
- data = (typeof value === 'number') ? new typeArrayConstructors[type]([value]) : new typeArrayConstructors[type](value);
121
- }
122
- else {
123
- throw new Error(`Unsupported value type for ${key}: ${typeof value}.\n Supported types are: number, Array, ArrayBuffer, TypedArray.`);
124
- }
125
- gl.bufferSubData(gl.UNIFORM_BUFFER, offset, data);
126
- gl.bindBuffer(gl.UNIFORM_BUFFER, null);
127
- }
128
- updateUBO(gl, ubo, nameValueMap) {
129
- gl.bindBuffer(gl.UNIFORM_BUFFER, ubo);
130
- for (const [name, value] of nameValueMap.entries()) {
131
- const offset = this.offsetMap.get(name);
132
- if (offset === undefined) {
133
- throw new Error(`Uniform block member ${name} not found in offset map.\nPossible members: ${Array.from(this.offsetMap.keys()).join(", ")}`);
134
- }
135
- // @ts-ignore
136
- const type = this.blockMembers.find(member => member.name === name).type;
137
- let data;
138
- if (Array.isArray(value)) {
139
- data = new typeArrayConstructors[type](value);
140
- }
141
- else if (typeof value === 'number') {
142
- data = new typeArrayConstructors[type]([value]);
143
- }
144
- else if (value instanceof ArrayBuffer) {
145
- data = new typeArrayConstructors[type](value);
146
- }
147
- else if (ArrayBuffer.isView(value) && !(value instanceof DataView))
148
- data = (typeof value === 'number') ? new typeArrayConstructors[type]([value]) : new typeArrayConstructors[type](value);
149
- else {
150
- throw new Error(`Unsupported value type for ${name}: ${typeof value}.\n Supported types are: number, Array, ArrayBuffer, TypedArray.`);
151
- }
152
- gl.bufferSubData(gl.UNIFORM_BUFFER, offset, data);
153
- }
154
- gl.bindBuffer(gl.UNIFORM_BUFFER, null);
155
- }
156
- // call this after linking the program
157
- assignBindingPoint(gl, program) {
158
- const blockIndex = gl.getUniformBlockIndex(program, this.blockName);
159
- gl.uniformBlockBinding(program, blockIndex, this.bindingPoint);
160
- }
161
- // call this before drawing
162
- bind(gl, ubo) {
163
- gl.bindBufferBase(gl.UNIFORM_BUFFER, this.bindingPoint, ubo);
164
- }
165
- // call this right after drawing
166
- unbind(gl) {
167
- gl.bindBufferBase(gl.UNIFORM_BUFFER, this.bindingPoint, null);
168
- }
169
- // implicit methods
170
- __create_LayoutSTD140_OffsetMap() {
171
- let offset = 0;
172
- const offsetMap = new Map();
173
- for (const member of this.blockMembers) {
174
- const { name, type } = member;
175
- const size = typeSizes[type];
176
- const alignment = typeAlignments[type];
177
- const padding = (alignment - (offset % alignment)) % alignment;
178
- offset += padding;
179
- offsetMap.set(name, offset);
180
- offset += size;
181
- }
182
- return offsetMap;
183
- }
184
- // __create_LayoutSTD140_OffsetMap() should be called before this
185
- __calculateSize() {
186
- const lastOffset = Array.from(this.offsetMap.values()).pop() || 0;
187
- const lastItemAlignment = typeAlignments[this.blockMembers[this.blockMembers.length - 1].type];
188
- return lastOffset + lastItemAlignment;
189
- }
190
- }
1
+ import { UBOHandler } from "../../../types";
2
+
3
+
4
+
5
+ const typeSizes = {
6
+ 'float': 4,
7
+ 'vec2': 8,
8
+ 'vec3': 16, // vec3 takes up same space as vec4 due to alignment
9
+ 'vec4': 16,
10
+ 'mat2': 32, // 2 vec4s (16 * 2)
11
+ 'mat3': 48, // 3 vec4s (16 * 3)
12
+ 'mat4': 64, // 4 vec4s (16 * 4)
13
+ 'int': 4,
14
+ 'ivec2': 8,
15
+ 'ivec3': 16,
16
+ 'ivec4': 16,
17
+ 'uvec4': 16,
18
+ 'uint': 4,
19
+ 'bool': 4,
20
+ };
21
+
22
+ const typeAlignments = {
23
+ 'float': 4,
24
+ 'vec2': 8,
25
+ 'vec3': 16,
26
+ 'vec4': 16,
27
+ 'mat2': 16, // aligns to vec4 boundary
28
+ 'mat3': 16, // aligns to vec4 boundary
29
+ 'mat4': 16, // aligns to vec4 boundary
30
+ 'int': 4,
31
+ 'ivec2': 8,
32
+ 'ivec3': 16,
33
+ 'ivec4': 16,
34
+ 'uvec4': 16,
35
+ 'uint': 4,
36
+ 'bool': 4,
37
+ };
38
+
39
+
40
+ const typeArrayConstructors = {
41
+ 'float': Float32Array,
42
+ 'vec2': Float32Array,
43
+ 'vec3': Float32Array,
44
+ 'vec4': Float32Array,
45
+ 'mat2': Float32Array,
46
+ 'mat3': Float32Array,
47
+ 'mat4': Float32Array,
48
+ 'int': Int32Array,
49
+ 'ivec2': Int32Array,
50
+ 'ivec3': Int32Array,
51
+ 'ivec4': Int32Array,
52
+ 'bool': Float32Array,
53
+ 'uint': Uint32Array,
54
+ 'uvec2': Uint32Array,
55
+ 'uvec3': Uint32Array,
56
+ 'uvec4': Uint32Array,
57
+
58
+ };
59
+
60
+ type UniformBlockMember = {
61
+ name: string;
62
+ type: keyof typeof typeSizes;
63
+ value: Float32Array | Int32Array | Uint32Array | ArrayBuffer | DataView | null;
64
+ };
65
+
66
+ type NameValueMap = Map<string, Float32Array | Int32Array | Uint32Array | ArrayBuffer | DataView>;
67
+
68
+ type UniformBlockName = string;
69
+
70
+ // TODO: the input types should be all same for a single block.
71
+ // no need to ask for typed array constructor in the constructor
72
+ // eacher remove it and raise error when different types are used in the same block
73
+ // or implicitly manage multiple blocks with different types
74
+
75
+
76
+ export class UniformBlockManager {
77
+
78
+ /**
79
+ *
80
+ * @param {UniformBlockName} blockName
81
+ * @param {Array<UniformBlockMember} blockMembers
82
+ * @param {string} prefix usage name of block in the shader
83
+ */
84
+
85
+ blockName: string;
86
+ blockMembers: Array<UniformBlockMember>;
87
+ bindingPoint: number;
88
+ prefix: string;
89
+ offsetMap: Map<string, number>;
90
+ size: number;
91
+
92
+ constructor(blockName: string, blockMembers: Array<UniformBlockMember>, bindingPoint: number, prefix: string = "") {
93
+ this.blockName = blockName;
94
+ this.blockMembers = blockMembers;
95
+ this.bindingPoint = bindingPoint;
96
+ this.prefix = prefix;
97
+ this.offsetMap = this.__create_LayoutSTD140_OffsetMap();
98
+ this.size = this.__calculateSize();
99
+ }
100
+
101
+
102
+
103
+ glslCode() {
104
+ let code = `layout(std140) uniform ${this.blockName} {`;
105
+ for (const member of this.blockMembers) {
106
+ const { name, type } = member;
107
+ code += `${type} ${this.prefix}${name};`;
108
+ }
109
+ if (this.prefix) {
110
+ code += `} ${this.prefix};`;
111
+ } else {
112
+ code += `};`;
113
+ }
114
+ return code;
115
+ }
116
+
117
+
118
+ createUBO(gl: WebGL2RenderingContext, bufferWriteType: string = "STATIC_DRAW"): UBOHandler {
119
+ const ubo = gl.createBuffer();
120
+ gl.bindBuffer(gl.UNIFORM_BUFFER, ubo);
121
+ // @ts-ignore
122
+ gl.bufferData(gl.UNIFORM_BUFFER, this.size, gl[bufferWriteType]);
123
+ gl.bindBufferBase(gl.UNIFORM_BUFFER, 0, ubo);
124
+
125
+ for (const member of this.blockMembers) {
126
+ const { name, type, value = null } = member;;
127
+ const offset = this.offsetMap.get(name) as number;
128
+ const data = (value === null) ? new typeArrayConstructors[type](typeSizes[type] / 4).fill(NaN) : value;
129
+ gl.bufferSubData(gl.UNIFORM_BUFFER, offset, data);
130
+ }
131
+ gl.bindBuffer(gl.UNIFORM_BUFFER, null);
132
+
133
+ return { // TODO typedef this, encapsulate this in a class or something, ask ai
134
+ ubo,
135
+ update: (nameValueMap: NameValueMap) => this.updateUBO(gl, ubo, nameValueMap),
136
+ updateSingle: (key: string, value: Float32Array | Int32Array | Uint32Array | ArrayBuffer | DataView) => this.updateUboSingle(gl, ubo, key, value),
137
+ bind: () => this.bind(gl, ubo),
138
+ unbind: () => this.unbind(gl),
139
+ free: () => gl.deleteBuffer(ubo),
140
+ };
141
+ }
142
+
143
+ updateUboSingle(gl: WebGL2RenderingContext, ubo: WebGLBuffer, key: string, value: Float32Array | Int32Array | Uint32Array | ArrayBuffer | DataView) { // TEST THIS
144
+ gl.bindBuffer(gl.UNIFORM_BUFFER, ubo);
145
+ const offset = this.offsetMap.get(key);
146
+ if (offset === undefined) {
147
+ throw new Error(`Uniform block member ${key} not found in offset map.\nPossible members: ${Array.from(this.offsetMap.keys()).join(", ")}`);
148
+ }
149
+ const memberType = this.blockMembers.find(member => member.name === key)!.type;
150
+ let data: Float32Array | Int32Array | Uint32Array | ArrayBuffer | DataView;
151
+ if (Array.isArray(value)) {
152
+ data = new typeArrayConstructors[memberType](value);
153
+ } else if (typeof value === 'number') {
154
+ data = new typeArrayConstructors[memberType]([value]);
155
+ } else if (value instanceof ArrayBuffer) {
156
+ data = new typeArrayConstructors[memberType](value);
157
+ } else if (ArrayBuffer.isView(value) && !(value instanceof DataView)) {
158
+ data = (typeof value === 'number') ? new typeArrayConstructors[memberType]([value]) : new typeArrayConstructors[memberType](value);
159
+ } else {
160
+ throw new Error(`Unsupported value type for ${key}: ${typeof value}.\n Supported types are: number, Array, ArrayBuffer, TypedArray.`);
161
+ }
162
+ gl.bufferSubData(gl.UNIFORM_BUFFER, offset, data);
163
+ gl.bindBuffer(gl.UNIFORM_BUFFER, null);
164
+
165
+ }
166
+
167
+ updateUBO(gl: WebGL2RenderingContext, ubo: WebGLBuffer, nameValueMap: NameValueMap) {
168
+ gl.bindBuffer(gl.UNIFORM_BUFFER, ubo);
169
+ for (const [name, value] of nameValueMap.entries()) {
170
+ const offset = this.offsetMap.get(name);
171
+ if (offset === undefined) {
172
+ throw new Error(`Uniform block member ${name} not found in offset map.\nPossible members: ${Array.from(this.offsetMap.keys()).join(", ")}`);
173
+ }
174
+ const type = this.blockMembers.find(member => member.name === name)!.type;
175
+ let data: Float32Array | Int32Array | Uint32Array | ArrayBuffer | DataView;
176
+ if (Array.isArray(value)) {
177
+ data = new typeArrayConstructors[type](value);
178
+ } else if (typeof value === 'number') {
179
+ data = new typeArrayConstructors[type]([value]);
180
+ } else if (value instanceof ArrayBuffer) {
181
+ data = new typeArrayConstructors[type](value);
182
+ } else if (ArrayBuffer.isView(value) && !(value instanceof DataView))
183
+ data = (typeof value === 'number') ? new typeArrayConstructors[type]([value]) : new typeArrayConstructors[type](value);
184
+ else {
185
+ throw new Error(`Unsupported value type for ${name}: ${typeof value}.\n Supported types are: number, Array, ArrayBuffer, TypedArray.`);
186
+ }
187
+ gl.bufferSubData(gl.UNIFORM_BUFFER, offset, data);
188
+ }
189
+ gl.bindBuffer(gl.UNIFORM_BUFFER, null);
190
+ }
191
+
192
+ // call this after linking the program
193
+ assignBindingPoint(gl: WebGL2RenderingContext, program: WebGLProgram) { // TODO: this can cause bugs on multiglobe
194
+ const blockIndex = gl.getUniformBlockIndex(program, this.blockName);
195
+ gl.uniformBlockBinding(program, blockIndex, this.bindingPoint);
196
+ }
197
+
198
+ // call this before drawing
199
+ bind(gl: WebGL2RenderingContext, ubo: WebGLBuffer) {
200
+ gl.bindBufferBase(gl.UNIFORM_BUFFER, this.bindingPoint, ubo);
201
+ }
202
+
203
+ // call this right after drawing
204
+ unbind(gl: WebGL2RenderingContext) {
205
+ gl.bindBufferBase(gl.UNIFORM_BUFFER, this.bindingPoint, null);
206
+ }
207
+
208
+
209
+ // implicit methods
210
+ __create_LayoutSTD140_OffsetMap(): Map<string, number> {
211
+ let offset = 0;
212
+ const offsetMap = new Map();
213
+ for (const member of this.blockMembers) {
214
+ const { name, type } = member;
215
+ const size = typeSizes[type];
216
+ const alignment = typeAlignments[type];
217
+ const padding = (alignment - (offset % alignment)) % alignment;
218
+ offset += padding;
219
+ offsetMap.set(name, offset);
220
+ offset += size;
221
+ }
222
+ return offsetMap;
223
+ }
224
+
225
+ // __create_LayoutSTD140_OffsetMap() should be called before this
226
+ __calculateSize() {
227
+ const lastOffset = Array.from(this.offsetMap.values()).pop() as number || 0;
228
+ const lastItemAlignment = typeAlignments[this.blockMembers[this.blockMembers.length - 1].type];
229
+ return lastOffset + lastItemAlignment;
230
+ }
231
+
232
+ }
@@ -1,4 +1,5 @@
1
- export function defaultblendfunction(gl) {
2
- gl.blendEquation(gl.FUNC_ADD); // TODO: TESTING THIS
3
- gl.blendFuncSeparate(gl.SRC_ALPHA, gl.ONE_MINUS_SRC_ALPHA, gl.ONE, gl.ONE_MINUS_SRC_ALPHA);
4
- }
1
+
2
+ export function defaultblendfunction(gl: WebGL2RenderingContext): void {
3
+ gl.blendEquation(gl.FUNC_ADD); // TODO: TESTING THIS
4
+ gl.blendFuncSeparate(gl.SRC_ALPHA, gl.ONE_MINUS_SRC_ALPHA, gl.ONE, gl.ONE_MINUS_SRC_ALPHA);
5
+ }
@@ -0,0 +1,9 @@
1
+ export function hashColorTo4IntArray(pickedColor: string): [number, number, number, number] {
2
+
3
+ const pickedHex = pickedColor.replace('#', '');
4
+ const pickedR = parseInt(pickedHex.substring(0, 2), 16) / 255;
5
+ const pickedG = parseInt(pickedHex.substring(2, 4), 16) / 255;
6
+ const pickedB = parseInt(pickedHex.substring(4, 6), 16) / 255;
7
+ const pickedA = parseInt(pickedHex.substring(6, 8) || 'FF', 16) / 255;
8
+ return [pickedR, pickedG, pickedB, pickedA];
9
+ }
package/util/index.js CHANGED
@@ -1,10 +1,9 @@
1
- "use strict";
2
- // import * as webglobjectbuilders from './webglobjectbuilders';
3
- // import * as shaderfunctions from './shaderfunctions';
4
- // import * as geometry from './geometry';
5
- // import * as webglobe from './webglobe';
6
- // export { webglobjectbuilders, shaderfunctions, geometry, webglobe };
7
- // export * from './webglobe';
8
- // export * from './webglobjectbuilders';
9
- // export * from './shaderfunctions';
10
- // export * from './geometry';
1
+ // import * as webglobjectbuilders from './webglobjectbuilders';
2
+ // import * as shaderfunctions from './shaderfunctions';
3
+ // import * as geometry from './geometry';
4
+ // import * as webglobe from './webglobe';
5
+ // export { webglobjectbuilders, shaderfunctions, geometry, webglobe };
6
+ // export * from './webglobe';
7
+ // export * from './webglobjectbuilders';
8
+ // export * from './shaderfunctions';
9
+ // export * from './geometry';
@@ -1 +0,0 @@
1
- "use strict";
@@ -1,2 +1,9 @@
1
- const createWorker = () => new Worker(new URL('./web-worker.js', import.meta.url), { type: 'module' });
2
- export { createWorker };
1
+ const createWorker = () => new Worker(
2
+ new URL(
3
+ './web-worker.js',
4
+ import.meta.url
5
+ ), { type: 'module' }
6
+ );
7
+
8
+
9
+ export {createWorker}