This feature is not Baseline because it does not work in some of the most widely-used browsers.
Note: This feature is available in Web Workers.
The texSubImage2D() method of the WebGLRenderingContext interface of the WebGL API specifies a two-dimensional sub-rectangle for a texture image.
// WebGL 1: texSubImage2D(target, level, xoffset, yoffset, width, height, format, type, srcData) texSubImage2D(target, level, xoffset, yoffset, format, type, source) // Additionally available in WebGL 2: texSubImage2D(target, level, xoffset, yoffset, width, height, format, type, srcData, srcOffset) texSubImage2D(target, level, xoffset, yoffset, width, height, format, type, source) texSubImage2D(target, level, xoffset, yoffset, width, height, format, type, offset)
targetA GLenum specifying the binding point (target) of the active texture. Possible values:
gl.TEXTURE_2D: A two-dimensional texture.gl.TEXTURE_CUBE_MAP_POSITIVE_X: Positive X face for a cube-mapped texture.gl.TEXTURE_CUBE_MAP_NEGATIVE_X: Negative X face for a cube-mapped texture.gl.TEXTURE_CUBE_MAP_POSITIVE_Y: Positive Y face for a cube-mapped texture.gl.TEXTURE_CUBE_MAP_NEGATIVE_Y: Negative Y face for a cube-mapped texture.gl.TEXTURE_CUBE_MAP_POSITIVE_Z: Positive Z face for a cube-mapped texture.gl.TEXTURE_CUBE_MAP_NEGATIVE_Z: Negative Z face for a cube-mapped texture.levelA GLint specifying the level of detail. Level 0 is the base image level and level n is the n-th mipmap reduction level.
xoffsetA GLint specifying the lower left texel x coordinate of a width-wide by height-wide rectangular subregion of the texture array.
yoffsetA GLint specifying the lower left texel y coordinate of a width-wide by height-wide rectangular subregion of the texture array.
widthA GLsizei specifying the width of the texture in texels.
heightA GLsizei specifying the height of the texture in texels.
formatA GLenum specifying how each integer element in the raw texel data should be interpreted as color components. Possible values:
gl.ALPHA: Discards the red, green and blue components and reads the alpha component.gl.RGB: Discards the alpha components and reads the red, green and blue components.gl.RGBA: Red, green, blue and alpha components are read from the color buffer.gl.LUMINANCE: Each color component is a luminance component, alpha is 1.0.gl.LUMINANCE_ALPHA: Each component is a luminance/alpha component.When using the EXT_sRGB extension:
ext.SRGB_EXText.SRGB_ALPHA_EXTWhen using a WebGL2RenderingContext, the following values are available additionally:
gl.REDgl.RED_INTEGERgl.RGgl.RG_INTEGERgl.RGB_INTEGERgl.RGBA_INTEGERgl.DEPTH_COMPONENTgl.DEPTH_STENCILtypeA GLenum specifying the size of each integer element in the raw texel data. For the combinations of format and type available, see WebGLRenderingContext.texImage2D().
The texture source can be provided in one of three ways: from an ArrayBuffer (possibly shared) using srcData and srcOffset; from a DOM pixel source; or, in WebGL 2, from gl.PIXEL_UNPACK_BUFFER using offset.
srcDataA TypedArray or DataView containing the compressed texture data. Its type must match the type parameter; see WebGLRenderingContext.texImage2D().
srcOffset Optional(WebGL 2 only) An integer specifying the index of srcData to start reading from. Defaults to 0.
sourceRead from a DOM pixel source, which can be one of:
ImageBitmapImageDataHTMLImageElementHTMLCanvasElementHTMLVideoElementOffscreenCanvasVideoFrameIn WebGL 1, the width and height are always inferred from the source. In WebGL 2, they can also be explicitly specified.
offset(WebGL 2 only) A GLintptr specifying the starting address in the buffer bound to gl.PIXEL_UNPACK_BUFFER.
None (undefined).
gl.texSubImage2D(gl.TEXTURE_2D, 0, 0, 0, gl.RGBA, gl.UNSIGNED_BYTE, image);
| Desktop | Mobile | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Opera | Safari | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | WebView Android | WebView on iOS | |
texSubImage2D |
9 | 12 | 4 | 12 | 5.1 | 25 | 4Textures from video elements are not supported. See bug 1884282. |
12 | 8 | 1.5 | 4.4.3 | 8 |
WebGLRenderingContext.createTexture()WebGLRenderingContext.bindTexture()WebGLRenderingContext.texImage2D()WebGLRenderingContext.compressedTexImage2D()WebGLRenderingContext.copyTexImage2D()WebGLRenderingContext.getTexParameter()OES_texture_floatOES_texture_half_floatEXT_sRGBEXT_texture_norm16
© 2005–2025 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/WebGLRenderingContext/texSubImage2D