@luma.gl/webgl 9.1.0-alpha.9 → 9.1.0-beta.11
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.
- package/dist/adapter/converters/device-parameters.d.ts +3 -3
- package/dist/adapter/converters/device-parameters.d.ts.map +1 -1
- package/dist/adapter/converters/device-parameters.js +1 -0
- package/dist/adapter/converters/device-parameters.js.map +1 -0
- package/dist/adapter/converters/sampler-parameters.js +7 -4
- package/dist/adapter/converters/sampler-parameters.js.map +1 -0
- package/dist/adapter/converters/shader-formats.js +1 -0
- package/dist/adapter/converters/shader-formats.js.map +1 -0
- package/dist/adapter/converters/vertex-formats.js +1 -0
- package/dist/adapter/converters/vertex-formats.js.map +1 -0
- package/dist/adapter/converters/webgl-texture-table.d.ts +40 -0
- package/dist/adapter/converters/webgl-texture-table.d.ts.map +1 -0
- package/dist/adapter/converters/webgl-texture-table.js +304 -0
- package/dist/adapter/converters/webgl-texture-table.js.map +1 -0
- package/dist/adapter/device-helpers/webgl-device-features.d.ts.map +1 -1
- package/dist/adapter/device-helpers/webgl-device-features.js +2 -2
- package/dist/adapter/device-helpers/webgl-device-features.js.map +1 -0
- package/dist/adapter/device-helpers/webgl-device-info.js +1 -0
- package/dist/adapter/device-helpers/webgl-device-info.js.map +1 -0
- package/dist/adapter/device-helpers/webgl-device-limits.js +1 -0
- package/dist/adapter/device-helpers/webgl-device-limits.js.map +1 -0
- package/dist/adapter/helpers/decode-webgl-types.js +1 -0
- package/dist/adapter/helpers/decode-webgl-types.js.map +1 -0
- package/dist/adapter/helpers/format-utils.d.ts.map +1 -0
- package/dist/{classic → adapter/helpers}/format-utils.js +7 -0
- package/dist/adapter/helpers/format-utils.js.map +1 -0
- package/dist/adapter/helpers/get-shader-layout.d.ts +1 -1
- package/dist/adapter/helpers/get-shader-layout.d.ts.map +1 -1
- package/dist/adapter/helpers/get-shader-layout.js +5 -4
- package/dist/adapter/helpers/get-shader-layout.js.map +1 -0
- package/dist/adapter/helpers/parse-shader-compiler-log.js +1 -0
- package/dist/adapter/helpers/parse-shader-compiler-log.js.map +1 -0
- package/dist/adapter/helpers/set-uniform.js +1 -0
- package/dist/adapter/helpers/set-uniform.js.map +1 -0
- package/dist/adapter/helpers/typed-array-utils.d.ts.map +1 -0
- package/dist/{classic → adapter/helpers}/typed-array-utils.js +1 -0
- package/dist/adapter/helpers/typed-array-utils.js.map +1 -0
- package/dist/adapter/helpers/webgl-texture-utils.d.ts +96 -25
- package/dist/adapter/helpers/webgl-texture-utils.d.ts.map +1 -1
- package/dist/adapter/helpers/webgl-texture-utils.js +225 -236
- package/dist/adapter/helpers/webgl-texture-utils.js.map +1 -0
- package/dist/adapter/helpers/webgl-topology-utils.js +1 -0
- package/dist/adapter/helpers/webgl-topology-utils.js.map +1 -0
- package/dist/adapter/resources/webgl-buffer.js +1 -0
- package/dist/adapter/resources/webgl-buffer.js.map +1 -0
- package/dist/adapter/resources/webgl-command-buffer.d.ts +59 -2
- package/dist/adapter/resources/webgl-command-buffer.d.ts.map +1 -1
- package/dist/adapter/resources/webgl-command-buffer.js +89 -32
- package/dist/adapter/resources/webgl-command-buffer.js.map +1 -0
- package/dist/adapter/resources/webgl-command-encoder.d.ts.map +1 -1
- package/dist/adapter/resources/webgl-command-encoder.js +4 -0
- package/dist/adapter/resources/webgl-command-encoder.js.map +1 -0
- package/dist/adapter/resources/webgl-external-texture.js +15 -0
- package/dist/adapter/resources/webgl-external-texture.js.map +1 -0
- package/dist/adapter/resources/webgl-framebuffer.d.ts +33 -35
- package/dist/adapter/resources/webgl-framebuffer.d.ts.map +1 -1
- package/dist/adapter/resources/webgl-framebuffer.js +68 -73
- package/dist/adapter/resources/webgl-framebuffer.js.map +1 -0
- package/dist/adapter/resources/webgl-query-set.js +1 -0
- package/dist/adapter/resources/webgl-query-set.js.map +1 -0
- package/dist/adapter/resources/webgl-render-pass.d.ts.map +1 -1
- package/dist/adapter/resources/webgl-render-pass.js +30 -17
- package/dist/adapter/resources/webgl-render-pass.js.map +1 -0
- package/dist/adapter/resources/webgl-render-pipeline.d.ts +2 -4
- package/dist/adapter/resources/webgl-render-pipeline.d.ts.map +1 -1
- package/dist/adapter/resources/webgl-render-pipeline.js +33 -18
- package/dist/adapter/resources/webgl-render-pipeline.js.map +1 -0
- package/dist/adapter/resources/webgl-sampler.js +1 -0
- package/dist/adapter/resources/webgl-sampler.js.map +1 -0
- package/dist/adapter/resources/webgl-shader.d.ts +1 -0
- package/dist/adapter/resources/webgl-shader.d.ts.map +1 -1
- package/dist/adapter/resources/webgl-shader.js +8 -5
- package/dist/adapter/resources/webgl-shader.js.map +1 -0
- package/dist/adapter/resources/webgl-texture-view.js +1 -0
- package/dist/adapter/resources/webgl-texture-view.js.map +1 -0
- package/dist/adapter/resources/webgl-texture.d.ts +32 -20
- package/dist/adapter/resources/webgl-texture.d.ts.map +1 -1
- package/dist/adapter/resources/webgl-texture.js +158 -218
- package/dist/adapter/resources/webgl-texture.js.map +1 -0
- package/dist/adapter/resources/webgl-transform-feedback.js +1 -0
- package/dist/adapter/resources/webgl-transform-feedback.js.map +1 -0
- package/dist/adapter/resources/webgl-vertex-array.js +1 -0
- package/dist/adapter/resources/webgl-vertex-array.js.map +1 -0
- package/dist/adapter/webgl-adapter.d.ts.map +1 -1
- package/dist/adapter/webgl-adapter.js +5 -10
- package/dist/adapter/webgl-adapter.js.map +1 -0
- package/dist/adapter/webgl-canvas-context.d.ts +1 -0
- package/dist/adapter/webgl-canvas-context.d.ts.map +1 -1
- package/dist/adapter/webgl-canvas-context.js +4 -0
- package/dist/adapter/webgl-canvas-context.js.map +1 -0
- package/dist/adapter/webgl-device.d.ts +11 -14
- package/dist/adapter/webgl-device.d.ts.map +1 -1
- package/dist/adapter/webgl-device.js +60 -39
- package/dist/adapter/webgl-device.js.map +1 -0
- package/dist/context/debug/spector-types.js +2 -1
- package/dist/context/debug/spector-types.js.map +1 -0
- package/dist/context/debug/spector.d.ts +5 -5
- package/dist/context/debug/spector.d.ts.map +1 -1
- package/dist/context/debug/spector.js +7 -6
- package/dist/context/debug/spector.js.map +1 -0
- package/dist/context/debug/webgl-developer-tools.d.ts +2 -3
- package/dist/context/debug/webgl-developer-tools.d.ts.map +1 -1
- package/dist/context/debug/webgl-developer-tools.js +7 -19
- package/dist/context/debug/webgl-developer-tools.js.map +1 -0
- package/dist/context/helpers/create-browser-context.d.ts +6 -22
- package/dist/context/helpers/create-browser-context.d.ts.map +1 -1
- package/dist/context/helpers/create-browser-context.js +41 -32
- package/dist/context/helpers/create-browser-context.js.map +1 -0
- package/dist/context/helpers/webgl-context-data.js +1 -0
- package/dist/context/helpers/webgl-context-data.js.map +1 -0
- package/dist/context/helpers/webgl-extensions.js +1 -0
- package/dist/context/helpers/webgl-extensions.js.map +1 -0
- package/dist/context/parameters/unified-parameter-api.js +1 -0
- package/dist/context/parameters/unified-parameter-api.js.map +1 -0
- package/dist/context/parameters/webgl-parameter-tables.d.ts +1 -1
- package/dist/context/parameters/webgl-parameter-tables.d.ts.map +1 -1
- package/dist/context/parameters/webgl-parameter-tables.js +3 -2
- package/dist/context/parameters/webgl-parameter-tables.js.map +1 -0
- package/dist/context/polyfills/polyfill-webgl1-extensions.js +1 -0
- package/dist/context/polyfills/polyfill-webgl1-extensions.js.map +1 -0
- package/dist/context/state-tracker/deep-array-equal.js +1 -0
- package/dist/context/state-tracker/deep-array-equal.js.map +1 -0
- package/dist/context/state-tracker/webgl-state-tracker.js +1 -0
- package/dist/context/state-tracker/webgl-state-tracker.js.map +1 -0
- package/dist/context/state-tracker/with-parameters.js +1 -0
- package/dist/context/state-tracker/with-parameters.js.map +1 -0
- package/dist/deprecated/accessor.d.ts.map +1 -0
- package/dist/{classic → deprecated}/accessor.js +37 -1
- package/dist/deprecated/accessor.js.map +1 -0
- package/dist/dist.dev.js +2217 -2366
- package/dist/dist.min.js +2 -2
- package/dist/index.cjs +2098 -2240
- package/dist/index.cjs.map +4 -4
- package/dist/index.d.ts +2 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -4
- package/dist/index.js.map +1 -0
- package/dist/types.js +1 -0
- package/dist/types.js.map +1 -0
- package/dist/utils/fill-array.d.ts +4 -4
- package/dist/utils/fill-array.d.ts.map +1 -1
- package/dist/utils/fill-array.js +1 -0
- package/dist/utils/fill-array.js.map +1 -0
- package/dist/utils/load-script.js +1 -0
- package/dist/utils/load-script.js.map +1 -0
- package/dist/utils/split-uniforms-and-bindings.d.ts +1 -1
- package/dist/utils/split-uniforms-and-bindings.d.ts.map +1 -1
- package/dist/utils/split-uniforms-and-bindings.js +1 -0
- package/dist/utils/split-uniforms-and-bindings.js.map +1 -0
- package/dist/utils/uid.js +1 -0
- package/dist/utils/uid.js.map +1 -0
- package/package.json +5 -5
- package/src/adapter/converters/device-parameters.ts +3 -3
- package/src/adapter/converters/sampler-parameters.ts +6 -4
- package/src/adapter/converters/webgl-texture-table.ts +404 -0
- package/src/adapter/device-helpers/webgl-device-features.ts +5 -2
- package/src/{classic → adapter/helpers}/format-utils.ts +6 -0
- package/src/adapter/helpers/get-shader-layout.ts +7 -4
- package/src/adapter/helpers/webgl-texture-utils.ts +400 -57
- package/src/adapter/resources/webgl-command-buffer.ts +125 -41
- package/src/adapter/resources/webgl-command-encoder.ts +6 -0
- package/src/adapter/resources/webgl-external-texture.ts +14 -0
- package/src/adapter/resources/webgl-framebuffer.ts +77 -83
- package/src/adapter/resources/webgl-render-pass.ts +52 -41
- package/src/adapter/resources/webgl-render-pipeline.ts +44 -21
- package/src/adapter/resources/webgl-shader.ts +8 -6
- package/src/adapter/resources/webgl-texture.ts +183 -250
- package/src/adapter/webgl-adapter.ts +4 -12
- package/src/adapter/webgl-canvas-context.ts +4 -0
- package/src/adapter/webgl-device.ts +100 -72
- package/src/context/debug/spector-types.ts +1 -1
- package/src/context/debug/spector.ts +11 -11
- package/src/context/debug/webgl-developer-tools.ts +8 -31
- package/src/context/helpers/create-browser-context.ts +53 -63
- package/src/context/parameters/webgl-parameter-tables.ts +2 -2
- package/src/{classic → deprecated}/accessor.ts +44 -3
- package/src/index.ts +2 -5
- package/src/utils/fill-array.ts +4 -4
- package/src/utils/split-uniforms-and-bindings.ts +3 -3
- package/dist/adapter/converters/texture-formats.d.ts +0 -83
- package/dist/adapter/converters/texture-formats.d.ts.map +0 -1
- package/dist/adapter/converters/texture-formats.js +0 -511
- package/dist/classic/accessor.d.ts.map +0 -1
- package/dist/classic/clear.d.ts +0 -22
- package/dist/classic/clear.d.ts.map +0 -1
- package/dist/classic/clear.js +0 -86
- package/dist/classic/copy-and-blit.d.ts +0 -64
- package/dist/classic/copy-and-blit.d.ts.map +0 -1
- package/dist/classic/copy-and-blit.js +0 -194
- package/dist/classic/format-utils.d.ts.map +0 -1
- package/dist/classic/typed-array-utils.d.ts.map +0 -1
- package/src/adapter/converters/texture-formats.ts +0 -657
- package/src/classic/clear.ts +0 -115
- package/src/classic/copy-and-blit.ts +0 -323
- /package/dist/{classic → adapter/helpers}/format-utils.d.ts +0 -0
- /package/dist/{classic → adapter/helpers}/typed-array-utils.d.ts +0 -0
- /package/dist/{classic → deprecated}/accessor.d.ts +0 -0
- /package/src/{classic → adapter/helpers}/typed-array-utils.ts +0 -0
package/src/classic/clear.ts
DELETED
|
@@ -1,115 +0,0 @@
|
|
|
1
|
-
// luma.gl
|
|
2
|
-
// SPDX-License-Identifier: MIT
|
|
3
|
-
// Copyright (c) vis.gl contributors
|
|
4
|
-
|
|
5
|
-
import {Device, Framebuffer} from '@luma.gl/core';
|
|
6
|
-
import {WebGLDevice} from '../adapter/webgl-device';
|
|
7
|
-
import {withGLParameters} from '../context/state-tracker/with-parameters';
|
|
8
|
-
|
|
9
|
-
// Should collapse during minification
|
|
10
|
-
const GL_DEPTH_BUFFER_BIT = 0x00000100;
|
|
11
|
-
const GL_STENCIL_BUFFER_BIT = 0x00000400;
|
|
12
|
-
const GL_COLOR_BUFFER_BIT = 0x00004000;
|
|
13
|
-
|
|
14
|
-
const GL_COLOR = 0x1800;
|
|
15
|
-
const GL_DEPTH = 0x1801;
|
|
16
|
-
const GL_STENCIL = 0x1802;
|
|
17
|
-
const GL_DEPTH_STENCIL = 0x84f9;
|
|
18
|
-
|
|
19
|
-
/**
|
|
20
|
-
* Optionally clears depth, color and stencil buffers
|
|
21
|
-
* @deprecated Set clear color when creating a RenderPass.
|
|
22
|
-
*/
|
|
23
|
-
export function clear(
|
|
24
|
-
device: Device,
|
|
25
|
-
options?: {framebuffer?: Framebuffer; color?: any; depth?: any; stencil?: any}
|
|
26
|
-
): void {
|
|
27
|
-
const {framebuffer = null, color = null, depth = null, stencil = null} = options || {};
|
|
28
|
-
const parameters: any = {};
|
|
29
|
-
|
|
30
|
-
if (framebuffer) {
|
|
31
|
-
parameters.framebuffer = framebuffer;
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
let clearFlags = 0;
|
|
35
|
-
|
|
36
|
-
if (color) {
|
|
37
|
-
clearFlags |= GL_COLOR_BUFFER_BIT;
|
|
38
|
-
if (color !== true) {
|
|
39
|
-
parameters.clearColor = color;
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
if (depth) {
|
|
44
|
-
clearFlags |= GL_DEPTH_BUFFER_BIT;
|
|
45
|
-
if (depth !== true) {
|
|
46
|
-
parameters.clearDepth = depth;
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
if (stencil) {
|
|
51
|
-
clearFlags |= GL_STENCIL_BUFFER_BIT;
|
|
52
|
-
if (depth !== true) {
|
|
53
|
-
parameters.clearStencil = depth;
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
// assert(clearFlags !== 0, ERR_ARGUMENTS);
|
|
58
|
-
|
|
59
|
-
// Temporarily set any clear "colors" and call clear
|
|
60
|
-
const gl = (device as WebGLDevice).gl;
|
|
61
|
-
withGLParameters(gl, parameters, () => {
|
|
62
|
-
gl.clear(clearFlags);
|
|
63
|
-
});
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
/**
|
|
67
|
-
* WebGL2 - clear a specific drawing buffer
|
|
68
|
-
* @deprecated Set clear color when creating a RenderPass
|
|
69
|
-
*/
|
|
70
|
-
export function clearBuffer(
|
|
71
|
-
device: Device,
|
|
72
|
-
options?: {framebuffer?: Framebuffer; buffer?: any; drawBuffer?: any; value?: any}
|
|
73
|
-
) {
|
|
74
|
-
const {
|
|
75
|
-
framebuffer = null,
|
|
76
|
-
buffer = GL_COLOR,
|
|
77
|
-
drawBuffer = 0,
|
|
78
|
-
value = [0, 0, 0, 0]
|
|
79
|
-
} = options || {};
|
|
80
|
-
const gl = (device as WebGLDevice).gl;
|
|
81
|
-
withGLParameters(gl, {framebuffer}, () => {
|
|
82
|
-
// Method selection per OpenGL ES 3 docs
|
|
83
|
-
switch (buffer) {
|
|
84
|
-
case GL_COLOR:
|
|
85
|
-
switch (value.constructor) {
|
|
86
|
-
case Int32Array:
|
|
87
|
-
gl.clearBufferiv(buffer, drawBuffer, value);
|
|
88
|
-
break;
|
|
89
|
-
case Uint32Array:
|
|
90
|
-
gl.clearBufferuiv(buffer, drawBuffer, value);
|
|
91
|
-
break;
|
|
92
|
-
case Float32Array:
|
|
93
|
-
default:
|
|
94
|
-
gl.clearBufferfv(buffer, drawBuffer, value);
|
|
95
|
-
}
|
|
96
|
-
break;
|
|
97
|
-
|
|
98
|
-
case GL_DEPTH:
|
|
99
|
-
gl.clearBufferfv(GL_DEPTH, 0, [value]);
|
|
100
|
-
break;
|
|
101
|
-
|
|
102
|
-
case GL_STENCIL:
|
|
103
|
-
gl.clearBufferiv(GL_STENCIL, 0, [value]);
|
|
104
|
-
break;
|
|
105
|
-
|
|
106
|
-
case GL_DEPTH_STENCIL:
|
|
107
|
-
const [depth, stencil] = value;
|
|
108
|
-
gl.clearBufferfi(GL_DEPTH_STENCIL, 0, depth, stencil);
|
|
109
|
-
break;
|
|
110
|
-
|
|
111
|
-
default:
|
|
112
|
-
// assert(false, ERR_ARGUMENTS);
|
|
113
|
-
}
|
|
114
|
-
});
|
|
115
|
-
}
|
|
@@ -1,323 +0,0 @@
|
|
|
1
|
-
// luma.gl
|
|
2
|
-
// SPDX-License-Identifier: MIT
|
|
3
|
-
// Copyright (c) vis.gl contributors
|
|
4
|
-
|
|
5
|
-
import {Buffer, Texture, Framebuffer, FramebufferProps} from '@luma.gl/core';
|
|
6
|
-
import {GL} from '@luma.gl/constants';
|
|
7
|
-
|
|
8
|
-
import {WEBGLFramebuffer} from '../adapter/resources/webgl-framebuffer';
|
|
9
|
-
import {getGLTypeFromTypedArray, getTypedArrayFromGLType} from './typed-array-utils';
|
|
10
|
-
import {glFormatToComponents, glTypeToBytes} from './format-utils';
|
|
11
|
-
import {WEBGLBuffer} from '../adapter/resources/webgl-buffer';
|
|
12
|
-
import {WEBGLTexture} from '../adapter/resources/webgl-texture';
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
* Copies data from a type or a Texture object into ArrayBuffer object.
|
|
16
|
-
* App can provide targetPixelArray or have it auto allocated by this method
|
|
17
|
-
* newly allocated by this method unless provided by app.
|
|
18
|
-
* @deprecated Use CommandEncoder.copyTextureToBuffer and Buffer.read
|
|
19
|
-
* @note Slow requires roundtrip to GPU
|
|
20
|
-
*
|
|
21
|
-
* @param source
|
|
22
|
-
* @param options
|
|
23
|
-
* @returns pixel array,
|
|
24
|
-
*/
|
|
25
|
-
export function readPixelsToArray(
|
|
26
|
-
source: Framebuffer | Texture,
|
|
27
|
-
options?: {
|
|
28
|
-
sourceX?: number;
|
|
29
|
-
sourceY?: number;
|
|
30
|
-
sourceFormat?: number;
|
|
31
|
-
sourceAttachment?: number;
|
|
32
|
-
target?: Uint8Array | Uint16Array | Float32Array;
|
|
33
|
-
// following parameters are auto deduced if not provided
|
|
34
|
-
sourceWidth?: number;
|
|
35
|
-
sourceHeight?: number;
|
|
36
|
-
sourceDepth?: number;
|
|
37
|
-
sourceType?: number;
|
|
38
|
-
}
|
|
39
|
-
): Uint8Array | Uint16Array | Float32Array {
|
|
40
|
-
const {
|
|
41
|
-
sourceX = 0,
|
|
42
|
-
sourceY = 0,
|
|
43
|
-
sourceAttachment = GL.COLOR_ATTACHMENT0 // TODO - support gl.readBuffer
|
|
44
|
-
} = options || {};
|
|
45
|
-
let {
|
|
46
|
-
target = null,
|
|
47
|
-
// following parameters are auto deduced if not provided
|
|
48
|
-
sourceWidth,
|
|
49
|
-
sourceHeight,
|
|
50
|
-
sourceDepth,
|
|
51
|
-
sourceFormat,
|
|
52
|
-
sourceType
|
|
53
|
-
} = options || {};
|
|
54
|
-
|
|
55
|
-
const {framebuffer, deleteFramebuffer} = getFramebuffer(source);
|
|
56
|
-
// assert(framebuffer);
|
|
57
|
-
const {gl, handle} = framebuffer;
|
|
58
|
-
const attachment = sourceAttachment - GL.COLOR_ATTACHMENT0;
|
|
59
|
-
|
|
60
|
-
sourceWidth ||= framebuffer.width;
|
|
61
|
-
sourceHeight ||= framebuffer.height;
|
|
62
|
-
|
|
63
|
-
// TODO - Set and unset gl.readBuffer
|
|
64
|
-
// if (sourceAttachment === GL.COLOR_ATTACHMENT0 && handle === null) {
|
|
65
|
-
// sourceAttachment = GL.FRONT;
|
|
66
|
-
// }
|
|
67
|
-
|
|
68
|
-
sourceDepth = framebuffer.colorAttachments[attachment]?.texture?.depth || 1;
|
|
69
|
-
|
|
70
|
-
sourceFormat ||= framebuffer.colorAttachments[attachment]?.texture?.glFormat || GL.RGBA;
|
|
71
|
-
// Deduce the type from color attachment if not provided.
|
|
72
|
-
sourceType ||= framebuffer.colorAttachments[attachment]?.texture?.glType || GL.UNSIGNED_BYTE;
|
|
73
|
-
|
|
74
|
-
// Deduce type and allocated pixelArray if needed
|
|
75
|
-
target = getPixelArray(target, sourceType, sourceFormat, sourceWidth, sourceHeight, sourceDepth);
|
|
76
|
-
|
|
77
|
-
// Pixel array available, if necessary, deduce type from it.
|
|
78
|
-
sourceType = sourceType || getGLTypeFromTypedArray(target);
|
|
79
|
-
|
|
80
|
-
const prevHandle = gl.bindFramebuffer(GL.FRAMEBUFFER, handle);
|
|
81
|
-
gl.readPixels(sourceX, sourceY, sourceWidth, sourceHeight, sourceFormat, sourceType, target);
|
|
82
|
-
// @ts-expect-error
|
|
83
|
-
gl.bindFramebuffer(GL.FRAMEBUFFER, prevHandle || null);
|
|
84
|
-
if (deleteFramebuffer) {
|
|
85
|
-
framebuffer.destroy();
|
|
86
|
-
}
|
|
87
|
-
return target;
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
/**
|
|
91
|
-
* Copies data from a Framebuffer or a Texture object into a Buffer object.
|
|
92
|
-
* NOTE: doesn't wait for copy to be complete, it programs GPU to perform a DMA transffer.
|
|
93
|
-
* @deprecated Use CommandEncoder
|
|
94
|
-
* @param source
|
|
95
|
-
* @param options
|
|
96
|
-
*/
|
|
97
|
-
export function readPixelsToBuffer(
|
|
98
|
-
source: Framebuffer | Texture,
|
|
99
|
-
options?: {
|
|
100
|
-
sourceX?: number;
|
|
101
|
-
sourceY?: number;
|
|
102
|
-
sourceFormat?: number;
|
|
103
|
-
target?: Buffer; // A new Buffer object is created when not provided.
|
|
104
|
-
targetByteOffset?: number; // byte offset in buffer object
|
|
105
|
-
// following parameters are auto deduced if not provided
|
|
106
|
-
sourceWidth?: number;
|
|
107
|
-
sourceHeight?: number;
|
|
108
|
-
sourceType?: number;
|
|
109
|
-
}
|
|
110
|
-
): WEBGLBuffer {
|
|
111
|
-
const {
|
|
112
|
-
target,
|
|
113
|
-
sourceX = 0,
|
|
114
|
-
sourceY = 0,
|
|
115
|
-
sourceFormat = GL.RGBA,
|
|
116
|
-
targetByteOffset = 0
|
|
117
|
-
} = options || {};
|
|
118
|
-
// following parameters are auto deduced if not provided
|
|
119
|
-
let {sourceWidth, sourceHeight, sourceType} = options || {};
|
|
120
|
-
const {framebuffer, deleteFramebuffer} = getFramebuffer(source);
|
|
121
|
-
// assert(framebuffer);
|
|
122
|
-
sourceWidth = sourceWidth || framebuffer.width;
|
|
123
|
-
sourceHeight = sourceHeight || framebuffer.height;
|
|
124
|
-
|
|
125
|
-
// Asynchronous read (PIXEL_PACK_BUFFER) is WebGL2 only feature
|
|
126
|
-
const webglFramebuffer = framebuffer;
|
|
127
|
-
|
|
128
|
-
// deduce type if not available.
|
|
129
|
-
sourceType = sourceType || GL.UNSIGNED_BYTE;
|
|
130
|
-
|
|
131
|
-
let webglBufferTarget = target as unknown as WEBGLBuffer | undefined;
|
|
132
|
-
if (!webglBufferTarget) {
|
|
133
|
-
// Create new buffer with enough size
|
|
134
|
-
const components = glFormatToComponents(sourceFormat);
|
|
135
|
-
const byteCount = glTypeToBytes(sourceType);
|
|
136
|
-
const byteLength = targetByteOffset + sourceWidth * sourceHeight * components * byteCount;
|
|
137
|
-
webglBufferTarget = webglFramebuffer.device.createBuffer({byteLength});
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
// TODO(donmccurdy): Do we have tests to confirm this is working?
|
|
141
|
-
const commandEncoder = source.device.createCommandEncoder();
|
|
142
|
-
commandEncoder.copyTextureToBuffer({
|
|
143
|
-
source: source as Texture,
|
|
144
|
-
width: sourceWidth,
|
|
145
|
-
height: sourceHeight,
|
|
146
|
-
origin: [sourceX, sourceY],
|
|
147
|
-
destination: webglBufferTarget,
|
|
148
|
-
byteOffset: targetByteOffset
|
|
149
|
-
});
|
|
150
|
-
commandEncoder.destroy();
|
|
151
|
-
|
|
152
|
-
if (deleteFramebuffer) {
|
|
153
|
-
framebuffer.destroy();
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
return webglBufferTarget;
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
/**
|
|
160
|
-
* Copy a rectangle from a Framebuffer or Texture object into a texture (at an offset)
|
|
161
|
-
* @deprecated Use CommandEncoder
|
|
162
|
-
*/
|
|
163
|
-
// eslint-disable-next-line complexity, max-statements
|
|
164
|
-
export function copyToTexture(
|
|
165
|
-
source: Framebuffer | Texture,
|
|
166
|
-
target: Texture | GL,
|
|
167
|
-
options?: {
|
|
168
|
-
sourceX?: number;
|
|
169
|
-
sourceY?: number;
|
|
170
|
-
|
|
171
|
-
targetX?: number;
|
|
172
|
-
targetY?: number;
|
|
173
|
-
targetZ?: number;
|
|
174
|
-
targetMipmaplevel?: number;
|
|
175
|
-
targetInternalFormat?: number;
|
|
176
|
-
|
|
177
|
-
width?: number; // defaults to target width
|
|
178
|
-
height?: number; // defaults to target height
|
|
179
|
-
}
|
|
180
|
-
): Texture {
|
|
181
|
-
const {
|
|
182
|
-
sourceX = 0,
|
|
183
|
-
sourceY = 0,
|
|
184
|
-
// attachment = GL.COLOR_ATTACHMENT0, // TODO - support gl.readBuffer
|
|
185
|
-
targetMipmaplevel = 0,
|
|
186
|
-
targetInternalFormat = GL.RGBA
|
|
187
|
-
} = options || {};
|
|
188
|
-
let {
|
|
189
|
-
targetX,
|
|
190
|
-
targetY,
|
|
191
|
-
targetZ,
|
|
192
|
-
width, // defaults to target width
|
|
193
|
-
height // defaults to target height
|
|
194
|
-
} = options || {};
|
|
195
|
-
|
|
196
|
-
const {framebuffer, deleteFramebuffer} = getFramebuffer(source);
|
|
197
|
-
// assert(framebuffer);
|
|
198
|
-
const webglFramebuffer = framebuffer;
|
|
199
|
-
const {device, handle} = webglFramebuffer;
|
|
200
|
-
const isSubCopy =
|
|
201
|
-
typeof targetX !== 'undefined' ||
|
|
202
|
-
typeof targetY !== 'undefined' ||
|
|
203
|
-
typeof targetZ !== 'undefined';
|
|
204
|
-
targetX = targetX || 0;
|
|
205
|
-
targetY = targetY || 0;
|
|
206
|
-
targetZ = targetZ || 0;
|
|
207
|
-
const prevHandle = device.gl.bindFramebuffer(GL.FRAMEBUFFER, handle);
|
|
208
|
-
// TODO - support gl.readBuffer (WebGL2 only)
|
|
209
|
-
// const prevBuffer = gl.readBuffer(attachment);
|
|
210
|
-
// assert(target);
|
|
211
|
-
let texture: WEBGLTexture | null = null;
|
|
212
|
-
let textureTarget: GL;
|
|
213
|
-
if (target instanceof WEBGLTexture) {
|
|
214
|
-
texture = target;
|
|
215
|
-
width = Number.isFinite(width) ? width : texture.width;
|
|
216
|
-
height = Number.isFinite(height) ? height : texture.height;
|
|
217
|
-
texture?.bind(0);
|
|
218
|
-
// @ts-ignore
|
|
219
|
-
textureTarget = texture.target;
|
|
220
|
-
} else {
|
|
221
|
-
// @ts-ignore
|
|
222
|
-
textureTarget = target;
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
if (!isSubCopy) {
|
|
226
|
-
device.gl.copyTexImage2D(
|
|
227
|
-
textureTarget,
|
|
228
|
-
targetMipmaplevel,
|
|
229
|
-
targetInternalFormat,
|
|
230
|
-
sourceX,
|
|
231
|
-
sourceY,
|
|
232
|
-
width,
|
|
233
|
-
height,
|
|
234
|
-
0 /* border must be 0 */
|
|
235
|
-
);
|
|
236
|
-
} else {
|
|
237
|
-
switch (textureTarget) {
|
|
238
|
-
case GL.TEXTURE_2D:
|
|
239
|
-
case GL.TEXTURE_CUBE_MAP:
|
|
240
|
-
device.gl.copyTexSubImage2D(
|
|
241
|
-
textureTarget,
|
|
242
|
-
targetMipmaplevel,
|
|
243
|
-
targetX,
|
|
244
|
-
targetY,
|
|
245
|
-
sourceX,
|
|
246
|
-
sourceY,
|
|
247
|
-
width,
|
|
248
|
-
height
|
|
249
|
-
);
|
|
250
|
-
break;
|
|
251
|
-
case GL.TEXTURE_2D_ARRAY:
|
|
252
|
-
case GL.TEXTURE_3D:
|
|
253
|
-
device.gl.copyTexSubImage3D(
|
|
254
|
-
textureTarget,
|
|
255
|
-
targetMipmaplevel,
|
|
256
|
-
targetX,
|
|
257
|
-
targetY,
|
|
258
|
-
targetZ,
|
|
259
|
-
sourceX,
|
|
260
|
-
sourceY,
|
|
261
|
-
width,
|
|
262
|
-
height
|
|
263
|
-
);
|
|
264
|
-
break;
|
|
265
|
-
default:
|
|
266
|
-
}
|
|
267
|
-
}
|
|
268
|
-
if (texture) {
|
|
269
|
-
texture.unbind();
|
|
270
|
-
}
|
|
271
|
-
// @ts-expect-error
|
|
272
|
-
device.gl.bindFramebuffer(GL.FRAMEBUFFER, prevHandle || null);
|
|
273
|
-
if (deleteFramebuffer) {
|
|
274
|
-
framebuffer.destroy();
|
|
275
|
-
}
|
|
276
|
-
return texture;
|
|
277
|
-
}
|
|
278
|
-
|
|
279
|
-
function getFramebuffer(source: Texture | Framebuffer): {
|
|
280
|
-
framebuffer: WEBGLFramebuffer;
|
|
281
|
-
deleteFramebuffer: boolean;
|
|
282
|
-
} {
|
|
283
|
-
if (!(source instanceof Framebuffer)) {
|
|
284
|
-
return {framebuffer: toFramebuffer(source), deleteFramebuffer: true};
|
|
285
|
-
}
|
|
286
|
-
return {framebuffer: source as WEBGLFramebuffer, deleteFramebuffer: false};
|
|
287
|
-
}
|
|
288
|
-
|
|
289
|
-
/**
|
|
290
|
-
* Wraps a given texture into a framebuffer object, that can be further used
|
|
291
|
-
* to read data from the texture object.
|
|
292
|
-
*/
|
|
293
|
-
export function toFramebuffer(texture: Texture, props?: FramebufferProps): WEBGLFramebuffer {
|
|
294
|
-
const {device, width, height, id} = texture;
|
|
295
|
-
const framebuffer = device.createFramebuffer({
|
|
296
|
-
...props,
|
|
297
|
-
id: `framebuffer-for-${id}`,
|
|
298
|
-
width,
|
|
299
|
-
height,
|
|
300
|
-
colorAttachments: [texture]
|
|
301
|
-
});
|
|
302
|
-
return framebuffer as WEBGLFramebuffer;
|
|
303
|
-
}
|
|
304
|
-
|
|
305
|
-
// eslint-disable-next-line max-params
|
|
306
|
-
function getPixelArray(
|
|
307
|
-
pixelArray,
|
|
308
|
-
type,
|
|
309
|
-
format,
|
|
310
|
-
width: number,
|
|
311
|
-
height: number,
|
|
312
|
-
depth?: number
|
|
313
|
-
): Uint8Array | Uint16Array | Float32Array {
|
|
314
|
-
if (pixelArray) {
|
|
315
|
-
return pixelArray;
|
|
316
|
-
}
|
|
317
|
-
// Allocate pixel array if not already available, using supplied type
|
|
318
|
-
type = type || GL.UNSIGNED_BYTE;
|
|
319
|
-
const ArrayType = getTypedArrayFromGLType(type, {clamped: false});
|
|
320
|
-
const components = glFormatToComponents(format);
|
|
321
|
-
// TODO - check for composite type (components = 1).
|
|
322
|
-
return new ArrayType(width * height * components) as Uint8Array | Uint16Array | Float32Array;
|
|
323
|
-
}
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|