@luma.gl/webgl 9.0.0-alpha.9 → 9.0.0-beta.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (553) hide show
  1. package/LICENSE +3 -1
  2. package/dist/adapter/converters/device-parameters.d.ts +12 -3
  3. package/dist/adapter/converters/device-parameters.d.ts.map +1 -1
  4. package/dist/adapter/converters/device-parameters.js +300 -146
  5. package/dist/adapter/converters/sampler-parameters.d.ts +3 -13
  6. package/dist/adapter/converters/sampler-parameters.d.ts.map +1 -1
  7. package/dist/adapter/converters/sampler-parameters.js +74 -219
  8. package/dist/adapter/converters/shader-formats.d.ts +9 -0
  9. package/dist/adapter/converters/shader-formats.d.ts.map +1 -0
  10. package/dist/adapter/converters/shader-formats.js +59 -0
  11. package/dist/adapter/converters/texture-formats.d.ts +41 -57
  12. package/dist/adapter/converters/texture-formats.d.ts.map +1 -1
  13. package/dist/adapter/converters/texture-formats.js +490 -925
  14. package/dist/adapter/converters/vertex-formats.d.ts +9 -3
  15. package/dist/adapter/converters/vertex-formats.d.ts.map +1 -1
  16. package/dist/adapter/converters/vertex-formats.js +56 -33
  17. package/dist/adapter/device-helpers/webgl-device-features.d.ts +20 -0
  18. package/dist/adapter/device-helpers/webgl-device-features.d.ts.map +1 -0
  19. package/dist/adapter/device-helpers/webgl-device-features.js +98 -0
  20. package/dist/adapter/device-helpers/webgl-device-info.d.ts +5 -0
  21. package/dist/adapter/device-helpers/webgl-device-info.d.ts.map +1 -0
  22. package/dist/adapter/device-helpers/webgl-device-info.js +90 -0
  23. package/dist/adapter/device-helpers/webgl-device-limits.d.ts +35 -0
  24. package/dist/adapter/device-helpers/webgl-device-limits.d.ts.map +1 -0
  25. package/dist/adapter/device-helpers/webgl-device-limits.js +47 -0
  26. package/dist/adapter/helpers/decode-webgl-types.d.ts +26 -0
  27. package/dist/adapter/helpers/decode-webgl-types.d.ts.map +1 -0
  28. package/dist/adapter/helpers/decode-webgl-types.js +101 -0
  29. package/dist/adapter/helpers/get-shader-layout.d.ts +2 -49
  30. package/dist/adapter/helpers/get-shader-layout.d.ts.map +1 -1
  31. package/dist/adapter/helpers/get-shader-layout.js +263 -307
  32. package/dist/adapter/helpers/parse-shader-compiler-log.d.ts +1 -1
  33. package/dist/adapter/helpers/parse-shader-compiler-log.d.ts.map +1 -1
  34. package/dist/adapter/helpers/parse-shader-compiler-log.js +48 -33
  35. package/dist/adapter/helpers/set-uniform.d.ts +3 -2
  36. package/dist/adapter/helpers/set-uniform.d.ts.map +1 -1
  37. package/dist/adapter/helpers/set-uniform.js +66 -111
  38. package/dist/adapter/helpers/webgl-topology-utils.d.ts +16 -0
  39. package/dist/adapter/helpers/webgl-topology-utils.d.ts.map +1 -0
  40. package/dist/adapter/helpers/webgl-topology-utils.js +88 -0
  41. package/dist/adapter/objects/constants-to-keys.d.ts +2 -4
  42. package/dist/adapter/objects/constants-to-keys.d.ts.map +1 -1
  43. package/dist/adapter/objects/constants-to-keys.js +18 -38
  44. package/dist/adapter/objects/webgl-renderbuffer.d.ts +15 -12
  45. package/dist/adapter/objects/webgl-renderbuffer.d.ts.map +1 -1
  46. package/dist/adapter/objects/webgl-renderbuffer.js +92 -91
  47. package/dist/adapter/objects/webgl-resource.d.ts +6 -31
  48. package/dist/adapter/objects/webgl-resource.d.ts.map +1 -1
  49. package/dist/adapter/objects/webgl-resource.js +103 -205
  50. package/dist/adapter/resources/webgl-buffer.d.ts +20 -16
  51. package/dist/adapter/resources/webgl-buffer.d.ts.map +1 -1
  52. package/dist/adapter/resources/webgl-buffer.js +163 -155
  53. package/dist/adapter/resources/webgl-command-buffer.d.ts +15 -9
  54. package/dist/adapter/resources/webgl-command-buffer.d.ts.map +1 -1
  55. package/dist/adapter/resources/webgl-command-buffer.js +283 -58
  56. package/dist/adapter/resources/webgl-command-encoder.d.ts +12 -6
  57. package/dist/adapter/resources/webgl-command-encoder.d.ts.map +1 -1
  58. package/dist/adapter/resources/webgl-command-encoder.js +36 -52
  59. package/dist/adapter/resources/webgl-external-texture.js +93 -1
  60. package/dist/adapter/resources/webgl-framebuffer.d.ts +21 -29
  61. package/dist/adapter/resources/webgl-framebuffer.d.ts.map +1 -1
  62. package/dist/adapter/resources/webgl-framebuffer.js +184 -261
  63. package/dist/adapter/resources/webgl-query-set.d.ts +44 -0
  64. package/dist/adapter/resources/webgl-query-set.d.ts.map +1 -0
  65. package/dist/adapter/resources/webgl-query-set.js +136 -0
  66. package/dist/adapter/resources/webgl-render-pass.d.ts +21 -4
  67. package/dist/adapter/resources/webgl-render-pass.d.ts.map +1 -1
  68. package/dist/adapter/resources/webgl-render-pass.js +140 -20
  69. package/dist/adapter/resources/webgl-render-pipeline.d.ts +44 -21
  70. package/dist/adapter/resources/webgl-render-pipeline.d.ts.map +1 -1
  71. package/dist/adapter/resources/webgl-render-pipeline.js +371 -413
  72. package/dist/adapter/resources/webgl-sampler.d.ts +5 -6
  73. package/dist/adapter/resources/webgl-sampler.d.ts.map +1 -1
  74. package/dist/adapter/resources/webgl-sampler.js +46 -46
  75. package/dist/adapter/resources/webgl-shader.d.ts +16 -6
  76. package/dist/adapter/resources/webgl-shader.d.ts.map +1 -1
  77. package/dist/adapter/resources/webgl-shader.js +113 -72
  78. package/dist/adapter/resources/webgl-texture-view.d.ts +14 -0
  79. package/dist/adapter/resources/webgl-texture-view.d.ts.map +1 -0
  80. package/dist/adapter/resources/webgl-texture-view.js +18 -0
  81. package/dist/adapter/resources/webgl-texture.d.ts +53 -35
  82. package/dist/adapter/resources/webgl-texture.d.ts.map +1 -1
  83. package/dist/adapter/resources/webgl-texture.js +623 -822
  84. package/dist/adapter/resources/webgl-transform-feedback.d.ts +47 -0
  85. package/dist/adapter/resources/webgl-transform-feedback.d.ts.map +1 -0
  86. package/dist/adapter/resources/webgl-transform-feedback.js +162 -0
  87. package/dist/adapter/resources/webgl-vertex-array.d.ts +67 -0
  88. package/dist/adapter/resources/webgl-vertex-array.d.ts.map +1 -0
  89. package/dist/adapter/resources/webgl-vertex-array.js +239 -0
  90. package/dist/adapter/webgl-canvas-context.d.ts +6 -7
  91. package/dist/adapter/webgl-canvas-context.d.ts.map +1 -1
  92. package/dist/adapter/webgl-canvas-context.js +61 -50
  93. package/dist/adapter/webgl-device.d.ts +112 -55
  94. package/dist/adapter/webgl-device.d.ts.map +1 -1
  95. package/dist/adapter/webgl-device.js +453 -331
  96. package/dist/classic/accessor.d.ts +3 -3
  97. package/dist/classic/accessor.d.ts.map +1 -1
  98. package/dist/classic/accessor.js +135 -130
  99. package/dist/classic/clear.d.ts +22 -0
  100. package/dist/classic/clear.d.ts.map +1 -0
  101. package/dist/classic/clear.js +89 -0
  102. package/dist/classic/copy-and-blit.d.ts +62 -0
  103. package/dist/classic/copy-and-blit.d.ts.map +1 -0
  104. package/dist/classic/copy-and-blit.js +191 -0
  105. package/dist/classic/format-utils.d.ts +3 -0
  106. package/dist/classic/format-utils.d.ts.map +1 -0
  107. package/dist/classic/format-utils.js +44 -0
  108. package/dist/classic/typed-array-utils.d.ts +17 -17
  109. package/dist/classic/typed-array-utils.d.ts.map +1 -1
  110. package/dist/classic/typed-array-utils.js +96 -102
  111. package/dist/context/debug/spector.d.ts +1 -2
  112. package/dist/context/debug/spector.d.ts.map +1 -1
  113. package/dist/context/debug/spector.js +56 -63
  114. package/dist/context/debug/webgl-developer-tools.d.ts +2 -3
  115. package/dist/context/debug/webgl-developer-tools.d.ts.map +1 -1
  116. package/dist/context/debug/webgl-developer-tools.js +106 -102
  117. package/dist/context/helpers/create-browser-context.d.ts +35 -0
  118. package/dist/context/helpers/create-browser-context.d.ts.map +1 -0
  119. package/dist/context/helpers/create-browser-context.js +67 -0
  120. package/dist/context/helpers/webgl-context-data.d.ts +13 -0
  121. package/dist/context/helpers/webgl-context-data.d.ts.map +1 -0
  122. package/dist/context/helpers/webgl-context-data.js +21 -0
  123. package/dist/context/helpers/webgl-extensions.d.ts +4 -0
  124. package/dist/context/helpers/webgl-extensions.d.ts.map +1 -0
  125. package/dist/context/helpers/webgl-extensions.js +10 -0
  126. package/dist/context/parameters/unified-parameter-api.d.ts +4 -5
  127. package/dist/context/parameters/unified-parameter-api.d.ts.map +1 -1
  128. package/dist/context/parameters/unified-parameter-api.js +91 -54
  129. package/dist/context/parameters/webgl-parameter-tables.d.ts +115 -106
  130. package/dist/context/parameters/webgl-parameter-tables.d.ts.map +1 -1
  131. package/dist/context/parameters/webgl-parameter-tables.js +463 -423
  132. package/dist/context/state-tracker/deep-array-equal.d.ts.map +1 -1
  133. package/dist/context/state-tracker/deep-array-equal.js +19 -18
  134. package/dist/context/state-tracker/track-context-state.d.ts +4 -4
  135. package/dist/context/state-tracker/track-context-state.d.ts.map +1 -1
  136. package/dist/context/state-tracker/track-context-state.js +192 -163
  137. package/dist/context/state-tracker/with-parameters.d.ts +2 -2
  138. package/dist/context/state-tracker/with-parameters.d.ts.map +1 -1
  139. package/dist/context/state-tracker/with-parameters.js +44 -32
  140. package/dist/dist.dev.js +6574 -0
  141. package/dist/dist.min.js +10 -0
  142. package/dist/index.cjs +5586 -0
  143. package/dist/index.cjs.map +7 -0
  144. package/dist/index.d.ts +25 -32
  145. package/dist/index.d.ts.map +1 -1
  146. package/dist/index.js +37 -28
  147. package/dist/types.d.ts +3 -1
  148. package/dist/types.d.ts.map +1 -1
  149. package/dist/types.js +3 -1
  150. package/dist.min.js +19 -0
  151. package/package.json +22 -15
  152. package/src/adapter/converters/device-parameters.ts +217 -54
  153. package/src/adapter/converters/sampler-parameters.ts +46 -126
  154. package/src/adapter/converters/shader-formats.ts +69 -0
  155. package/src/adapter/converters/texture-formats.ts +369 -340
  156. package/src/adapter/converters/vertex-formats.ts +71 -10
  157. package/src/adapter/device-helpers/webgl-device-features.ts +121 -0
  158. package/src/adapter/device-helpers/webgl-device-info.ts +111 -0
  159. package/src/adapter/device-helpers/webgl-device-limits.ts +53 -0
  160. package/src/adapter/helpers/{uniforms.ts → decode-webgl-types.ts} +38 -25
  161. package/src/adapter/helpers/get-shader-layout.ts +104 -158
  162. package/src/adapter/helpers/parse-shader-compiler-log.ts +31 -11
  163. package/src/adapter/helpers/set-uniform.ts +39 -36
  164. package/src/adapter/helpers/webgl-topology-utils.ts +110 -0
  165. package/src/adapter/objects/constants-to-keys.ts +8 -26
  166. package/src/adapter/objects/webgl-renderbuffer.ts +68 -40
  167. package/src/adapter/objects/webgl-resource.ts +16 -156
  168. package/src/adapter/resources/webgl-buffer.ts +103 -112
  169. package/src/adapter/resources/webgl-command-buffer.ts +333 -41
  170. package/src/adapter/resources/webgl-command-encoder.ts +33 -22
  171. package/src/adapter/resources/webgl-external-texture.ts +11 -8
  172. package/src/adapter/resources/webgl-framebuffer.ts +125 -165
  173. package/src/adapter/resources/webgl-query-set.ts +171 -0
  174. package/src/adapter/resources/webgl-render-pass.ts +176 -6
  175. package/src/adapter/resources/webgl-render-pipeline.ts +308 -229
  176. package/src/adapter/resources/webgl-sampler.ts +19 -18
  177. package/src/adapter/resources/webgl-shader.ts +91 -32
  178. package/src/adapter/resources/webgl-texture-view.ts +28 -0
  179. package/src/adapter/resources/webgl-texture.ts +147 -184
  180. package/src/adapter/resources/webgl-transform-feedback.ts +196 -0
  181. package/src/adapter/resources/webgl-vertex-array.ts +282 -0
  182. package/src/adapter/webgl-canvas-context.ts +23 -22
  183. package/src/adapter/webgl-device.ts +411 -196
  184. package/src/classic/accessor.ts +12 -8
  185. package/src/classic/clear.ts +118 -0
  186. package/src/classic/copy-and-blit.ts +318 -0
  187. package/src/classic/format-utils.ts +47 -0
  188. package/src/classic/typed-array-utils.ts +19 -31
  189. package/src/context/debug/spector.ts +16 -10
  190. package/src/context/debug/webgl-developer-tools.ts +52 -32
  191. package/src/context/helpers/create-browser-context.ts +116 -0
  192. package/src/context/helpers/webgl-context-data.ts +31 -0
  193. package/src/context/helpers/webgl-extensions.ts +17 -0
  194. package/src/context/parameters/unified-parameter-api.ts +11 -16
  195. package/src/context/parameters/webgl-parameter-tables.ts +171 -121
  196. package/src/context/state-tracker/deep-array-equal.ts +3 -0
  197. package/src/context/state-tracker/track-context-state.ts +35 -26
  198. package/src/context/state-tracker/with-parameters.ts +12 -3
  199. package/src/index.ts +41 -55
  200. package/src/types.ts +6 -0
  201. package/dist/adapter/converters/device-parameters.js.map +0 -1
  202. package/dist/adapter/converters/renderbuffer-formats.d.ts +0 -16
  203. package/dist/adapter/converters/renderbuffer-formats.d.ts.map +0 -1
  204. package/dist/adapter/converters/renderbuffer-formats.js +0 -185
  205. package/dist/adapter/converters/renderbuffer-formats.js.map +0 -1
  206. package/dist/adapter/converters/sampler-parameters.js.map +0 -1
  207. package/dist/adapter/converters/texture-formats.js.map +0 -1
  208. package/dist/adapter/converters/vertex-formats.js.map +0 -1
  209. package/dist/adapter/device-helpers/device-features.d.ts +0 -9
  210. package/dist/adapter/device-helpers/device-features.d.ts.map +0 -1
  211. package/dist/adapter/device-helpers/device-features.js +0 -112
  212. package/dist/adapter/device-helpers/device-features.js.map +0 -1
  213. package/dist/adapter/device-helpers/device-limits.d.ts +0 -52
  214. package/dist/adapter/device-helpers/device-limits.d.ts.map +0 -1
  215. package/dist/adapter/device-helpers/device-limits.js +0 -91
  216. package/dist/adapter/device-helpers/device-limits.js.map +0 -1
  217. package/dist/adapter/device-helpers/get-device-info.d.ts +0 -4
  218. package/dist/adapter/device-helpers/get-device-info.d.ts.map +0 -1
  219. package/dist/adapter/device-helpers/get-device-info.js +0 -44
  220. package/dist/adapter/device-helpers/get-device-info.js.map +0 -1
  221. package/dist/adapter/device-helpers/is-old-ie.d.ts +0 -2
  222. package/dist/adapter/device-helpers/is-old-ie.d.ts.map +0 -1
  223. package/dist/adapter/device-helpers/is-old-ie.js +0 -8
  224. package/dist/adapter/device-helpers/is-old-ie.js.map +0 -1
  225. package/dist/adapter/helpers/attribute-utils.d.ts +0 -11
  226. package/dist/adapter/helpers/attribute-utils.d.ts.map +0 -1
  227. package/dist/adapter/helpers/attribute-utils.js +0 -81
  228. package/dist/adapter/helpers/attribute-utils.js.map +0 -1
  229. package/dist/adapter/helpers/get-shader-layout.js.map +0 -1
  230. package/dist/adapter/helpers/parse-shader-compiler-log.js.map +0 -1
  231. package/dist/adapter/helpers/set-uniform.js.map +0 -1
  232. package/dist/adapter/helpers/uniforms.d.ts +0 -26
  233. package/dist/adapter/helpers/uniforms.d.ts.map +0 -1
  234. package/dist/adapter/helpers/uniforms.js +0 -99
  235. package/dist/adapter/helpers/uniforms.js.map +0 -1
  236. package/dist/adapter/objects/constants-to-keys.js.map +0 -1
  237. package/dist/adapter/objects/webgl-renderbuffer.js.map +0 -1
  238. package/dist/adapter/objects/webgl-resource.js.map +0 -1
  239. package/dist/adapter/objects/webgl-vertex-array-object.d.ts +0 -27
  240. package/dist/adapter/objects/webgl-vertex-array-object.d.ts.map +0 -1
  241. package/dist/adapter/objects/webgl-vertex-array-object.js +0 -84
  242. package/dist/adapter/objects/webgl-vertex-array-object.js.map +0 -1
  243. package/dist/adapter/resources/webgl-buffer.js.map +0 -1
  244. package/dist/adapter/resources/webgl-command-buffer.js.map +0 -1
  245. package/dist/adapter/resources/webgl-command-encoder.js.map +0 -1
  246. package/dist/adapter/resources/webgl-external-texture.js.map +0 -1
  247. package/dist/adapter/resources/webgl-framebuffer.js.map +0 -1
  248. package/dist/adapter/resources/webgl-render-pass.js.map +0 -1
  249. package/dist/adapter/resources/webgl-render-pipeline.js.map +0 -1
  250. package/dist/adapter/resources/webgl-sampler.js.map +0 -1
  251. package/dist/adapter/resources/webgl-shader.js.map +0 -1
  252. package/dist/adapter/resources/webgl-texture.js.map +0 -1
  253. package/dist/adapter/webgl-canvas-context.js.map +0 -1
  254. package/dist/adapter/webgl-device.js.map +0 -1
  255. package/dist/bundle.d.ts +0 -2
  256. package/dist/bundle.d.ts.map +0 -1
  257. package/dist/bundle.js +0 -5
  258. package/dist/bundle.js.map +0 -1
  259. package/dist/classic/accessor.js.map +0 -1
  260. package/dist/classic/buffer.d.ts +0 -95
  261. package/dist/classic/buffer.d.ts.map +0 -1
  262. package/dist/classic/buffer.js +0 -392
  263. package/dist/classic/buffer.js.map +0 -1
  264. package/dist/classic/typed-array-utils.js.map +0 -1
  265. package/dist/context/context/context-state.d.ts +0 -18
  266. package/dist/context/context/context-state.d.ts.map +0 -1
  267. package/dist/context/context/context-state.js +0 -26
  268. package/dist/context/context/context-state.js.map +0 -1
  269. package/dist/context/context/create-browser-context.d.ts +0 -41
  270. package/dist/context/context/create-browser-context.d.ts.map +0 -1
  271. package/dist/context/context/create-browser-context.js +0 -61
  272. package/dist/context/context/create-browser-context.js.map +0 -1
  273. package/dist/context/context/create-headless-context.d.ts +0 -9
  274. package/dist/context/context/create-headless-context.d.ts.map +0 -1
  275. package/dist/context/context/create-headless-context.js +0 -43
  276. package/dist/context/context/create-headless-context.js.map +0 -1
  277. package/dist/context/context/device-pixels.d.ts +0 -25
  278. package/dist/context/context/device-pixels.d.ts.map +0 -1
  279. package/dist/context/context/device-pixels.js +0 -103
  280. package/dist/context/context/device-pixels.js.map +0 -1
  281. package/dist/context/context/webgl-checks.d.ts +0 -13
  282. package/dist/context/context/webgl-checks.d.ts.map +0 -1
  283. package/dist/context/context/webgl-checks.js +0 -34
  284. package/dist/context/context/webgl-checks.js.map +0 -1
  285. package/dist/context/debug/spector.js.map +0 -1
  286. package/dist/context/debug/webgl-developer-tools.js.map +0 -1
  287. package/dist/context/parameters/unified-parameter-api.js.map +0 -1
  288. package/dist/context/parameters/webgl-parameter-tables.js.map +0 -1
  289. package/dist/context/polyfill/get-parameter-polyfill.d.ts +0 -2
  290. package/dist/context/polyfill/get-parameter-polyfill.d.ts.map +0 -1
  291. package/dist/context/polyfill/get-parameter-polyfill.js +0 -91
  292. package/dist/context/polyfill/get-parameter-polyfill.js.map +0 -1
  293. package/dist/context/polyfill/polyfill-context.d.ts +0 -5
  294. package/dist/context/polyfill/polyfill-context.d.ts.map +0 -1
  295. package/dist/context/polyfill/polyfill-context.js +0 -91
  296. package/dist/context/polyfill/polyfill-context.js.map +0 -1
  297. package/dist/context/polyfill/polyfill-table.d.ts +0 -48
  298. package/dist/context/polyfill/polyfill-table.d.ts.map +0 -1
  299. package/dist/context/polyfill/polyfill-table.js +0 -160
  300. package/dist/context/polyfill/polyfill-table.js.map +0 -1
  301. package/dist/context/polyfill/polyfill-vertex-array-object.d.ts +0 -2
  302. package/dist/context/polyfill/polyfill-vertex-array-object.d.ts.map +0 -1
  303. package/dist/context/polyfill/polyfill-vertex-array-object.js +0 -335
  304. package/dist/context/polyfill/polyfill-vertex-array-object.js.map +0 -1
  305. package/dist/context/state-tracker/deep-array-equal.js.map +0 -1
  306. package/dist/context/state-tracker/track-context-state.js.map +0 -1
  307. package/dist/context/state-tracker/with-parameters.js.map +0 -1
  308. package/dist/es5/adapter/converters/device-parameters.js +0 -185
  309. package/dist/es5/adapter/converters/device-parameters.js.map +0 -1
  310. package/dist/es5/adapter/converters/renderbuffer-formats.js +0 -163
  311. package/dist/es5/adapter/converters/renderbuffer-formats.js.map +0 -1
  312. package/dist/es5/adapter/converters/sampler-parameters.js +0 -245
  313. package/dist/es5/adapter/converters/sampler-parameters.js.map +0 -1
  314. package/dist/es5/adapter/converters/texture-formats.js +0 -1031
  315. package/dist/es5/adapter/converters/texture-formats.js.map +0 -1
  316. package/dist/es5/adapter/converters/vertex-formats.js +0 -45
  317. package/dist/es5/adapter/converters/vertex-formats.js.map +0 -1
  318. package/dist/es5/adapter/device-helpers/device-features.js +0 -155
  319. package/dist/es5/adapter/device-helpers/device-features.js.map +0 -1
  320. package/dist/es5/adapter/device-helpers/device-limits.js +0 -64
  321. package/dist/es5/adapter/device-helpers/device-limits.js.map +0 -1
  322. package/dist/es5/adapter/device-helpers/get-device-info.js +0 -55
  323. package/dist/es5/adapter/device-helpers/get-device-info.js.map +0 -1
  324. package/dist/es5/adapter/device-helpers/is-old-ie.js +0 -16
  325. package/dist/es5/adapter/device-helpers/is-old-ie.js.map +0 -1
  326. package/dist/es5/adapter/helpers/attribute-utils.js +0 -91
  327. package/dist/es5/adapter/helpers/attribute-utils.js.map +0 -1
  328. package/dist/es5/adapter/helpers/get-shader-layout.js +0 -391
  329. package/dist/es5/adapter/helpers/get-shader-layout.js.map +0 -1
  330. package/dist/es5/adapter/helpers/parse-shader-compiler-log.js +0 -72
  331. package/dist/es5/adapter/helpers/parse-shader-compiler-log.js.map +0 -1
  332. package/dist/es5/adapter/helpers/set-uniform.js +0 -125
  333. package/dist/es5/adapter/helpers/set-uniform.js.map +0 -1
  334. package/dist/es5/adapter/helpers/uniforms.js +0 -112
  335. package/dist/es5/adapter/helpers/uniforms.js.map +0 -1
  336. package/dist/es5/adapter/objects/constants-to-keys.js +0 -54
  337. package/dist/es5/adapter/objects/constants-to-keys.js.map +0 -1
  338. package/dist/es5/adapter/objects/webgl-renderbuffer.js +0 -150
  339. package/dist/es5/adapter/objects/webgl-renderbuffer.js.map +0 -1
  340. package/dist/es5/adapter/objects/webgl-resource.js +0 -292
  341. package/dist/es5/adapter/objects/webgl-resource.js.map +0 -1
  342. package/dist/es5/adapter/objects/webgl-vertex-array-object.js +0 -137
  343. package/dist/es5/adapter/objects/webgl-vertex-array-object.js.map +0 -1
  344. package/dist/es5/adapter/resources/webgl-buffer.js +0 -243
  345. package/dist/es5/adapter/resources/webgl-buffer.js.map +0 -1
  346. package/dist/es5/adapter/resources/webgl-command-buffer.js +0 -96
  347. package/dist/es5/adapter/resources/webgl-command-buffer.js.map +0 -1
  348. package/dist/es5/adapter/resources/webgl-command-encoder.js +0 -98
  349. package/dist/es5/adapter/resources/webgl-command-encoder.js.map +0 -1
  350. package/dist/es5/adapter/resources/webgl-external-texture.js +0 -2
  351. package/dist/es5/adapter/resources/webgl-external-texture.js.map +0 -1
  352. package/dist/es5/adapter/resources/webgl-framebuffer.js +0 -346
  353. package/dist/es5/adapter/resources/webgl-framebuffer.js.map +0 -1
  354. package/dist/es5/adapter/resources/webgl-render-pass.js +0 -62
  355. package/dist/es5/adapter/resources/webgl-render-pass.js.map +0 -1
  356. package/dist/es5/adapter/resources/webgl-render-pipeline.js +0 -530
  357. package/dist/es5/adapter/resources/webgl-render-pipeline.js.map +0 -1
  358. package/dist/es5/adapter/resources/webgl-sampler.js +0 -96
  359. package/dist/es5/adapter/resources/webgl-sampler.js.map +0 -1
  360. package/dist/es5/adapter/resources/webgl-shader.js +0 -150
  361. package/dist/es5/adapter/resources/webgl-shader.js.map +0 -1
  362. package/dist/es5/adapter/resources/webgl-texture.js +0 -986
  363. package/dist/es5/adapter/resources/webgl-texture.js.map +0 -1
  364. package/dist/es5/adapter/webgl-canvas-context.js +0 -97
  365. package/dist/es5/adapter/webgl-canvas-context.js.map +0 -1
  366. package/dist/es5/adapter/webgl-device.js +0 -463
  367. package/dist/es5/adapter/webgl-device.js.map +0 -1
  368. package/dist/es5/bundle.js +0 -7
  369. package/dist/es5/bundle.js.map +0 -1
  370. package/dist/es5/classic/accessor.js +0 -181
  371. package/dist/es5/classic/accessor.js.map +0 -1
  372. package/dist/es5/classic/buffer.js +0 -478
  373. package/dist/es5/classic/buffer.js.map +0 -1
  374. package/dist/es5/classic/typed-array-utils.js +0 -126
  375. package/dist/es5/classic/typed-array-utils.js.map +0 -1
  376. package/dist/es5/context/context/context-state.js +0 -31
  377. package/dist/es5/context/context/context-state.js.map +0 -1
  378. package/dist/es5/context/context/create-browser-context.js +0 -83
  379. package/dist/es5/context/context/create-browser-context.js.map +0 -1
  380. package/dist/es5/context/context/create-headless-context.js +0 -60
  381. package/dist/es5/context/context/create-headless-context.js.map +0 -1
  382. package/dist/es5/context/context/device-pixels.js +0 -121
  383. package/dist/es5/context/context/device-pixels.js.map +0 -1
  384. package/dist/es5/context/context/webgl-checks.js +0 -54
  385. package/dist/es5/context/context/webgl-checks.js.map +0 -1
  386. package/dist/es5/context/debug/spector.js +0 -133
  387. package/dist/es5/context/debug/spector.js.map +0 -1
  388. package/dist/es5/context/debug/webgl-developer-tools.js +0 -198
  389. package/dist/es5/context/debug/webgl-developer-tools.js.map +0 -1
  390. package/dist/es5/context/parameters/unified-parameter-api.js +0 -97
  391. package/dist/es5/context/parameters/unified-parameter-api.js.map +0 -1
  392. package/dist/es5/context/parameters/webgl-parameter-tables.js +0 -392
  393. package/dist/es5/context/parameters/webgl-parameter-tables.js.map +0 -1
  394. package/dist/es5/context/polyfill/get-parameter-polyfill.js +0 -81
  395. package/dist/es5/context/polyfill/get-parameter-polyfill.js.map +0 -1
  396. package/dist/es5/context/polyfill/polyfill-context.js +0 -134
  397. package/dist/es5/context/polyfill/polyfill-context.js.map +0 -1
  398. package/dist/es5/context/polyfill/polyfill-table.js +0 -166
  399. package/dist/es5/context/polyfill/polyfill-table.js.map +0 -1
  400. package/dist/es5/context/polyfill/polyfill-vertex-array-object.js +0 -341
  401. package/dist/es5/context/polyfill/polyfill-vertex-array-object.js.map +0 -1
  402. package/dist/es5/context/state-tracker/deep-array-equal.js +0 -28
  403. package/dist/es5/context/state-tracker/deep-array-equal.js.map +0 -1
  404. package/dist/es5/context/state-tracker/track-context-state.js +0 -211
  405. package/dist/es5/context/state-tracker/track-context-state.js.map +0 -1
  406. package/dist/es5/context/state-tracker/with-parameters.js +0 -44
  407. package/dist/es5/context/state-tracker/with-parameters.js.map +0 -1
  408. package/dist/es5/index.js +0 -290
  409. package/dist/es5/index.js.map +0 -1
  410. package/dist/es5/init.js +0 -10
  411. package/dist/es5/init.js.map +0 -1
  412. package/dist/es5/types/webgl.js +0 -6
  413. package/dist/es5/types/webgl.js.map +0 -1
  414. package/dist/es5/types.js +0 -2
  415. package/dist/es5/types.js.map +0 -1
  416. package/dist/esm/adapter/converters/device-parameters.js +0 -168
  417. package/dist/esm/adapter/converters/device-parameters.js.map +0 -1
  418. package/dist/esm/adapter/converters/renderbuffer-formats.js +0 -185
  419. package/dist/esm/adapter/converters/renderbuffer-formats.js.map +0 -1
  420. package/dist/esm/adapter/converters/sampler-parameters.js +0 -227
  421. package/dist/esm/adapter/converters/sampler-parameters.js.map +0 -1
  422. package/dist/esm/adapter/converters/texture-formats.js +0 -954
  423. package/dist/esm/adapter/converters/texture-formats.js.map +0 -1
  424. package/dist/esm/adapter/converters/vertex-formats.js +0 -35
  425. package/dist/esm/adapter/converters/vertex-formats.js.map +0 -1
  426. package/dist/esm/adapter/device-helpers/device-features.js +0 -112
  427. package/dist/esm/adapter/device-helpers/device-features.js.map +0 -1
  428. package/dist/esm/adapter/device-helpers/device-limits.js +0 -91
  429. package/dist/esm/adapter/device-helpers/device-limits.js.map +0 -1
  430. package/dist/esm/adapter/device-helpers/get-device-info.js +0 -44
  431. package/dist/esm/adapter/device-helpers/get-device-info.js.map +0 -1
  432. package/dist/esm/adapter/device-helpers/is-old-ie.js +0 -8
  433. package/dist/esm/adapter/device-helpers/is-old-ie.js.map +0 -1
  434. package/dist/esm/adapter/helpers/attribute-utils.js +0 -81
  435. package/dist/esm/adapter/helpers/attribute-utils.js.map +0 -1
  436. package/dist/esm/adapter/helpers/get-shader-layout.js +0 -330
  437. package/dist/esm/adapter/helpers/get-shader-layout.js.map +0 -1
  438. package/dist/esm/adapter/helpers/parse-shader-compiler-log.js +0 -37
  439. package/dist/esm/adapter/helpers/parse-shader-compiler-log.js.map +0 -1
  440. package/dist/esm/adapter/helpers/set-uniform.js +0 -115
  441. package/dist/esm/adapter/helpers/set-uniform.js.map +0 -1
  442. package/dist/esm/adapter/helpers/uniforms.js +0 -99
  443. package/dist/esm/adapter/helpers/uniforms.js.map +0 -1
  444. package/dist/esm/adapter/objects/constants-to-keys.js +0 -42
  445. package/dist/esm/adapter/objects/constants-to-keys.js.map +0 -1
  446. package/dist/esm/adapter/objects/webgl-renderbuffer.js +0 -94
  447. package/dist/esm/adapter/objects/webgl-renderbuffer.js.map +0 -1
  448. package/dist/esm/adapter/objects/webgl-resource.js +0 -216
  449. package/dist/esm/adapter/objects/webgl-resource.js.map +0 -1
  450. package/dist/esm/adapter/objects/webgl-vertex-array-object.js +0 -84
  451. package/dist/esm/adapter/objects/webgl-vertex-array-object.js.map +0 -1
  452. package/dist/esm/adapter/resources/webgl-buffer.js +0 -164
  453. package/dist/esm/adapter/resources/webgl-buffer.js.map +0 -1
  454. package/dist/esm/adapter/resources/webgl-command-buffer.js +0 -65
  455. package/dist/esm/adapter/resources/webgl-command-buffer.js.map +0 -1
  456. package/dist/esm/adapter/resources/webgl-command-encoder.js +0 -53
  457. package/dist/esm/adapter/resources/webgl-command-encoder.js.map +0 -1
  458. package/dist/esm/adapter/resources/webgl-external-texture.js +0 -2
  459. package/dist/esm/adapter/resources/webgl-external-texture.js.map +0 -1
  460. package/dist/esm/adapter/resources/webgl-framebuffer.js +0 -267
  461. package/dist/esm/adapter/resources/webgl-framebuffer.js.map +0 -1
  462. package/dist/esm/adapter/resources/webgl-render-pass.js +0 -21
  463. package/dist/esm/adapter/resources/webgl-render-pass.js.map +0 -1
  464. package/dist/esm/adapter/resources/webgl-render-pipeline.js +0 -428
  465. package/dist/esm/adapter/resources/webgl-render-pipeline.js.map +0 -1
  466. package/dist/esm/adapter/resources/webgl-sampler.js +0 -50
  467. package/dist/esm/adapter/resources/webgl-sampler.js.map +0 -1
  468. package/dist/esm/adapter/resources/webgl-shader.js +0 -76
  469. package/dist/esm/adapter/resources/webgl-shader.js.map +0 -1
  470. package/dist/esm/adapter/resources/webgl-texture.js +0 -834
  471. package/dist/esm/adapter/resources/webgl-texture.js.map +0 -1
  472. package/dist/esm/adapter/webgl-canvas-context.js +0 -54
  473. package/dist/esm/adapter/webgl-canvas-context.js.map +0 -1
  474. package/dist/esm/adapter/webgl-device.js +0 -337
  475. package/dist/esm/adapter/webgl-device.js.map +0 -1
  476. package/dist/esm/bundle.js +0 -5
  477. package/dist/esm/bundle.js.map +0 -1
  478. package/dist/esm/classic/accessor.js +0 -144
  479. package/dist/esm/classic/accessor.js.map +0 -1
  480. package/dist/esm/classic/buffer.js +0 -392
  481. package/dist/esm/classic/buffer.js.map +0 -1
  482. package/dist/esm/classic/typed-array-utils.js +0 -112
  483. package/dist/esm/classic/typed-array-utils.js.map +0 -1
  484. package/dist/esm/context/context/context-state.js +0 -26
  485. package/dist/esm/context/context/context-state.js.map +0 -1
  486. package/dist/esm/context/context/create-browser-context.js +0 -61
  487. package/dist/esm/context/context/create-browser-context.js.map +0 -1
  488. package/dist/esm/context/context/create-headless-context.js +0 -43
  489. package/dist/esm/context/context/create-headless-context.js.map +0 -1
  490. package/dist/esm/context/context/device-pixels.js +0 -103
  491. package/dist/esm/context/context/device-pixels.js.map +0 -1
  492. package/dist/esm/context/context/webgl-checks.js +0 -34
  493. package/dist/esm/context/context/webgl-checks.js.map +0 -1
  494. package/dist/esm/context/debug/spector.js +0 -76
  495. package/dist/esm/context/debug/spector.js.map +0 -1
  496. package/dist/esm/context/debug/webgl-developer-tools.js +0 -121
  497. package/dist/esm/context/debug/webgl-developer-tools.js.map +0 -1
  498. package/dist/esm/context/parameters/unified-parameter-api.js +0 -63
  499. package/dist/esm/context/parameters/unified-parameter-api.js.map +0 -1
  500. package/dist/esm/context/parameters/webgl-parameter-tables.js +0 -445
  501. package/dist/esm/context/parameters/webgl-parameter-tables.js.map +0 -1
  502. package/dist/esm/context/polyfill/get-parameter-polyfill.js +0 -91
  503. package/dist/esm/context/polyfill/get-parameter-polyfill.js.map +0 -1
  504. package/dist/esm/context/polyfill/polyfill-context.js +0 -91
  505. package/dist/esm/context/polyfill/polyfill-context.js.map +0 -1
  506. package/dist/esm/context/polyfill/polyfill-table.js +0 -160
  507. package/dist/esm/context/polyfill/polyfill-table.js.map +0 -1
  508. package/dist/esm/context/polyfill/polyfill-vertex-array-object.js +0 -335
  509. package/dist/esm/context/polyfill/polyfill-vertex-array-object.js.map +0 -1
  510. package/dist/esm/context/state-tracker/deep-array-equal.js +0 -21
  511. package/dist/esm/context/state-tracker/deep-array-equal.js.map +0 -1
  512. package/dist/esm/context/state-tracker/track-context-state.js +0 -183
  513. package/dist/esm/context/state-tracker/track-context-state.js.map +0 -1
  514. package/dist/esm/context/state-tracker/with-parameters.js +0 -36
  515. package/dist/esm/context/state-tracker/with-parameters.js.map +0 -1
  516. package/dist/esm/index.js +0 -28
  517. package/dist/esm/index.js.map +0 -1
  518. package/dist/esm/init.js +0 -4
  519. package/dist/esm/init.js.map +0 -1
  520. package/dist/esm/types/webgl.js +0 -2
  521. package/dist/esm/types/webgl.js.map +0 -1
  522. package/dist/esm/types.js +0 -2
  523. package/dist/esm/types.js.map +0 -1
  524. package/dist/index.js.map +0 -1
  525. package/dist/init.d.ts +0 -2
  526. package/dist/init.d.ts.map +0 -1
  527. package/dist/init.js +0 -4
  528. package/dist/init.js.map +0 -1
  529. package/dist/types/webgl.d.ts +0 -145
  530. package/dist/types/webgl.d.ts.map +0 -1
  531. package/dist/types/webgl.js +0 -2
  532. package/dist/types/webgl.js.map +0 -1
  533. package/dist/types.js.map +0 -1
  534. package/src/adapter/converters/renderbuffer-formats.ts +0 -92
  535. package/src/adapter/device-helpers/device-features.ts +0 -158
  536. package/src/adapter/device-helpers/device-limits.ts +0 -153
  537. package/src/adapter/device-helpers/get-device-info.ts +0 -49
  538. package/src/adapter/device-helpers/is-old-ie.ts +0 -11
  539. package/src/adapter/helpers/attribute-utils.ts +0 -61
  540. package/src/adapter/objects/webgl-vertex-array-object.ts +0 -111
  541. package/src/bundle.ts +0 -4
  542. package/src/classic/buffer.ts +0 -474
  543. package/src/context/context/context-state.ts +0 -41
  544. package/src/context/context/create-browser-context.ts +0 -118
  545. package/src/context/context/create-headless-context.ts +0 -48
  546. package/src/context/context/device-pixels.ts +0 -158
  547. package/src/context/context/webgl-checks.ts +0 -49
  548. package/src/context/polyfill/get-parameter-polyfill.ts +0 -118
  549. package/src/context/polyfill/polyfill-context.ts +0 -97
  550. package/src/context/polyfill/polyfill-table.ts +0 -162
  551. package/src/context/polyfill/polyfill-vertex-array-object.ts +0 -360
  552. package/src/init.ts +0 -4
  553. package/src/types/webgl.ts +0 -284
@@ -1,834 +1,635 @@
1
- import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
2
- import { isObjectEmpty } from '@luma.gl/api';
3
- import { Texture, cast, log, assert, isPowerOfTwo, loadImage } from '@luma.gl/api';
4
- import GL from '@luma.gl/constants';
5
- import { withParameters } from '../../context/state-tracker/with-parameters';
6
- import { getWebGLTextureFormat, getWebGLTextureParameters, getTextureFormatBytesPerPixel } from '../converters/texture-formats';
7
- import { convertSamplerParametersToWebGL, updateSamplerParametersForNPOT } from '../converters/sampler-parameters';
8
- import WEBGLBuffer from './webgl-buffer';
9
- import WEBGLSampler from './webgl-sampler';
10
- export default class WEBGLTexture extends Texture {
11
- constructor(device, props) {
12
- var _this$props;
13
-
14
- super(device, {
15
- format: GL.RGBA,
16
- ...props
17
- });
18
-
19
- _defineProperty(this, "MAX_ATTRIBUTES", void 0);
20
-
21
- _defineProperty(this, "device", void 0);
22
-
23
- _defineProperty(this, "gl", void 0);
24
-
25
- _defineProperty(this, "gl2", void 0);
26
-
27
- _defineProperty(this, "handle", void 0);
28
-
29
- _defineProperty(this, "data", void 0);
30
-
31
- _defineProperty(this, "width", undefined);
32
-
33
- _defineProperty(this, "height", undefined);
34
-
35
- _defineProperty(this, "depth", undefined);
36
-
37
- _defineProperty(this, "format", undefined);
38
-
39
- _defineProperty(this, "type", undefined);
40
-
41
- _defineProperty(this, "dataFormat", undefined);
42
-
43
- _defineProperty(this, "mipmaps", undefined);
44
-
45
- _defineProperty(this, "target", void 0);
46
-
47
- _defineProperty(this, "textureUnit", undefined);
48
-
49
- _defineProperty(this, "sampler", undefined);
50
-
51
- _defineProperty(this, "loaded", false);
52
-
53
- _defineProperty(this, "_video", void 0);
54
-
55
- this.device = cast(device);
56
- this.gl = this.device.gl;
57
- this.gl2 = this.device.gl2;
58
- this.handle = this.props.handle || this.gl.createTexture();
59
- this.handle.__SPECTOR_Metadata = { ...this.props,
60
- data: typeof this.props.data
61
- };
62
- this.target = getWebGLTextureTarget(this.props);
63
- this.loaded = false;
64
-
65
- if (typeof ((_this$props = this.props) === null || _this$props === void 0 ? void 0 : _this$props.data) === 'string') {
66
- Object.assign(this.props, {
67
- data: loadImage(this.props.data)
68
- });
69
- }
70
-
71
- this.initialize(this.props);
72
- Object.seal(this);
73
- }
74
-
75
- destroy() {
76
- if (this.handle) {
77
- this.gl.deleteTexture(this.handle);
78
- this.removeStats();
79
- this.trackDeallocatedMemory('Texture');
80
- this.destroyed = true;
81
- }
82
- }
83
-
84
- toString() {
85
- return "Texture(".concat(this.id, ",").concat(this.width, "x").concat(this.height, ")");
86
- }
87
-
88
- initialize(props = {}) {
89
- if (this.props.dimension === 'cube') {
90
- return this.initializeCube(props);
91
- }
92
-
93
- let data = props.data;
94
-
95
- if (data instanceof Promise) {
96
- data.then(resolvedImageData => this.initialize(Object.assign({}, props, {
97
- pixels: resolvedImageData,
98
- data: resolvedImageData
99
- })));
100
- return this;
101
- }
102
-
103
- const isVideo = typeof HTMLVideoElement !== 'undefined' && data instanceof HTMLVideoElement;
104
-
105
- if (isVideo && data.readyState < HTMLVideoElement.HAVE_METADATA) {
106
- this._video = null;
107
- data.addEventListener('loadeddata', () => this.initialize(props));
108
- return this;
109
- }
110
-
111
- let {
112
- parameters = {}
113
- } = props;
114
- const {
115
- pixels = null,
116
- recreate = false,
117
- pixelStore = {},
118
- textureUnit = undefined
119
- } = props;
120
-
121
- if (!data) {
122
- data = pixels;
123
- }
124
-
125
- let {
126
- width,
127
- height,
128
- dataFormat,
129
- type,
130
- compressed = false,
131
- mipmaps = true
132
- } = props;
133
- const {
134
- depth = 0
135
- } = props;
136
- ({
137
- width,
138
- height,
139
- compressed,
140
- dataFormat,
141
- type
142
- } = this._deduceParameters({
143
- format: props.format,
144
- type,
145
- dataFormat,
146
- compressed,
147
- data,
148
- width,
149
- height
150
- }));
151
- const format = getWebGLTextureFormat(this.gl, props.format);
152
- this.width = width;
153
- this.height = height;
154
- this.depth = depth;
155
- this.format = format;
156
- this.type = type;
157
- this.dataFormat = dataFormat;
158
- this.textureUnit = textureUnit;
159
-
160
- if (Number.isFinite(this.textureUnit)) {
161
- this.gl.activeTexture(GL.TEXTURE0 + this.textureUnit);
162
- this.gl.bindTexture(this.target, this.handle);
163
- }
164
-
165
- if (mipmaps && this.device.isWebGL1 && isNPOT(this.width, this.height)) {
166
- log.warn("texture: ".concat(this, " is Non-Power-Of-Two, disabling mipmaps"))();
167
- mipmaps = false;
168
- }
169
-
170
- this.mipmaps = mipmaps;
171
- this.setImageData({
172
- data,
173
- width,
174
- height,
175
- depth,
176
- format,
177
- type,
178
- dataFormat,
179
- parameters: pixelStore,
180
- compressed
181
- });
182
- this.setSampler(props.sampler);
183
-
184
- this._setSamplerParameters(parameters);
185
-
186
- if (mipmaps) {
187
- this.generateMipmap();
1
+ // luma.gl
2
+ // SPDX-License-Identifier: MIT
3
+ // Copyright (c) vis.gl contributors
4
+ import { Texture, log, assert, loadImage, isObjectEmpty } from '@luma.gl/core';
5
+ import { GL } from '@luma.gl/constants';
6
+ import { withGLParameters } from "../../context/state-tracker/with-parameters.js";
7
+ import { convertTextureFormatToGL, getWebGLTextureParameters, getTextureFormatBytesPerPixel } from "../converters/texture-formats.js";
8
+ import { convertSamplerParametersToWebGL } from "../converters/sampler-parameters.js";
9
+ import { WEBGLBuffer } from "./webgl-buffer.js";
10
+ import { WEBGLSampler } from "./webgl-sampler.js";
11
+ import { WEBGLTextureView } from "./webgl-texture-view.js";
12
+ export const DEFAULT_WEBGL_TEXTURE_PROPS = {
13
+ // deprecated
14
+ parameters: {},
15
+ pixelStore: {},
16
+ pixels: null,
17
+ border: 0,
18
+ dataFormat: undefined,
19
+ textureUnit: undefined,
20
+ target: undefined
21
+ };
22
+ // Polyfill
23
+ export class WEBGLTexture extends Texture {
24
+ // TODO - remove?
25
+ static FACES = [
26
+ 34069,
27
+ 34070,
28
+ 34071,
29
+ 34072,
30
+ 34073,
31
+ 34074
32
+ ];
33
+ MAX_ATTRIBUTES;
34
+ device;
35
+ gl;
36
+ handle;
37
+ // (TODO - currently unused in WebGL, but WebGL 2 does support sampler objects) */
38
+ sampler = undefined;
39
+ view = undefined;
40
+ // data;
41
+ glFormat = undefined;
42
+ type = undefined;
43
+ dataFormat = undefined;
44
+ mipmaps = undefined;
45
+ /**
46
+ * @note `target` cannot be modified by bind:
47
+ * textures are special because when you first bind them to a target,
48
+ * they get special information. When you first bind a texture as a
49
+ * GL_TEXTURE_2D, you are saying that this texture is a 2D texture.
50
+ * And it will always be a 2D texture; this state cannot be changed ever.
51
+ * A texture that was first bound as a GL_TEXTURE_2D, must always be bound as a GL_TEXTURE_2D;
52
+ * attempting to bind it as GL_TEXTURE_3D will give rise to a run-time error
53
+ * */
54
+ target;
55
+ textureUnit = undefined;
56
+ /**
57
+ * Program.draw() checks the loaded flag of all textures to avoid
58
+ * Textures that are still loading from promises
59
+ * Set to true as soon as texture has been initialized with valid data
60
+ */
61
+ loaded = false;
62
+ _video;
63
+ constructor(device, props) {
64
+ super(device, { ...DEFAULT_WEBGL_TEXTURE_PROPS, format: 'rgba8unorm', ...props });
65
+ this.device = device;
66
+ this.gl = this.device.gl;
67
+ this.handle = this.props.handle || this.gl.createTexture();
68
+ this.device.setSpectorMetadata(this.handle, { ...this.props, data: typeof this.props.data }); // {name: this.props.id};
69
+ this.glFormat = 6408;
70
+ this.target = getWebGLTextureTarget(this.props);
71
+ // Program.draw() checks the loaded flag of all textures
72
+ this.loaded = false;
73
+ // Signature: new Texture2D(gl, {data: url})
74
+ if (typeof this.props?.data === 'string') {
75
+ Object.assign(this.props, { data: loadImage(this.props.data) });
76
+ }
77
+ this.initialize(this.props);
78
+ Object.seal(this);
79
+ }
80
+ destroy() {
81
+ if (this.handle) {
82
+ this.gl.deleteTexture(this.handle);
83
+ this.removeStats();
84
+ this.trackDeallocatedMemory('Texture');
85
+ // this.handle = null;
86
+ this.destroyed = true;
87
+ }
188
88
  }
189
-
190
- if (recreate) {
191
- this.data = data;
89
+ toString() {
90
+ return `Texture(${this.id},${this.width}x${this.height})`;
192
91
  }
193
-
194
- if (isVideo) {
195
- this._video = {
196
- video: data,
197
- parameters,
198
- lastTime: data.readyState >= HTMLVideoElement.HAVE_CURRENT_DATA ? data.currentTime : -1
199
- };
92
+ createView(props) {
93
+ return new WEBGLTextureView(this.device, { ...props, texture: this });
200
94
  }
201
-
202
- return this;
203
- }
204
-
205
- initializeCube(props) {
206
- const {
207
- mipmaps = true,
208
- parameters = {}
209
- } = props;
210
- this.setCubeMapImageData(props).then(() => {
211
- this.loaded = true;
212
-
213
- if (mipmaps) {
214
- this.generateMipmap(props);
215
- }
216
-
217
- this.setSampler(props.sampler);
218
-
219
- this._setSamplerParameters(parameters);
220
- });
221
- return this;
222
- }
223
-
224
- setSampler(sampler = {}) {
225
- let samplerProps;
226
-
227
- if (sampler instanceof WEBGLSampler) {
228
- this.sampler = sampler;
229
- samplerProps = sampler.props;
230
- } else {
231
- this.sampler = new WEBGLSampler(this.device, sampler);
232
- samplerProps = sampler;
95
+ // eslint-disable-next-line max-statements
96
+ initialize(props = {}) {
97
+ // Cube textures
98
+ if (this.props.dimension === 'cube') {
99
+ return this.initializeCube(props);
100
+ }
101
+ let data = props.data;
102
+ if (data instanceof Promise) {
103
+ data.then(resolvedImageData => this.initialize(Object.assign({}, props, {
104
+ pixels: resolvedImageData,
105
+ data: resolvedImageData
106
+ })));
107
+ return this;
108
+ }
109
+ const isVideo = typeof HTMLVideoElement !== 'undefined' && data instanceof HTMLVideoElement;
110
+ // @ts-expect-error
111
+ if (isVideo && data.readyState < HTMLVideoElement.HAVE_METADATA) {
112
+ this._video = null; // Declare member before the object is sealed
113
+ // @ts-expect-error
114
+ data.addEventListener('loadeddata', () => this.initialize(props));
115
+ return this;
116
+ }
117
+ const { parameters = {} } = props;
118
+ const { pixels = null, pixelStore = {}, textureUnit = undefined, mipmaps = true } = props;
119
+ // pixels variable is for API compatibility purpose
120
+ if (!data) {
121
+ // TODO - This looks backwards? Commenting out for now until we decide
122
+ // which prop to use
123
+ // log.deprecated('data', 'pixels')();
124
+ data = pixels;
125
+ }
126
+ let { width, height, dataFormat, type, compressed = false } = props;
127
+ const { depth = 0 } = props;
128
+ const glFormat = convertTextureFormatToGL(props.format);
129
+ // Deduce width and height
130
+ ({ width, height, compressed, dataFormat, type } = this._deduceParameters({
131
+ format: props.format,
132
+ type,
133
+ dataFormat,
134
+ compressed,
135
+ data,
136
+ width,
137
+ height
138
+ }));
139
+ // Store opts for accessors
140
+ this.width = width;
141
+ this.height = height;
142
+ // this.depth = depth;
143
+ this.glFormat = glFormat;
144
+ this.type = type;
145
+ this.dataFormat = dataFormat;
146
+ this.textureUnit = textureUnit;
147
+ if (Number.isFinite(this.textureUnit)) {
148
+ this.gl.activeTexture(33984 + this.textureUnit);
149
+ this.gl.bindTexture(this.target, this.handle);
150
+ }
151
+ this.mipmaps = mipmaps;
152
+ this.setImageData({
153
+ data,
154
+ width,
155
+ height,
156
+ depth,
157
+ format: glFormat,
158
+ type,
159
+ dataFormat,
160
+ // @ts-expect-error
161
+ parameters: pixelStore,
162
+ compressed
163
+ });
164
+ // Set texture sampler parameters
165
+ this.setSampler(props.sampler);
166
+ this._setSamplerParameters(parameters);
167
+ this.view = this.createView({ ...this.props, mipLevelCount: 1, arrayLayerCount: 1 });
168
+ if (mipmaps && this.device.isTextureFormatFilterable(props.format)) {
169
+ this.generateMipmap();
170
+ }
171
+ if (isVideo) {
172
+ this._video = {
173
+ video: data,
174
+ parameters,
175
+ // @ts-expect-error
176
+ lastTime: data.readyState >= HTMLVideoElement.HAVE_CURRENT_DATA ? data.currentTime : -1
177
+ };
178
+ }
179
+ return this;
180
+ }
181
+ initializeCube(props) {
182
+ const { mipmaps = true, parameters = {} } = props;
183
+ // Store props for accessors
184
+ // this.props = props;
185
+ // @ts-expect-error
186
+ this.setCubeMapImageData(props).then(() => {
187
+ this.loaded = true;
188
+ // TODO - should genMipmap() be called on the cubemap or on the faces?
189
+ // TODO - without generateMipmap() cube textures do not work at all!!! Why?
190
+ if (mipmaps) {
191
+ this.generateMipmap(props);
192
+ }
193
+ this.setSampler(props.sampler);
194
+ this._setSamplerParameters(parameters);
195
+ });
196
+ return this;
197
+ }
198
+ setSampler(sampler = {}) {
199
+ let samplerProps;
200
+ if (sampler instanceof WEBGLSampler) {
201
+ this.sampler = sampler;
202
+ samplerProps = sampler.props;
203
+ }
204
+ else {
205
+ this.sampler = new WEBGLSampler(this.device, sampler);
206
+ samplerProps = sampler;
207
+ }
208
+ const parameters = convertSamplerParametersToWebGL(samplerProps);
209
+ this._setSamplerParameters(parameters);
210
+ return this;
211
+ }
212
+ /**
213
+ * If size has changed, reinitializes with current format
214
+ * @note note clears image and mipmaps
215
+ */
216
+ resize(options) {
217
+ const { height, width, mipmaps = false } = options;
218
+ if (width !== this.width || height !== this.height) {
219
+ return this.initialize({
220
+ width,
221
+ height,
222
+ format: this.format,
223
+ type: this.type,
224
+ dataFormat: this.dataFormat,
225
+ mipmaps
226
+ });
227
+ }
228
+ return this;
229
+ }
230
+ /** Update external texture (video frame) */
231
+ update() {
232
+ if (this._video) {
233
+ const { video, parameters, lastTime } = this._video;
234
+ // @ts-expect-error
235
+ if (lastTime === video.currentTime || video.readyState < HTMLVideoElement.HAVE_CURRENT_DATA) {
236
+ return;
237
+ }
238
+ this.setSubImageData({
239
+ data: video,
240
+ parameters
241
+ });
242
+ if (this.mipmaps) {
243
+ this.generateMipmap();
244
+ }
245
+ this._video.lastTime = video.currentTime;
246
+ }
233
247
  }
234
-
235
- const parameters = convertSamplerParametersToWebGL(samplerProps);
236
-
237
- this._setSamplerParameters(parameters);
238
-
239
- return this;
240
- }
241
-
242
- resize(options) {
243
- const {
244
- height,
245
- width,
246
- mipmaps = false
247
- } = options;
248
-
249
- if (width !== this.width || height !== this.height) {
250
- return this.initialize({
251
- width,
252
- height,
253
- format: this.format,
254
- type: this.type,
255
- dataFormat: this.dataFormat,
256
- mipmaps
257
- });
248
+ // Call to regenerate mipmaps after modifying texture(s)
249
+ generateMipmap(params = {}) {
250
+ this.mipmaps = true;
251
+ this.gl.bindTexture(this.target, this.handle);
252
+ withGLParameters(this.gl, params, () => {
253
+ this.gl.generateMipmap(this.target);
254
+ });
255
+ this.gl.bindTexture(this.target, null);
256
+ return this;
257
+ }
258
+ /*
259
+ * Allocates storage
260
+ * @param {*} pixels -
261
+ * null - create empty texture of specified format
262
+ * Typed array - init from image data in typed array
263
+ * Buffer|WebGLBuffer - (WEBGL2) init from image data in WebGLBuffer
264
+ * HTMLImageElement|Image - Inits with content of image. Auto width/height
265
+ * HTMLCanvasElement - Inits with contents of canvas. Auto width/height
266
+ * HTMLVideoElement - Creates video texture. Auto width/height
267
+ *
268
+ * @param width -
269
+ * @param height -
270
+ * @param mipMapLevel -
271
+ * @param {GLenum} format - format of image data.
272
+ * @param {GLenum} type
273
+ * - format of array (autodetect from type) or
274
+ * - (WEBGL2) format of buffer
275
+ * @param {Number} offset - (WEBGL2) offset from start of buffer
276
+ * @parameters - temporary settings to be applied, can be used to supply pixel store settings.
277
+ */
278
+ // eslint-disable-next-line max-statements, complexity
279
+ setImageData(options) {
280
+ if (this.props.dimension === '3d' || this.props.dimension === '2d-array') {
281
+ return this.setImageData3D(options);
282
+ }
283
+ this.trackDeallocatedMemory('Texture');
284
+ const { target = this.target, pixels = null, level = 0, glFormat = this.glFormat, offset = 0, parameters = {} } = options;
285
+ let { data = null, type = this.type, width = this.width, height = this.height, dataFormat = this.dataFormat, compressed = false } = options;
286
+ // pixels variable is for API compatibility purpose
287
+ if (!data) {
288
+ data = pixels;
289
+ }
290
+ ({ type, dataFormat, compressed, width, height } = this._deduceParameters({
291
+ format: this.props.format,
292
+ type,
293
+ dataFormat,
294
+ compressed,
295
+ data,
296
+ width,
297
+ height
298
+ }));
299
+ const { gl } = this;
300
+ gl.bindTexture(this.target, this.handle);
301
+ let dataType = null;
302
+ ({ data, dataType } = this._getDataType({ data, compressed }));
303
+ withGLParameters(this.gl, parameters, () => {
304
+ switch (dataType) {
305
+ case 'null':
306
+ gl.texImage2D(target, level, glFormat, width, height, 0 /* border*/, dataFormat, type, data);
307
+ break;
308
+ case 'typed-array':
309
+ gl.texImage2D(target, level, glFormat, width, height, 0, // border (must be 0)
310
+ dataFormat, type, data, offset);
311
+ break;
312
+ case 'buffer':
313
+ // WebGL2 enables creating textures directly from a WebGL buffer
314
+ this.device.gl.bindBuffer(35052, data.handle || data);
315
+ this.device.gl.texImage2D(target, level, glFormat, width, height, 0 /* border*/, dataFormat, type, offset);
316
+ this.device.gl.bindBuffer(35052, null);
317
+ break;
318
+ case 'browser-object':
319
+ gl.texImage2D(target, level, glFormat, width, height, 0 /* border*/, dataFormat, type, data);
320
+ break;
321
+ case 'compressed':
322
+ for (const [levelIndex, levelData] of data.entries()) {
323
+ gl.compressedTexImage2D(target, levelIndex, levelData.format, levelData.width, levelData.height, 0 /* border, must be 0 */, levelData.data);
324
+ }
325
+ break;
326
+ default:
327
+ assert(false, 'Unknown image data type');
328
+ }
329
+ });
330
+ if (data && data.byteLength) {
331
+ this.trackAllocatedMemory(data.byteLength, 'Texture');
332
+ }
333
+ else {
334
+ const bytesPerPixel = getTextureFormatBytesPerPixel(this.props.format);
335
+ this.trackAllocatedMemory(this.width * this.height * bytesPerPixel, 'Texture');
336
+ }
337
+ this.loaded = true;
338
+ return this;
339
+ }
340
+ /**
341
+ * Redefines an area of an existing texture
342
+ * Note: does not allocate storage
343
+ * Redefines an area of an existing texture
344
+ */
345
+ setSubImageData({ target = this.target, pixels = null, data = null, x = 0, y = 0, width = this.width, height = this.height, level = 0, glFormat = this.glFormat, type = this.type, dataFormat = this.dataFormat, compressed = false, offset = 0, parameters = {} }) {
346
+ ({ type, dataFormat, compressed, width, height } = this._deduceParameters({
347
+ format: this.props.format,
348
+ type,
349
+ dataFormat,
350
+ compressed,
351
+ data,
352
+ width,
353
+ height
354
+ }));
355
+ assert(this.depth === 1, 'texSubImage not supported for 3D textures');
356
+ // pixels variable is for API compatibility purpose
357
+ if (!data) {
358
+ data = pixels;
359
+ }
360
+ // Support ndarrays
361
+ if (data && data.data) {
362
+ const ndarray = data;
363
+ data = ndarray.data;
364
+ width = ndarray.shape[0];
365
+ height = ndarray.shape[1];
366
+ }
367
+ // Support buffers
368
+ if (data instanceof WEBGLBuffer) {
369
+ data = data.handle;
370
+ }
371
+ this.gl.bindTexture(this.target, this.handle);
372
+ withGLParameters(this.gl, parameters, () => {
373
+ // TODO - x,y parameters
374
+ if (compressed) {
375
+ this.gl.compressedTexSubImage2D(target, level, x, y, width, height, glFormat, data);
376
+ }
377
+ else if (data === null) {
378
+ this.gl.texSubImage2D(target, level, x, y, width, height, dataFormat, type, null);
379
+ }
380
+ else if (ArrayBuffer.isView(data)) {
381
+ this.gl.texSubImage2D(target, level, x, y, width, height, dataFormat, type, data, offset);
382
+ }
383
+ else if (typeof WebGLBuffer !== 'undefined' && data instanceof WebGLBuffer) {
384
+ // WebGL2 allows us to create texture directly from a WebGL buffer
385
+ // This texImage2D signature uses currently bound GL.PIXEL_UNPACK_BUFFER
386
+ this.device.gl.bindBuffer(35052, data);
387
+ this.device.gl.texSubImage2D(target, level, x, y, width, height, dataFormat, type, offset);
388
+ this.device.gl.bindBuffer(35052, null);
389
+ }
390
+ else {
391
+ // Assume data is a browser supported object (ImageData, Canvas, ...)
392
+ this.device.gl.texSubImage2D(target, level, x, y, width, height, dataFormat, type, data);
393
+ }
394
+ });
395
+ this.gl.bindTexture(this.target, null);
396
+ }
397
+ /**
398
+ * Defines a two-dimensional texture image or cube-map texture image with
399
+ * pixels from the current framebuffer (rather than from client memory).
400
+ * (gl.copyTexImage2D wrapper)
401
+ *
402
+ * Note that binding a texture into a Framebuffer's color buffer and
403
+ * rendering can be faster.
404
+ */
405
+ copyFramebuffer(opts = {}) {
406
+ log.error('Texture.copyFramebuffer({...}) is no logner supported, use copyToTexture(source, target, opts})')();
407
+ return null;
408
+ }
409
+ getActiveUnit() {
410
+ return this.gl.getParameter(34016) - 33984;
411
+ }
412
+ bind(textureUnit = this.textureUnit) {
413
+ const { gl } = this;
414
+ if (textureUnit !== undefined) {
415
+ this.textureUnit = textureUnit;
416
+ gl.activeTexture(33984 + textureUnit);
417
+ }
418
+ gl.bindTexture(this.target, this.handle);
419
+ return textureUnit;
420
+ }
421
+ unbind(textureUnit = this.textureUnit) {
422
+ const { gl } = this;
423
+ if (textureUnit !== undefined) {
424
+ this.textureUnit = textureUnit;
425
+ gl.activeTexture(33984 + textureUnit);
426
+ }
427
+ gl.bindTexture(this.target, null);
428
+ return textureUnit;
258
429
  }
259
-
260
- return this;
261
- }
262
-
263
- update() {
264
- if (this._video) {
265
- const {
266
- video,
267
- parameters,
268
- lastTime
269
- } = this._video;
270
-
271
- if (lastTime === video.currentTime || video.readyState < HTMLVideoElement.HAVE_CURRENT_DATA) {
430
+ // PRIVATE METHODS
431
+ _getDataType({ data, compressed = false }) {
432
+ if (compressed) {
433
+ return { data, dataType: 'compressed' };
434
+ }
435
+ if (data === null) {
436
+ return { data, dataType: 'null' };
437
+ }
438
+ if (ArrayBuffer.isView(data)) {
439
+ return { data, dataType: 'typed-array' };
440
+ }
441
+ if (data instanceof WEBGLBuffer) {
442
+ return { data: data.handle, dataType: 'buffer' };
443
+ }
444
+ // Raw WebGL handle (not a luma wrapper)
445
+ if (typeof WebGLBuffer !== 'undefined' && data instanceof WebGLBuffer) {
446
+ return { data, dataType: 'buffer' };
447
+ }
448
+ // Assume data is a browser supported object (ImageData, Canvas, ...)
449
+ return { data, dataType: 'browser-object' };
450
+ }
451
+ // HELPER METHODS
452
+ _deduceParameters(opts) {
453
+ const { format, data } = opts;
454
+ let { width, height, dataFormat, type, compressed } = opts;
455
+ // Deduce format and type from format
456
+ const parameters = getWebGLTextureParameters(format);
457
+ dataFormat = dataFormat || parameters.dataFormat;
458
+ type = type || parameters.type;
459
+ compressed = compressed || parameters.compressed;
460
+ ({ width, height } = this._deduceImageSize(data, width, height));
461
+ return { dataFormat, type, compressed, width, height, format, data };
462
+ }
463
+ // eslint-disable-next-line complexity
464
+ _deduceImageSize(data, width, height) {
465
+ let size;
466
+ if (typeof ImageData !== 'undefined' && data instanceof ImageData) {
467
+ size = { width: data.width, height: data.height };
468
+ }
469
+ else if (typeof HTMLImageElement !== 'undefined' && data instanceof HTMLImageElement) {
470
+ size = { width: data.naturalWidth, height: data.naturalHeight };
471
+ }
472
+ else if (typeof HTMLCanvasElement !== 'undefined' && data instanceof HTMLCanvasElement) {
473
+ size = { width: data.width, height: data.height };
474
+ }
475
+ else if (typeof ImageBitmap !== 'undefined' && data instanceof ImageBitmap) {
476
+ size = { width: data.width, height: data.height };
477
+ }
478
+ else if (typeof HTMLVideoElement !== 'undefined' && data instanceof HTMLVideoElement) {
479
+ size = { width: data.videoWidth, height: data.videoHeight };
480
+ }
481
+ else if (!data) {
482
+ size = { width: width >= 0 ? width : 1, height: height >= 0 ? height : 1 };
483
+ }
484
+ else {
485
+ size = { width, height };
486
+ }
487
+ assert(size, 'Could not deduced texture size');
488
+ assert(width === undefined || size.width === width, 'Deduced texture width does not match supplied width');
489
+ assert(height === undefined || size.height === height, 'Deduced texture height does not match supplied height');
490
+ return size;
491
+ }
492
+ // CUBE MAP METHODS
493
+ /* eslint-disable max-statements, max-len */
494
+ async setCubeMapImageData(options) {
495
+ const { gl } = this;
496
+ const { width, height, pixels, data, format = 6408, type = 5121 } = options;
497
+ const imageDataMap = pixels || data;
498
+ // pixel data (imageDataMap) is an Object from Face to Image or Promise.
499
+ // For example:
500
+ // {
501
+ // GL.TEXTURE_CUBE_MAP_POSITIVE_X : Image-or-Promise,
502
+ // GL.TEXTURE_CUBE_MAP_NEGATIVE_X : Image-or-Promise,
503
+ // ... }
504
+ // To provide multiple level-of-details (LODs) this can be Face to Array
505
+ // of Image or Promise, like this
506
+ // {
507
+ // GL.TEXTURE_CUBE_MAP_POSITIVE_X : [Image-or-Promise-LOD-0, Image-or-Promise-LOD-1],
508
+ // GL.TEXTURE_CUBE_MAP_NEGATIVE_X : [Image-or-Promise-LOD-0, Image-or-Promise-LOD-1],
509
+ // ... }
510
+ const resolvedFaces = await Promise.all(WEBGLTexture.FACES.map(face => {
511
+ const facePixels = imageDataMap[face];
512
+ return Promise.all(Array.isArray(facePixels) ? facePixels : [facePixels]);
513
+ }));
514
+ this.bind();
515
+ WEBGLTexture.FACES.forEach((face, index) => {
516
+ if (resolvedFaces[index].length > 1 && this.props.mipmaps !== false) {
517
+ // If the user provides multiple LODs, then automatic mipmap
518
+ // generation generateMipmap() should be disabled to avoid overwritting them.
519
+ log.warn(`${this.id} has mipmap and multiple LODs.`)();
520
+ }
521
+ resolvedFaces[index].forEach((image, lodLevel) => {
522
+ // TODO: adjust width & height for LOD!
523
+ if (width && height) {
524
+ gl.texImage2D(face, lodLevel, format, width, height, 0 /* border*/, format, type, image);
525
+ }
526
+ else {
527
+ gl.texImage2D(face, lodLevel, format, format, type, image);
528
+ }
529
+ });
530
+ });
531
+ this.unbind();
532
+ }
533
+ /** @todo update this method to accept LODs */
534
+ setImageDataForFace(options) {
535
+ const { face, width, height, pixels, data, format = 6408, type = 5121
536
+ // generateMipmap = false // TODO
537
+ } = options;
538
+ const { gl } = this;
539
+ const imageData = pixels || data;
540
+ this.bind();
541
+ if (imageData instanceof Promise) {
542
+ imageData.then(resolvedImageData => this.setImageDataForFace(Object.assign({}, options, {
543
+ face,
544
+ data: resolvedImageData,
545
+ pixels: resolvedImageData
546
+ })));
547
+ }
548
+ else if (this.width || this.height) {
549
+ gl.texImage2D(face, 0, format, width, height, 0 /* border*/, format, type, imageData);
550
+ }
551
+ else {
552
+ gl.texImage2D(face, 0, format, format, type, imageData);
553
+ }
554
+ return this;
555
+ }
556
+ /** Image 3D copies from Typed Array or WebGLBuffer */
557
+ setImageData3D(options) {
558
+ const { level = 0, dataFormat, format, type, // = GL.UNSIGNED_BYTE,
559
+ width, height, depth = 1, offset = 0, data, parameters = {} } = options;
560
+ this.trackDeallocatedMemory('Texture');
561
+ this.gl.bindTexture(this.target, this.handle);
562
+ const webglTextureFormat = getWebGLTextureParameters(format);
563
+ withGLParameters(this.gl, parameters, () => {
564
+ if (ArrayBuffer.isView(data)) {
565
+ this.gl.texImage3D(this.target, level, webglTextureFormat.format, width, height, depth, 0 /* border, must be 0 */, webglTextureFormat.dataFormat, webglTextureFormat.type, // dataType: getWebGL,
566
+ data);
567
+ }
568
+ if (data instanceof WEBGLBuffer) {
569
+ this.gl.bindBuffer(35052, data.handle);
570
+ this.gl.texImage3D(this.target, level, dataFormat, width, height, depth, 0 /* border, must be 0 */, format, type, offset);
571
+ }
572
+ });
573
+ if (data && data.byteLength) {
574
+ this.trackAllocatedMemory(data.byteLength, 'Texture');
575
+ }
576
+ else {
577
+ const bytesPerPixel = getTextureFormatBytesPerPixel(this.props.format);
578
+ this.trackAllocatedMemory(this.width * this.height * this.depth * bytesPerPixel, 'Texture');
579
+ }
580
+ this.loaded = true;
581
+ return this;
582
+ }
583
+ // RESOURCE METHODS
584
+ /**
585
+ * Sets sampler parameters on texture
586
+ */
587
+ _setSamplerParameters(parameters) {
588
+ // NPOT parameters may populate an empty object
589
+ if (isObjectEmpty(parameters)) {
590
+ return;
591
+ }
592
+ logParameters(parameters);
593
+ this.gl.bindTexture(this.target, this.handle);
594
+ for (const [pname, pvalue] of Object.entries(parameters)) {
595
+ const param = Number(pname);
596
+ const value = pvalue;
597
+ // Apparently there are integer/float conversion issues requires two parameter setting functions in JavaScript.
598
+ // For now, pick the float version for parameters specified as GLfloat.
599
+ switch (param) {
600
+ case 33082:
601
+ case 33083:
602
+ this.gl.texParameterf(this.target, param, value);
603
+ break;
604
+ default:
605
+ this.gl.texParameteri(this.target, param, value);
606
+ break;
607
+ }
608
+ }
609
+ this.gl.bindTexture(this.target, null);
272
610
  return;
273
- }
274
-
275
- this.setSubImageData({
276
- data: video,
277
- parameters
278
- });
279
-
280
- if (this.mipmaps) {
281
- this.generateMipmap();
282
- }
283
-
284
- this._video.lastTime = video.currentTime;
285
- }
286
- }
287
-
288
- generateMipmap(params = {}) {
289
- if (this.device.isWebGL1 && isNPOT(this.width, this.height)) {
290
- log.warn("texture: ".concat(this, " is Non-Power-Of-Two, disabling mipmaping"))();
291
- return this;
292
- }
293
-
294
- this.mipmaps = true;
295
- this.gl.bindTexture(this.target, this.handle);
296
- withParameters(this.gl, params, () => {
297
- this.gl.generateMipmap(this.target);
298
- });
299
- this.gl.bindTexture(this.target, null);
300
- return this;
301
- }
302
-
303
- setImageData(options) {
304
- if (this.props.dimension === '3d') {
305
- return this.setImageData3D(options);
306
- }
307
-
308
- this.trackDeallocatedMemory('Texture');
309
- const {
310
- target = this.target,
311
- pixels = null,
312
- level = 0,
313
- format = this.format,
314
- offset = 0,
315
- parameters = {}
316
- } = options;
317
- let {
318
- data = null,
319
- type = this.type,
320
- width = this.width,
321
- height = this.height,
322
- dataFormat = this.dataFormat,
323
- compressed = false
324
- } = options;
325
-
326
- if (!data) {
327
- data = pixels;
328
- }
329
-
330
- ({
331
- type,
332
- dataFormat,
333
- compressed,
334
- width,
335
- height
336
- } = this._deduceParameters({
337
- format: this.props.format,
338
- type,
339
- dataFormat,
340
- compressed,
341
- data,
342
- width,
343
- height
344
- }));
345
- const {
346
- gl
347
- } = this;
348
- gl.bindTexture(this.target, this.handle);
349
- let dataType = null;
350
- ({
351
- data,
352
- dataType
353
- } = this._getDataType({
354
- data,
355
- compressed
356
- }));
357
- let gl2;
358
- withParameters(this.gl, parameters, () => {
359
- switch (dataType) {
360
- case 'null':
361
- gl.texImage2D(target, level, format, width, height, 0, dataFormat, type, data);
362
- break;
363
-
364
- case 'typed-array':
365
- gl.texImage2D(target, level, format, width, height, 0, dataFormat, type, data, offset);
366
- break;
367
-
368
- case 'buffer':
369
- gl2 = this.device.assertWebGL2();
370
- gl2.bindBuffer(GL.PIXEL_UNPACK_BUFFER, data.handle || data);
371
- gl2.texImage2D(target, level, format, width, height, 0, dataFormat, type, offset);
372
- gl2.bindBuffer(GL.PIXEL_UNPACK_BUFFER, null);
373
- break;
374
-
375
- case 'browser-object':
376
- if (this.device.isWebGL2) {
377
- gl.texImage2D(target, level, format, width, height, 0, dataFormat, type, data);
378
- } else {
379
- gl.texImage2D(target, level, format, dataFormat, type, data);
380
- }
381
-
382
- break;
383
-
384
- case 'compressed':
385
- for (const [levelIndex, levelData] of data.entries()) {
386
- gl.compressedTexImage2D(target, levelIndex, levelData.format, levelData.width, levelData.height, 0, levelData.data);
387
- }
388
-
389
- break;
390
-
391
- default:
392
- assert(false, 'Unknown image data type');
393
- }
394
- });
395
-
396
- if (data && data.byteLength) {
397
- this.trackAllocatedMemory(data.byteLength, 'Texture');
398
- } else {
399
- const bytesPerPixel = getTextureFormatBytesPerPixel(this.gl, this.props.format);
400
- this.trackAllocatedMemory(this.width * this.height * bytesPerPixel, 'Texture');
401
- }
402
-
403
- this.loaded = true;
404
- return this;
405
- }
406
-
407
- setSubImageData({
408
- target = this.target,
409
- pixels = null,
410
- data = null,
411
- x = 0,
412
- y = 0,
413
- width = this.width,
414
- height = this.height,
415
- level = 0,
416
- format = this.format,
417
- type = this.type,
418
- dataFormat = this.dataFormat,
419
- compressed = false,
420
- offset = 0,
421
- parameters = {}
422
- }) {
423
- ({
424
- type,
425
- dataFormat,
426
- compressed,
427
- width,
428
- height
429
- } = this._deduceParameters({
430
- format: this.props.format,
431
- type,
432
- dataFormat,
433
- compressed,
434
- data,
435
- width,
436
- height
437
- }));
438
- assert(this.depth === 1, 'texSubImage not supported for 3D textures');
439
-
440
- if (!data) {
441
- data = pixels;
442
- }
443
-
444
- if (data && data.data) {
445
- const ndarray = data;
446
- data = ndarray.data;
447
- width = ndarray.shape[0];
448
- height = ndarray.shape[1];
449
- }
450
-
451
- if (data instanceof WEBGLBuffer) {
452
- data = data.handle;
453
611
  }
454
-
455
- this.gl.bindTexture(this.target, this.handle);
456
- withParameters(this.gl, parameters, () => {
457
- if (compressed) {
458
- this.gl.compressedTexSubImage2D(target, level, x, y, width, height, format, data);
459
- } else if (data === null) {
460
- this.gl.texSubImage2D(target, level, x, y, width, height, dataFormat, type, null);
461
- } else if (ArrayBuffer.isView(data)) {
462
- this.gl.texSubImage2D(target, level, x, y, width, height, dataFormat, type, data, offset);
463
- } else if (typeof WebGLBuffer !== 'undefined' && data instanceof WebGLBuffer) {
464
- const gl2 = this.device.assertWebGL2();
465
- gl2.bindBuffer(GL.PIXEL_UNPACK_BUFFER, data);
466
- gl2.texSubImage2D(target, level, x, y, width, height, dataFormat, type, offset);
467
- gl2.bindBuffer(GL.PIXEL_UNPACK_BUFFER, null);
468
- } else if (this.device.isWebGL2) {
469
- const gl2 = this.device.assertWebGL2();
470
- gl2.texSubImage2D(target, level, x, y, width, height, dataFormat, type, data);
471
- } else {
472
- this.gl.texSubImage2D(target, level, x, y, dataFormat, type, data);
473
- }
474
- });
475
- this.gl.bindTexture(this.target, null);
476
- }
477
-
478
- copyFramebuffer(opts = {}) {
479
- log.error('Texture.copyFramebuffer({...}) is no logner supported, use copyToTexture(source, target, opts})')();
480
- return null;
481
- }
482
-
483
- getActiveUnit() {
484
- return this.gl.getParameter(GL.ACTIVE_TEXTURE) - GL.TEXTURE0;
485
- }
486
-
487
- bind(textureUnit = this.textureUnit) {
488
- const {
489
- gl
490
- } = this;
491
-
492
- if (textureUnit !== undefined) {
493
- this.textureUnit = textureUnit;
494
- gl.activeTexture(gl.TEXTURE0 + textureUnit);
495
- }
496
-
497
- gl.bindTexture(this.target, this.handle);
498
- return textureUnit;
499
- }
500
-
501
- unbind(textureUnit = this.textureUnit) {
502
- const {
503
- gl
504
- } = this;
505
-
506
- if (textureUnit !== undefined) {
507
- this.textureUnit = textureUnit;
508
- gl.activeTexture(gl.TEXTURE0 + textureUnit);
509
- }
510
-
511
- gl.bindTexture(this.target, null);
512
- return textureUnit;
513
- }
514
-
515
- _getDataType({
516
- data,
517
- compressed = false
518
- }) {
519
- if (compressed) {
520
- return {
521
- data,
522
- dataType: 'compressed'
523
- };
524
- }
525
-
526
- if (data === null) {
527
- return {
528
- data,
529
- dataType: 'null'
530
- };
531
- }
532
-
533
- if (ArrayBuffer.isView(data)) {
534
- return {
535
- data,
536
- dataType: 'typed-array'
537
- };
538
- }
539
-
540
- if (data instanceof WEBGLBuffer) {
541
- return {
542
- data: data.handle,
543
- dataType: 'buffer'
544
- };
545
- }
546
-
547
- if (typeof WebGLBuffer !== 'undefined' && data instanceof WebGLBuffer) {
548
- return {
549
- data,
550
- dataType: 'buffer'
551
- };
552
- }
553
-
554
- return {
555
- data,
556
- dataType: 'browser-object'
557
- };
558
- }
559
-
560
- _deduceParameters(opts) {
561
- const {
562
- format,
563
- data
564
- } = opts;
565
- let {
566
- width,
567
- height,
568
- dataFormat,
569
- type,
570
- compressed
571
- } = opts;
572
- const parameters = getWebGLTextureParameters(this.gl, format);
573
- dataFormat = dataFormat || parameters.dataFormat;
574
- type = type || parameters.type;
575
- compressed = compressed || parameters.compressed;
576
- ({
577
- width,
578
- height
579
- } = this._deduceImageSize(data, width, height));
580
- return {
581
- dataFormat,
582
- type,
583
- compressed,
584
- width,
585
- height,
586
- format,
587
- data
588
- };
589
- }
590
-
591
- _deduceImageSize(data, width, height) {
592
- let size;
593
-
594
- if (typeof ImageData !== 'undefined' && data instanceof ImageData) {
595
- size = {
596
- width: data.width,
597
- height: data.height
598
- };
599
- } else if (typeof HTMLImageElement !== 'undefined' && data instanceof HTMLImageElement) {
600
- size = {
601
- width: data.naturalWidth,
602
- height: data.naturalHeight
603
- };
604
- } else if (typeof HTMLCanvasElement !== 'undefined' && data instanceof HTMLCanvasElement) {
605
- size = {
606
- width: data.width,
607
- height: data.height
608
- };
609
- } else if (typeof ImageBitmap !== 'undefined' && data instanceof ImageBitmap) {
610
- size = {
611
- width: data.width,
612
- height: data.height
613
- };
614
- } else if (typeof HTMLVideoElement !== 'undefined' && data instanceof HTMLVideoElement) {
615
- size = {
616
- width: data.videoWidth,
617
- height: data.videoHeight
618
- };
619
- } else if (!data) {
620
- size = {
621
- width: width >= 0 ? width : 1,
622
- height: height >= 0 ? height : 1
623
- };
624
- } else {
625
- size = {
626
- width,
627
- height
628
- };
629
- }
630
-
631
- assert(size, 'Could not deduced texture size');
632
- assert(width === undefined || size.width === width, 'Deduced texture width does not match supplied width');
633
- assert(height === undefined || size.height === height, 'Deduced texture height does not match supplied height');
634
- return size;
635
- }
636
-
637
- async setCubeMapImageData(options) {
638
- const {
639
- gl
640
- } = this;
641
- const {
642
- width,
643
- height,
644
- pixels,
645
- data,
646
- format = GL.RGBA,
647
- type = GL.UNSIGNED_BYTE
648
- } = options;
649
- const imageDataMap = pixels || data;
650
- const resolvedFaces = await Promise.all(WEBGLTexture.FACES.map(face => {
651
- const facePixels = imageDataMap[face];
652
- return Promise.all(Array.isArray(facePixels) ? facePixels : [facePixels]);
653
- }));
654
- this.bind();
655
- WEBGLTexture.FACES.forEach((face, index) => {
656
- if (resolvedFaces[index].length > 1 && this.props.mipmaps !== false) {
657
- log.warn("".concat(this.id, " has mipmap and multiple LODs."))();
658
- }
659
-
660
- resolvedFaces[index].forEach((image, lodLevel) => {
661
- if (width && height) {
662
- gl.texImage2D(face, lodLevel, format, width, height, 0, format, type, image);
663
- } else {
664
- gl.texImage2D(face, lodLevel, format, format, type, image);
665
- }
666
- });
667
- });
668
- this.unbind();
669
- }
670
-
671
- setImageDataForFace(options) {
672
- const {
673
- face,
674
- width,
675
- height,
676
- pixels,
677
- data,
678
- format = GL.RGBA,
679
- type = GL.UNSIGNED_BYTE
680
- } = options;
681
- const {
682
- gl
683
- } = this;
684
- const imageData = pixels || data;
685
- this.bind();
686
-
687
- if (imageData instanceof Promise) {
688
- imageData.then(resolvedImageData => this.setImageDataForFace(Object.assign({}, options, {
689
- face,
690
- data: resolvedImageData,
691
- pixels: resolvedImageData
692
- })));
693
- } else if (this.width || this.height) {
694
- gl.texImage2D(face, 0, format, width, height, 0, format, type, imageData);
695
- } else {
696
- gl.texImage2D(face, 0, format, format, type, imageData);
697
- }
698
-
699
- return this;
700
- }
701
-
702
- setImageData3D(options) {
703
- const {
704
- level = 0,
705
- dataFormat,
706
- format,
707
- type,
708
- width,
709
- height,
710
- depth = 1,
711
- offset = 0,
712
- data,
713
- parameters = {}
714
- } = options;
715
- this.trackDeallocatedMemory('Texture');
716
- this.gl.bindTexture(this.target, this.handle);
717
- const webglTextureFormat = getWebGLTextureParameters(this.gl, format);
718
- withParameters(this.gl, parameters, () => {
719
- if (ArrayBuffer.isView(data)) {
720
- this.gl.texImage3D(this.target, level, webglTextureFormat.format, width, height, depth, 0, webglTextureFormat.dataFormat, webglTextureFormat.type, data);
721
- }
722
-
723
- if (data instanceof WEBGLBuffer) {
724
- this.gl.bindBuffer(GL.PIXEL_UNPACK_BUFFER, data.handle);
725
- this.gl.texImage3D(this.target, level, dataFormat, width, height, depth, 0, format, type, offset);
726
- }
727
- });
728
-
729
- if (data && data.byteLength) {
730
- this.trackAllocatedMemory(data.byteLength, 'Texture');
731
- } else {
732
- const bytesPerPixel = getTextureFormatBytesPerPixel(this.gl, this.props.format);
733
- this.trackAllocatedMemory(this.width * this.height * this.depth * bytesPerPixel, 'Texture');
734
- }
735
-
736
- this.loaded = true;
737
- return this;
738
- }
739
-
740
- _setSamplerParameters(parameters) {
741
- if (this.device.isWebGL1 && isNPOT(this.width, this.height)) {
742
- parameters = updateSamplerParametersForNPOT(parameters);
743
- }
744
-
745
- if (isObjectEmpty(parameters)) {
746
- return;
747
- }
748
-
749
- logParameters(parameters);
750
- this.gl.bindTexture(this.target, this.handle);
751
-
752
- for (const [pname, pvalue] of Object.entries(parameters)) {
753
- const param = Number(pname);
754
- let value = pvalue;
755
-
756
- switch (param) {
757
- case GL.TEXTURE_MIN_LOD:
758
- case GL.TEXTURE_MAX_LOD:
759
- this.gl.texParameterf(this.target, param, value);
760
- break;
761
-
762
- default:
763
- this.gl.texParameteri(this.target, param, value);
764
- break;
765
- }
766
- }
767
-
768
- this.gl.bindTexture(this.target, null);
769
- return this;
770
- }
771
-
772
- _getWebGL1NPOTParameterOverride(pname, value) {
773
- const npot = this.device.isWebGL1 && isNPOT(this.width, this.height);
774
-
775
- if (npot) {
776
- switch (pname) {
777
- case GL.TEXTURE_MIN_FILTER:
778
- if (value !== GL.LINEAR && value !== GL.NEAREST) {
779
- return GL.LINEAR;
780
- }
781
-
782
- break;
783
-
784
- case GL.TEXTURE_WRAP_S:
785
- case GL.TEXTURE_WRAP_T:
786
- return GL.CLAMP_TO_EDGE;
787
-
788
- default:
789
- break;
790
- }
791
- }
792
-
793
- return value;
794
- }
795
-
796
612
  }
797
-
798
- _defineProperty(WEBGLTexture, "FACES", [GL.TEXTURE_CUBE_MAP_POSITIVE_X, GL.TEXTURE_CUBE_MAP_NEGATIVE_X, GL.TEXTURE_CUBE_MAP_POSITIVE_Y, GL.TEXTURE_CUBE_MAP_NEGATIVE_Y, GL.TEXTURE_CUBE_MAP_POSITIVE_Z, GL.TEXTURE_CUBE_MAP_NEGATIVE_Z]);
799
-
613
+ // HELPERS
800
614
  function getWebGLTextureTarget(props) {
801
- switch (props.dimension) {
802
- case '2d':
803
- return GL.TEXTURE_2D;
804
-
805
- case 'cube':
806
- return GL.TEXTURE_CUBE_MAP;
807
-
808
- case '2d-array':
809
- return GL.TEXTURE_2D_ARRAY;
810
-
811
- case '3d':
812
- return GL.TEXTURE_3D;
813
-
814
- case '1d':
815
- case 'cube-array':
816
- default:
817
- throw new Error(props.dimension);
818
- }
819
- }
820
-
821
- function isNPOT(width, height) {
822
- if (!width || !height) {
823
- return false;
824
- }
825
-
826
- return !isPowerOfTwo(width) || !isPowerOfTwo(height);
615
+ switch (props.dimension) {
616
+ // supported in WebGL
617
+ case '2d':
618
+ return 3553;
619
+ case 'cube':
620
+ return 34067;
621
+ // supported in WebGL2
622
+ case '2d-array':
623
+ return 35866;
624
+ case '3d':
625
+ return 32879;
626
+ // not supported in any WebGL version
627
+ case '1d':
628
+ case 'cube-array':
629
+ default:
630
+ throw new Error(props.dimension);
631
+ }
827
632
  }
828
-
829
633
  function logParameters(parameters) {
830
- log.log(1, 'texture sampler parameters', parameters)();
831
-
832
- for (const [pname, pvalue] of Object.entries(parameters)) {}
634
+ log.log(1, 'texture sampler parameters', parameters)();
833
635
  }
834
- //# sourceMappingURL=webgl-texture.js.map