OpenGL Shader实现光照发光体特效

作者:JulyYu 时间:2022-03-16 18:51:50 

内发光原理

内发光原理简单概况是:采样周边像素alpha取平均值叠加效果。概括来说似乎好像特别简单,但需要一定的理解和消化。发光物体可以当做是一个圆形对象,去采集圆形对象周边像素值。例如已知圆形半径是R,角度是Angle,然后根据半径和角度推导算出当前像素坐标位置,用当前像素坐标位置得到透明度再去做计算。

但其实在阴影遮罩效果中似乎已经介绍过了同样能够通过。不同点在于阴影遮盖是利用圆形绘制向外部晕染而内发光效果是作用于内部。

OpenGL Shader实现光照发光体特效

发光体实现

首先采用绘制圆的方法实现RGB叠加。可以看到中心位置绘制圆的位置颜色较深,向外扩散颜色逐渐暗淡。效果虽然不对但已经知道下一步该怎么实现了。

void main() {
   vec2 uv = gl_FragCoord.xy / iResolution.xy;
   uv -= 0.5;
   uv.x *= iResolution.x/iResolution.y;
   vec3 color = vec3(0.);
   float glow = length(uv);
   color += glow;
   gl_FragColor = vec4(color,1.);
}

OpenGL Shader实现光照发光体特效

通过取反操作,可用一个数除以length(uv)再相乘一个小数来稍微减小值的大小。从最终结果可以看到所期望的效果。对比之前效果展示相除相当于对原结果取反,原先内部是数值最小,相除之后内部数值变成最大。

void main() {
   vec2 uv = gl_FragCoord.xy / iResolution.xy;
   uv -= 0.5;
   uv.x *= iResolution.x/iResolution.y;
   vec3 color = vec3(0.);
   float glow = 0.05 * 3./length(uv);
   color += glow;
   gl_FragColor = vec4(color,1.);
}

OpenGL Shader实现光照发光体特效

但过渡效果泛白范围似乎过大了一些继续对原算法进行优化。增加pow方法将数值变得更小一些。

float getGlow(float dist, float radius, float intensity){
   return pow(radius/dist, intensity);
}

void main() {
   vec2 uv = gl_FragCoord.xy / iResolution.xy;
   uv -= 0.5;
   uv.x *= iResolution.x/iResolution.y;
   vec3 color = vec3(0.);
   float glow = 0.05 * getGlow(length(uv), 1., 2.);
   color += glow;
   gl_FragColor = vec4(color,1.);
}

OpenGL Shader实现光照发光体特效

扩展效果

小太阳

改变发光位置和发光颜色模拟实现太阳光照的效果。

float getGlow(float dist, float radius, float intensity){
   return radius/dist;
}

void main() {
   vec2 uv = gl_FragCoord.xy / iResolution.xy;
   vec3 color = vec3(0.);

vec2 uv2 = uv;
   uv2 -=1.0;
   float glow = 0.09 * 3./length(uv2);
   color += (5.0 * vec3(0.02 * glow) + vec3(0.9686, 0.6941, 0.0) * glow);
   gl_FragColor = vec4(color,1.);
}

OpenGL Shader实现光照发光体特效

光源移动效果

float getGlow(float dist, float radius, float intensity){
   return radius/dist;
}

void main() {
   vec2 uv = gl_FragCoord.xy / iResolution.xy;
   vec3 color = texture(iChannel1,uv).rgb;

float position = sin(iTime) / 2.;
   vec2 uv2 = uv;
   uv2 -=0.5;
   uv2.x *= iResolution.x/iResolution.y;
   uv2 += position;
   float glow = 0.09 * 3./length(uv2);
   color += (5.0 * vec3(0.02 * glow));
   gl_FragColor = vec4(color,1.);
}

OpenGL Shader实现光照发光体特效

来源:https://juejin.cn/post/7063261134811299870

标签:OpenGL,Shader,光照,发光
0
投稿

猜你喜欢

  • Java 蒙特卡洛算法求圆周率近似值实例详解

    2023-10-19 23:32:10
  • C# 文件操作函数 创建文件 判断存在

    2023-08-12 15:14:51
  • Java版的7种单例模式写法示例

    2023-08-13 04:24:57
  • SpringBoot绿叶显示yml和端口问题及解决方法

    2023-12-09 00:29:13
  • ReentrantLock从源码解析Java多线程同步学习

    2023-10-13 02:32:55
  • Android短信验证码(用的Mob短信验证)

    2022-12-16 15:22:41
  • JNI方法实现图片压缩(压缩率极高)

    2021-08-07 11:32:55
  • Java中多线程下载图片并压缩能提高效率吗

    2023-08-06 07:40:10
  • Android 优雅的实现通用格式化编辑

    2023-02-08 05:24:02
  • Android图片占用内存全面分析

    2023-02-20 01:05:38
  • OpenCV和C++实现图像的翻转(镜像)、平移、旋转、仿射与透视变换

    2023-07-14 23:47:22
  • 详解Java的按位操作符

    2022-02-02 10:55:25
  • java获取百度网盘真实下载链接的方法

    2021-09-07 21:16:08
  • java操作elasticsearch的案例解析

    2021-06-27 19:17:13
  • Feign Client 超时时间配置不生效的解决

    2021-09-05 15:49:11
  • vs 中C#项目读取JSON配置文件的方法

    2022-09-22 15:04:05
  • SpringBoot整合Mybatis实现CRUD

    2022-01-10 09:26:45
  • Spring如何基于注解配置使用ehcache

    2022-08-16 03:24:32
  • SWT(JFace)体验之ViewForm的使用

    2023-10-20 13:02:01
  • java中单例模式讲解

    2022-05-22 14:24:07
  • asp之家 软件编程 m.aspxhome.com