Professional Documents
Culture Documents
Errors [2.5]
enum GetError( void );
Open GL ES commands are formed from a return type, a name, and optionally a type letter i for 32-bit int, or f for 32-bit float,
as shown by the prototype below:
Texturing [3.7]
RGBA
Internal Components
ALPHA
LUMINANCE
LUMINANCE _ALPHA
R, A
L, A
RGB
R, G, B
R, G, B
RGBA
R, G, B, A
R, G, B, A
format: RGBA
type: UNSIGNED_BYTE
Note: ReadPixels() also accepts a queriable implementationdefined format/type combination, see [4.3.1].
Description
Boolean
Signed binary integer
Unsigned binary integer
Characters making up strings
Signed 2s complement binary integer
Unsigned binary integer
Signed 2s complement binary integer
Unsigned binary integer
Signed 2s complement 16.16 scaled integer
Non-negative binary integer size
Enumerated binary integer value
Signed 2s complement binary integer
Non-negative binary integer size
Bit field
Floating-point value
Floating-point value clamped to [0; 1]
Vertices
Current Vertex State [2.7]
void VertexAttrib{1234}{f}(uint index, T values);
void VertexAttrib{1234}{f}v(uint index, T values);
Vertex data may be sourced from arrays that are stored in application
memory (via a pointer) or faster GPU memory (in a buffer object).
Rasterization [3]
Points [3.3]
Polygons [3.5]
Enable/Disable(CULL_FACE)
void PolygonOffset(float factor, float units);
Enable/Disable(POLYGON_OFFSET_FILL)
www.khronos.org/opengles
Uniform Variables
uint CreateProgram(void);
void AttachShader(uint program, uint shader);
void DetachShader(uint program, uint shader);
void LinkProgram(uint program);
void UseProgram(uint program);
void DeleteProgram(uint program);
Per-Fragment Operations
Scissor Test [4.1.2]
Enable/Disable(SCISSOR_TEST)
void Scissor(int left, int bottom, sizei width, sizei height );
Enable/Disable(STENCIL_TEST)
void StencilFunc(enum func, int ref, uint mask);
void StencilFuncSeparate(enum face, enum func, int ref,
uint mask);
void StencilOp(enum sfail, enum dpfail, enum dppass);
void StencilOpSeparate(enum face, enum sfail, enum dpfail,
enum dppass);
face: FRONT, BACK, FRONT_AND_BACK
sfail, dpfail, and dppass: KEEP, ZERO, REPLACE, INCR, DECR, INVERT,
INCR_WRAP, DECR_WRAP
func: NEVER, ALWAYS, LESS, LEQUAL, EQUAL, GREATER, GEQUAL,
NOTEQUAL
Shader Queries
Framebuffer Objects
Special Functions
Enable/Disable(DEPTH_TEST)
void DepthFunc(enum func);
Blending [4.1.6]
Enable/Disable(BLEND)
(applies to all draw buffers)
void BlendEquation(enum mode);
void BlendEquationSeparate(enum modeRGB,
enum modeAlpha);
mode, modeRGB, and modeAlpha: FUNC_ADD, FUNC_SUBTRACT,
FUNC_REVERSE_SUBTRACT
void Flush(void);
void Finish(void);
Hints [5.2]
Dithering [4.1.7]
Enable/Disable(DITHER)
target: FRAMEBUFFER
attachment: COLOR_ATTACHMENT0, DEPTH_ATTACHMENT,
STENCIL_ATTACHMENT
renderbuffertarget: RENDERBUFFER
target: FRAMEBUFFER
returns: FRAMEBUFFER_COMPLETE or a constant indicating which
value violates framebuffer completeness
target: RENDERBUFFER
pname: RENDERBUFFER_x (where x may be WIDTH, HEIGHT,
RED_SIZE, GREEN_SIZE, BLUE_SIZE, ALPHA_SIZE, DEPTH_SIZE,
STENCIL_SIZE, INTERNAL_FORMAT)
www.khronos.org/opengles
www.khronos.org/opengles
Types [4.1]
Basic Types
Preprocessor [3.4]
Preprocessor Directives
The number sign (#) can be immediately preceded or followed in its line by spaces or horizontal tabs.
#
#define
#undef
#if
#ifdef
#ifndef
#else
#elif
#endif
#error
#pragma
#extension
#version
#line
Examples of Preprocessor Directives
#version 100 in a shader program specifies that the program is written in GLSL ES version 1.00. It is optional. If used, it must occur before
anything else in the program other than whitespace or comments.
#extension extension_name : behavior, where behavior can be require, enable, warn, or disable; and where extension_name is
the extension supported by the compiler
Predefined Macros
__FILE__
Decimal integer constant that is one more than the number of preceding new-lines in the current
source string
Decimal integer constant that says which source string number is currently being processed.
__VERSION__
GL_ES
GL_FRAGMENT_PRECISION_HIGH
__LINE__
void
bool
Boolean
int
signed integer
float
floating scalar
Boolean vector
Qualifiers
sampler2D
access a 2D texture
samplerCube
const
attribute
uniform
varying
struct type-name {
members
} struct-name[];
Arrays
float foo[3];
* structures and blocks can be arrays
* only 1-dimensional arrays supported
* structure members can be arrays
Uniform [4.3.4]
()
2.
[]
()
.
++ --
parenthetical grouping
array subscript
function call & constructor structure
L-R
field or method selector, swizzler
postfix increment and decrement
N/A
3.
++ -+- !
R-L
4.
* /
multiplicative
L-R
5.
+-
additive
L-R
L-R
Varying [4.3.5]
The varying qualifier can be used only with the data types
float, vec2, vec3, vec4, mat2, mat3, mat4, or arrays of these.
Structures cannot be varying. Varying variables are required
to have global scope. Declaration is as follows:
varying vec3 normal;
8.
== !=
equality
L-R
12.
&&
logical and
L-R
13.
^^
logical exclusive or
L-R
14.
||
logical inclusive or
L-R
15.
?:
L-R
16.
=
+= -=
*= /=
assignment
arithmetic assignments
L-R
mat2(float)
mat2(vec2, vec2);
mat2(float, float,
float, float);
17.
sequence
L-R
(262 , 262)
(262 , 262)
Relative 216
(216 , 216)
mediump
(214 , 214)
(214 , 214)
Relative 210
(210 , 210)
(2, 2)
(2 , 2)
Absolute 2
(28 , 28)
lowp
v = v * v;
// vector * vector component-wise
m = m +/- m; // matrix component-wise addition/subtraction
m = m * m;
// linear algebraic multiply
m = v * m;
// row vector * matrix linear algebraic multiply
m = m * v; // matrix * column vector linear algebraic multiply
f = dot(v, v); // vector dot product
v = cross(v, v); // vector cross product
m = matrixCompMult(m, m);
// component-wise multiply
www.khronos.org/opengles
Shader programs use Special Variables to communicate with fixed-function parts of the pipeline.
Output Special Variables may be read back after writing. Input Special Variables are read-only.
All Special Variables have global scope.
Description
transformed vertex position
transformed point size (point rasterization only)
Fragment shaders may write to gl_FragColor or to one or more elements of gl_FragData[], but not both.
The size of the gl_FragData array is given by the built-in constant gl_MaxDrawBuffers.
Inputs:
Variable
Description
Units or coordinate system
mediump vec4 gl_FragCoord;
fragment position within frame buffer
window coordinates
bool
gl_FrontFacing;
fragment belongs to a front-facing primitive
Boolean
mediump int gl_PointCoord;
fragment position within a point (point rasterization only) 0.0 to 1.0 for each component
Outputs:
Variable
Description
Units or coordinate system
mediump vec4 gl_FragColor;
fragment color
RGBA color
mediump vec4 gl_FragData[n]
fragment color for color attachment n
RGBA color
Built-In Functions
Minimum value
8
128
8
0
8
8
16
1
call by value-return
for (;;) { break, continue }
while ( ) { break, continue }
do { break, continue } while ( );
if ( ) { }
if ( ) { } else { }
break, continue, return
discard
// Fragment shader only
void main()
Entry
Sample Program
Vertex Shader
// vertex position
// vertex normal
// texture coordinates
Fragment Shader
precision mediump float;
uniform sampler2D t_reflectance;
uniform vec4
i_ambient;
varying
varying
float
vec2
v_diffuse;
v_texcoord;
OpenGL ES is a registered trademark of Silicon Graphics International, used under license by Khronos Group.
The Khronos Group is an industry consortium creating open standards for the authoring and acceleration of
parallel computing, graphics and dynamic media on a wide variety of platforms and devices.
See www.khronos.org to learn more about the Khronos Group.
See www.khronos.org/opengles to learn more about OpenGL ES.
www.khronos.org/opengles