Class ARBViewportArray
- java.lang.Object
- 
- org.lwjgl.opengl.ARBViewportArray
 
- 
 
 public class ARBViewportArray extends java.lang.ObjectNative bindings to the ARB_viewport_array extension.OpenGL is modeled on a pipeline of operations. The final stage in this pipeline before rasterization is the viewport transformation. This stage transforms vertices from view space into window coordinates and allows the application to specify a rectangular region of screen space into which OpenGL should draw primitives. Unextended OpenGL implementations provide a single viewport per context. In order to draw primitives into multiple viewports, the OpenGL viewport may be changed between several draw calls. With the advent of Geometry Shaders, it has become possible for an application to amplify geometry and produce multiple output primitives for each primitive input to the Geometry Shader. It is possible to direct these primitives to render into a selected render target. However, all render targets share the same, global OpenGL viewport. This extension enhances OpenGL by providing a mechanism to expose multiple viewports. Each viewport is specified as a rectangle. The destination viewport may be selected per-primitive by the geometry shader. This allows the Geometry Shader to produce different versions of primitives destined for separate viewport rectangles on the same surface. Additionally, when combined with multiple framebuffer attachments, it allows a different viewport rectangle to be selected for each. This extension also exposes a separate scissor rectangle for each viewport. Finally, the viewport bounds are now floating point quantities allowing fractional pixel offsets to be applied during the viewport transform. Requires OpenGL 3.2or EXT_geometry_shader4 orARB_geometry_shader4. Promoted to core inOpenGL 4.1.
- 
- 
Field SummaryFields Modifier and Type Field and Description static intGL_LAYER_PROVOKING_VERTEX
 GL_MAX_VIEWPORTSAccepted by thepnameparameter of GetBooleanv, GetIntegerv, GetFloatv, GetDoublev and GetInteger64v.static intGL_UNDEFINED_VERTEXReturned in thedataparameter from a Get query with apnameof LAYER_PROVOKING_VERTEX or VIEWPORT_INDEX_PROVOKING_VERTEX.static intGL_VIEWPORT_BOUNDS_RANGE
 GL_VIEWPORT_INDEX_PROVOKING_VERTEX
 GL_VIEWPORT_SUBPIXEL_BITSAccepted by thepnameparameter of GetBooleanv, GetIntegerv, GetFloatv, GetDoublev and GetInteger64v.
 - 
Method SummaryAll Methods Static Methods Concrete Methods Modifier and Type Method and Description static voidglDepthRangeArrayv(int first, double[] v)Array version of:DepthRangeArrayvstatic voidglDepthRangeArrayv(int first, java.nio.DoubleBuffer v)Specifies mapping of depth values from normalized device coordinates to window coordinates for a specified set of viewports.static voidglDepthRangeIndexed(int index, double zNear, double zFar)Specifies mapping of depth values from normalized device coordinates to window coordinates for a specified viewport.static voidglGetDoublei_v(int target, int index, double[] data)Array version of:GetDoublei_vstatic voidglGetDoublei_v(int target, int index, java.nio.DoubleBuffer data)Queries the double value of an indexed state variable.static doubleglGetDoublei(int target, int index)Queries the double value of an indexed state variable.static voidglGetFloati_v(int target, int index, float[] data)Array version of:GetFloati_vstatic voidglGetFloati_v(int target, int index, java.nio.FloatBuffer data)Queries the float value of an indexed state variable.static floatglGetFloati(int target, int index)Queries the float value of an indexed state variable.static voidglScissorArrayv(int first, int[] v)Array version of:ScissorArrayvstatic voidglScissorArrayv(int first, java.nio.IntBuffer v)Defines the scissor box for multiple viewports.static voidglScissorIndexed(int index, int left, int bottom, int width, int height)Defines the scissor box for a specific viewport.static voidglScissorIndexedv(int index, int[] v)Array version of:ScissorIndexedvstatic voidglScissorIndexedv(int index, java.nio.IntBuffer v)Pointer version ofScissorIndexed.static voidglViewportArrayv(int first, float[] v)Array version of:ViewportArrayvstatic voidglViewportArrayv(int first, java.nio.FloatBuffer v)Sets multiple viewports.static voidglViewportIndexedf(int index, float x, float y, float w, float h)Sets a specified viewport.static voidglViewportIndexedfv(int index, float[] v)Array version of:ViewportIndexedfvstatic voidglViewportIndexedfv(int index, java.nio.FloatBuffer v)Pointer version ofViewportIndexedf.
 
- 
- 
- 
Field Detail- 
GL_MAX_VIEWPORTS, GL_VIEWPORT_SUBPIXEL_BITS, GL_VIEWPORT_BOUNDS_RANGE, GL_LAYER_PROVOKING_VERTEX, GL_VIEWPORT_INDEX_PROVOKING_VERTEXAccepted by thepnameparameter of GetBooleanv, GetIntegerv, GetFloatv, GetDoublev and GetInteger64v.
 - 
GL_UNDEFINED_VERTEXReturned in thedataparameter from a Get query with apnameof LAYER_PROVOKING_VERTEX or VIEWPORT_INDEX_PROVOKING_VERTEX.
 
- 
 - 
Method Detail- 
glViewportArrayvpublic static void glViewportArrayv(int first, java.nio.FloatBuffer v)Sets multiple viewports.- Parameters:
- first- the first viewport to set
- v- an array containing the viewport parameters
 
 - 
glViewportIndexedfpublic static void glViewportIndexedf(int index, float x, float y, float w, float h)Sets a specified viewport.- Parameters:
- index- the viewport to set
- x- the left viewport coordinate
- y- the bottom viewport coordinate
- w- the viewport width
- h- the viewport height
 
 - 
glViewportIndexedfvpublic static void glViewportIndexedfv(int index, java.nio.FloatBuffer v)Pointer version ofViewportIndexedf.- Parameters:
- index- the viewport to set
- v- the viewport parameters
 
 - 
glScissorArrayvpublic static void glScissorArrayv(int first, java.nio.IntBuffer v)Defines the scissor box for multiple viewports.- Parameters:
- first- the index of the first viewport whose scissor box to modify
- v- an array containing the left, bottom, width and height of each scissor box, in that order
 
 - 
glScissorIndexedpublic static void glScissorIndexed(int index, int left, int bottom, int width, int height)Defines the scissor box for a specific viewport.- Parameters:
- index- the index of the viewport whose scissor box to modify
- left- the left scissor box coordinate
- bottom- the bottom scissor box coordinate
- width- the scissor box width
- height- the scissor box height
 
 - 
glScissorIndexedvpublic static void glScissorIndexedv(int index, java.nio.IntBuffer v)Pointer version ofScissorIndexed.- Parameters:
- index- the index of the viewport whose scissor box to modify
- v- an array containing the left, bottom, width and height of each scissor box, in that order
 
 - 
glDepthRangeArrayvpublic static void glDepthRangeArrayv(int first, java.nio.DoubleBuffer v)Specifies mapping of depth values from normalized device coordinates to window coordinates for a specified set of viewports.- Parameters:
- first- the index of the first viewport whose depth range to update
- v- n array containing the near and far values for the depth range of each modified viewport
 
 - 
glDepthRangeIndexedpublic static void glDepthRangeIndexed(int index, double zNear, double zFar)Specifies mapping of depth values from normalized device coordinates to window coordinates for a specified viewport.- Parameters:
- index- the index of the viewport whose depth range to update
- zNear- the mapping of the near clipping plane to window coordinates. The initial value is 0.
- zFar- the mapping of the far clipping plane to window coordinates. The initial value is 1.
 
 - 
glGetFloati_vpublic static void glGetFloati_v(int target, int index, java.nio.FloatBuffer data)Queries the float value of an indexed state variable.- Parameters:
- target- the indexed state to query
- index- the index of the element being queried
- data- a scalar or buffer in which to place the returned data
 
 - 
glGetFloatipublic static float glGetFloati(int target, int index)Queries the float value of an indexed state variable.- Parameters:
- target- the indexed state to query
- index- the index of the element being queried
 
 - 
glGetDoublei_vpublic static void glGetDoublei_v(int target, int index, java.nio.DoubleBuffer data)Queries the double value of an indexed state variable.- Parameters:
- target- the indexed state to query
- index- the index of the element being queried
- data- a scalar or buffer in which to place the returned data
 
 - 
glGetDoubleipublic static double glGetDoublei(int target, int index)Queries the double value of an indexed state variable.- Parameters:
- target- the indexed state to query
- index- the index of the element being queried
 
 - 
glViewportArrayvpublic static void glViewportArrayv(int first, float[] v)Array version of:ViewportArrayv
 - 
glViewportIndexedfvpublic static void glViewportIndexedfv(int index, float[] v)Array version of:ViewportIndexedfv
 - 
glScissorArrayvpublic static void glScissorArrayv(int first, int[] v)Array version of:ScissorArrayv
 - 
glScissorIndexedvpublic static void glScissorIndexedv(int index, int[] v)Array version of:ScissorIndexedv
 - 
glDepthRangeArrayvpublic static void glDepthRangeArrayv(int first, double[] v)Array version of:DepthRangeArrayv
 - 
glGetFloati_vpublic static void glGetFloati_v(int target, int index, float[] data)Array version of:GetFloati_v
 - 
glGetDoublei_vpublic static void glGetDoublei_v(int target, int index, double[] data)Array version of:GetDoublei_v
 
- 
 
-