table of contents
GLCALLLISTS(3G) | OpenGL Manual | GLCALLLISTS(3G) |
NAME¶
glCallLists - execute a list of display lists
C SPECIFICATION¶
void glCallLists(GLsizei n, GLenum type, const GLvoid * lists);
PARAMETERS¶
n
type
lists
DESCRIPTION¶
glCallLists causes each display list in the list of names passed as lists to be executed. As a result, the commands saved in each display list are executed in order, just as if they were called without using a display list. Names of display lists that have not been defined are ignored.
glCallLists provides an efficient means for executing more than one display list. type allows lists with various name formats to be accepted. The formats are as follows:
GL_BYTE
GL_UNSIGNED_BYTE
GL_SHORT
GL_UNSIGNED_SHORT
GL_INT
GL_UNSIGNED_INT
GL_FLOAT
GL_2_BYTES
GL_3_BYTES
GL_4_BYTES
The list of display-list names is not null-terminated. Rather, n specifies how many names are to be taken from lists.
An additional level of indirection is made available with the glListBase() command, which specifies an unsigned offset that is added to each display-list name specified in lists before that display list is executed.
glCallLists can appear inside a display list. To avoid the possibility of infinite recursion resulting from display lists calling one another, a limit is placed on the nesting level of display lists during display-list execution. This limit must be at least 64, and it depends on the implementation.
GL state is not saved and restored across a call to glCallLists. Thus, changes made to GL state during the execution of the display lists remain after execution is completed. Use glPushAttrib(), glPopAttrib(), glPushMatrix(), and glPopMatrix() to preserve GL state across glCallLists calls.
NOTES¶
Display lists can be executed between a call to glBegin() and the corresponding call to glEnd(), as long as the display list includes only commands that are allowed in this interval.
ERRORS¶
GL_INVALID_VALUE is generated if n is negative.
GL_INVALID_ENUM is generated if type is not one of GL_BYTE, GL_UNSIGNED_BYTE, GL_SHORT, GL_UNSIGNED_SHORT, GL_INT, GL_UNSIGNED_INT, GL_FLOAT, GL_2_BYTES, GL_3_BYTES, GL_4_BYTES.
ASSOCIATED GETS¶
glGet() with argument GL_LIST_BASE
glGet() with argument GL_MAX_LIST_NESTING
glIsList()
SEE ALSO¶
glCallList(), glDeleteLists(), glGenLists(), glListBase(), glNewList(), glPushAttrib(), glPushMatrix()
COPYRIGHT¶
Copyright © 1991-2006 Silicon Graphics, Inc. This document is licensed under the SGI Free Software B License. For details, see http://oss.sgi.com/projects/FreeB/.
AUTHORS¶
opengl.org
05/02/2014 | opengl.org |