All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.lwjgl.opengl.NVClipSpaceWScaling Maven / Gradle / Ivy

/*
 * Copyright LWJGL. All rights reserved.
 * License terms: https://www.lwjgl.org/license
 * MACHINE GENERATED FILE, DO NOT EDIT
 */
package org.lwjgl.opengl;

import org.lwjgl.system.*;

import static org.lwjgl.system.Checks.*;

/**
 * Virtual Reality (VR) applications often involve a post-processing step to apply a "barrel" distortion to the rendered image to correct the "pincushion"
 * distortion introduced by the optics in a VR device. The barrel distorted image has lower resolution along the edges compared to the center. Since the
 * original image is rendered at high resolution, which is uniform across the complete image, a lot of pixels towards the edges do not make it to the
 * final post-processed image.
 * 
 * 

This extension also provides a mechanism to render VR scenes at a non-uniform resolution, in particular a resolution that falls linearly from the * center towards the edges. This is achieved by scaling the "w" coordinate of the vertices in the clip space before perspective divide. The clip space * "w" coordinate of the vertices may be offset as of a function of "x" and "y" coordinates as follows:

* *
 * w' = w + Ax + By
* *

In the intended use case for viewport position scaling, an application should use a set of 4 viewports, one for each of the 4 quadrants of a Cartesian * coordinate system. Each viewport is set to the dimension of the image, but is scissored to the quadrant it represents. The application should specify A * and B coefficients of the w-scaling equation above, that have the same value, but different signs, for each of the viewports. The signs of A and B * should match the signs of X and Y for the quadrant that they represent such that the value of "w'" will always be greater than or equal to the original * "w" value for the entire image. Since the offset to "w", (Ax + By), is always positive and increases with the absolute values of "x" and "y", the * effective resolution will fall off linearly from the center of the image to its edges.

*/ public class NVClipSpaceWScaling { /** Accepted by the {@code cap} parameter of Enable, Disable, IsEnabled. */ public static final int GL_VIEWPORT_POSITION_W_SCALE_NV = 0x937C; /** Accepted by the {@code pname} parameter of GetBooleani_v, GetDoublei_v, GetIntegeri_v, GetFloati_v, and GetInteger64i_v. */ public static final int GL_VIEWPORT_POSITION_W_SCALE_X_COEFF = 0x937D, GL_VIEWPORT_POSITION_W_SCALE_Y_COEFF = 0x937E; static { GL.initialize(); } protected NVClipSpaceWScaling() { throw new UnsupportedOperationException(); } static boolean isAvailable(GLCapabilities caps) { return checkFunctions( caps.glViewportPositionWScaleNV ); } // --- [ glViewportPositionWScaleNV ] --- /** * If {@link #GL_VIEWPORT_POSITION_W_SCALE_NV VIEWPORT_POSITION_W_SCALE_NV} is enabled, the w coordinates for each primitive sent to a given viewport will be scaled as a function of its x and y * coordinates using the following equation: * *
     * w' = xcoeff * x + ycoeff * y + w;
* *

The coefficients for "x" and "y" used in the above equation depend on the viewport index, and are controlled by this command.

* *

The viewport specified by {@code index} has its coefficients for "x" and "y" set to the {@code xcoeff} and {@code ycoeff} values. Specifying these * coefficients enables rendering images at a non-uniform resolution, in particular a resolution that falls off linearly from the center towards the * edges, which is useful for VR applications. VR applications often involve a post-processing step to apply a "barrel" distortion to the rendered image * to correct the "pincushion" distortion introduced by the optics in a VR device. The barrel distorted image, has lower resolution along the edges * compared to the center. Since the original image is rendered at high resolution, which is uniform across the complete image, a lot of pixels towards * the edges do not make it to the final post-processed image. VR applications may use the w-scaling to minimize the processing of unused fragments. To * achieve the intended effect, applications should use a set of 4 viewports one for each of the 4 quadrants of a Cartesian coordinate system. Each * viewport is set to the dimension of the image, but is scissored to the quadrant it represents. The application should specify the x and y coefficients * of the w-scaling equation above, that have the same value, but different signs, for each of the viewports. The signs of {@code xcoeff} and * {@code ycoeff} should match the signs of X and Y for the quadrant that they represent such that the value of "w'" will always be greater than or equal * to the original "w" value for the entire image. Since the offset to "w", (Ax + By), is always positive and increases with the absolute values of "x" * and "y", the effective resolution will fall off linearly from the center of the image to its edges.

* * @param index the viewport index * @param xcoeff the x coefficient * @param ycoeff the y coefficient */ public static native void glViewportPositionWScaleNV(@NativeType("GLuint") int index, @NativeType("GLfloat") float xcoeff, @NativeType("GLfloat") float ycoeff); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy