图像亮度、对比度 算法--cg

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/mansir123/article/details/78740924

亮度、对比度原理:
亮度对比度的算法公式
一副图像的亮度对比度调节属于图像的灰度线性变换,其公式如下:
y = [x - 127.5 * (1 - B)] * k + 127.5 * (1 + B);
x为调节前的像素值,y为调节后的像素值。
其中B取值[-1,1],调节亮度;
k调节对比度,arctan(k)取值[1,89],所以
k = tan( (45 + 44 * c) / 180 * pi );
其中c取值[-1,1]。通常我们用该值来设置对比度
特别的,
当B=0 时:y = (x - 127.5) * k + 127.5; 这时只调节对比度。
当c=0 时,k = 1:y = x + 255 * B; 这时只调节亮度。

同时,我项目中是需要处理成黑白颜色的。rgb处理成黑白的方法通常是用经验算法:
float gray = dot( color, float3(0.2989, 0.5870, 0.1140));

cg实现:

sampler2D RT : register(s0);
float4 Gan_ps(//in float4 pos : POSITION,
                     float2 iTexCoord : TEXCOORD0,
                     float4 outPos : TEXCOORD1,
                    , float4 outColor : TEXCOORD2
                    ,uniform float br//亮度
                    ,uniform float duibi 
                     ) : COLOR
{
    float4 color=tex2D(RT, iTexCoord); 
    float c = dot( color.rgb, float3(0.2989, 0.5870, 0.1140)); //黑白处理
    float k=tan((45+44*duibi)/180.0*3.1415926);
    c=(c-0.5*(1-br))*k+0.5*(1+br);//亮度、对比度计算

    return float4(c,c,c,1);
}


猜你喜欢

转载自blog.csdn.net/mansir123/article/details/78740924