GLAPI/glViewportArray: Difference between revisions

From OpenGL Wiki
Jump to navigation Jump to search
4.0 API.
 
Math equations.
Line 20: Line 20:
== Description ==
== Description ==


'''glViewportArrayv''' specifies the parameters for multiple viewports simulataneously. ''first'' specifies the index of the first viewport to modify and ''count'' specifies the number of viewports to modify. ''first'' must be less than the value of {{code|GL_MAX_VIEWPORTS}}, and ''first'' + ''count'' must be less than or equal to the value of {{code|GL_MAX_VIEWPORTS}}. Viewports whose indices lie outside the range [''first'', ''first'' + ''count'') are not modified. ''v'' contains the address of an array of floating point values specifying the left (<!--Missing Equation-->), bottom (<!--Missing Equation-->), width (<!--Missing Equation-->), and height (<!--Missing Equation-->) of each viewport, in that order. <!--Missing Equation--> and <!--Missing Equation--> give the location of the viewport's lower left corner, and <!--Missing Equation--> and <!--Missing Equation--> give the width and height of the viewport, respectively. The viewport specifies the affine transformation of <!--Missing Equation--> and <!--Missing Equation--> from normalized device coordinates to window coordinates. Let <!--Missing Equation--> be normalized device coordinates. Then the window coordinates <!--Missing Equation--> are computed as follows:
'''glViewportArrayv''' specifies the parameters for multiple viewports simulataneously. ''first'' specifies the index of the first viewport to modify and ''count'' specifies the number of viewports to modify. ''first'' must be less than the value of {{code|GL_MAX_VIEWPORTS}}, and ''first'' + ''count'' must be less than or equal to the value of {{code|GL_MAX_VIEWPORTS}}. Viewports whose indices lie outside the range [''first'', ''first'' + ''count'') are not modified. ''v'' contains the address of an array of floating point values specifying the left (''x''), bottom (''y''), width (''w''), and height (''h'') of each viewport, in that order. ''x'' and ''y'' give the location of the viewport's lower left corner, and ''w'' and ''h'' give the width and height of the viewport, respectively. The viewport specifies the affine transformation of ''x'' and ''y'' from normalized device coordinates to window coordinates. Let (x<sub>nd</sub>, y<sub>nd</sub>) be normalized device coordinates. Then the window coordinates (x<sub>w</sub>, y<sub>w</sub>) are computed as follows:


<!--Missing Equation-->
{{glapi viewport equations}}


<!--Missing Equation-->
The location of the viewport's bottom left corner, given by (''x'', ''y'') is clamped to be within the implementaiton-dependent viewport bounds range. The viewport bounds range [''min'', ''max''] can be determined by calling [[GLAPI/glGet|glGet]] with argument {{code|GL_VIEWPORT_BOUNDS_RANGE}}. Viewport width and height are silently clamped to a range that depends on the implementation. To query this range, call [[GLAPI/glGet|glGet]] with argument {{code|GL_MAX_VIEWPORT_DIMS}}.
 
The location of the viewport's bottom left corner, given by (<!--Missing Equation-->, <!--Missing Equation-->) is clamped to be within the implementaiton-dependent viewport bounds range. The viewport bounds range [<!--Missing Equation-->, <!--Missing Equation-->] can be determined by calling [[GLAPI/glGet|glGet]] with argument {{code|GL_VIEWPORT_BOUNDS_RANGE}}. Viewport width and height are silently clamped to a range that depends on the implementation. To query this range, call [[GLAPI/glGet|glGet]] with argument {{code|GL_MAX_VIEWPORT_DIMS}}.


The precision with which the GL interprets the floating point viewport bounds is implementation-dependent and may be determined by querying the impementation-defined constant {{code|GL_VIEWPORT_SUBPIXEL_BITS}}.
The precision with which the GL interprets the floating point viewport bounds is implementation-dependent and may be determined by querying the impementation-defined constant {{code|GL_VIEWPORT_SUBPIXEL_BITS}}.

Revision as of 22:40, 31 January 2012

glViewportArray
Core in version 4.6
Core since version 4.1
Core ARB extension ARB_viewport_array

glViewportArray: set multiple viewports

Function Definition

 void glViewportArrayv(GLuint first, GLsizei count, const GLfloat *v);
first
Specify the first viewport to set.
count
Specify the number of viewports to set.
v
Specify the address of an array containing the viewport parameters.

Description

glViewportArrayv specifies the parameters for multiple viewports simulataneously. first specifies the index of the first viewport to modify and count specifies the number of viewports to modify. first must be less than the value of GL_MAX_VIEWPORTS, and first + count must be less than or equal to the value of GL_MAX_VIEWPORTS. Viewports whose indices lie outside the range [first, first + count) are not modified. v contains the address of an array of floating point values specifying the left (x), bottom (y), width (w), and height (h) of each viewport, in that order. x and y give the location of the viewport's lower left corner, and w and h give the width and height of the viewport, respectively. The viewport specifies the affine transformation of x and y from normalized device coordinates to window coordinates. Let (xnd, ynd) be normalized device coordinates. Then the window coordinates (xw, yw) are computed as follows:

$ x_{w}=(x_{nd}+1)\left({\tfrac {width}{2}}\right)+x $

$ y_{w}=(y_{nd}+1)\left({\tfrac {height}{2}}\right)+y $


The location of the viewport's bottom left corner, given by (x, y) is clamped to be within the implementaiton-dependent viewport bounds range. The viewport bounds range [min, max] can be determined by calling glGet with argument GL_VIEWPORT_BOUNDS_RANGE. Viewport width and height are silently clamped to a range that depends on the implementation. To query this range, call glGet with argument GL_MAX_VIEWPORT_DIMS.

The precision with which the GL interprets the floating point viewport bounds is implementation-dependent and may be determined by querying the impementation-defined constant GL_VIEWPORT_SUBPIXEL_BITS.

Errors

GL_INVALID_VALUE is generated if first is greater than or equal to the value of GL_MAX_VIEWPORTS.

GL_INVALID_VALUE is generated if first + count is greater than or equal to the value of GL_MAX_VIEWPORTS.

GL_INVALID_VALUE is generated if either width or height is negative.

Associated Gets

glGet with argument GL_VIEWPORT

glGet with argument GL_MAX_VIEWPORT_DIMS

glGet with argument GL_VIEWPORT_BOUNDS_RANGE

glGet with argument GL_VIEWPORT_SUBPIXEL_BITS

See Also

glDepthRange, glViewport, glViewportIndexed

Copyright

Copyright © 2010 Khronos Group. This material may be distributed subject to the terms and conditions set forth in the Open Publication License, v 1.0, 8 June 1999. http://opencontent.org/openpub/.