我们专注攀枝花网站设计 攀枝花网站制作 攀枝花网站建设
成都网站建设公司服务热线:400-028-6601

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

基于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://mswzjz.cn/article/pecjgp.html

其他资讯