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

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

Go to download

The most widely adopted 2D and 3D graphics API in the industry, bringing thousands of applications to a wide variety of computer platforms.

There is a newer version: 3.3.5
Show newest version
/*
 * 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.*;

/**
 * Native bindings to the AMD_interleaved_elements extension.
 * 
 * 

The glDrawElements function and its variants (instanced and indirect, for example) allow OpenGL to draw indexed arrays of vertices. Since its * inception, OpenGL has supported unsigned bytes, unsigned shorts and unsigned integers as index types. However, all enabled vertex arrays may be * represented by at most one shared index.

* *

A common scenario in graphics rendering is that several faces share a vertex where, for each face some properties of a vertex (position and texture * coordinates, for example) should be common but others must be unique (colors, normals, and so on). Consider a mesh of a cube with per-face normals, for * example. There are 8 vertices and 6 normals, and 12 triangles (where each face of the cube is represented as two triangles). To render this cube, we * must compute the 24 unique permutations of position and normal and build a new element list to index into it. In fact, any advantage of indexed draw is * lost here as the number of required permutations is equal to the final vertex count required to draw the object.

* *

This extension allows OpenGL to process multi-component packed element data. The maximum size of a vertex's index data is not increased, but the * facility to store 2 16-bit or 2 or 4 8-bit indices per vertex is introduced. Each vertex attribute is given a swizzle property to allow its index to be * sourced from one of up to 4 channels of index data. This effectively allows an application to supply multiple interleaved streams of index data to * OpenGL. Each vertex attribute is given a 'channel selector' to select one of the up to 4 channels of vertex index information presented to OpenGL. This * enables the use-case described above and many more. The swizzle parameter is also applied to vertex indices passed to shaders, and updates to the * definition of base vertex parameters and primitive restart are applied.

*/ public class AMDInterleavedElements { /** Accepted by the {@code pname} parameter of VertexAttribParameteriAMD and GetVertexAttrib{iv|dv|fv|Iiv|Iuiv|Ldv}. */ public static final int GL_VERTEX_ELEMENT_SWIZZLE_AMD = 0x91A4; /** Selected by the {@code pname} parameter of ProgramParameteri and GetProgramiv. */ public static final int GL_VERTEX_ID_SWIZZLE_AMD = 0x91A5; static { GL.initialize(); } protected AMDInterleavedElements() { throw new UnsupportedOperationException(); } static boolean isAvailable(GLCapabilities caps) { return checkFunctions( caps.glVertexAttribParameteriAMD ); } // --- [ glVertexAttribParameteriAMD ] --- public static native void glVertexAttribParameteriAMD(@NativeType("GLuint") int index, @NativeType("GLenum") int pname, @NativeType("GLint") int param); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy