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

Common.MatDefs.Post.ContrastAdjustment.frag Maven / Gradle / Ivy

/*
 * Copyright (c) 2009-2021 jMonkeyEngine
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are
 * met:
 *
 * * Redistributions of source code must retain the above copyright
 *   notice, this list of conditions and the following disclaimer.
 *
 * * Redistributions in binary form must reproduce the above copyright
 *   notice, this list of conditions and the following disclaimer in the
 *   documentation and/or other materials provided with the distribution.
 *
 * * Neither the name of 'jMonkeyEngine' nor the names of its contributors
 *   may be used to endorse or promote products derived from this software
 *   without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

/*
 * Used by ContrastAdjustment.j3md to adjust the color channels.
 *
 * First, the input range is normalized to upper and lower limits.
 * Then a power law is applied, using the exponent for each channel.
 * Finally, the output value is scaled linearly, using the scaling factor for each channel.
 *
 * Supports GLSL100 GLSL110 GLSL120 GLSL130.
 */

//constant inputs from java source
uniform float m_redChannelExponent;
uniform float m_greenChannelExponent;
uniform float m_blueChannelExponent;

//final scale values
uniform float m_redChannelScale;
uniform float m_greenChannelScale;
uniform float m_blueChannelScale;

//input range
uniform float m_lowerLimit;
uniform float m_upperLimit;

//container for the input from post.vert
uniform sampler2D m_Texture;

//varying input from post.vert vertex shader
varying vec2 texCoord;

void main() {
    //get the color from a 2d sampler.
    vec4 color = texture2D(m_Texture, texCoord);

    //apply the color transfer function.

    //1) adjust the channels input range
    color.rgb = (color.rgb - vec3(m_lowerLimit)) / (vec3(m_upperLimit) - vec3(m_lowerLimit));

    // avoid negative levels
    color.r = max(color.r, 0.0);
    color.g = max(color.g, 0.0);
    color.b = max(color.b, 0.0);

    //2) apply transfer functions on different channels.
    color.r = pow(color.r, m_redChannelExponent);
    color.g = pow(color.g, m_greenChannelExponent);
    color.b = pow(color.b, m_blueChannelExponent);

    //3) scale the output levels
    color.r = color.r * m_redChannelScale;
    color.b = color.b * m_blueChannelScale;
    color.g = color.g * m_greenChannelScale;

    //4) process the textures colors.
    gl_FragColor = color;
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy