文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

OpenGL Shader如何实现阴影遮罩效果

2023-06-29 03:29

关注

小编给大家分享一下OpenGL Shader如何实现阴影遮罩效果,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

smoothstep另一种用法

在之前OpenGL Shader-抗锯齿实现文章中所介绍的那样:为了抗锯齿效果可以用smoothstep函数对绘制形状进行平滑过渡来实现。其中也提到了当smoothstep函数中入参ab范围过大时就会出现渐变效果。如OpenGL Shader-抗锯齿实现中所展示的效果:

OpenGL Shader如何实现阴影遮罩效果

遮罩效果实现

看到这个效果后似乎可以利用smoothstep函数中ab入参取大范围来实现不一样的特效能力。例如可以使用该特点来实现类似于老电影中遮罩效果,在视图边缘出现一层朦胧遮罩中间最亮四周有一层淡淡的阴影效果。

OpenGL Shader如何实现阴影遮罩效果

实现原理其实就是利用smoothstep函数入参使用大范围值,在绘制圆基础上改造处理。底色使用白色vec3(1.),阴影遮盖使用黑色vec3(1.)就能达到阴影遮罩效果了。

void main() {    vec2 uv = gl_FragCoord.xy / iResolution.xy;    vec4 texture = texture(iChannel2,uv);    uv -= 0.5;    uv.x *= iResolution.x/iResolution.y;    float m = 0.4;    m = smoothstep(m-0.2,m+0.2,length(uv) - 0.2);    vec3 pixel = mix(vec3(1.),vec3(0.),m);    gl_FragColor = vec4(pixel,1.0);    }

OpenGL Shader如何实现阴影遮罩效果

除了采用smoothstep函数实现外,下面还有一种方法也能实现阴影遮罩效果。如下glsl所示 对颜色向量vec4 texturevignette相乘,相当于改变色值通道亮度达到明暗对比;同时对于取值uv.y-0.5可以理解越接近中心取值越接近为0,那么计算得出的vignette就越大约接近为1。

void main() {    vec2 uv = gl_FragCoord.xy / iResolution.xy;    vec4 texture = vec4(1.);    float vigAmt = 4.0;    float vignette = (1.0-vigAmt*(uv.y-0.5)*(uv.y-0.5))*(1.0-vigAmt*(uv.x-0.5)*(uv.x-0.5));    texture *= vignette;    gl_FragColor = texture;}

OpenGL Shader如何实现阴影遮罩效果

通过对照也能发现采用圆形公式实现遮罩是有一定圆弧趋势,而另一种遮罩是偏向矩形,在特效效果上略有差异。以此类推肯定还可以根据这种方式来实现星型,爱心等形状遮罩。

smoothstep

OpenGL Shader如何实现阴影遮罩效果

OpenGL Shader如何实现阴影遮罩效果

vignette

OpenGL Shader如何实现阴影遮罩效果

OpenGL Shader如何实现阴影遮罩效果

效果扩展

最后可以增加一个time时间入参,通过vigAmt值不断变化vignette强弱来实现忽明忽暗的效果,会有一种在看老电影的感受。

#define time iTimevoid main() {    vec2 uv = gl_FragCoord.xy / iResolution.xy;    vec4 texture = texture(iChannel2,uv);    float vigAmt = 4.0 + 0.3 * sin(time + 5.0 * cos(time*5.0));    float vignette = (1.0-vigAmt*(uv.y-0.5)*(uv.y-0.5))*(1.0-vigAmt*(uv.x-0.5)*(uv.x-0.5));    texture *= vignette;    gl_FragColor = texture;}

OpenGL Shader如何实现阴影遮罩效果

以上是“OpenGL Shader如何实现阴影遮罩效果”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯