@pirireis/webglobeplugins 0.16.0 → 0.16.1

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 (480) hide show
  1. package/Math/angle-calculation.js +13 -14
  2. package/Math/bounds/line-bbox.js +186 -225
  3. package/Math/index.js +1 -0
  4. package/Math/mesh/mapbox-delaunay.js +544 -607
  5. package/Math/utils.js +2 -3
  6. package/algorithms/search-binary.js +16 -14
  7. package/altitude-locator/adaptors.js +1 -0
  8. package/altitude-locator/keymethod.js +1 -0
  9. package/altitude-locator/plugin.js +345 -446
  10. package/altitude-locator/types.js +21 -26
  11. package/arrowfield/adaptor.js +11 -11
  12. package/arrowfield/index.js +3 -3
  13. package/arrowfield/plugin.js +83 -128
  14. package/bearing-line/index.js +2 -2
  15. package/bearing-line/plugin.js +444 -520
  16. package/circle-line-chain/chain-list-map.js +201 -221
  17. package/circle-line-chain/init.js +1 -0
  18. package/circle-line-chain/plugin.js +411 -464
  19. package/circle-line-chain/util.js +1 -1
  20. package/compass-rose/compass-rose-padding-flat.js +230 -274
  21. package/compass-rose/compass-text-writer.js +149 -173
  22. package/compass-rose/index.js +3 -3
  23. package/compassrose/compassrose.js +293 -341
  24. package/compassrose/index.js +2 -2
  25. package/constants.js +3 -0
  26. package/heatwave/index.js +3 -4
  27. package/heatwave/isobar/objectarraylabels.js +200 -247
  28. package/heatwave/isobar/plugin.js +302 -339
  29. package/heatwave/isobar/quadtreecontours.js +298 -336
  30. package/heatwave/plugins/heatwaveglobeshell.js +204 -259
  31. package/index.js +12 -15
  32. package/jest.config.js +7 -6
  33. package/package.json +1 -4
  34. package/partialrings/buffer-manager.js +75 -89
  35. package/partialrings/index.js +2 -3
  36. package/partialrings/plugin.js +128 -160
  37. package/partialrings/program.js +188 -233
  38. package/pin/pin-object-array.js +300 -381
  39. package/pin/pin-point-totem.js +60 -77
  40. package/point-heat-map/adaptors/timetracksplugin-format-to-this.js +63 -78
  41. package/point-heat-map/index.js +1 -0
  42. package/point-heat-map/plugin-webworker.js +121 -148
  43. package/point-heat-map/point-to-heat-map-flow.js +124 -150
  44. package/point-tracks/key-methods.js +2 -3
  45. package/point-tracks/plugin.js +393 -480
  46. package/programs/arrowfield/index.js +2 -2
  47. package/programs/arrowfield/logic.js +141 -173
  48. package/programs/arrowfield/object.js +60 -89
  49. package/programs/data2legend/density-to-legend.js +73 -90
  50. package/programs/data2legend/point-to-density-texture.js +70 -87
  51. package/programs/float2legendwithratio/index.js +2 -3
  52. package/programs/float2legendwithratio/logic.js +118 -144
  53. package/programs/float2legendwithratio/object.js +104 -141
  54. package/programs/globe-util/is-globe-moved.js +19 -27
  55. package/programs/globeshell/index.js +2 -2
  56. package/programs/globeshell/wiggle/index.js +2 -3
  57. package/programs/globeshell/wiggle/logic.js +243 -272
  58. package/programs/globeshell/wiggle/object.js +66 -93
  59. package/programs/helpers/blender/index.js +1 -0
  60. package/programs/helpers/blender/program.js +58 -73
  61. package/programs/helpers/fadeaway/index.js +2 -3
  62. package/programs/helpers/fadeaway/logic.js +46 -53
  63. package/programs/helpers/fadeaway/object.js +14 -20
  64. package/programs/helpers/index.js +2 -2
  65. package/programs/index.js +9 -21
  66. package/programs/line-on-globe/circle-accurate-3d.js +87 -115
  67. package/programs/line-on-globe/circle-accurate-flat.js +149 -201
  68. package/programs/line-on-globe/degree-padding-around-circle-3d.js +104 -136
  69. package/programs/line-on-globe/index.js +1 -0
  70. package/programs/line-on-globe/lines-color-instanced-flat.js +83 -102
  71. package/programs/line-on-globe/util.js +5 -8
  72. package/programs/picking/pickable-polygon-renderer.js +98 -129
  73. package/programs/picking/pickable-renderer.js +98 -129
  74. package/programs/point-on-globe/element-globe-surface-glow.js +93 -122
  75. package/programs/point-on-globe/element-point-glow.js +80 -114
  76. package/programs/point-on-globe/square-pixel-point.js +120 -138
  77. package/programs/rings/distancering/circleflatprogram.js +116 -138
  78. package/programs/rings/distancering/circlepaddingfreeangleprogram.js +275 -323
  79. package/programs/rings/distancering/circlepaddysharedbuffer.js +368 -423
  80. package/programs/rings/distancering/index.js +6 -5
  81. package/programs/rings/distancering/paddyflatprogram.js +127 -148
  82. package/programs/rings/distancering/paddyflatprogram2d.js +129 -153
  83. package/programs/rings/distancering/paddyflatprogram3d.js +128 -149
  84. package/programs/rings/index.js +1 -1
  85. package/{dist/programs → programs}/totems/camerauniformblock.js +10 -3
  86. package/programs/totems/gpu-selection-uniform-block.js +99 -127
  87. package/programs/two-d/pixel-circle.js +1 -0
  88. package/programs/two-d/pixel-padding-for-compass.js +97 -112
  89. package/programs/util.js +14 -19
  90. package/programs/vectorfields/index.js +3 -3
  91. package/programs/vectorfields/logics/drawrectangleparticles.js +58 -78
  92. package/programs/vectorfields/logics/index.js +2 -4
  93. package/programs/vectorfields/logics/pixelbased.js +73 -92
  94. package/programs/vectorfields/logics/ubo.js +51 -57
  95. package/programs/vectorfields/pingpongbuffermanager.js +73 -80
  96. package/rangerings/index.js +5 -5
  97. package/rangerings/plugin.js +543 -644
  98. package/rangerings/rangeringangletext.js +326 -369
  99. package/rangerings/ring-account.js +112 -129
  100. package/shaders/fragment-toy/firework.js +1 -1
  101. package/shaders/fragment-toy/singularity.js +2 -5
  102. package/timetracks/adaptors-line-strip.js +65 -80
  103. package/timetracks/index.js +1 -0
  104. package/timetracks/plugin-line-strip.js +240 -295
  105. package/timetracks/program-line-strip.js +411 -491
  106. package/timetracks/programpoint-line-strip.js +98 -122
  107. package/util/account/bufferoffsetmanager.js +176 -209
  108. package/util/account/index.js +3 -6
  109. package/util/account/util.js +18 -22
  110. package/util/algorithms/index.js +1 -0
  111. package/util/algorithms/search-binary.js +25 -26
  112. package/util/check/index.js +1 -0
  113. package/util/geometry/index.js +121 -0
  114. package/util/gl-util/uniform-block/shader.js +1 -0
  115. package/util/heatwavedatamanager/datamanager.js +149 -168
  116. package/util/heatwavedatamanager/index.js +2 -2
  117. package/util/index.js +13 -13
  118. package/util/interpolation/index.js +1 -0
  119. package/util/interpolation/timetrack/index.js +2 -9
  120. package/util/interpolation/timetrack/timetrack-interpolator.js +79 -94
  121. package/util/interpolation/timetrack/web-worker.js +46 -51
  122. package/util/jshelpers/data-filler.js +17 -19
  123. package/util/jshelpers/equality.js +18 -17
  124. package/util/jshelpers/index.js +2 -1
  125. package/util/jshelpers/timefilters.js +30 -32
  126. package/util/picking/fence.js +43 -46
  127. package/util/picking/picker-displayer.js +136 -177
  128. package/util/programs/draw-texture-on-canvas.js +66 -82
  129. package/util/programs/index.js +1 -1
  130. package/util/programs/shapesonglobe.js +167 -203
  131. package/util/programs/supersampletotextures.js +99 -132
  132. package/util/programs/texturetoglobe.js +128 -152
  133. package/util/shaderfunctions/index.js +2 -2
  134. package/util/shaderfunctions/nodata.js +2 -4
  135. package/util/shaderfunctions/noisefunctions.js +7 -10
  136. package/util/surface-line-data/arcs-to-cuts.js +50 -74
  137. package/util/surface-line-data/cut-arc.js +1 -0
  138. package/util/surface-line-data/rbush-manager.js +1 -0
  139. package/util/surface-line-data/web-worker.js +1 -0
  140. package/util/webglobe/gldefaultstates.js +4 -5
  141. package/util/webglobe/index.js +2 -2
  142. package/util/webglobe/rasteroverlay.js +75 -96
  143. package/waveparticles/adaptor.js +15 -16
  144. package/waveparticles/index.js +3 -3
  145. package/waveparticles/plugin.js +290 -342
  146. package/wind/imagetovectorfieldandmagnitude.js +56 -71
  147. package/wind/index.js +5 -5
  148. package/wind/plugin.js +670 -845
  149. package/wind/vectorfieldimage.js +23 -27
  150. package/write-text/attached-text-writer.js +87 -105
  151. package/{dist/write-text → write-text}/context-text-bulk.js +28 -15
  152. package/write-text/context-text.js +94 -125
  153. package/write-text/context-text3old.js +152 -179
  154. package/write-text/index.js +1 -1
  155. package/write-text/writer-plugin.js +8 -7
  156. package/Math/arc-cdf-points.ts +0 -329
  157. package/Math/arc-generate-points-exponantial.ts +0 -299
  158. package/Math/arc.ts +0 -299
  159. package/Math/circle-cdf-points.ts +0 -143
  160. package/Math/circle.ts +0 -49
  161. package/Math/constants.ts +0 -12
  162. package/Math/juction/arc-plane.ts +0 -129
  163. package/Math/juction/line-sphere.ts +0 -30
  164. package/Math/juction/plane-plane.ts +0 -64
  165. package/Math/line.ts +0 -84
  166. package/Math/matrix4.ts +0 -0
  167. package/Math/methods.ts +0 -157
  168. package/Math/plane.ts +0 -92
  169. package/Math/quaternion.ts +0 -128
  170. package/Math/roadmap.md +0 -10
  171. package/Math/templete-shapes/grid-visually-equal.ts +0 -119
  172. package/Math/types.ts +0 -66
  173. package/Math/vec3.ts +0 -180
  174. package/circle-line-chain/readme.md +0 -57
  175. package/depth-locator/readme.md +0 -26
  176. package/dist/Math/angle-calculation.js +0 -13
  177. package/dist/Math/bounds/line-bbox.js +0 -186
  178. package/dist/Math/index.js +0 -1
  179. package/dist/Math/mesh/mapbox-delaunay.js +0 -544
  180. package/dist/Math/utils.js +0 -2
  181. package/dist/algorithms/search-binary.js +0 -16
  182. package/dist/altitude-locator/adaptors.js +0 -1
  183. package/dist/altitude-locator/keymethod.js +0 -1
  184. package/dist/altitude-locator/plugin.js +0 -345
  185. package/dist/altitude-locator/types.js +0 -21
  186. package/dist/arrowfield/adaptor.js +0 -11
  187. package/dist/arrowfield/index.js +0 -3
  188. package/dist/arrowfield/plugin.js +0 -83
  189. package/dist/bearing-line/index.js +0 -2
  190. package/dist/bearing-line/plugin.js +0 -444
  191. package/dist/circle-line-chain/chain-list-map.js +0 -201
  192. package/dist/circle-line-chain/init.js +0 -1
  193. package/dist/circle-line-chain/plugin.js +0 -411
  194. package/dist/circle-line-chain/util.js +0 -1
  195. package/dist/compass-rose/compass-rose-padding-flat.js +0 -230
  196. package/dist/compass-rose/compass-text-writer.js +0 -149
  197. package/dist/compass-rose/index.js +0 -3
  198. package/dist/compassrose/compassrose.js +0 -293
  199. package/dist/compassrose/index.js +0 -2
  200. package/dist/heatwave/index.js +0 -3
  201. package/dist/heatwave/isobar/objectarraylabels.js +0 -200
  202. package/dist/heatwave/isobar/plugin.js +0 -302
  203. package/dist/heatwave/isobar/quadtreecontours.js +0 -298
  204. package/dist/heatwave/plugins/heatwaveglobeshell.js +0 -204
  205. package/dist/index.js +0 -12
  206. package/dist/jest.config.js +0 -7
  207. package/dist/partialrings/buffer-manager.js +0 -75
  208. package/dist/partialrings/index.js +0 -2
  209. package/dist/partialrings/plugin.js +0 -128
  210. package/dist/partialrings/program.js +0 -279
  211. package/dist/pin/pin-object-array.js +0 -300
  212. package/dist/pin/pin-point-totem.js +0 -60
  213. package/dist/point-heat-map/adaptors/timetracksplugin-format-to-this.js +0 -63
  214. package/dist/point-heat-map/index.js +0 -1
  215. package/dist/point-heat-map/plugin-webworker.js +0 -121
  216. package/dist/point-heat-map/point-to-heat-map-flow.js +0 -124
  217. package/dist/point-tracks/key-methods.js +0 -2
  218. package/dist/point-tracks/plugin.js +0 -393
  219. package/dist/programs/arrowfield/index.js +0 -2
  220. package/dist/programs/arrowfield/logic.js +0 -254
  221. package/dist/programs/arrowfield/object.js +0 -60
  222. package/dist/programs/data2legend/density-to-legend.js +0 -98
  223. package/dist/programs/data2legend/point-to-density-texture.js +0 -97
  224. package/dist/programs/float2legendwithratio/index.js +0 -2
  225. package/dist/programs/float2legendwithratio/logic.js +0 -167
  226. package/dist/programs/float2legendwithratio/object.js +0 -104
  227. package/dist/programs/globe-util/is-globe-moved.js +0 -19
  228. package/dist/programs/globeshell/index.js +0 -2
  229. package/dist/programs/globeshell/wiggle/index.js +0 -2
  230. package/dist/programs/globeshell/wiggle/logic.js +0 -342
  231. package/dist/programs/globeshell/wiggle/object.js +0 -66
  232. package/dist/programs/helpers/blender/index.js +0 -1
  233. package/dist/programs/helpers/blender/program.js +0 -76
  234. package/dist/programs/helpers/fadeaway/index.js +0 -2
  235. package/dist/programs/helpers/fadeaway/logic.js +0 -69
  236. package/dist/programs/helpers/fadeaway/object.js +0 -14
  237. package/dist/programs/helpers/index.js +0 -2
  238. package/dist/programs/index.js +0 -9
  239. package/dist/programs/line-on-globe/circle-accurate-3d.js +0 -138
  240. package/dist/programs/line-on-globe/circle-accurate-flat.js +0 -210
  241. package/dist/programs/line-on-globe/degree-padding-around-circle-3d.js +0 -156
  242. package/dist/programs/line-on-globe/index.js +0 -1
  243. package/dist/programs/line-on-globe/lines-color-instanced-flat.js +0 -131
  244. package/dist/programs/line-on-globe/util.js +0 -5
  245. package/dist/programs/picking/pickable-polygon-renderer.js +0 -184
  246. package/dist/programs/picking/pickable-renderer.js +0 -184
  247. package/dist/programs/point-on-globe/element-globe-surface-glow.js +0 -138
  248. package/dist/programs/point-on-globe/element-point-glow.js +0 -150
  249. package/dist/programs/point-on-globe/square-pixel-point.js +0 -171
  250. package/dist/programs/rings/distancering/circleflatprogram.js +0 -116
  251. package/dist/programs/rings/distancering/circlepaddingfreeangleprogram.js +0 -326
  252. package/dist/programs/rings/distancering/circlepaddysharedbuffer.js +0 -368
  253. package/dist/programs/rings/distancering/index.js +0 -6
  254. package/dist/programs/rings/distancering/paddyflatprogram.js +0 -127
  255. package/dist/programs/rings/distancering/paddyflatprogram2d.js +0 -129
  256. package/dist/programs/rings/distancering/paddyflatprogram3d.js +0 -128
  257. package/dist/programs/rings/index.js +0 -1
  258. package/dist/programs/totems/gpu-selection-uniform-block.js +0 -104
  259. package/dist/programs/two-d/pixel-circle.js +0 -1
  260. package/dist/programs/two-d/pixel-padding-for-compass.js +0 -159
  261. package/dist/programs/util.js +0 -14
  262. package/dist/programs/vectorfields/index.js +0 -3
  263. package/dist/programs/vectorfields/logics/drawrectangleparticles.js +0 -113
  264. package/dist/programs/vectorfields/logics/index.js +0 -2
  265. package/dist/programs/vectorfields/logics/pixelbased.js +0 -140
  266. package/dist/programs/vectorfields/logics/ubo.js +0 -60
  267. package/dist/programs/vectorfields/pingpongbuffermanager.js +0 -73
  268. package/dist/rangerings/index.js +0 -5
  269. package/dist/rangerings/plugin.js +0 -543
  270. package/dist/rangerings/rangeringangletext.js +0 -326
  271. package/dist/rangerings/ring-account.js +0 -112
  272. package/dist/shaders/fragment-toy/firework.js +0 -55
  273. package/dist/shaders/fragment-toy/singularity.js +0 -56
  274. package/dist/timetracks/adaptors-line-strip.js +0 -65
  275. package/dist/timetracks/index.js +0 -1
  276. package/dist/timetracks/plugin-line-strip.js +0 -240
  277. package/dist/timetracks/program-line-strip.js +0 -608
  278. package/dist/timetracks/programpoint-line-strip.js +0 -151
  279. package/dist/util/account/bufferoffsetmanager.js +0 -176
  280. package/dist/util/account/index.js +0 -3
  281. package/dist/util/account/util.js +0 -18
  282. package/dist/util/algorithms/index.js +0 -1
  283. package/dist/util/algorithms/search-binary.js +0 -25
  284. package/dist/util/check/index.js +0 -1
  285. package/dist/util/geometry/index.js +0 -47
  286. package/dist/util/gl-util/uniform-block/shader.js +0 -1
  287. package/dist/util/heatwavedatamanager/datamanager.js +0 -149
  288. package/dist/util/heatwavedatamanager/index.js +0 -2
  289. package/dist/util/index.js +0 -13
  290. package/dist/util/interpolation/index.js +0 -1
  291. package/dist/util/interpolation/timetrack/index.js +0 -2
  292. package/dist/util/interpolation/timetrack/timetrack-interpolator.js +0 -79
  293. package/dist/util/interpolation/timetrack/web-worker.js +0 -46
  294. package/dist/util/jshelpers/data-filler.js +0 -17
  295. package/dist/util/jshelpers/equality.js +0 -18
  296. package/dist/util/jshelpers/index.js +0 -2
  297. package/dist/util/jshelpers/timefilters.js +0 -30
  298. package/dist/util/picking/fence.js +0 -43
  299. package/dist/util/picking/picker-displayer.js +0 -136
  300. package/dist/util/programs/draw-texture-on-canvas.js +0 -86
  301. package/dist/util/programs/index.js +0 -1
  302. package/dist/util/programs/shapesonglobe.js +0 -210
  303. package/dist/util/programs/supersampletotextures.js +0 -109
  304. package/dist/util/programs/texturetoglobe.js +0 -179
  305. package/dist/util/shaderfunctions/index.js +0 -2
  306. package/dist/util/shaderfunctions/nodata.js +0 -8
  307. package/dist/util/shaderfunctions/noisefunctions.js +0 -41
  308. package/dist/util/surface-line-data/arcs-to-cuts.js +0 -50
  309. package/dist/util/surface-line-data/cut-arc.js +0 -1
  310. package/dist/util/surface-line-data/rbush-manager.js +0 -1
  311. package/dist/util/surface-line-data/web-worker.js +0 -1
  312. package/dist/util/webglobe/gldefaultstates.js +0 -4
  313. package/dist/util/webglobe/index.js +0 -2
  314. package/dist/util/webglobe/rasteroverlay.js +0 -75
  315. package/dist/waveparticles/adaptor.js +0 -15
  316. package/dist/waveparticles/index.js +0 -3
  317. package/dist/waveparticles/plugin.js +0 -290
  318. package/dist/wind/imagetovectorfieldandmagnitude.js +0 -56
  319. package/dist/wind/index.js +0 -5
  320. package/dist/wind/plugin.js +0 -921
  321. package/dist/wind/vectorfieldimage.js +0 -23
  322. package/dist/write-text/attached-text-writer.js +0 -87
  323. package/dist/write-text/context-text.js +0 -94
  324. package/dist/write-text/context-text3old.js +0 -152
  325. package/dist/write-text/index.js +0 -1
  326. package/dist/write-text/writer-plugin.js +0 -8
  327. package/partialrings/goals.md +0 -17
  328. package/point-heat-map/readme.md +0 -15
  329. package/programs/line-on-globe/linestrip/data.ts +0 -29
  330. package/programs/line-on-globe/linestrip/linestrip.ts +0 -201
  331. package/programs/line-on-globe/naive-accurate-flexible.ts +0 -258
  332. package/programs/polygon-on-globe/texture-dem-triangle-test-plugin.ts +0 -120
  333. package/programs/polygon-on-globe/texture-dem-triangles.ts +0 -207
  334. package/programs/programcache.ts +0 -131
  335. package/programs/rings/partial-ring/piece-of-pie.ts +0 -323
  336. package/programs/totems/camerauniformblock.ts +0 -310
  337. package/programs/totems/canvas-webglobe-info.ts +0 -156
  338. package/programs/totems/globe-changes.ts +0 -79
  339. package/programs/totems/index.ts +0 -2
  340. package/programs/vectorfields/logics/constants.ts +0 -5
  341. package/programs/vectorfields/logics/ubo-new.ts +0 -37
  342. package/publish.bat +0 -62
  343. package/range-tools-on-terrain/bearing-line/adapters.ts +0 -154
  344. package/range-tools-on-terrain/bearing-line/plugin.ts +0 -569
  345. package/range-tools-on-terrain/bearing-line/types.ts +0 -65
  346. package/range-tools-on-terrain/circle-line-chain/adapters.ts +0 -109
  347. package/range-tools-on-terrain/circle-line-chain/chain-list-map.ts +0 -446
  348. package/range-tools-on-terrain/circle-line-chain/plugin.ts +0 -607
  349. package/range-tools-on-terrain/circle-line-chain/types.ts +0 -43
  350. package/range-tools-on-terrain/range-ring/adapters.ts +0 -114
  351. package/range-tools-on-terrain/range-ring/enum.ts +0 -2
  352. package/range-tools-on-terrain/range-ring/plugin.ts +0 -447
  353. package/range-tools-on-terrain/range-ring/rangeringangletext.ts +0 -396
  354. package/range-tools-on-terrain/range-ring/types.ts +0 -30
  355. package/rangerings/enum.ts +0 -2
  356. package/semiplugins/interface.ts +0 -14
  357. package/semiplugins/lightweight/line-plugin.ts +0 -343
  358. package/semiplugins/lightweight/piece-of-pie-plugin.ts +0 -275
  359. package/semiplugins/shape-on-terrain/arc-plugin.ts +0 -602
  360. package/semiplugins/shape-on-terrain/circle-plugin.ts +0 -588
  361. package/semiplugins/shape-on-terrain/goal.md +0 -12
  362. package/semiplugins/shape-on-terrain/padding-1-degree.ts +0 -714
  363. package/semiplugins/shape-on-terrain/terrain-cover/notes.md +0 -90
  364. package/semiplugins/shape-on-terrain/terrain-cover/texture-dem-cover.ts +0 -0
  365. package/semiplugins/type.ts +0 -8
  366. package/tests/Math/arc-sampling-test.js +0 -367
  367. package/tests/Math/arc-sampling-test.ts +0 -429
  368. package/tests/Math/arc.test.ts +0 -102
  369. package/tests/Math/junction/arc-plane.test.ts +0 -163
  370. package/tests/Math/junction/plane-plane.test.ts +0 -91
  371. package/tests/Math/plane-test.ts +0 -17
  372. package/tests/Math/plane.test.ts +0 -43
  373. package/tests/Math/vec3.test.ts +0 -14
  374. package/timetracks/readme.md +0 -1
  375. package/tsconfig.json +0 -22
  376. package/types.ts +0 -265
  377. package/util/account/create-buffermap-orchastration.ts +0 -85
  378. package/util/account/single-attribute-buffer-management/buffer-manager.ts +0 -149
  379. package/util/account/single-attribute-buffer-management/buffer-orchestrator.ts +0 -332
  380. package/util/account/single-attribute-buffer-management/buffer-orchestrator1.ts +0 -184
  381. package/util/account/single-attribute-buffer-management/index.ts +0 -11
  382. package/util/account/single-attribute-buffer-management/object-store.ts +0 -76
  383. package/util/account/single-attribute-buffer-management/types.ts +0 -43
  384. package/util/build-strategy/general-strategy.ts +0 -99
  385. package/util/build-strategy/static-dynamic.ts +0 -50
  386. package/util/check/typecheck.ts +0 -74
  387. package/util/frame-counter-trigger.ts +0 -99
  388. package/util/geometry/index.ts +0 -64
  389. package/util/gl-util/buffer/attribute-loader.ts +0 -84
  390. package/util/gl-util/buffer/index.ts +0 -6
  391. package/util/gl-util/draw-options/methods.ts +0 -47
  392. package/util/gl-util/uniform-block/manager.ts +0 -210
  393. package/util/gl-util/uniform-block/roadmap.md +0 -70
  394. package/util/gl-util/uniform-block/types.ts +0 -20
  395. package/util/heatwavedatamanager/pointcoordsmeta.ts +0 -28
  396. package/util/heatwavedatamanager/texture-point-sampler.ts +0 -198
  397. package/util/shaderfunctions/geometrytransformations.ts +0 -388
  398. package/util/surface-line-data/arc-bboxes.ts +0 -42
  399. package/util/surface-line-data/flow.ts +0 -52
  400. package/util/surface-line-data/types.ts +0 -27
  401. package/util/webglobjectbuilders.ts +0 -446
  402. package/write-text/context-text-bulk.ts +0 -268
  403. package/write-text/context-text3.ts +0 -253
  404. package/write-text/context-text4.ts +0 -243
  405. /package/{dist/Math → Math}/arc-cdf-points.js +0 -0
  406. /package/{dist/Math → Math}/arc-generate-points-exponantial.js +0 -0
  407. /package/{dist/Math → Math}/arc.js +0 -0
  408. /package/{dist/Math → Math}/circle-cdf-points.js +0 -0
  409. /package/{dist/Math → Math}/circle.js +0 -0
  410. /package/{dist/Math → Math}/constants.js +0 -0
  411. /package/{dist/Math → Math}/juction/arc-plane.js +0 -0
  412. /package/{dist/Math → Math}/juction/line-sphere.js +0 -0
  413. /package/{dist/Math → Math}/juction/plane-plane.js +0 -0
  414. /package/{dist/Math → Math}/line.js +0 -0
  415. /package/{dist/Math → Math}/matrix4.js +0 -0
  416. /package/{dist/Math → Math}/methods.js +0 -0
  417. /package/{dist/Math → Math}/plane.js +0 -0
  418. /package/{dist/Math → Math}/quaternion.js +0 -0
  419. /package/{dist/Math → Math}/templete-shapes/grid-visually-equal.js +0 -0
  420. /package/{dist/Math → Math}/types.js +0 -0
  421. /package/{dist/Math → Math}/vec3.js +0 -0
  422. /package/{dist/programs → programs}/line-on-globe/linestrip/data.js +0 -0
  423. /package/{dist/programs → programs}/line-on-globe/linestrip/linestrip.js +0 -0
  424. /package/{dist/programs → programs}/line-on-globe/naive-accurate-flexible.js +0 -0
  425. /package/{dist/programs → programs}/polygon-on-globe/texture-dem-triangle-test-plugin.js +0 -0
  426. /package/{dist/programs → programs}/polygon-on-globe/texture-dem-triangles.js +0 -0
  427. /package/{dist/programs → programs}/programcache.js +0 -0
  428. /package/{dist/programs → programs}/rings/partial-ring/piece-of-pie.js +0 -0
  429. /package/{dist/programs → programs}/totems/canvas-webglobe-info.js +0 -0
  430. /package/{dist/programs → programs}/totems/globe-changes.js +0 -0
  431. /package/{dist/programs → programs}/totems/index.js +0 -0
  432. /package/{dist/programs → programs}/vectorfields/logics/constants.js +0 -0
  433. /package/{dist/programs → programs}/vectorfields/logics/ubo-new.js +0 -0
  434. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/bearing-line/adapters.js +0 -0
  435. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/bearing-line/plugin.js +0 -0
  436. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/bearing-line/types.js +0 -0
  437. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/circle-line-chain/adapters.js +0 -0
  438. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/circle-line-chain/chain-list-map.js +0 -0
  439. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/circle-line-chain/plugin.js +0 -0
  440. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/circle-line-chain/types.js +0 -0
  441. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/range-ring/adapters.js +0 -0
  442. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/range-ring/enum.js +0 -0
  443. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/range-ring/plugin.js +0 -0
  444. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/range-ring/rangeringangletext.js +0 -0
  445. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/range-ring/types.js +0 -0
  446. /package/{dist/rangerings → rangerings}/enum.js +0 -0
  447. /package/{dist/semiplugins → semiplugins}/interface.js +0 -0
  448. /package/{dist/semiplugins → semiplugins}/lightweight/line-plugin.js +0 -0
  449. /package/{dist/semiplugins → semiplugins}/lightweight/piece-of-pie-plugin.js +0 -0
  450. /package/{dist/semiplugins → semiplugins}/shape-on-terrain/arc-plugin.js +0 -0
  451. /package/{dist/semiplugins → semiplugins}/shape-on-terrain/circle-plugin.js +0 -0
  452. /package/{dist/semiplugins → semiplugins}/shape-on-terrain/padding-1-degree.js +0 -0
  453. /package/{dist/semiplugins → semiplugins}/shape-on-terrain/terrain-cover/texture-dem-cover.js +0 -0
  454. /package/{dist/semiplugins → semiplugins}/type.js +0 -0
  455. /package/{dist/types.js → types.js} +0 -0
  456. /package/{dist/util → util}/account/create-buffermap-orchastration.js +0 -0
  457. /package/{dist/util → util}/account/single-attribute-buffer-management/buffer-manager.js +0 -0
  458. /package/{dist/util → util}/account/single-attribute-buffer-management/buffer-orchestrator.js +0 -0
  459. /package/{dist/util → util}/account/single-attribute-buffer-management/buffer-orchestrator1.js +0 -0
  460. /package/{dist/util → util}/account/single-attribute-buffer-management/index.js +0 -0
  461. /package/{dist/util → util}/account/single-attribute-buffer-management/object-store.js +0 -0
  462. /package/{dist/util → util}/account/single-attribute-buffer-management/types.js +0 -0
  463. /package/{dist/util → util}/build-strategy/general-strategy.js +0 -0
  464. /package/{dist/util → util}/build-strategy/static-dynamic.js +0 -0
  465. /package/{dist/util → util}/check/typecheck.js +0 -0
  466. /package/{dist/util → util}/frame-counter-trigger.js +0 -0
  467. /package/{dist/util → util}/gl-util/buffer/attribute-loader.js +0 -0
  468. /package/{dist/util → util}/gl-util/buffer/index.js +0 -0
  469. /package/{dist/util → util}/gl-util/draw-options/methods.js +0 -0
  470. /package/{dist/util → util}/gl-util/uniform-block/manager.js +0 -0
  471. /package/{dist/util → util}/gl-util/uniform-block/types.js +0 -0
  472. /package/{dist/util → util}/heatwavedatamanager/pointcoordsmeta.js +0 -0
  473. /package/{dist/util → util}/heatwavedatamanager/texture-point-sampler.js +0 -0
  474. /package/{dist/util → util}/shaderfunctions/geometrytransformations.js +0 -0
  475. /package/{dist/util → util}/surface-line-data/arc-bboxes.js +0 -0
  476. /package/{dist/util → util}/surface-line-data/flow.js +0 -0
  477. /package/{dist/util → util}/surface-line-data/types.js +0 -0
  478. /package/{dist/util → util}/webglobjectbuilders.js +0 -0
  479. /package/{dist/write-text → write-text}/context-text3.js +0 -0
  480. /package/{dist/write-text → write-text}/context-text4.js +0 -0
@@ -1,194 +1,162 @@
1
- /**
2
- * Author: Toprak Nihat Deniz Ozturk
3
- */
4
-
5
- import { createProgram, defaultblendfunction, shaderfunctions } from "../util";
6
-
7
- export default class TrackGlowLineProgram {
8
- /**
9
- * @param {WebGL2RenderingContext} gl
10
- * @param {number} width
11
- * @param {number} height
12
- * @param {Object} options
13
- * @param {number} options.headPercentage 0 ~ 1
14
- * @param {number} options.routeAlpha 0 ~ 1
15
- * @param {Array.<Number>} options.weights [w1, w2, w3, w4, w5]
16
- * @param {number} options.alphaThreshold 0 ~ 1
17
- * @param {number} options.exposure 0 ~ inf
18
- * @param {number} options.gamma 0 ~ inf
19
- * @param {number} options.finalAlphaRatio 0 ~ 1
20
- * @param {+int} options.blurRepetition 1 ~ inf default 2
21
- */
22
- constructor(gl, attrBuffer, width, height, options = {}) {
23
- this.gl = gl;
24
- this.program = null;
25
-
26
-
27
- // this._inBuffer = gl.createBuffer();
28
- this._inBuffer = attrBuffer;
29
-
30
- this._frameBuffer = gl.createFramebuffer();
31
- this._lineProgram = this._createLineProgram();
32
- this._blurProgram = this._createBlurProgram();
33
- this._combineProgram = this._createCombineProgram();
34
- this.resize(width, height);
35
-
36
- this._middleTexture = null;
37
- this._blurTextures = null;
38
- this._createInnerTextures();
39
-
40
- this._blurFrameBuffers = [gl.createFramebuffer(), gl.createFramebuffer()];
41
-
42
- this._blurRepetition = options.blurRepetition || 1;
43
- this._totalLength = 0;
44
- this._initUniforms(options);
45
- }
46
-
47
-
48
- _createInnerTextures() {
49
- this._middleTexture = this._createTextures();
50
- this._blurTextures = [this._createTextures(), this._createTextures()];
51
- }
52
-
53
- _initUniforms(options = {}) {
54
- const { gl, _lineProgram, _blurProgram, _combineProgram } = this;
55
-
56
- const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
57
-
58
- gl.useProgram(_lineProgram.program);
59
- gl.uniform1f(_lineProgram.u_head_percentage, options.headPercentage || 1.0 / 30.0);
60
- gl.uniform1f(_lineProgram.u_route_alpha, options.routeAlpha || 0.025);
61
-
62
- gl.useProgram(_blurProgram.program);
63
- gl.uniform1fv(_blurProgram.u_weight, options.weights || [0.55, 0.45045946, 0.3216216, 0.254054, 0.056216]);
64
-
65
- gl.useProgram(_combineProgram.program);
66
- gl.uniform1f(_combineProgram.u_exposure, options.exposure || 1.0);
67
- gl.uniform1f(_combineProgram.u_gamma, options.gamma || 1.0);
68
- gl.uniform1f(_combineProgram.u_final_alpha_ratio, options.finalAlphaRatio || 1.0);
69
- gl.useProgram(currentProgram);
70
- }
71
-
72
-
73
-
74
-
75
-
76
- /**
77
- * @param {number} gamma 0 ~ inf
78
- */
79
- setGamma(gamma) {
80
- if (gamma < 0) {
81
- console.warn("gamma should be equal or greater than 0, but got", gamma);
82
- return;
83
- }
84
- const { gl, _combineProgram } = this;
85
- const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
86
- gl.useProgram(_combineProgram.program);
87
- gl.uniform1f(_combineProgram.u_gamma, gamma);
88
- gl.useProgram(currentProgram);
89
- }
90
-
91
- /**
92
- *
93
- * @param {number} exposure 0 ~ inf
94
- * @returns
95
- */
96
- setExposure(exposure) {
97
- if (exposure < 0) {
98
- console.warn("exposure should be equal or greater than 0, but got", exposure);
99
- return;
100
- }
101
- const { gl, _combineProgram } = this;
102
- const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
103
- gl.useProgram(_combineProgram.program);
104
- gl.uniform1f(_combineProgram.u_exposure, exposure);
105
- gl.useProgram(currentProgram);
106
- }
107
-
108
-
109
- /**
110
- *
111
- * @param {number} ratio 0 ~ 1
112
- * @returns
113
- */
114
- setFinalAlphaRatio(ratio) {
115
- if (ratio < 0 || ratio > 1) {
116
- console.warn("ratio should be between 0 and 1, but got", ratio);
117
- return;
118
- }
119
- const { gl, _combineProgram } = this;
120
- const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
121
- gl.useProgram(_combineProgram.program);
122
- gl.uniform1f(_combineProgram.u_final_alpha_ratio, ratio);
123
- gl.useProgram(currentProgram);
124
-
125
- }
126
-
127
- /**
128
- * @param {Array.<Number>} weight [w1, w2, w3, w4, w5]
129
- */
130
- setBlurWeights(weights) {
131
- if (weights.length !== 5) {
132
- console.warn("weights should be an array of 5 numbers, but got", weights);
133
- return;
134
- }
135
- const { gl, _blurProgram } = this;
136
- const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
137
- gl.useProgram(_blurProgram.program);
138
- gl.uniform1fv(_blurProgram.u_weight, weights);
139
- gl.useProgram(currentProgram);
140
- }
141
-
142
-
143
- /**
144
- * @param {number} routeAlpha 0 ~ 1
145
- */
146
- setRouteAlpha(routeAlpha) {
147
- if (routeAlpha < 0 || routeAlpha > 1) {
148
- console.warn("routeAlpha should be between 0 and 1, but got", routeAlpha);
149
- return;
150
- }
151
- const { gl, _lineProgram } = this;
152
- const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
153
- gl.useProgram(_lineProgram.program);
154
- gl.uniform1f(_lineProgram.u_route_alpha, routeAlpha);
155
- gl.useProgram(currentProgram);
156
- }
157
-
158
-
159
- /**
160
- * blur uses pingpong effect. This number decides how many times the blur will be applied.
161
- * @param {+int} repetition
162
- * @returns
163
- */
164
- setBlurRepetition(repetition) {
165
- if (repetition < 0 && repetition % 1 !== 0) {
166
- console.warn("repetition should be an integer greater than 0, but got", repetition);
167
- return;
168
- }
169
- this._blurRepetition = repetition;
170
- }
171
-
172
- /**
173
- * Head Is colored as white. This number decides proportion of the head according to the total length of the line.
174
- * @param {Number} percentage 0 ~ 1
175
- */
176
- setHeadPercentage(percentage) {
177
- if (percentage < 0 || 1 < percentage) {
178
- console.warn("percentage should be between 0 and 1, but got", percentage);
179
- return
180
- };
181
- const { gl, _lineProgram } = this;
182
- const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
183
- gl.useProgram(_lineProgram.program);
184
- gl.uniform1f(_lineProgram.u_head_percentage, percentage);
185
- gl.useProgram(currentProgram);
186
- }
187
-
188
-
189
- _createDrawTextureProgram() {
190
- const gl = this.gl;
191
-
1
+ /**
2
+ * Author: Toprak Nihat Deniz Ozturk
3
+ */
4
+ import { createProgram, defaultblendfunction, shaderfunctions } from "../util";
5
+ export default class TrackGlowLineProgram {
6
+ /**
7
+ * @param {WebGL2RenderingContext} gl
8
+ * @param {number} width
9
+ * @param {number} height
10
+ * @param {Object} options
11
+ * @param {number} options.headPercentage 0 ~ 1
12
+ * @param {number} options.routeAlpha 0 ~ 1
13
+ * @param {Array.<Number>} options.weights [w1, w2, w3, w4, w5]
14
+ * @param {number} options.alphaThreshold 0 ~ 1
15
+ * @param {number} options.exposure 0 ~ inf
16
+ * @param {number} options.gamma 0 ~ inf
17
+ * @param {number} options.finalAlphaRatio 0 ~ 1
18
+ * @param {+int} options.blurRepetition 1 ~ inf default 2
19
+ */
20
+ constructor(gl, attrBuffer, width, height, options = {}) {
21
+ this.gl = gl;
22
+ this.program = null;
23
+ // this._inBuffer = gl.createBuffer();
24
+ this._inBuffer = attrBuffer;
25
+ this._frameBuffer = gl.createFramebuffer();
26
+ this._lineProgram = this._createLineProgram();
27
+ this._blurProgram = this._createBlurProgram();
28
+ this._combineProgram = this._createCombineProgram();
29
+ this.resize(width, height);
30
+ this._middleTexture = null;
31
+ this._blurTextures = null;
32
+ this._createInnerTextures();
33
+ this._blurFrameBuffers = [gl.createFramebuffer(), gl.createFramebuffer()];
34
+ this._blurRepetition = options.blurRepetition || 1;
35
+ this._totalLength = 0;
36
+ this._initUniforms(options);
37
+ }
38
+ _createInnerTextures() {
39
+ this._middleTexture = this._createTextures();
40
+ this._blurTextures = [this._createTextures(), this._createTextures()];
41
+ }
42
+ _initUniforms(options = {}) {
43
+ const { gl, _lineProgram, _blurProgram, _combineProgram } = this;
44
+ const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
45
+ gl.useProgram(_lineProgram.program);
46
+ gl.uniform1f(_lineProgram.u_head_percentage, options.headPercentage || 1.0 / 30.0);
47
+ gl.uniform1f(_lineProgram.u_route_alpha, options.routeAlpha || 0.025);
48
+ gl.useProgram(_blurProgram.program);
49
+ gl.uniform1fv(_blurProgram.u_weight, options.weights || [0.55, 0.45045946, 0.3216216, 0.254054, 0.056216]);
50
+ gl.useProgram(_combineProgram.program);
51
+ gl.uniform1f(_combineProgram.u_exposure, options.exposure || 1.0);
52
+ gl.uniform1f(_combineProgram.u_gamma, options.gamma || 1.0);
53
+ gl.uniform1f(_combineProgram.u_final_alpha_ratio, options.finalAlphaRatio || 1.0);
54
+ gl.useProgram(currentProgram);
55
+ }
56
+ /**
57
+ * @param {number} gamma 0 ~ inf
58
+ */
59
+ setGamma(gamma) {
60
+ if (gamma < 0) {
61
+ console.warn("gamma should be equal or greater than 0, but got", gamma);
62
+ return;
63
+ }
64
+ const { gl, _combineProgram } = this;
65
+ const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
66
+ gl.useProgram(_combineProgram.program);
67
+ gl.uniform1f(_combineProgram.u_gamma, gamma);
68
+ gl.useProgram(currentProgram);
69
+ }
70
+ /**
71
+ *
72
+ * @param {number} exposure 0 ~ inf
73
+ * @returns
74
+ */
75
+ setExposure(exposure) {
76
+ if (exposure < 0) {
77
+ console.warn("exposure should be equal or greater than 0, but got", exposure);
78
+ return;
79
+ }
80
+ const { gl, _combineProgram } = this;
81
+ const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
82
+ gl.useProgram(_combineProgram.program);
83
+ gl.uniform1f(_combineProgram.u_exposure, exposure);
84
+ gl.useProgram(currentProgram);
85
+ }
86
+ /**
87
+ *
88
+ * @param {number} ratio 0 ~ 1
89
+ * @returns
90
+ */
91
+ setFinalAlphaRatio(ratio) {
92
+ if (ratio < 0 || ratio > 1) {
93
+ console.warn("ratio should be between 0 and 1, but got", ratio);
94
+ return;
95
+ }
96
+ const { gl, _combineProgram } = this;
97
+ const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
98
+ gl.useProgram(_combineProgram.program);
99
+ gl.uniform1f(_combineProgram.u_final_alpha_ratio, ratio);
100
+ gl.useProgram(currentProgram);
101
+ }
102
+ /**
103
+ * @param {Array.<Number>} weight [w1, w2, w3, w4, w5]
104
+ */
105
+ setBlurWeights(weights) {
106
+ if (weights.length !== 5) {
107
+ console.warn("weights should be an array of 5 numbers, but got", weights);
108
+ return;
109
+ }
110
+ const { gl, _blurProgram } = this;
111
+ const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
112
+ gl.useProgram(_blurProgram.program);
113
+ gl.uniform1fv(_blurProgram.u_weight, weights);
114
+ gl.useProgram(currentProgram);
115
+ }
116
+ /**
117
+ * @param {number} routeAlpha 0 ~ 1
118
+ */
119
+ setRouteAlpha(routeAlpha) {
120
+ if (routeAlpha < 0 || routeAlpha > 1) {
121
+ console.warn("routeAlpha should be between 0 and 1, but got", routeAlpha);
122
+ return;
123
+ }
124
+ const { gl, _lineProgram } = this;
125
+ const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
126
+ gl.useProgram(_lineProgram.program);
127
+ gl.uniform1f(_lineProgram.u_route_alpha, routeAlpha);
128
+ gl.useProgram(currentProgram);
129
+ }
130
+ /**
131
+ * blur uses pingpong effect. This number decides how many times the blur will be applied.
132
+ * @param {+int} repetition
133
+ * @returns
134
+ */
135
+ setBlurRepetition(repetition) {
136
+ if (repetition < 0 && repetition % 1 !== 0) {
137
+ console.warn("repetition should be an integer greater than 0, but got", repetition);
138
+ return;
139
+ }
140
+ this._blurRepetition = repetition;
141
+ }
142
+ /**
143
+ * Head Is colored as white. This number decides proportion of the head according to the total length of the line.
144
+ * @param {Number} percentage 0 ~ 1
145
+ */
146
+ setHeadPercentage(percentage) {
147
+ if (percentage < 0 || 1 < percentage) {
148
+ console.warn("percentage should be between 0 and 1, but got", percentage);
149
+ return;
150
+ }
151
+ ;
152
+ const { gl, _lineProgram } = this;
153
+ const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
154
+ gl.useProgram(_lineProgram.program);
155
+ gl.uniform1f(_lineProgram.u_head_percentage, percentage);
156
+ gl.useProgram(currentProgram);
157
+ }
158
+ _createDrawTextureProgram() {
159
+ const gl = this.gl;
192
160
  const vertexShader = `#version 300 es
193
161
  precision highp float;
194
162
 
@@ -200,8 +168,7 @@ void main() {
200
168
  gl_Position = vec4(a_position, 0.0, 1.0);
201
169
  v_texcoord = a_position.xy * 0.5 + 0.5;
202
170
  }
203
- `;
204
-
171
+ `;
205
172
  const fragmentShader = `#version 300 es
206
173
  precision highp float;
207
174
 
@@ -220,38 +187,33 @@ void main() {
220
187
  outColor = hdrColor;
221
188
  outColor.a *= u_final_alpha_ratio;
222
189
  }
223
- `;
224
- const program = createProgram(this.gl, vertexShader, fragmentShader);
225
-
226
- const buffer = gl.createBuffer();
227
- const a_position = gl.getAttribLocation(program, "a_position");
228
- const vao = gl.createVertexArray();
229
- gl.bindVertexArray(vao);
230
- gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
231
- gl.bufferData(gl.ARRAY_BUFFER, new Float32Array([
232
- -1, -1,
233
- 1, -1,
234
- 1, 1,
235
- -1, -1,
236
- 1, 1,
237
- -1, 1,
238
- ]), gl.STATIC_DRAW);
239
- gl.enableVertexAttribArray(a_position);
240
- gl.vertexAttribPointer(a_position, 2, gl.FLOAT, false, 0, 0);
241
- gl.bindVertexArray(null);
242
-
243
- return {
244
- program: program,
245
- vao: vao,
246
- u_main_texture: gl.getUniformLocation(program, "u_main_texture"),
247
- u_final_alpha_ratio: gl.getUniformLocation(program, "u_final_alpha_ratio"),
248
- };
249
- }
250
-
251
-
252
- _createCombineProgram() {
253
- const gl = this.gl;
254
-
190
+ `;
191
+ const program = createProgram(this.gl, vertexShader, fragmentShader);
192
+ const buffer = gl.createBuffer();
193
+ const a_position = gl.getAttribLocation(program, "a_position");
194
+ const vao = gl.createVertexArray();
195
+ gl.bindVertexArray(vao);
196
+ gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
197
+ gl.bufferData(gl.ARRAY_BUFFER, new Float32Array([
198
+ -1, -1,
199
+ 1, -1,
200
+ 1, 1,
201
+ -1, -1,
202
+ 1, 1,
203
+ -1, 1,
204
+ ]), gl.STATIC_DRAW);
205
+ gl.enableVertexAttribArray(a_position);
206
+ gl.vertexAttribPointer(a_position, 2, gl.FLOAT, false, 0, 0);
207
+ gl.bindVertexArray(null);
208
+ return {
209
+ program: program,
210
+ vao: vao,
211
+ u_main_texture: gl.getUniformLocation(program, "u_main_texture"),
212
+ u_final_alpha_ratio: gl.getUniformLocation(program, "u_final_alpha_ratio"),
213
+ };
214
+ }
215
+ _createCombineProgram() {
216
+ const gl = this.gl;
255
217
  const vertexShader = `#version 300 es
256
218
  precision highp float;
257
219
 
@@ -263,8 +225,7 @@ void main() {
263
225
  gl_Position = vec4(a_position, 0.0, 1.0);
264
226
  v_texcoord = a_position.xy * 0.5 + 0.5;
265
227
  }
266
- `;
267
-
228
+ `;
268
229
  const fragmentShader = `#version 300 es
269
230
  precision highp float;
270
231
 
@@ -288,41 +249,36 @@ void main() {
288
249
  result.a *= u_final_alpha_ratio;
289
250
  outColor = result;
290
251
  }
291
- `;
292
- const program = createProgram(this.gl, vertexShader, fragmentShader);
293
-
294
- const buffer = gl.createBuffer();
295
- const a_position = gl.getAttribLocation(program, "a_position");
296
- const vao = gl.createVertexArray();
297
- gl.bindVertexArray(vao);
298
- gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
299
- gl.bufferData(gl.ARRAY_BUFFER, new Float32Array([
300
- -1, -1,
301
- 1, -1,
302
- 1, 1,
303
- -1, -1,
304
- 1, 1,
305
- -1, 1,
306
- ]), gl.STATIC_DRAW);
307
- gl.enableVertexAttribArray(a_position);
308
- gl.vertexAttribPointer(a_position, 2, gl.FLOAT, false, 0, 0);
309
- gl.bindVertexArray(null);
310
-
311
- return {
312
- program: program,
313
- vao: vao,
314
- u_main_texture: gl.getUniformLocation(program, "u_main_texture"),
315
- u_bloom_texture: gl.getUniformLocation(program, "u_bloom_texture"),
316
- u_exposure: gl.getUniformLocation(program, "u_exposure"),
317
- u_gamma: gl.getUniformLocation(program, "u_gamma"),
318
- u_final_alpha_ratio: gl.getUniformLocation(program, "u_final_alpha_ratio"),
319
- };
320
- }
321
-
322
-
323
- _createBlurProgram() {
324
- const gl = this.gl;
325
-
252
+ `;
253
+ const program = createProgram(this.gl, vertexShader, fragmentShader);
254
+ const buffer = gl.createBuffer();
255
+ const a_position = gl.getAttribLocation(program, "a_position");
256
+ const vao = gl.createVertexArray();
257
+ gl.bindVertexArray(vao);
258
+ gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
259
+ gl.bufferData(gl.ARRAY_BUFFER, new Float32Array([
260
+ -1, -1,
261
+ 1, -1,
262
+ 1, 1,
263
+ -1, -1,
264
+ 1, 1,
265
+ -1, 1,
266
+ ]), gl.STATIC_DRAW);
267
+ gl.enableVertexAttribArray(a_position);
268
+ gl.vertexAttribPointer(a_position, 2, gl.FLOAT, false, 0, 0);
269
+ gl.bindVertexArray(null);
270
+ return {
271
+ program: program,
272
+ vao: vao,
273
+ u_main_texture: gl.getUniformLocation(program, "u_main_texture"),
274
+ u_bloom_texture: gl.getUniformLocation(program, "u_bloom_texture"),
275
+ u_exposure: gl.getUniformLocation(program, "u_exposure"),
276
+ u_gamma: gl.getUniformLocation(program, "u_gamma"),
277
+ u_final_alpha_ratio: gl.getUniformLocation(program, "u_final_alpha_ratio"),
278
+ };
279
+ }
280
+ _createBlurProgram() {
281
+ const gl = this.gl;
326
282
  const vertexShader = `#version 300 es
327
283
  precision highp float;
328
284
 
@@ -332,7 +288,7 @@ out vec2 v_texcoord;
332
288
  void main() {
333
289
  gl_Position = vec4(a_position, 0.0, 1.0);
334
290
  v_texcoord = a_position.xy * 0.5 + 0.5;
335
- }`;
291
+ }`;
336
292
  const fragmentShader = `#version 300 es
337
293
  precision highp float;
338
294
 
@@ -382,54 +338,45 @@ void main()
382
338
  }
383
339
  outColor = vec4(color, total_alpha);
384
340
  }
385
- `;
386
-
387
- const program = createProgram(this.gl, vertexShader, fragmentShader);
388
-
389
- const buffer = gl.createBuffer();
390
- const a_position = gl.getAttribLocation(program, "a_position");
391
- gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
392
- gl.bufferData(gl.ARRAY_BUFFER, new Float32Array([
393
- -1, -1,
394
- 1, -1,
395
- 1, 1,
396
- -1, -1,
397
- 1, 1,
398
- -1, 1,
399
- ]), gl.STATIC_DRAW);
400
- const vao = gl.createVertexArray();
401
- gl.bindVertexArray(vao);
402
- gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
403
- gl.enableVertexAttribArray(a_position);
404
-
405
- gl.vertexAttribPointer(a_position, 2, gl.FLOAT, false, 0, 0);
406
- gl.bindVertexArray(null);
407
-
408
- return {
409
- program: program,
410
- vao: vao,
411
- u_texture: gl.getUniformLocation(program, "u_texture"),
412
- u_horizontal: gl.getUniformLocation(program, "u_horizontal"),
413
- u_weight: gl.getUniformLocation(program, "u_weight"),
414
- };
415
- }
416
-
417
-
418
- resize(width, height) {
419
- const { gl, _lineProgram } = this;
420
- this._width = width;
421
- this._height = height;
422
- const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
423
- this._createInnerTextures();
424
- gl.useProgram(_lineProgram.program);
425
- gl.uniform2fv(_lineProgram.u_scrWH, [width, height]);
426
- gl.useProgram(currentProgram);
427
- }
428
-
429
- _createLineProgram() {
430
-
431
- const gl = this.gl;
432
-
341
+ `;
342
+ const program = createProgram(this.gl, vertexShader, fragmentShader);
343
+ const buffer = gl.createBuffer();
344
+ const a_position = gl.getAttribLocation(program, "a_position");
345
+ gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
346
+ gl.bufferData(gl.ARRAY_BUFFER, new Float32Array([
347
+ -1, -1,
348
+ 1, -1,
349
+ 1, 1,
350
+ -1, -1,
351
+ 1, 1,
352
+ -1, 1,
353
+ ]), gl.STATIC_DRAW);
354
+ const vao = gl.createVertexArray();
355
+ gl.bindVertexArray(vao);
356
+ gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
357
+ gl.enableVertexAttribArray(a_position);
358
+ gl.vertexAttribPointer(a_position, 2, gl.FLOAT, false, 0, 0);
359
+ gl.bindVertexArray(null);
360
+ return {
361
+ program: program,
362
+ vao: vao,
363
+ u_texture: gl.getUniformLocation(program, "u_texture"),
364
+ u_horizontal: gl.getUniformLocation(program, "u_horizontal"),
365
+ u_weight: gl.getUniformLocation(program, "u_weight"),
366
+ };
367
+ }
368
+ resize(width, height) {
369
+ const { gl, _lineProgram } = this;
370
+ this._width = width;
371
+ this._height = height;
372
+ const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
373
+ this._createInnerTextures();
374
+ gl.useProgram(_lineProgram.program);
375
+ gl.uniform2fv(_lineProgram.u_scrWH, [width, height]);
376
+ gl.useProgram(currentProgram);
377
+ }
378
+ _createLineProgram() {
379
+ const gl = this.gl;
433
380
  const vertexShader = `#version 300 es
434
381
  precision highp float;
435
382
 
@@ -468,8 +415,7 @@ void main() {
468
415
  gl_Position = uProjectionMatrix * vec4(xy.x, xy.y, 0.0, 1.0);
469
416
  }
470
417
  }
471
- `;
472
-
418
+ `;
473
419
  const fragmentShader = `#version 300 es
474
420
  precision lowp float;
475
421
 
@@ -508,181 +454,155 @@ void main() {
508
454
  }
509
455
  outColor0 = vec4(v_color , 1.0);
510
456
  }
511
- `;
512
- const program = createProgram(this.gl, vertexShader, fragmentShader);
513
- const a_position = gl.getAttribLocation(program, "a_position");
514
- const a_time = gl.getAttribLocation(program, "a_time");
515
- const a_track_start_time = gl.getAttribLocation(program, "a_track_start_time");
516
- const a_track_end_time = gl.getAttribLocation(program, "a_track_end_time");
517
- const a_color = gl.getAttribLocation(program, "a_color");
518
-
519
- const vao = gl.createVertexArray();
520
- gl.bindVertexArray(vao);
521
- gl.bindBuffer(gl.ARRAY_BUFFER, this._inBuffer);
522
- gl.enableVertexAttribArray(a_position);
523
- gl.vertexAttribPointer(a_position, 3, gl.FLOAT, false, 36, 0);
524
- gl.enableVertexAttribArray(a_time);
525
- gl.vertexAttribPointer(a_time, 1, gl.FLOAT, false, 36, 12);
526
- gl.enableVertexAttribArray(a_color);
527
- gl.vertexAttribPointer(a_color, 3, gl.FLOAT, false, 36, 16);
528
- gl.enableVertexAttribArray(a_track_start_time);
529
- gl.vertexAttribPointer(a_track_start_time, 1, gl.FLOAT, false, 36, 28);
530
- gl.enableVertexAttribArray(a_track_end_time);
531
- gl.vertexAttribPointer(a_track_end_time, 1, gl.FLOAT, false, 36, 32);
532
- gl.bindVertexArray(null);
533
- return {
534
- program: program,
535
- vao: vao,
536
- u_head_time: gl.getUniformLocation(program, "u_head_time"),
537
- u_tail_time: gl.getUniformLocation(program, "u_tail_time"),
538
- uTranslate: gl.getUniformLocation(program, "uTranslate"),
539
- uModelViewMatrix: gl.getUniformLocation(program, "uModelViewMatrix"),
540
- uProjectionMatrix: gl.getUniformLocation(program, "uProjectionMatrix"),
541
- u_is_3d: gl.getUniformLocation(program, "u_is_3d"),
542
- u_mapWH: gl.getUniformLocation(program, "u_mapWH"),
543
- u_scrWH: gl.getUniformLocation(program, "u_scrWH"),
544
- u_head_percentage: gl.getUniformLocation(program, "u_head_percentage"),
545
- u_route_alpha: gl.getUniformLocation(program, "u_route_alpha"),
546
- };
547
- }
548
-
549
-
550
- /**
551
- * @param { Float32Array} data // [x, y, z, time, x, y, z, time, ...]
552
- */
553
- // setInBuffer(data) {
554
- // const gl = this.gl;
555
- // gl.bindBuffer(gl.ARRAY_BUFFER, this._inBuffer);
556
- // gl.bufferData(gl.ARRAY_BUFFER, data, gl.STATIC_DRAW);
557
- // }
558
-
559
-
560
-
561
- setIs3D(is3d) {
562
- const { gl, _lineProgram } = this;
563
- const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
564
- gl.useProgram(_lineProgram.program);
565
- gl.uniform1i(_lineProgram.u_is_3d, is3d);
566
- gl.useProgram(currentProgram);
567
- }
568
-
569
-
570
- setTotalLength(totalLength) {
571
- this._totalLength = totalLength;
572
- }
573
-
574
-
575
- _createTextures() {
576
- const { gl, _width, _height } = this;
577
-
578
- const texture = gl.createTexture();
579
- gl.bindTexture(gl.TEXTURE_2D, texture);
580
- gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA8, _width, _height, 0, gl.RGBA, gl.UNSIGNED_BYTE, null); // UNSIGNED_BYTE
581
- gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST);
582
- gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST);
583
- gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);
584
- gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);
585
- gl.bindTexture(gl.TEXTURE_2D, null);
586
- return texture;
587
- }
588
-
589
- _resetTexture() {
590
- const { gl, _width, _height } = this;
591
- gl.bindTexture(gl.TEXTURE_2D, this._middleTexture); // UNSIGNED_BYTE
592
- gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA8, _width, _height, 0, gl.RGBA, gl.UNSIGNED_BYTE, null);
593
- gl.bindTexture(gl.TEXTURE_2D, this._blurTextures[0]);
594
- gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA8, _width, _height, 0, gl.RGBA, gl.UNSIGNED_BYTE, null);
595
- gl.bindTexture(gl.TEXTURE_2D, this._blurTextures[1]);
596
- gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA8, _width, _height, 0, gl.RGBA, gl.UNSIGNED_BYTE, null);
597
- gl.bindTexture(gl.TEXTURE_2D, null);
598
- }
599
-
600
-
601
-
602
- draw(u_head_time, u_tail_time, uProjectionMatrix, uModelViewMatrix, uTranslate, u_mapWH = null) {
603
- const { gl, _lineProgram, _blurProgram, _blurRepetition } = this;
604
- this._resetTexture();
605
-
606
- gl.enable(gl.BLEND);
607
- gl.blendFuncSeparate(gl.SRC_ALPHA, gl.ONE_MINUS_SRC_ALPHA, gl.SRC_ALPHA, gl.ONE_MINUS_SRC_ALPHA);
608
-
609
- { // draw lines
610
- gl.bindFramebuffer(gl.FRAMEBUFFER, this._frameBuffer);
611
- gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, this._middleTexture, 0);
612
- gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT1, gl.TEXTURE_2D, this._blurTextures[0], 0);
613
- gl.drawBuffers([
614
- gl.COLOR_ATTACHMENT0,
615
- gl.COLOR_ATTACHMENT1,
616
-
617
- ])
618
- gl.useProgram(_lineProgram.program);
619
- gl.uniform1f(_lineProgram.u_head_time, u_head_time);
620
- gl.uniform1f(_lineProgram.u_tail_time, u_tail_time);
621
- gl.uniformMatrix4fv(_lineProgram.uProjectionMatrix, false, uProjectionMatrix);
622
- if (u_mapWH) {
623
- gl.uniform2fv(_lineProgram.u_mapWH, u_mapWH);
624
-
625
- } else {
626
- gl.uniformMatrix4fv(_lineProgram.uModelViewMatrix, false, uModelViewMatrix);
627
- }
628
- gl.uniform3fv(_lineProgram.uTranslate, uTranslate);
629
-
630
- gl.bindVertexArray(_lineProgram.vao);
631
- gl.drawArrays(gl.LINE_STRIP, 0, this._totalLength);
632
- gl.drawBuffers([
633
- gl.COLOR_ATTACHMENT0,
634
- gl.NONE
635
- ])
636
- }
637
-
638
- { // blur ping pong
639
- gl.useProgram(_blurProgram.program);
640
- gl.bindVertexArray(_blurProgram.vao);
641
- for (let i = 0; i < _blurRepetition * 2; i++) {
642
- gl.bindFramebuffer(gl.FRAMEBUFFER, this._blurFrameBuffers[i % 2]);
643
- gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, this._blurTextures[(i + 1) % 2], 0);
644
- gl.bindTexture(gl.TEXTURE_2D, this._blurTextures[i % 2]);
645
- gl.uniform1i(_blurProgram.u_texture, 0);
646
- gl.uniform1f(_blurProgram.u_horizontal, i % 2 == 0);
647
- gl.drawArrays(gl.TRIANGLES, 0, 6);
648
- }
649
- }
650
-
651
- { // combine
652
- gl.bindFramebuffer(gl.FRAMEBUFFER, null);
653
- gl.useProgram(this._combineProgram.program);
654
- gl.bindVertexArray(this._combineProgram.vao);
655
- gl.activeTexture(gl.TEXTURE1);
656
- gl.bindTexture(gl.TEXTURE_2D, this._blurTextures[1]);
657
- gl.uniform1i(this._combineProgram.u_bloom_texture, 1);
658
- gl.activeTexture(gl.TEXTURE0);
659
- gl.bindTexture(gl.TEXTURE_2D, this._middleTexture);
660
- gl.uniform1i(this._combineProgram.u_main_texture, 0);
661
- gl.drawArrays(gl.TRIANGLES, 0, 6);
662
- }
663
- gl.bindVertexArray(null);
664
-
665
- defaultblendfunction(gl)
666
-
667
- }
668
-
669
-
670
- free() {
671
- const { gl, _lineProgram, _blurProgram, _combineProgram } = this;
672
- gl.deleteBuffer(this._inBuffer);
673
- gl.deleteFramebuffer(this._frameBuffer);
674
- gl.deleteFramebuffer(this._blurFrameBuffers[0]);
675
- gl.deleteFramebuffer(this._blurFrameBuffers[1]);
676
- // gl.deleteBuffer(this._middleTexture);
677
- gl.deleteTexture(this._middleTexture);
678
- gl.deleteTexture(this._blurTextures[0]);
679
- gl.deleteTexture(this._blurTextures[1]);
680
- gl.deleteVertexArray(_lineProgram.vao);
681
- gl.deleteVertexArray(_blurProgram.vao);
682
- gl.deleteVertexArray(_combineProgram.vao);
683
- gl.deleteProgram(_lineProgram.program);
684
- gl.deleteProgram(_blurProgram.program);
685
- gl.deleteProgram(_combineProgram.program);
686
- }
687
- }
688
-
457
+ `;
458
+ const program = createProgram(this.gl, vertexShader, fragmentShader);
459
+ const a_position = gl.getAttribLocation(program, "a_position");
460
+ const a_time = gl.getAttribLocation(program, "a_time");
461
+ const a_track_start_time = gl.getAttribLocation(program, "a_track_start_time");
462
+ const a_track_end_time = gl.getAttribLocation(program, "a_track_end_time");
463
+ const a_color = gl.getAttribLocation(program, "a_color");
464
+ const vao = gl.createVertexArray();
465
+ gl.bindVertexArray(vao);
466
+ gl.bindBuffer(gl.ARRAY_BUFFER, this._inBuffer);
467
+ gl.enableVertexAttribArray(a_position);
468
+ gl.vertexAttribPointer(a_position, 3, gl.FLOAT, false, 36, 0);
469
+ gl.enableVertexAttribArray(a_time);
470
+ gl.vertexAttribPointer(a_time, 1, gl.FLOAT, false, 36, 12);
471
+ gl.enableVertexAttribArray(a_color);
472
+ gl.vertexAttribPointer(a_color, 3, gl.FLOAT, false, 36, 16);
473
+ gl.enableVertexAttribArray(a_track_start_time);
474
+ gl.vertexAttribPointer(a_track_start_time, 1, gl.FLOAT, false, 36, 28);
475
+ gl.enableVertexAttribArray(a_track_end_time);
476
+ gl.vertexAttribPointer(a_track_end_time, 1, gl.FLOAT, false, 36, 32);
477
+ gl.bindVertexArray(null);
478
+ return {
479
+ program: program,
480
+ vao: vao,
481
+ u_head_time: gl.getUniformLocation(program, "u_head_time"),
482
+ u_tail_time: gl.getUniformLocation(program, "u_tail_time"),
483
+ uTranslate: gl.getUniformLocation(program, "uTranslate"),
484
+ uModelViewMatrix: gl.getUniformLocation(program, "uModelViewMatrix"),
485
+ uProjectionMatrix: gl.getUniformLocation(program, "uProjectionMatrix"),
486
+ u_is_3d: gl.getUniformLocation(program, "u_is_3d"),
487
+ u_mapWH: gl.getUniformLocation(program, "u_mapWH"),
488
+ u_scrWH: gl.getUniformLocation(program, "u_scrWH"),
489
+ u_head_percentage: gl.getUniformLocation(program, "u_head_percentage"),
490
+ u_route_alpha: gl.getUniformLocation(program, "u_route_alpha"),
491
+ };
492
+ }
493
+ /**
494
+ * @param { Float32Array} data // [x, y, z, time, x, y, z, time, ...]
495
+ */
496
+ // setInBuffer(data) {
497
+ // const gl = this.gl;
498
+ // gl.bindBuffer(gl.ARRAY_BUFFER, this._inBuffer);
499
+ // gl.bufferData(gl.ARRAY_BUFFER, data, gl.STATIC_DRAW);
500
+ // }
501
+ setIs3D(is3d) {
502
+ const { gl, _lineProgram } = this;
503
+ const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
504
+ gl.useProgram(_lineProgram.program);
505
+ gl.uniform1i(_lineProgram.u_is_3d, is3d);
506
+ gl.useProgram(currentProgram);
507
+ }
508
+ setTotalLength(totalLength) {
509
+ this._totalLength = totalLength;
510
+ }
511
+ _createTextures() {
512
+ const { gl, _width, _height } = this;
513
+ const texture = gl.createTexture();
514
+ gl.bindTexture(gl.TEXTURE_2D, texture);
515
+ gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA8, _width, _height, 0, gl.RGBA, gl.UNSIGNED_BYTE, null); // UNSIGNED_BYTE
516
+ gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST);
517
+ gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST);
518
+ gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);
519
+ gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);
520
+ gl.bindTexture(gl.TEXTURE_2D, null);
521
+ return texture;
522
+ }
523
+ _resetTexture() {
524
+ const { gl, _width, _height } = this;
525
+ gl.bindTexture(gl.TEXTURE_2D, this._middleTexture); // UNSIGNED_BYTE
526
+ gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA8, _width, _height, 0, gl.RGBA, gl.UNSIGNED_BYTE, null);
527
+ gl.bindTexture(gl.TEXTURE_2D, this._blurTextures[0]);
528
+ gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA8, _width, _height, 0, gl.RGBA, gl.UNSIGNED_BYTE, null);
529
+ gl.bindTexture(gl.TEXTURE_2D, this._blurTextures[1]);
530
+ gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA8, _width, _height, 0, gl.RGBA, gl.UNSIGNED_BYTE, null);
531
+ gl.bindTexture(gl.TEXTURE_2D, null);
532
+ }
533
+ draw(u_head_time, u_tail_time, uProjectionMatrix, uModelViewMatrix, uTranslate, u_mapWH = null) {
534
+ const { gl, _lineProgram, _blurProgram, _blurRepetition } = this;
535
+ this._resetTexture();
536
+ gl.enable(gl.BLEND);
537
+ gl.blendFuncSeparate(gl.SRC_ALPHA, gl.ONE_MINUS_SRC_ALPHA, gl.SRC_ALPHA, gl.ONE_MINUS_SRC_ALPHA);
538
+ { // draw lines
539
+ gl.bindFramebuffer(gl.FRAMEBUFFER, this._frameBuffer);
540
+ gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, this._middleTexture, 0);
541
+ gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT1, gl.TEXTURE_2D, this._blurTextures[0], 0);
542
+ gl.drawBuffers([
543
+ gl.COLOR_ATTACHMENT0,
544
+ gl.COLOR_ATTACHMENT1,
545
+ ]);
546
+ gl.useProgram(_lineProgram.program);
547
+ gl.uniform1f(_lineProgram.u_head_time, u_head_time);
548
+ gl.uniform1f(_lineProgram.u_tail_time, u_tail_time);
549
+ gl.uniformMatrix4fv(_lineProgram.uProjectionMatrix, false, uProjectionMatrix);
550
+ if (u_mapWH) {
551
+ gl.uniform2fv(_lineProgram.u_mapWH, u_mapWH);
552
+ }
553
+ else {
554
+ gl.uniformMatrix4fv(_lineProgram.uModelViewMatrix, false, uModelViewMatrix);
555
+ }
556
+ gl.uniform3fv(_lineProgram.uTranslate, uTranslate);
557
+ gl.bindVertexArray(_lineProgram.vao);
558
+ gl.drawArrays(gl.LINE_STRIP, 0, this._totalLength);
559
+ gl.drawBuffers([
560
+ gl.COLOR_ATTACHMENT0,
561
+ gl.NONE
562
+ ]);
563
+ }
564
+ { // blur ping pong
565
+ gl.useProgram(_blurProgram.program);
566
+ gl.bindVertexArray(_blurProgram.vao);
567
+ for (let i = 0; i < _blurRepetition * 2; i++) {
568
+ gl.bindFramebuffer(gl.FRAMEBUFFER, this._blurFrameBuffers[i % 2]);
569
+ gl.framebufferTexture2D(gl.FRAMEBUFFER, gl.COLOR_ATTACHMENT0, gl.TEXTURE_2D, this._blurTextures[(i + 1) % 2], 0);
570
+ gl.bindTexture(gl.TEXTURE_2D, this._blurTextures[i % 2]);
571
+ gl.uniform1i(_blurProgram.u_texture, 0);
572
+ gl.uniform1f(_blurProgram.u_horizontal, i % 2 == 0);
573
+ gl.drawArrays(gl.TRIANGLES, 0, 6);
574
+ }
575
+ }
576
+ { // combine
577
+ gl.bindFramebuffer(gl.FRAMEBUFFER, null);
578
+ gl.useProgram(this._combineProgram.program);
579
+ gl.bindVertexArray(this._combineProgram.vao);
580
+ gl.activeTexture(gl.TEXTURE1);
581
+ gl.bindTexture(gl.TEXTURE_2D, this._blurTextures[1]);
582
+ gl.uniform1i(this._combineProgram.u_bloom_texture, 1);
583
+ gl.activeTexture(gl.TEXTURE0);
584
+ gl.bindTexture(gl.TEXTURE_2D, this._middleTexture);
585
+ gl.uniform1i(this._combineProgram.u_main_texture, 0);
586
+ gl.drawArrays(gl.TRIANGLES, 0, 6);
587
+ }
588
+ gl.bindVertexArray(null);
589
+ defaultblendfunction(gl);
590
+ }
591
+ free() {
592
+ const { gl, _lineProgram, _blurProgram, _combineProgram } = this;
593
+ gl.deleteBuffer(this._inBuffer);
594
+ gl.deleteFramebuffer(this._frameBuffer);
595
+ gl.deleteFramebuffer(this._blurFrameBuffers[0]);
596
+ gl.deleteFramebuffer(this._blurFrameBuffers[1]);
597
+ // gl.deleteBuffer(this._middleTexture);
598
+ gl.deleteTexture(this._middleTexture);
599
+ gl.deleteTexture(this._blurTextures[0]);
600
+ gl.deleteTexture(this._blurTextures[1]);
601
+ gl.deleteVertexArray(_lineProgram.vao);
602
+ gl.deleteVertexArray(_blurProgram.vao);
603
+ gl.deleteVertexArray(_combineProgram.vao);
604
+ gl.deleteProgram(_lineProgram.program);
605
+ gl.deleteProgram(_blurProgram.program);
606
+ gl.deleteProgram(_combineProgram.program);
607
+ }
608
+ }