人生处万类,知识最为贤。这篇文章主要讲述Unity3D移动端海水的实时绘制相关的知识,希望能为你提供帮助。
海水的实时仿真一直是一个比较热门的话题,移动端海水的仿真更是热上加热,目前在这方面的研究已经很多了,但是结果都不是很近人意,在这里给大家介绍一种在移动端实时绘制的算法,满足了移动端运行的要求,而且可以在海面上显示高光,反射,以及折射效果,海浪滚动效果以及海上的泡沫效果,以及物体在大海上随海浪上下颠覆效果,比较真实的模拟了海浪的形成。
移动端海浪的生成尤其局限性,在这里采用网格块拼接,实现无限地形。GPU的渲染也需要使其在移动端能够运行。先将其效果图展示一下:
文章图片
反射,折射,海面光照都有了,而且实现了泡沫效果。
接下来开始分析其如何实现的。
【Unity3D移动端海水的实时绘制】首先我们要自定义生成网格块,然后再将其拼接,同时产生高度图,网格如下图示。
文章图片
代码如下所示:
文章图片
文章图片
接下来需要渲染海面高光图示如下:
文章图片
代码如下所示:
文章图片
文章图片
由于反射以及折射的效果渲染涉及到Shader的编程,我们将其代码实现如下:
文章图片
下面实现海浪的滚动以及泡沫效果图:
文章图片
其实现代码如下所示:
文章图片
以上代码采用的是Fourier算法实现的,通过枚举设置其方向。
其渲染Shader如下所示:
文章图片
以上就实现了移动端海水的实时仿真,最后把在手机上运行的效果图展示一下:
文章图片
推荐阅读
- #导入MD文档图片#Android自定义view
- 微信小程序模拟购物界面联动
- Android技术分享| 实现视频连麦直播
- Unity3D静态对象优化系列二
- Cocos2d-x《赵云要格斗》--虚拟摇杆控制精灵上下左右运动
- 如何用程序员的方式,营造七夕氛围感()
- iOS开发面试只需知道这些,技术基本通关!(block篇)
- Cocos2d-x《雷电大战》-双层地图无限滚动
- 如何从JavaScript中的字符串中剥离HTML(仅提取文本内容)