RELATEED CONSULTING
相关咨询
选择下列产品马上在线沟通
服务时间:8:30-17:00
你可能遇到了下面的问题
关闭右侧工具栏

新闻中心

这里有您想知道的互联网营销解决方案
基于Qt的OpenGL可编程管线学习(15)-颜色加深、颜色减淡、想家相减

1、颜色加深

网站建设哪家好,找成都创新互联!专注于网页设计、网站建设、微信开发、成都小程序开发、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了旌阳免费建站欢迎大家使用!

shader

//颜色加深
uniform sampler2D U_MainTexture;
uniform sampler2D U_SubTexture;

varying vec2 M_coord;

void main()
{
        vec4 blendColor = texture2D(U_SubTexture, M_coord);
        vec4 baseColor = texture2D(U_MainTexture, M_coord);
        gl_FragColor = vec4(1.0) - (vec4(1.0) - baseColor) / blendColor;
}

效果图

基于Qt的OpenGL可编程管线学习(15)- 颜色加深、颜色减淡、想家相减

2、颜色减淡

shader

//颜色减淡
uniform sampler2D U_MainTexture;
uniform sampler2D U_SubTexture;

varying vec2 M_coord;

void main()
{
        vec4 blendColor = texture2D(U_SubTexture, M_coord);
        vec4 baseColor = texture2D(U_MainTexture, M_coord);
        gl_FragColor = baseColor / (vec4(1.0) - blendColor);
}

效果图

基于Qt的OpenGL可编程管线学习(15)- 颜色加深、颜色减淡、想家相减

3、相加

shader

//相加
uniform sampler2D U_MainTexture;
uniform sampler2D U_SubTexture;

varying vec2 M_coord;

void main()
{
        vec4 blendColor = texture2D(U_SubTexture, M_coord);
        vec4 baseColor = texture2D(U_MainTexture, M_coord);
        gl_FragColor = blendColor + baseColor;
}

基于Qt的OpenGL可编程管线学习(15)- 颜色加深、颜色减淡、想家相减

4、相减

shader

//相减
uniform sampler2D U_MainTexture;
uniform sampler2D U_SubTexture;

varying vec2 M_coord;

void main()
{
        vec4 blendColor = texture2D(U_SubTexture, M_coord);
        vec4 baseColor = texture2D(U_MainTexture, M_coord);
        gl_FragColor = vec4(baseColor.rgb - blendColor.rgb, 1.0);
}

效果图

基于Qt的OpenGL可编程管线学习(15)- 颜色加深、颜色减淡、想家相减


分享文章:基于Qt的OpenGL可编程管线学习(15)-颜色加深、颜色减淡、想家相减
网页地址:http://scyingshan.cn/article/pecjgp.html