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

org.lwjgl.opengles.EXTInstancedArrays Maven / Gradle / Ivy

Go to download

A royalty-free, cross-platform API for full-function 2D and 3D graphics on embedded systems - including consoles, phones, appliances and vehicles.

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

import java.nio.*;

import org.lwjgl.system.*;

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

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

A common use case in GL for some applications is to be able to draw the same object, or groups of similar objects that share vertex data, primitive * count and type, multiple times. This extension provides a means of accelerating such use cases while reducing the number of API calls, and keeping the * amount of duplicate data to a minimum.

* *

This extension introduces an array "divisor" for generic vertex array attributes, which when non-zero specifies that the attribute is "instanced." An * instanced attribute does not advance per-vertex as usual, but rather after every {@code divisor} conceptual draw calls.

* *

(Attributes which aren't instanced are repeated in their entirety for every conceptual draw call.)

* *

By specifying transform data in an instanced attribute or series of instanced attributes, vertex shaders can, in concert with the instancing draw * calls, draw multiple instances of an object with one draw call.

* *

Requires {@link GLES20 GLES 2.0}.

*/ public class EXTInstancedArrays { static { GLES.initialize(); } /** Accepted by the {@code pname} parameters of GetVertexAttribfv and GetVertexAttribiv. */ public static final int GL_VERTEX_ATTRIB_ARRAY_DIVISOR_EXT = 0x88FE; protected EXTInstancedArrays() { throw new UnsupportedOperationException(); } // --- [ glDrawArraysInstancedEXT ] --- public static native void glDrawArraysInstancedEXT(@NativeType("GLenum") int mode, @NativeType("GLint") int start, @NativeType("GLsizei") int count, @NativeType("GLsizei") int primcount); // --- [ glDrawElementsInstancedEXT ] --- public static native void nglDrawElementsInstancedEXT(int mode, int count, int type, long indices, int primcount); public static void glDrawElementsInstancedEXT(@NativeType("GLenum") int mode, @NativeType("GLsizei") int count, @NativeType("GLenum") int type, @NativeType("void const *") long indices, @NativeType("GLsizei") int primcount) { nglDrawElementsInstancedEXT(mode, count, type, indices, primcount); } public static void glDrawElementsInstancedEXT(@NativeType("GLenum") int mode, @NativeType("GLenum") int type, @NativeType("void const *") ByteBuffer indices, @NativeType("GLsizei") int primcount) { nglDrawElementsInstancedEXT(mode, indices.remaining() >> GLESChecks.typeToByteShift(type), type, memAddress(indices), primcount); } public static void glDrawElementsInstancedEXT(@NativeType("GLenum") int mode, @NativeType("void const *") ByteBuffer indices, @NativeType("GLsizei") int primcount) { nglDrawElementsInstancedEXT(mode, indices.remaining(), GLES20.GL_UNSIGNED_BYTE, memAddress(indices), primcount); } public static void glDrawElementsInstancedEXT(@NativeType("GLenum") int mode, @NativeType("void const *") ShortBuffer indices, @NativeType("GLsizei") int primcount) { nglDrawElementsInstancedEXT(mode, indices.remaining(), GLES20.GL_UNSIGNED_SHORT, memAddress(indices), primcount); } public static void glDrawElementsInstancedEXT(@NativeType("GLenum") int mode, @NativeType("void const *") IntBuffer indices, @NativeType("GLsizei") int primcount) { nglDrawElementsInstancedEXT(mode, indices.remaining(), GLES20.GL_UNSIGNED_INT, memAddress(indices), primcount); } // --- [ glVertexAttribDivisorEXT ] --- public static native void glVertexAttribDivisorEXT(@NativeType("GLuint") int index, @NativeType("GLuint") int divisor); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy