Manual Reference Pages  - GLTEXENV (3G)

NAME

glTexEnvf, glTexEnvi, glTexEnvfv, glTexEnviv - set texture environment parameters

CONTENTS

C Specification
Parameters
C Specification
Parameters
Description
Notes
Associated Gets
See Also

C SPECIFICATION

void glTexEnvf( GLenum target,

              GLenum pname,
              GLfloat param )

void glTexEnvi( GLenum target,

              GLenum pname,
              GLint param )

PARAMETERS

target Specifies a texture environment. Must be  GL_TEXTURE_ENV.
pname Specifies the symbolic name of a single-valued texture environment parameter. Must be  GL_TEXTURE_ENV_MODE.
param Specifies a single symbolic constant, one of  GL_MODULATE,  GL_DECAL,  GL_BLEND, or  GL_REPLACE.

C SPECIFICATION

void glTexEnvfv( GLenum target,

               GLenum pname,
               const GLfloat *params )

void glTexEnviv( GLenum target,

               GLenum pname,
               const GLint *params )

PARAMETERS

target Specifies a texture environment. Must be  GL_TEXTURE_ENV.
pname Specifies the symbolic name of a texture environment parameter. Accepted values are  GL_TEXTURE_ENV_MODE and  GL_TEXTURE_ENV_COLOR.
params Specifies a pointer to a parameter array that contains either a single symbolic constant or an RGBA color.

DESCRIPTION

A texture environment specifies how texture values are interpreted when a fragment is textured. target must be  GL_TEXTURE_ENV. pname can be either  GL_TEXTURE_ENV_MODE or  GL_TEXTURE_ENV_COLOR.

If pname is  GL_TEXTURE_ENV_MODE, then params is (or points to) the symbolic name of a texture function. Four texture functions may be specified:  GL_MODULATE,  GL_DECAL,  GL_BLEND, and  GL_REPLACE.

A texture function acts on the fragment to be textured using the texture image value that applies to the fragment (see  glTexParameter) and produces an RGBA color for that fragment. The following table shows how the RGBA color is produced for each of the three texture functions that can be chosen. C is a triple of color values (RGB) and A is the associated alpha value. RGBA values extracted from a texture image are in the range [0,1]. The subscript f refers to the incoming fragment, the subscript t to the texture image, the subscript c to the texture environment color, and subscript v indicates a value produced by the texture function.

A texture image can have up to four components per texture element (see  glTexImage1D,  glTexImage2D,  glTexImage3D,  glCopyTexImage1D, and  glCopyTexImage2D). In a one-component image, Lt indicates that single component. A two-component image uses Lt and At. A three-component image has only a color value, Ct. A four-component image has both a color value Ct and an alpha value At.

Base internalTexture functions
  GL_MODULATE GL_DECAL GL_BLEND GL_REPLACE
 GL_ALPHACv = CfundefinedCv = CfCv = Cf
Av = AfAtAv = AfAv = At
 GL_LUMINANCECv = LtCfundefinedCv = (1-Lt)CfCv = Lt
   +LtCc 
1 Av = Af Av = AfAv = Af
 GL_LUMINANCECv = LtCfundefinedCv = (1-Lt)CfCv = Lt
\f3_ALPHA   +LtCc 
2Av = AtAfAv = AtAfAv = At
 GL_INTENSITYCv = CfItundefinedCv = (1-It)CfCv = It
   +ItCc 
cAv = AfItAv = (1-It)AfAv = It
   +ItAc 
 GL_RGBCv = CtCfCv = CtCv = (1-Ct)CfCv = Ct
    +CtCc 
3Av = AfAv = AfAv = AfAv = Af
 GL_RGBACv = CtCfCv = (1-At)CfCv = (1-Ct)CfCv = Ct
  +AtCt +CtCc 
4Av = AtAfAv = AfAv = AtAfAv = At
If pname is  GL_TEXTURE_ENV_COLOR, params is a pointer to an array that holds an RGBA color consisting of four values. Integer color components are interpreted linearly such that the most positive integer maps to 1.0, and the most negative integer maps to -1.0. The values are clamped to the range [0,1] when they are specified. Cc takes these four values.

 GL_TEXTURE_ENV_MODE defaults to  GL_MODULATE and  GL_TEXTURE_ENV_COLOR defaults to (0, 0, 0, 0).

NOTES

 GL_REPLACE may only be used if the GL version is 1.1 or greater.

Internal formats other than 1, 2, 3, or 4 may only be used if the GL version is 1.1 or greater.

When the  GL_ARB_multitexture extension is supported,  glTexEnv controls the texture environment for the current active texture unit, selected by  glActiveTextureARB.  GL_INVALID_ENUM is generated when target or pname is not one of the accepted defined values, or when params should have a defined constant value (based on the value of pname) and does not.

 GL_INVALID_OPERATION is generated if  glTexEnv is executed between the execution of  glBegin and the corresponding execution of  glEnd.

ASSOCIATED GETS

 glGetTexEnv

SEE ALSO

 glActiveTextureARB(3G),  glCopyPixels(3G),  glCopyTexImage1D(3G),  glCopyTexImage2D(3G),  glCopyTexSubImage1D(3G),  glCopyTexSubImage2D(3G),  glCopyTexSubImage3D(3G),  glTexImage1D(3G),  glTexImage2D(3G),  glTexImage3D(3G),  glTexParameter(3G),  glTexSubImage1D(3G),  glTexSubImage2D(3G),  glTexSubImage3D(3G)

Jump to page    or go to Top of page |  Section 3G |  Main Index.


GLTEXENV (3G)
Generated by manServer 1.07 from /usr/X11R6/man/man3/../man3/glTexEnv.3x.gz using man macros with eqn & tbl support.