Extension syncing: Introduce a NeedsSync pref
[chromium-blink-merge.git] / gpu / GLES2 / extensions / CHROMIUM / CHROMIUM_copy_texture.txt
blobbe60af22dbbc309713ecfaed153ef25306dbbc0d
1 Name
3     CHROMIUM_copy_texture
5 Name Strings
7     GL_CHROMIUM_copy_texture
9 Version
11     Last Modifed Date: July 16, 2014
13 Dependencies
15     OpenGL ES 2.0 is required.
17     EXT_texture_format_BGRA8888 affects the definition of this extension.
18     ARB_texture_rg affects the definition of this extension.
20 Overview
22     This extension expands on the functionality provided by the
23     glCopyTexImage2D command.  A new function is exported,
24     glCopyTextureCHROMIUM, that performs the same copy operation as
25     glCopyTexImage2D.
27     The extension also supports copying BGRA textures and copying
28     EXTERNAL_OES texture to BGRA texture, which is not explicitly
29     granted by EXT_texture_format_BGRA8888.
31 New Procedures and Functions
33     The command
35         void glCopyTextureCHROMIUM (GLenum target, GLenum source_id,
36                                     GLenum dest_id,
37                                     GLint internal_format, GLenum dest_type,
38                                     GLboolean unpack_flip_y,
39                                     GLboolean unpack_premultiply_alpha,
40                                     GLboolean unpack_unmultiply_alpha)
42     Copies the contents of texture referred to by <source_id> to <dest_id>
43     texture. If <source_id> texture is not defined or has different dimension
44     to <dest_id> texture, define <source_id> texture same to <dest_id> texture.
46     Texture level 0 is copied from the source image to level 0 of the
47     destination texture.
49     The internal format of the destination texture is converted to that
50     specified by <internal_format>. Must be one of the following symbolic
51     constants: GL_RGB, GL_RGBA
52     The internal format of <source_id> texture must be one of the following
53     symbolic constants: GL_R8, GL_ALPHA, GL_LUMINANCE, GL_LUMINANCE_ALPHA,
54     GL_RGB, GL_RGBA, GL_BGRA_EXT
55     When <source_id> texture doens't contain a superset of the component
56     required by <internal_format>, fill the components by following rules.
58                    source format          color components
59              =================================================
60                    GL_ALPHA               (0, 0, 0, A)
61                    GL_R8                  (R, 0, 0, 1)
62                    GL_LUMINANCE           (L, L, L, 1)
63                    GL_LUMINANCE_ALPHA     (L, L, L, A)
64                    GL_RGB                 (R, G, B, 1)
65                    GL_RGBA                (R, G, B, A)
66                    GL_BGRA_EXT            (R, G, B, A)
68     The format type of the destination texture is converted to that specified
69     by <dest_type>.
71     <target> uses the same parameters as TexImage2D.
73     If <flip_y> is true, vertically flip texture image data.
75     If <unpack_premultiply_alpha> and <unpack_unmultiply_alpha> are true,
76     no alpha processing occurs.  This is the equivalent of having neither flag
77     set.
79     INVALID_OPERATION is generated if <internal_format> is not one of the valid formats
80     described above.
82     INVALID_OPERATION is generated if the internal format of <source_id> is not one of
83     formats from the table above.
85     INVALID_VALUE is generated if <target> is not GL_TEXTURE_2D.
87     INVALID_VALUE is generated if <source_id> or <dest_id> are not valid texture
88     objects.
90     INVALID_VALUE is generated if textures corresponding to <dest_id> have not
91     been bound as GL_TEXTURE_2D object.
93     INVALID_VALUE is generated if textures corresponding to <source_id> have not
94     been bound as GL_TEXTURE_2D, GL_TEXTURE_RECTANGLE_ARB or
95     GL_TEXTURE_EXTERNAL_OES objects.
97     INVALID_VALUE is generated if level 0 of the source texture is not defined.
99     The command
101         void glCopySubTextureCHROMIUM (GLenum target, GLenum source_id,
102                                        GLenum dest_id,
103                                        GLint xoffset, GLint yoffset,
104                                        GLint x, GLint y,
105                                        GLsizei width, GLsizei height,
106                                        GLboolean unpack_flip_y,
107                                        GLboolean unpack_premultiply_alpha,
108                                        GLboolean unpack_unmultiply_alpha)
110     Copies the sub contents of texture referred to by <source_id> to <dest_id>
111     texture without redefining <dest_id> texture.
113     See CopyTextureCHROMIUM for the interpretation of the <target>, <flip_y>,
114     <premultiply_alpha>, and <unmultiply_alpha> arguments.
116     <xoffset> and <yoffset> specify a texel offset in the x and y direction
117     respectively within the destination texture.
119     <x> and <y> specify specify a texel offset in the x and y direction
120     respectively within the source texture.
122     <width> specifies the width of the texture subimage.
124     <height> specifies the width of the texture subimage.
126     INVALID_OPERATION is generated if source internal_format and destination
127     internal_format are not one of the valid formats described above.
129     INVALID_VALUE is generated if <target> is not GL_TEXTURE_2D.
131     INVALID_OPERATION is generated if the destination texture has not been
132     defined.
134     INVALID_VALUE is generated if level 0 of the source texture or
135     the destination texture is not defined.
137     INVALID_VALUE is generated if <xoffset> < 0 , or <yoffset> < 0.
139     INVALID_VALUE is generated if (<xoffset> + source_width) > dest_width,
140     or (<yoffset> + source_height) > dest_height.
142 Dependencies on ARB_texture_rg
144     If ARB_texture_rg is not supported:
145      * delete any reference to the R8 format.
147 Errors
149     None.
151 New Tokens
153     None.
155 New State
157     None.
159 Revision History
161     8/1/2011    Documented the extension
162     7/4/2013    Add a new parameter dest_type to glCopyTextureCHROMIUM()
163     16/7/2014   Add GL_TEXTURE_RECTANGLE_ARB as valid source_id target
164     19/6/2015   Add arguments unpack_flip_y, unpack_premultiply_alpha, and
165                 unpack_unmultiply_alpha to both commands.