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

org.lwjgl.opengl.KHRBlendEquationAdvanced 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.*;

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

This extension adds a number of "advanced" blending equations that can be used to perform new color blending operations, many of which are more complex * than the standard blend modes provided by unextended OpenGL. This extension provides two different extension string entries:

* *
    *
  • KHR_blend_equation_advanced:Provides the new blending equations, but guarantees defined results only if each sample is touched no more than * once in any single rendering pass. The command {@link #glBlendBarrierKHR BlendBarrierKHR} is provided to indicate a boundary between passes.
  • *
  • {@link KHRBlendEquationAdvancedCoherent KHR_blend_equation_advanced_coherent}: Provides the new blending equations, and guarantees that blending is * done coherently and in API primitive order. An enable is provided to allow implementations to opt out of fully coherent blending and instead behave * as though only KHR_blend_equation_advanced were supported.
  • *
* *

Some implementations may support KHR_blend_equation_advanced without supporting KHR_blend_equation_advanced_coherent.

* *

In unextended OpenGL, the set of blending equations is limited, and can be expressed very simply. The {@link GL14#GL_MIN MIN} and {@link GL14#GL_MAX MAX} blend equations * simply compute component-wise minimums or maximums of source and destination color components. The {@link GL14#GL_FUNC_ADD FUNC_ADD}, {@link GL14#GL_FUNC_SUBTRACT FUNC_SUBTRACT}, and * {@link GL14#GL_FUNC_REVERSE_SUBTRACT FUNC_REVERSE_SUBTRACT} multiply the source and destination colors by source and destination factors and either add the two products together * or subtract one from the other. This limited set of operations supports many common blending operations but precludes the use of more sophisticated * transparency and blending operations commonly available in many dedicated imaging APIs.

* *

This extension provides a number of new "advanced" blending equations. Unlike traditional blending operations using the {@link GL14#GL_FUNC_ADD FUNC_ADD} equation, * these blending equations do not use source and destination factors specified by {@link GL11#glBlendFunc BlendFunc}. Instead, each blend equation specifies a complete * equation based on the source and destination colors. These new blend equations are used for both RGB and alpha components; they may not be used to * perform separate RGB and alpha blending (via functions like {@link GL20#glBlendEquationSeparate BlendEquationSeparate}).

* *

These blending operations are performed using premultiplied source and destination colors, where RGB colors produced by the fragment shader and stored * in the framebuffer are considered to be multiplied by alpha (coverage). Many of these advanced blending equations are formulated where the result of * blending source and destination colors with partial coverage have three separate contributions: from the portions covered by both the source and the * destination, from the portion covered only by the source, and from the portion covered only by the destination. Such equations are defined assuming that * the source and destination coverage have no spatial correlation within the pixel.

* *

In addition to the coherency issues on implementations not supporting KHR_blend_equation_advanced_coherent, this extension has several limitations worth * noting. First, the new blend equations are not supported while rendering to more than one color buffer at once; an {@link GL11#GL_INVALID_OPERATION INVALID_OPERATION} will be * generated if an application attempts to render any primitives in this unsupported configuration. Additionally, blending precision may be limited to * 16-bit floating-point, which could result in a loss of precision and dynamic range for framebuffer formats with 32-bit floating-point components, and in * a loss of precision for formats with 12- and 16-bit signed or unsigned normalized integer components.

* *

Requires {@link GL20 OpenGL 2.0}.

*/ public class KHRBlendEquationAdvanced { /** Accepted by the {@code mode} parameter of BlendEquation and BlendEquationi. */ public static final int GL_MULTIPLY_KHR = 0x9294, GL_SCREEN_KHR = 0x9295, GL_OVERLAY_KHR = 0x9296, GL_DARKEN_KHR = 0x9297, GL_LIGHTEN_KHR = 0x9298, GL_COLORDODGE_KHR = 0x9299, GL_COLORBURN_KHR = 0x929A, GL_HARDLIGHT_KHR = 0x929B, GL_SOFTLIGHT_KHR = 0x929C, GL_DIFFERENCE_KHR = 0x929E, GL_EXCLUSION_KHR = 0x92A0, GL_HSL_HUE_KHR = 0x92AD, GL_HSL_SATURATION_KHR = 0x92AE, GL_HSL_COLOR_KHR = 0x92AF, GL_HSL_LUMINOSITY_KHR = 0x92B0; static { GL.initialize(); } protected KHRBlendEquationAdvanced() { throw new UnsupportedOperationException(); } static boolean isAvailable(GLCapabilities caps) { return checkFunctions( caps.glBlendBarrierKHR ); } // --- [ glBlendBarrierKHR ] --- /** * Specifies a boundary between passes when using advanced blend equations. * *

When using advanced blending equations, applications should split their rendering into a collection of blending passes, none of which touch an * individual sample in the framebuffer more than once. The results of blending are undefined if the sample being blended has been touched previously in * the same pass. Any command that causes the value of a sample to be modified using the framebuffer is considered to touch the sample, including clears, * blended or unblended primitives, and {@link GL30#glBlitFramebuffer BlitFramebuffer} copies.

*/ public static native void glBlendBarrierKHR(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy