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

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

There is a newer version: 3.3.0
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 static org.lwjgl.system.Checks.*;

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

OpenGL currently supports (at least) 16 vertex attributes and 16 vertex buffer bindings, with a fixed mapping between vertex attributes and vertex * buffer bindings. This extension allows the application to change the mapping between attributes and bindings, which can make it more efficient to update * vertex buffer bindings for interleaved vertex formats where many attributes share the same buffer.

* *

This extension also separates the vertex binding update from the vertex attribute format update, which saves applications the effort of redundantly * specifying the same format state over and over.

* *

Conceptually, this extension splits the state for generic vertex attribute arrays into:

* *
    *
  • An array of vertex buffer binding points, each of which specifies: * *
      *
    • a bound buffer object
    • *
    • a starting offset for the vertex attribute data in that buffer object
    • *
    • a stride used by all attributes using that binding point, and
    • *
    • a frequency divisor used by all attributes using that binding point.
    • *
  • *
  • An array of generic vertex attribute format information records, each of which specifies: * *
      *
    • a reference to one of the new buffer binding points above
    • *
    • a component count and format, and a normalization flag for the attribute data, and
    • *
    • the offset of the attribute data relative to the base offset of each vertex found at the associated binding point.
    • *
  • *
* *

Promoted to core in {@link GL43 OpenGL 4.3}.

*/ public class ARBVertexAttribBinding { /** Accepted by the {@code pname} parameter of GetVertexAttrib*v. */ public static final int GL_VERTEX_ATTRIB_BINDING = 0x82D4, GL_VERTEX_ATTRIB_RELATIVE_OFFSET = 0x82D5; /** Accepted by the {@code target} parameter of GetBooleani_v, GetIntegeri_v, GetFloati_v, GetDoublei_v, and GetInteger64i_v. */ public static final int GL_VERTEX_BINDING_DIVISOR = 0x82D6, GL_VERTEX_BINDING_OFFSET = 0x82D7, GL_VERTEX_BINDING_STRIDE = 0x82D8, GL_VERTEX_BINDING_BUFFER = 0x8F4F; /** Accepted by the {@code pname} parameter of GetIntegerv, .... */ public static final int GL_MAX_VERTEX_ATTRIB_RELATIVE_OFFSET = 0x82D9, GL_MAX_VERTEX_ATTRIB_BINDINGS = 0x82DA; static { GL.initialize(); } protected ARBVertexAttribBinding() { throw new UnsupportedOperationException(); } static boolean isAvailable(GLCapabilities caps, java.util.Set ext) { return checkFunctions( caps.glBindVertexBuffer, caps.glVertexAttribFormat, caps.glVertexAttribIFormat, caps.glVertexAttribLFormat, caps.glVertexAttribBinding, caps.glVertexBindingDivisor, ext.contains("GL_EXT_direct_state_access") ? caps.glVertexArrayBindVertexBufferEXT : -1L, ext.contains("GL_EXT_direct_state_access") ? caps.glVertexArrayVertexAttribFormatEXT : -1L, ext.contains("GL_EXT_direct_state_access") ? caps.glVertexArrayVertexAttribIFormatEXT : -1L, ext.contains("GL_EXT_direct_state_access") ? caps.glVertexArrayVertexAttribLFormatEXT : -1L, ext.contains("GL_EXT_direct_state_access") ? caps.glVertexArrayVertexAttribBindingEXT : -1L, ext.contains("GL_EXT_direct_state_access") ? caps.glVertexArrayVertexBindingDivisorEXT : -1L ); } // --- [ glBindVertexBuffer ] --- /** * Binds a buffer to a vertex buffer bind point. * * @param bindingindex the index of the vertex buffer binding point to which to bind the buffer * @param buffer the name of an existing buffer to bind to the vertex buffer binding point * @param offset the offset of the first element of the buffer * @param stride the distance between elements within the buffer */ public static native void glBindVertexBuffer(int bindingindex, int buffer, long offset, int stride); // --- [ glVertexAttribFormat ] --- /** * Specifies the organization of data in vertex arrays. * * @param attribindex the generic vertex attribute array being described * @param size the number of values per vertex that are stored in the array. One of:
1234{@link GL12#GL_BGRA BGRA}
* @param type the type of the data stored in the array * @param normalized if true then integer data is normalized to the range [-1, 1] or [0, 1] if it is signed or unsigned, respectively. If false then integer data is * directly converted to floating point. * @param relativeoffset the offset, measured in basic machine units of the first element relative to the start of the vertex buffer binding this attribute fetches from */ public static native void glVertexAttribFormat(int attribindex, int size, int type, boolean normalized, int relativeoffset); // --- [ glVertexAttribIFormat ] --- /** * Specifies the organization of pure integer data in vertex arrays. * * @param attribindex the generic vertex attribute array being described * @param size the number of values per vertex that are stored in the array. One of:
1234{@link GL12#GL_BGRA BGRA}
* @param type the type of the data stored in the array * @param relativeoffset the offset, measured in basic machine units of the first element relative to the start of the vertex buffer binding this attribute fetches from */ public static native void glVertexAttribIFormat(int attribindex, int size, int type, int relativeoffset); // --- [ glVertexAttribLFormat ] --- /** * Specifies the organization of 64-bit double data in vertex arrays. * * @param attribindex the generic vertex attribute array being described * @param size the number of values per vertex that are stored in the array. One of:
1234{@link GL12#GL_BGRA BGRA}
* @param type the type of the data stored in the array * @param relativeoffset the offset, measured in basic machine units of the first element relative to the start of the vertex buffer binding this attribute fetches from */ public static native void glVertexAttribLFormat(int attribindex, int size, int type, int relativeoffset); // --- [ glVertexAttribBinding ] --- /** * Associate a vertex attribute and a vertex buffer binding. * * @param attribindex the index of the attribute to associate with a vertex buffer binding * @param bindingindex the index of the vertex buffer binding with which to associate the generic vertex attribute */ public static native void glVertexAttribBinding(int attribindex, int bindingindex); // --- [ glVertexBindingDivisor ] --- /** * Modifies the rate at which generic vertex attributes advance during instanced rendering. * * @param bindingindex the index of the generic vertex attribute * @param divisor the number of instances that will pass between updates of the generic attribute at slot {@code index} */ public static native void glVertexBindingDivisor(int bindingindex, int divisor); // --- [ glVertexArrayBindVertexBufferEXT ] --- /** * DSA version of {@link #glBindVertexBuffer BindVertexBuffer}. * * @param vaobj the vertex array object * @param bindingindex the index of the vertex buffer binding point to which to bind the buffer * @param buffer the name of an existing buffer to bind to the vertex buffer binding point * @param offset the offset of the first element of the buffer * @param stride the distance between elements within the buffer */ public static native void glVertexArrayBindVertexBufferEXT(int vaobj, int bindingindex, int buffer, long offset, int stride); // --- [ glVertexArrayVertexAttribFormatEXT ] --- /** * DSA version of {@link #glVertexAttribFormat VertexAttribFormat}. * * @param vaobj the vertex array object * @param attribindex the generic vertex attribute array being described * @param size the number of values per vertex that are stored in the array. One of:
1234{@link GL12#GL_BGRA BGRA}
* @param type the type of the data stored in the array * @param normalized if true then integer data is normalized to the range [-1, 1] or [0, 1] if it is signed or unsigned, respectively. If false then integer data is * directly converted to floating point. * @param relativeoffset the offset, measured in basic machine units of the first element relative to the start of the vertex buffer binding this attribute fetches from */ public static native void glVertexArrayVertexAttribFormatEXT(int vaobj, int attribindex, int size, int type, boolean normalized, int relativeoffset); // --- [ glVertexArrayVertexAttribIFormatEXT ] --- /** * DSA version of {@link #glVertexAttribIFormat VertexAttribIFormat}. * * @param vaobj the vertex array object * @param attribindex the generic vertex attribute array being described * @param size the number of values per vertex that are stored in the array. One of:
1234{@link GL12#GL_BGRA BGRA}
* @param type the type of the data stored in the array * @param relativeoffset the offset, measured in basic machine units of the first element relative to the start of the vertex buffer binding this attribute fetches from */ public static native void glVertexArrayVertexAttribIFormatEXT(int vaobj, int attribindex, int size, int type, int relativeoffset); // --- [ glVertexArrayVertexAttribLFormatEXT ] --- /** * DSA version of {@link #glVertexAttribLFormat VertexAttribLFormat}. * * @param vaobj the vertex array object * @param attribindex the generic vertex attribute array being described * @param size the number of values per vertex that are stored in the array. One of:
1234{@link GL12#GL_BGRA BGRA}
* @param type the type of the data stored in the array * @param relativeoffset the offset, measured in basic machine units of the first element relative to the start of the vertex buffer binding this attribute fetches from */ public static native void glVertexArrayVertexAttribLFormatEXT(int vaobj, int attribindex, int size, int type, int relativeoffset); // --- [ glVertexArrayVertexAttribBindingEXT ] --- /** * DSA version of {@link #glVertexAttribBinding VertexAttribBinding}. * * @param vaobj the vertex array object * @param attribindex the index of the attribute to associate with a vertex buffer binding * @param bindingindex the index of the vertex buffer binding with which to associate the generic vertex attribute */ public static native void glVertexArrayVertexAttribBindingEXT(int vaobj, int attribindex, int bindingindex); // --- [ glVertexArrayVertexBindingDivisorEXT ] --- /** * DSA version of {@link #glVertexBindingDivisor VertexBindingDivisor}. * * @param vaobj the vertex array object * @param bindingindex the index of the generic vertex attribute * @param divisor the number of instances that will pass between updates of the generic attribute at slot {@code index} */ public static native void glVertexArrayVertexBindingDivisorEXT(int vaobj, int bindingindex, int divisor); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy