glIntro(3G) OpenGL Reference glIntro(3G)
glIntro - Introduction to OpenGL
OpenGL is a high-performance 3D-oriented renderer that supersedes IrisGL.
It is supported on all SGI graphics adaptors except for the G, GT and
GTX. A number of other workstation and personal computer vendors also
support OpenGL.
See glXIntro for a short example program and compilation instructions.
SGI has implemented the following extensions to OpenGL. Note that the
set of supported extensions varies from machine to machine; see below for
more information.
EXT_abgr [Toc] [Back]
extends the list of host-memory color formats. Specifically, it
provides a reverse-order alternative to image format RGBA. The ABGR
component order matches the cpack Iris GL format on big-endian
machines. For more information, see glDrawPixels, glGetTexImage,
glReadPixels, glTexImage1D, and glTexImage2D.
SGIX_async [Toc] [Back]
provides a way to allow certain OpenGL commands to complete out-oforder
with respect to others. This extension does not by itself
enable asynchrony; it is a framework establishing functions for
bookkeeping and synchronization, into which specific further OpenGL
extensions can be inserted. Supported on Octane2 VPro systems. For
more information, see glAsyncMarkerSGIX, glFinishAsyncSGIX,
glPollAsyncSGIX, glGenAsyncMarkersSGIX, glDeleteAsyncMarkersSGIX,
glIsAsyncMarkerSGIX, and glFinish.
SGIX_async_pixel [Toc] [Back]
provides a new asynchronous mode for texture download, pixel
download and pixel readback commands, in conjunction with the
SGIX_async extension. It allows programs to transfer textures or
images from the host to the graphics accelerator in parallel with
the execution of other graphics commands. It also allows programs
to issue non-blocking pixel readback commands that return
immediately after they are issued, so that the program can issue
other commands while the readback takes place. Supported on Octane2
VPro systems. For more information, see glDrawPixels, glEnable,
glReadPixels, glTexImage1D, glTexImage2D, glTexImage3D,
glTexSubImage1D, glTexSubImage2D, and glTexSubImage3D.
Page 1
glIntro(3G) OpenGL Reference glIntro(3G)
SGIX_blend_alpha_minmax [Toc] [Back]
enhances glBlendEquation by providing new blend equations which
produce outcomes for all four color components based only on the
comparison of the alpha component's source and destination values.
Supported on Octane2 VPro systems. For more information, see
glBlendEquation.
EXT_blend_color [Toc] [Back]
allows a constant to be used as a factor in the blending equation.
A typical use is to blend two RGB images. Without the constant
blend factor, one image must have an alpha channel with each pixel
set to the desired blend factor. For more information, see
glBlendColorEXT, glBlendFunc, glGetBooleanv, glGetIntegerv,
glGetFloatv, and glGetDoublev.
EXT_blend_logic_op [Toc] [Back]
defines an additional blending equation for glBlendEquationEXT.
This equation is a simple logical combination of the source and
destination colors. For more information, see glGetBooleanv,
glGetIntegerv, glGetFloatv, and glGetDoublev.
EXT_blend_minmax [Toc] [Back]
allows the blend equation to be changed using glBlendEquationEXT and
introduces two new blend equations, one to produce the minimum color
components of the source and destination colors and one to produce
the maximum. For more information, see glGetBooleanv,
glGetIntegerv, glGetFloatv, and glGetDoublev.
EXT_blend_subtract [Toc] [Back]
defines two additional blending equations for use with
glBlendEquationEXT. These new equations are similar to the default
blending equation, but produce the difference of its terms, rather
than the sum. Image differences are useful in many image processing
applications. For more information, see glGetBooleanv,
glGetIntegerv, glGetFloatv, and glGetDoublev.
SGIX_calligraphic_fragment [Toc] [Back]
modifies fragment processing, such that when
GL_CALLIGRAPHIC_FRAGMENT_SGIX is enabled, fragment information is
also sent to the calligraphic interface. Supported only on
InfiniteReality systems. For more information, see glEnable and
glGet.
SGIX_clipmap [Toc] [Back]
introduces new filtering and memory management techniques for
handling extraordinarily large textures. Clipmaps provide many of
Page 2
glIntro(3G) OpenGL Reference glIntro(3G)
the features of mipmaps, while using a small fraction of the texture
memory required for mipmaps of equivalent size. They are especially
useful for rendering terrain and roaming over large images.
Clipmaps are supported on InfiniteReality systems. For more
information, see glTexParameter.
SGI_color_matrix [Toc] [Back]
adds a 4x4 matrix stack and matrix multiplication to the pixel
transfer path. The color matrix operates on RGBA pixel components.
It can be used to reorder or duplicate color components, and to
implement simple color-space conversions. For more information, see
glGetBooleanv, glGetIntegerv, glGetFloatv, glGetDoublev, and
glPixelTransfer.
SGI_color_table [Toc] [Back]
defines a new RGBA-format color lookup table mechanism, and several
new lookup tables in the OpenGL pixel path. The new lookup tables
are treated as one-dimensional images with internal formats, like
texture images and convolution filter images. This allows the
tables to operate on a subset of the components of passing pixels.
(For example, a table with internal format GL_ALPHA modifies only
the A component of each passing pixel, leaving the R, G, and B
components untouched.) A small subset of this extension is
supported on RealityEngine, RealityEngine2, and VTX systems; because
of this, the extension is not listed in the extensions string
returned by glGetString. The full extension is supported on all
other systems. For more information, see glColorTableSGI,
glColorTableParameterSGI, and glGetColorTableParameterSGI.
EXT_convolution [Toc] [Back]
adds 1- or 2-dimensional convolution operations to the pixel
transfer process. Pixel drawing, reading, and copying, as well as
texture image definition, are candidates for convolution. The
convolution kernels are themselves treated as 1- and 2-dimensional
images, which can be loaded from application memory or from the
framebuffer. A subset of this extension is supported on
RealityEngine, RealityEngine2, and VTX systems; the full extension
is supported on all other systems. For more information, see
glConvolutionFilter1DEXT, glConvolutionFilter2DEXT,
glCopyConvolutionFilter1DEXT, glCopyConvolutionFilter2DEXT,
glGetConvolutionFilterEXT, glSeparableFilter2DEXT,
glGetSeparableFilterEXT, glConvolutionParameteriEXT,
glConvolutionParameterivEXT, glConvolutionParameterfEXT,
glConvolutionParameterfvEXT, glGetConvolutionParameterivEXT,
glGetConvolutionParameterfvEXT, glEnable, glDisable, glIsEnabled,
glGetBooleanv, glGetIntegerv, glGetFloatv, glGetDoublev,
glPixelTransferi, and glPixelTransferf.
Page 3
glIntro(3G) OpenGL Reference glIntro(3G)
SGIX_convolution_accuracy [Toc] [Back]
provides a way to trade off convolution performance against
arithmetic accuracy. Supported on Octane2 VPro systems. For more
information, see glHint.
EXT_copy_texture [Toc] [Back]
provides the ability to copy pixels directly from the framebuffer
into texture memory. At present only a small subset of this
extension has been implemented on RealityEngine, RealityEngine2, and
VTX systems, so the extension name is not listed in the extensions
string returned by glGetString. It is fully supported on all other
systems. For more information, see glCopyTexImage1DEXT,
glCopyTexImage2DEXT, glCopyTexSubImage1DEXT, glCopyTexSubImage2DEXT
and glCopyTexSubImage3DEXT.
SGIS_detail_texture [Toc] [Back]
introduces texture magnification filters that blend between the
level 0 image and a separately defined "detail" image. This detail
blending can be enabled for all color channels, for the alpha
channel only, or for the red, green, and blue channels only. It is
available only for 2D textures. Supported on RealityEngine,
RealityEngine2, and VTX systems, on InfiniteReality systems and on
Octane2 VPro systems. For more information, see
glDetailTexFuncSGIS, glGetDetailTexFuncSGIS, glTexImage2D,
glTexParameterf, glTexParameterfv, glTexParameteri,
glTexParameteriv, glTexSubImage2DEXT, glGetTexImage,
glGetTexLevelParameterfv, glGetTexLevelParameteriv,
glGetTexParameterfv, glGetTexParameteriv, glGetBooleanv,
glGetIntegerv, glGetFloatv, and glGetDoublev.
SGIX_flush_raster [Toc] [Back]
defines the glFlushRasterSGIX command, which ensures that all pixel
fragment operations generated by preceding commands have been
completed. Unlike glFinish, glFlushRasterSGIX does not block the
application until notification of completion has been delivered.
This is useful in conjunction with some performance measurement
techniques (see SGIX_ir_instrument1, for example). Supported only
on InfiniteReality systems. For more information, see
glFlushRasterSGIX, glGetInstrumentsSGIX, glInstrumentsBufferSGIX,
glPollInstrumentsSGIX, glReadInstrumentsSGIX,
glStartInstrumentsSGIX, and glStopInstrumentsSGIX.
SGIS_fog_function [Toc] [Back]
Standard OpenGL defines three fog modes: GL_LINEAR, GL_EXP
(exponential), and GL_EXP2 (exponential squared). Visual simulation
systems can benefit from more sophisticated atmospheric effects.
This extension provides the ability to define a custom fog blending
function by specifying a set of control points that will be
Page 4
glIntro(3G) OpenGL Reference glIntro(3G)
interpolated by the function. Supported on InfiniteReality and
Octane2 VPro systems. For more information, see glFogFuncSGIS,
glFog, and glGet.
SGIX_fog_offset [Toc] [Back]
In highly-fogged environments, emissive objects (like simulated
automobile headlights or runway landing lights) can appear
unrealistically dim. This extension brightens fogged objects by
offsetting the Z value used in fog computations. Supported on
InfiniteReality and Octane2 VPro systems. For more information, see
glEnable, glFog, and glGet.
SGIX_fragment_lighting [Toc] [Back]
provides a general lighting facility for lighting effects obtained
by interpolation of normals over a primitive, rather than by
interpolation of color. Supported on Octane2 VPro systems. For
more information, see glGetFragmentLightfvSGIX,
glGetFragmentLightivSGIX, glGetFragmentMaterialfvSGIX,
glGetFragmentMaterialivSGIX, glFragmentColorMaterialSGIX,
glFragmentLightfSGIX, glFragmentLightiSGIX, glFragmentLightfvSGIX,
glFragmentLightivSGIX, glFragmentLightModelfSGIX,
glFragmentLightModeliSGIX, glFragmentLightModelfvSGIX,
glFragmentLightModelivSGIX, glFragmentMaterialfSGIX,
glFragmentMaterialiSGIX, glFragmentMaterialfvSGIX,
glFragmentMaterialivSGIX, and glLightEnviSGIX.
EXT_histogram [Toc] [Back]
defines pixel operations that count occurrences of specific color
component values (histogram) and track the minimum and maximum color
component values (minmax). An optional mode allows pixel data to be
discarded after the histogram and/or minmax operations are
completed. Otherwise the pixel data continue on to the next
operation unaffected. For more information, see glHistogramEXT,
glResetHistogramEXT, glGetHistogramEXT,
glGetHistogramParameterivEXT, glGetHistogramParameterfvEXT,
glMinmaxEXT, glResetMinmaxEXT, glGetMinmaxEXT,
glGetMinmaxParameterivEXT, glGetMinmaxParameterfvEXT, glEnable,
glDisable, glIsEnabled, glGetBooleanv, glGetIntegerv, glGetFloatv,
and glGetDoublev.
ARB_imaging [Toc] [Back]
defines a large set of image processing primitives, such as color
tables, convolution, color matrices, histogramming, and additional
blending behavior. The definition of this extension is provided as
optional material in the OpenGL 1.2 specification.
Page 5
glIntro(3G) OpenGL Reference glIntro(3G)
SGIX_instruments [Toc] [Back]
defines a mechanism to take performance measurements from
instruments within the GL. Currently supported only on
InfiniteReality systems. For more information, see glEnable,
glGetInstrumentsSGIX, glInstrumentsBufferSGIX,
glPollInstrumentsSGIX, glReadInstrumentsSGIX,
glStartInstrumentsSGIX, glStopInstrumentsSGIX, and
glFlushRasterSGIX.
SGIX_interlace [Toc] [Back]
modifies the behavior of glDrawPixels, glCopyPixels, glTexImage2D,
glTexSubImage2DEXT, glCopyTexImage2DEXT and glCopyTexSubImage2DEXT,
such that when GL_INTERLACE_SGIX is enabled the source image is
considered to be a field of an "interlaced" frame. That is, the
effective source image has height equal to twice the actual height
and every other row contains "transparent" pixels that do not affect
the corresponding destination pixels in the target image. For
example:
glEnable(GL_INTERLACE_SGIX);
set current raster position to (x , y )
r r
glDrawPixels(width, height, GL_RGBA, GL_UNSIGNED_BYTE, I );
0
set raster position to (x , y +zoom )
r r y
glDrawPixels(width, height, GL_RGBA, GL_UNSIGNED_BYTE, I );
1
is equivalent to
glDisable( GL_INTERLACE_SGIX);
set current raster position to (x , y )
r r
glDrawPixels(width, 2xheight, GL_RGBA, GL_UNSIGNED_BYTE, I );
2
where pixel rows (0,2,4,...) of I are from image I , and rows
2 0
(1,3,5,...) are from image I .
1
This is particularly useful for assembling consecutive interlaced
video format fields into a complete frame in either the framebuffer
or in texture memory. Supported on RealityEngine, RealityEngine2,
and VTX systems, on InfiniteReality systems, on Octane2 VPro
systems, and on O2 systems.
INGR_interlace_read [Toc] [Back]
modifies the behavior of glReadPixels, glCopyPixels,
glCopyTexImage2DEXT and glCopyTexSubImage2DEXT. When
GL_INTERLACE_READ_INGR is enabled the pixels being read or copied
represent one field of an "interlaced" frame. The source image
height in the framebuffer is equivalent to twice the specified
height of the transfer. Every other row of the source pixel
rectangle is skipped, so that only source rows (0,2,4,...) affect
Page 6
glIntro(3G) OpenGL Reference glIntro(3G)
the destination image. This is useful for extracting fields from an
interlaced video frame in the framebuffer. Supported on Octane2
VPro systems, and on O2 systems.
SGIX_ir_instrument1 [Toc] [Back]
defines a performance-measurement instrument for InfiniteReality
systems. The instrument is controlled with the SGIX_instruments
extension. For more information, see glInstrumentsBufferSGIX,
glGetInstrumentsSGIX, glPollInstrumentsSGIX, glReadInstrumentsSGIX,
glStartInstrumentsSGIX, glStopInstrumentsSGIX, and glEnable.
SGIX_list_priority [Toc] [Back]
defines a mechanism to specify priorities for display lists. Some
machines have special high-performance display list memories; this
extension allows the user to tell the GL which display lists should
be stored in those memories. Supported on High Impact and Maximum
Impact systems and on InfiniteReality and Octane2 VPro systems. For
more information, see glListParameterfSGIX, glListParameteriSGIX,
glListParameterfvSGIX, glListParameterivSGIX,
glGetListParameterfvSGIX and glGetListParameterivSGIX.
SGIS_multisample [Toc] [Back]
provides a mechanism to antialias all primitives. The technique is
to sample all primitives multiple times at different locations
within each pixel (rather than just the pixel center). The color
sample values are resolved to a single, displayable color each time
a pixel is updated, so the antialiasing appears to be automatic at
the application level. Supported on RealityEngine, RealityEngine2,
and VTX systems and on InfiniteReality systems. For more
information, see glSampleMaskSGIS, glSamplePatternSGIS,
glTagSampleBufferSGIX, glXChooseVisual, glXGetConfig, glEnable,
glDisable, glIsEnabled, glPushAttrib, glGetBooleanv, glGetDoublev,
glGetIntegerv, and glGetFloatv.
EXT_packed_pixels [Toc] [Back]
provides support for packed pixels in host memory. A packed pixel
is represented entirely by one unsigned byte, one unsigned short, or
one unsigned integer. The fields with the packed pixel are not
proper machine types, but the pixel as a whole is. Thus the pixel
storage modes, and their unpacking counterparts, all work correctly
with packed pixels. This extension is not supported on
RealityEngine, RealityEngine2, and VTX systems. For more
information, see glDrawPixels, glReadPixels, glTexImage1D,
glTexImage2D, glTexImage3DEXT, glTexSubImage1DEXT,
glTexSubImage2DEXT, glTexSubImage3DEXT, glConvolutionFilter1DEXT,
glConvolutionFilter2DEXT, glConvolutionFilter3DEXT,
glSeparableFilter2DEXT, glSeparableFilter3DEXT, glColorTableSGI,
glTexImage4DSGIS, and glTexSubImage4DSGIS.
Page 7
glIntro(3G) OpenGL Reference glIntro(3G)
SGIS_pixel_texture [Toc] [Back]
allows the color components of pixel groups to be used as texture
coordinates, effectively converting a color image into a texture
coordinate image. Supported on Octane2 VPro systems. For more
information, see glPixelTexGenParameterSGIS.
SGIS_point_parameters [Toc] [Back]
provides support for light points (approximations of distant light
sources that are used in simulations of nighttime scenes).
Supported only on InfiniteReality systems. For more information,
see glPointParameterSGIS.
EXT_polygon_offset [Toc] [Back]
allows depth values of fragments to be displaced so that lines (or
points) and polygons that lie in the same plane can be rendered
without interaction -- the lines are rendered either completely in
front of or behind the polygons (depending on the sign of the offset
factor). It also allows multiple coplanar polygons to be rendered
without interaction, if different offset factors are used for each
polygon. For more information, see glPolygonOffsetEXT, glEnable,
glDisable, glIsEnabled, glGetBooleanv, glGetIntegerv, glGetFloatv,
and glGetDoublev.
SGIX_reference_plane [Toc] [Back]
allows a group of coplanar primitives to be rendered without depthbuffering
artifacts. This is accomplished by generating the depth
values for all the primitives from a single ``reference plane''
rather than from the primitives themselves. This ensures that all
the primitives in the group have exactly the same depth value at any
given sample point, no matter what imprecision may exist in the
original specifications of the primitives or in the GL's coordinate
transformation process. SGIX_reference_plane is useful for
generating hidden-line drawings, for applying decals to polygons,
and for multipass rendering techniques. Supported on
InfiniteReality systems. For more information, see
glReferencePlaneSGIX.
SGIX_resample [Toc] [Back]
enhances the unpacking resampling capabilities of the SGIX_subsample
extension. Supported on Octane2 VPro systems. For more
information, see glPixelStoref and glPixelStorei.
SGIX_scalebias_hint [Toc] [Back]
provides a way to trade off arithmetic accuracy against performance.
typically for large scale factors. Supported on Octane2 VPro
systems. For more information, see glHint.
Page 8
glIntro(3G) OpenGL Reference glIntro(3G)
SGIX_shadow [Toc] [Back]
provides support for rendering shadows using shadow maps. First the
application renders the scene from the point of view of the light
source, and copies the resulting depth buffer to a texture with
internal format GL_DEPTH_COMPONENT, GL_DEPTH_COMPONENT16_SGIX,
GL_DEPTH_COMPONENT24_SGIX, or GL_DEPTH_COMPONENT32_SGIX. Next the
application renders the scene from the normal viewpoint. Then the
application enables the texture parameter GL_TEXTURE_COMPARE_SGIX,
sets the texture comparison operator and texture matrix
appropriately, and re-renders the scene with 2D texturing enabled.
During this final rendering pass, the depth value generated by
iterating the r texture coordinate is compared with the shadow map
stored in texture memory, and the results of the comparison indicate
whether the pixel being textured is in shadow. The filtered result
of the shadow comparisons can be blended with the pixel to darken
it. Supported on InfiniteReality systems. For more information,
see glTexParameter.
SGIX_shadow_ambient [Toc] [Back]
controls the filtered texture value generated in shadowed regions
(see SGIX_shadow). In effect, this changes the ambient lighting in
shadows. Supported on InfiniteReality systems. For more
information, see glTexParameter.
SGIS_sharpen_texture [Toc] [Back]
introduces texture magnification filters that sharpen the resulting
image by extrapolating from the level 1 image to the level 0 image.
Sharpening can be enabled for all color channels, for the alpha
channel only, or for the red, green, and blue channels only.
Supported on RealityEngine, RealityEngine2, and VTX systems and on
InfiniteReality systems. For more information, see
glSharpenTexFuncSGIS, glGetSharpenTexFuncSGIS, glTexParameteri,
glTexParameterf, glTexParameteriv, glTexParameterfv,
glGetTexParameteriv, and glGetTexParameterfv.
SGIX_sprite [Toc] [Back]
provides a mechanism that automatically rotates primitives to face
the viewer. Rotation about an axis is used for objects that are
roughly cylindrically symmetric, like trees. Rotation about a point
is used for objects that are roughly spherically symmetric, like
clouds or explosions. Supported only on InfiniteReality systems.
For more information, see glSpriteParameterSGIX.
SGIX_subsample [Toc] [Back]
defines new pixel storage modes used in the conversion of image data
to and from component subsampled formats on the client side.
Supported on Octane2 VPro systems. For more information, see
glPixelStoref and glPixelStorei.
Page 9
glIntro(3G) OpenGL Reference glIntro(3G)
EXT_subtexture [Toc] [Back]
allows a contiguous portion of an already-existing texture image to
be redefined without affecting the remaining portion of the image or
any of the other state that describes the texture. There are three
new calls: glTexSubImage1DEXT, glTexSubImage2DEXT, and
glTexSubImage3DEXT. A subset of this extension is available on
RealityEngine, RealityEngine2, and VTX systems, and the full
extension is available on all other systems. Refer to the man pages
for more details.
EXT_texture [Toc] [Back]
provides support for a variety of resolutions of color components in
texture images. That is, instead of treating a retained image as
having 1, 2, 3, or 4 components, it is treated as though it had a
specific format, such as GL_LUMINANCE_ALPHA, or just GL_ALPHA. This
extension also defines a robust method for applications to determine
what combinations of texture dimensions and resolutions are
supported by an implementation and it introduces a new texture
environment: GL_REPLACE_EXT. For more information, see
glTexImage1D, glTexImage2D, glGetTexLevelParameteriv,
glGetTexLevelParameterfv, glTexEnvf, glTexEnvi, glTexEnvfv, and
glTexEnviv.
EXT_texture3D [Toc] [Back]
supports 3-dimensional texture mapping. It also defines the inmemory
formats for 3D images, and adds pixel storage modes to
support them. For more information, see glTexImage3DEXT,
glPixelStore, glEnable, glDisable, glIsEnabled, glTexParameteriv,
glTexParameterfv, glGetBooleanv, glGetIntegerv, glGetFloatv,
glGetDoublevEnable, glGetTexImage, glGetTexLevelParameteriv,
glGetTexLevelParameterfv, glGetTexParameteriv, and
glGetTexParameterfv.
SGIX_texture_add_env [Toc] [Back]
defines a new texture environment function which scales the texture
value by the constant texture color and then adds a bias color.
Supported only on InfiniteReality systems. For more information,
see glTexEnv.
SGIS_texture_border_clamp [Toc] [Back]
provides a variation in the texture clamping arithmetic which
results in sampling the border color rather than the average of the
edge and border colors. Supported on Octane2 VPro systems. For
more information, see glTexParameteriv and glTexParameterfv.
Page 10
glIntro(3G) OpenGL Reference glIntro(3G)
SGI_texture_color_table [Toc] [Back]
adds a color lookup table to the texture mapping process. For more
information, see glColorTableSGI.
SGIS_texture_color_mask [Toc] [Back]
adds state to control the storing of individual color components
during texture image definition. For more information, see
glTextureColorMaskSGIS.
SGIX_texture_coordinate_clamp [Toc] [Back]
provides a way to set the maximum texture coordinate clamping value
to something other than 1.0. Supported on Octane2 VPro systems.
For more information, see glTexParameter.
SGIS_texture_edge_clamp [Toc] [Back]
The GL normally clamps texture coordinates to the range [0,1]. This
can cause the texture sampling filter to straddle the edge of the
texture image, taking half its sample values from within the texture
image, and the other half from the texture border. Sometimes this
is undesirable. SGIS_texture_edge_clamp defines a new texture
clamping method that ensures all sample values fall within the
texture image. Supported on InfiniteReality and Octane2 VPro
systems. For more information, see glTexParameter.
EXT_texture_env_add [Toc] [Back]
defines a new texture environment function which simply adds the
texture color to the fragment color. Supported on Octane2 VPro
systems. For more information, see glTexEnv.
SGIS_texture_filter4 [Toc] [Back]
allows 1D and 2D textures to be filtered using an applicationdefined
symmetric and separable filter with four samples per
dimension. In the most common 2D case, the filter is bicubic. This
filtering can yield better-quality images than mipmapping, and is
often used in image processing applications. Supported on
InfiniteReality systems. For more information, see glTexParameter,
glGetTexParameter, glTexFilterFuncSGIS, and glGetTexFilterFuncSGIS.
SGIS_texture_lod [Toc] [Back]
provides mechanisms that reduce the number of mipmap levels required
for mipmapped texturing. This allows a large texture to be loaded
and used initially at low resolution, and to increase the resolution
gradually as time passes or as more mipmap levels become available.
Supported on InfiniteReality and Octane2 VPro systems. For more
information, see glTexParameter.
Page 11
glIntro(3G) OpenGL Reference glIntro(3G)
SGIX_texture_lod_bias [Toc] [Back]
provides mechanisms that apply a bias to the n, m and l parameters
in the LOD calculation, to compensate for over- or under-sampled
texture images. Supported on InfiniteReality and Octane2 VPro
systems. For more information, see glTexParameter.
EXT_texture_object [Toc] [Back]
supports named texture objects whose contents and parameters may be
changed after they are defined. (Contrast this with textures in
display lists, which cannot be modified after the display lists are
created.) For machines with special texture memories,
EXT_texture_object also provides simple texture memory management.
For more information, see glGenTexturesEXT, glDeleteTexturesEXT,
glBindTextureEXT, glPrioritizeTexturesEXT, glAreTexturesResidentEXT,
and glIsTextureEXT.
SGIX_texture_scale_bias [Toc] [Back]
adds scale, bias, and clamp operations to the texture pipeline.
These operations are applied to the filtered result of a texture
lookup, before that result is used in the texture environment
equations and before the texture color lookup table of
SGI_texture_color_table, if that extension exists. Not supported on
RealityEngine, RealityEngine2, and VTX systems or on High Impact and
Maximum Impact systems. For more information, see glTexParameterfv,
glTexParameteriv, and glGetTexParameter.
SGIS_texture_select [Toc] [Back]
adds new texture internal formats beyond those defined by
EXT_texture. The purpose of these new formats is to reorganize the
components of a texture into groups of components. This allows
better utilization of texture memory by subdividing the internal
representation of a texel into 1, 2, or 4 smaller texels.
For example on InfiniteReality systems, an 8-bit luminance texture
would normally use a full 16 bits of texture memory for each texel,
but if the application chooses the GL_DUAL_LUMINANCE8_SGIS internal
format, then two 8-bit luminance textures can be packed into the
same space. When such a texture is active, the application must
select which of the two packed textures will be used for drawing.
Supported on InfiniteReality systems and on High Impact and Maximum
Impact systems. For more information, see glTexImage1D,
glTexImage2D, glTexImage3DEXT, glTexParameterfv, glTexParameteriv,
and glGetTexParameter.
EXT_vertex_array [Toc] [Back]
adds the ability to specify multiple geometric primitives with very
few subroutine calls. Instead of calling an OpenGL procedure to pass
each individual vertex, normal, or color, separate arrays of
Page 12
glIntro(3G) OpenGL Reference glIntro(3G)
vertices, normals, and colors are prespecified, and are used to
define a sequence of primitives (all of the same type) when a single
call is made to glDrawArraysEXT. A stride mechanism is provided so
that an application can choose to keep all vertex data staggered in
a single array, or sparsely in separate arrays. Single-array storage
generally will provide better performance.
This extension also supports the rendering of individual array
elements, each specified as an index into the enabled arrays.
For more information, see glArrayElementEXT, glDrawArraysEXT,
glVertexPointerEXT, glNormalPointerEXT, glColorPointerEXT,
glIndexPointerEXT, glTexCoordPointerEXT, glEdgeFlagPointerEXT, and
glGetPointervEXT.
SGIX_vertex_preclip [Toc] [Back]
supplies a way to control the precision of interpolation of
parameters across the extent of primitives with large screen space
dimensions. This control allows trading off precision for higher
rasterization performance. Supported on Octane2 VPro systems. For
more information, see glEnable and glHint.
Procedure names and tokens for OpenGL extensions are suffixed with EXT or
with a vendor-specfic acronym. EXT is used for extensions that have been
reviewed and will be supported by more than one OpenGL vendor.
SGI also supports some vendor-specific extensions. Procedure names and
tokens for the SGI-specific extensions are suffixed with SGI, SGIS or
SGIX. ``SGI'' is used for extensions that will be available across the
product line (although the support for all machines might not be released
simultaneously). ``SGIS'' is used for extensions that will be available
on a subset of SGI platforms. ``SGIX'' extensions are experimental; in
future releases, the API for these extensions might change or might not
be supported at all.
All supported extensions have an associated macro definition in gl.h and
a corresponding token in the extensions string returned by glGetString.
For example, if the EXT_abgr extension is supported then the token
GL_EXT_abgr will be defined in gl.h and GL_EXT_abgr will appear in the
extensions string returned by glGetString.
The definitions in gl.h can be used at compile time to determine if an
extension's tokens and procedures exist in the OpenGL library. However,
the tokens returned by glGetString must be consulted at runtime to
determine whether the extension is supported on the particular display in
use at that moment.
Page 13
glIntro(3G) OpenGL Reference glIntro(3G)
As an alternative to parsing the extensions string, you can determine
which extensions are supported by examining the renderer string (to
determine which graphics subsystem is being used) and the version string
(to determine the release number of the software being used). For more
information, see glGetString.
On some machines an extension may be incompletely implemented, and
therefore its name will not appear in the extensions string. In such
cases the only way to determine if the extension can be used is to query
the renderer and version strings.
GLX also has been extended. Refer to glXIntro for more information.
When an OpenGL application uses indirect rendering, additional instances
of Xsgi, the SGI X server, process show up under ps. The additional
processes are multiple threads of the X server, used to implement
indirect rendering.
Do not mix OpenGL and IrisGL calls from within a single process.
Different OpenGL processes which render to the same window using direct
rendering will not share the software ancillary buffers on that window.
If an OpenGL program does a server grab using its X connection, then for
the duration of the grab it should not render OpenGL into any window that
the client doing the grab did not create. Otherwise a deadlock occurs.
The client is still able to do X rendering. This holds for both local
and remote rendering.
If the OpenGL DSO (libGL.so) is unloaded, by calling dlclose(), before
the X connection is closed (or before the application is shutdown), a
segv will occur. To get around this, call XCloseDisplay before unloading
libGL.so.
glXCopyContext does not work correctly for direct rendering contexts if
the source context is not the current context or, on most systems, if the
destination context has never been made current to any thread. For more
information, see glXCopyContext.
On Solid Impact, High Impact and Maximum Impact systems, and on
RealityEngine, RealityEngine2, and VTX systems, GLX_BUFFER_SIZE is not
the sum of GLX_RED_SIZE, GLX_GREEN_SIZE, GLX_BLUE_SIZE, and
GLX_ALPHA_SIZE for visuals with 12-bit RGBA components.
glXSwapBuffers does not work for double-buffered GLX pixel buffers.
Page 14
glIntro(3G) OpenGL Reference glIntro(3G)
On XS, XZ, Elan, and Extreme systems, and Indy and XL systems,
glConvolutionFilter1DEXT, glConvolutionFilter2DEXT, and
glSeparableFilter2DEXT, will skip pixels and/or rows when the pixel zoom
is set so that it minifies (i.e., -1 < zoom < 1).
Even though the SGIX_texture_scale_bias extension is implemented on XS,
XZ, Elan, and Extreme systems, and on Indy and XL systems, it is not
possible to query GL_POST_TEXTURE_FILTER_BIAS_RANGE_SGIX and
GL_POST_TEXTURE_FILTER_SCALE_RANGE_SGIX. Doing so will result in a gl
error.
On XS, XZ, Elan, and Extreme systems, and on Indy and XL systems, calling
glHistogramEXT, glResetHistogramEXT, glMinmaxEXT, or glResetMinmaxEXT
between a glBegin and glEnd will not generate a GL_INVALID_OPERATION
error as it should.
No locking of display list structures is done on behalf of indirect
OpenGL contexts that share display list spaces. Applications that use
such contexts should use their own mechanisms to ensure mutual exclusion
when defining or destroying display lists.
You may notice some discrepancies between the OpenGL Reference Manual
which is available through InSight and the man pages (i.e., the ones you
get using the "man gl..." command in a shell window). If so, the man
pages contain the correct, up to date, information.
MACHINE DEPENDENCIES
Most machine dependencies are documented in the reference pages for the
commands with which they're most closely associated. Some more general
observations follow:
VGX and VGXT [Toc] [Back]
On VGX and VGXT systems, OpenGL is implemented atop IrisGL. This
implementation passes the ``mustpass'' OpenGL conformance tests but,
nonetheless, the following inconsistencies exist: pixel centers lie on
integer coordinates (not half-integer coordinates), and diffuse and
specular light colors are ignored.
If any of the following are enabled, then all geometric primitives will
be rendered through software (i.e., no hardware acceleration will be
used):
o alpha test (unless test is GL_ALWAYS or GL_NOTEQUAL and reference
value is zero)
o texture
Page 15
glIntro(3G) OpenGL Reference glIntro(3G)
o lighting enabled but no lights enabled
o clock-wise front face
o fog enabled and color index visual
o drawing into both front and back buffer AND blend is enabled, or
logic op is enabled
Points will be rendered through software if evaluators are used (e.g.,
GL_MAP1_VERTEX3 is enabled).
Polygons and strips will be rendered through software if any of the
following are true:
o front mode is not the same as back mode and the polygon mode is not
GL_FILL
o polygon offset is enabled and the scale and bias offset factors are
not 1 and 0, respectively.
o points have to go through software and the polygon mode is GL_POINT
On VGXT fog is done per-vertex instead of per-pixel.
glXIntro
PPPPaaaaggggeeee 11116666 [ Back ]
|