基于GLSL的聚光灯效果的绘制

本文介绍了如何使用GLSL在OpenGL中实现聚光灯效果,包括计算片段与光源的角度,设定聚光灯张角,利用平滑插值函数处理光强,并通过高斯模糊和独立帧缓存实现丁达尔效应。同时,调整片段距离和法线方向以增强光束的真实感和立体感。

体积光的绘制

写在前面的话:

这是基于openGL可编程管线的一次绘制实践,具体版本:openGL 3.3。

贴在前面的最终效果图:

显示结果


对于上述图片的简述:

1. 被光束照到的墙面的漫反射与镜面反射都得到了加强,且被照亮的区域边缘有自然的过渡;
2. 被光束照到的空间里产生了丁达尔现象,而且该圆锥形空间的边际模糊;
3. 光的强度随着投射距离的增大而逐渐变弱。

实现过程

在片段着色器中计算片段、光源两点的连线与聚光灯正射方向之间的夹角α大· 小,设定聚光灯光圆锥体的张角为一个常数Θ,若α大于Θ/2,则不点亮,若小于,则点亮。这样就完成了基本的一个聚光灯的效果。


用两个角度值来表示一个聚光灯的张角:较大的角Θ表示聚光灯能照射到的圆锥体空间的张角,若α大于Θ/2,则不被照亮;较小的角β表示聚光灯能完全照亮的圆锥体空间的张角,若α小于β/2,则光强为一个较大的常数;当α在两角之间,则用一个平滑插值smoothStep函数来计算这些中间区域的光强。这样就完成了一个光亮区域边缘软化的聚光灯效果。


在光束圆锥空间上实时绘制一个半透明的圆锥,这样就可以绘制一个简单的丁达尔现象。


在绘制光束圆锥体的时候将结果绘制到一个独立帧缓存绑定的纹理上去,然后用高斯模糊将其打散,在显示最后结果的纹理上再将打散之后的光束圆锥体画上去,这样就绘制出了一个比较真实的丁达尔现象。(高斯模糊效果可见下图中的红色区域)
高斯模糊之后的光束体


在片段着色器中绘制光束圆锥体时,根据片段与光源的距离去改变该片段的不透明度,在绘制被照亮的物体时,根据片段与光源的距离去改变光照的强度,岂可获得一个光亮有限且随距离柔和递减的光束。


在片段着色器中绘制光束圆锥体时,根据片段的法线方向,去改变不透明度,即可将一个整体的光束打撒成若干束光合成一个圆锥体光束的效果。(这一效果属于参数错误时意外所得)

1 课程简介:本课程详细讲解了OpenGL从入门到精通的理论+实践知识,对于每一个知识点都会带领学员通过代码来实现功能。其中涵盖了基础图元绘制,基础光照,高级过程,高级光照等内容;当前图形引擎的应用已经越来越广泛,春晚以及各大综艺节目已经开始使用XR作为主流的内容制作技术,房地产漫游及Web渲染技术已经开始茁壮发展,VR也即将突破硬件瓶颈;普遍的游戏引擎在独特的领域已经无法完全实用,且我们国家要发展自主科技技术,图形引擎以及CAD等卡脖子技术一定会蓬勃发展,所以同学们要抓住机会,趁势而上,熟悉底层,博取更大发展,学习OpenGL底层接口的应用以及图形学算法,将是您向纵深发展的第一步!2 课程解决优势:很多同学学习OpenGL最难的是找到路径,并且其中牵扯到的理论知识点无法完全理解透彻(比如VAO与VBO的区别,MVP矩阵变换的推导及原理,光照系统的设计及算法推导,帧缓存的灵活应用等),我们的课程可以带领大家从原理+实践的角度进行学习,每一个知识点都会:a 推导基础公式及原理 b 一行一行进行代码实践从而能够保证每位同学都学有所得,能够看得懂,学得会,用得上,并且能够培养自主研究的能力。学习课程所得:学习本课程完毕之后,学员可以全方位的完全了解OpenGL当中的必要接口,并且可以对图形学的基础知识融会贯通,可以制作中级的特效。并且对于UnrealEngine以及Unity3D的学习更加轻松,对于各类商业引擎当中的算法以及内容制作手法更加深刻理解把控。学员也可以自行进行图形引擎的设计以及研究,并且将本课程的知识点进行代码模块化编写;能够自主推导图形学管线以及应用当中的各类公式,并且理解其几何含义。 代码与PPT资源,已随课程附赠,请同学们对应课程下载 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值