OpenGL ES之实现动态(水波纹)涟漪效果

阅读: 评论:0

OpenGL ES之实现动态(水波纹)涟漪效果

OpenGL ES之实现动态(水波纹)涟漪效果

  • 在物理世界中水波纹的特点如下所示,从水面的正上方往下看,在凹面上方观察到的是缩小效果,而在凸面上方观察到的是放大效果,然后整个水波纹效果就是放大和缩小效果的交叉排列:

  • 因此,要实现“水波纹涟漪”的效果,实际上就是一组组相互交替、幅度向外部逐渐减小的缩小放大效果组合。可以将水波纹模型简化成一组放大和缩小效果随时间逐步向外部偏移。水波纹效果原理如下所示,以点击位置为中心,发生形变的区域是内圆和外圆之间的区域,以归一化时间变量 u_Time 大小为半径构建的圆(蓝色虚线)为边界,设定内侧是实现缩小效果的区域,外侧为实现放大效果的区域,也可以反之设定:

  • 发生形变区域的宽度为固定值 2*u_Boundary ,然后这个形变区域随着 u_Time 的变大逐步向外侧移动,最后就形成了动态的水波纹效果。设采样点到中心点的距离为 Distance ,然后计算 Distance-u_Time=diff 的值来判定,采样点是位于缩小区域(diff < 0)还是放大区域(diff > 0),最后只需要构建一个平滑的函数,以 diff 作为输入,diff < 0 的时候函数输出正值,diff > 0 的时候函数输出负值。

本文发布于:2024-01-29 01:53:40,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170646442311870.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:涟漪   效果   动态   水波纹   OpenGL
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23