在安卓中基于OpenGL ES实现随风飘荡3D动画效果

一、 背景

之前在一款金融APP上看到了类似A波浪一样的3D背景动画效果,觉得还挺好玩的,于是打算自己复刻一个出来玩玩。

二、分析和方案:

我希望做一个随时间变化的3D波浪动画,因此涉及的变量有:时间、每一个三维坐标的浪高z。而如果需要z轴的值根据x,y的坐标值不同有渐变的波浪作为规律基地,那么把z的值以sin(x + t) + cos(y + t)作为基础模板使得z和x,y,t都产生关系,即通过x,y的值获取波浪初始浪高,t作为相位移动波浪,结果赋予z值,即可产生波浪在波动的效果。后续通过叠加二维三角函数和调整参数符合自己效果即可。

实现方案1:通过在CPU计算上述规则,每一次drawCall都发起重新计算一次坐标的z值,重新buffer给显存。

实现方案2:初始化一个z值为0的平面,在vertex shader中通过传入的t值计算z值,最后再乘以变换矩阵。

显然第二种方法更适合这种对并行度有要求的事情,基本解放了CPU。

三、实现代码:

这里只放一个vertex shader,因为其余代码都只是模板代码而已:

cpp 复制代码
        uniform mat4 uMVPMatrix;
        uniform float uTimeStamp;
        attribute vec4 vPosition;
        varying float vDepth;
        void main() {
            vec4 point = vec4(vPosition);
            float t = uTimeStamp / 400.0;
            float z0 = ( sin(radians(vPosition.x * 100.0) + t) + cos(radians(vPosition.y * 50.0) + t / 2.0) ) * 0.5;
            float z1 = ( sin(radians(vPosition.x * 50.0) + t / 4.0) + cos(radians(vPosition.y * 60.0) + t / 3.0) ) * 0.5;
            point.z = z0 + z1;
            gl_Position = uMVPMatrix * point;
            vDepth = point.z;
        }

四、最终效果:

在vertex shader上用三角函数做大波浪玩玩

相关推荐
探物 AI16 天前
【3D·感知】从PointNet到PointPillars:如何让自动驾驶汽车“实时“看见3D世界?
3d·自动驾驶·汽车
苏州邦恩精密16 天前
GOM三维扫描在制造中的真实价值:让“修模”从经验动作变成数据动作
人工智能·科技·机器学习·3d·自动化·制造
YHHLAI16 天前
CSS 3D 硬核解析:四个属性手写旋转立方体
前端·css·3d
云飞云共享云桌面17 天前
传统工作站 vs 云飞云共享云桌面:制造业设计云桌面选型深度对比
运维·服务器·前端·网络·3d·架构·制造
LONGZETECH17 天前
无人机仿真教学软件选型实战:5 个硬核技术维度,避开实训建设踩坑
3d·无人机·交互·cocos2d
装不满的克莱因瓶17 天前
了解3D卷积原理——从空间感知到时空建模的深度学习核心算子
人工智能·pytorch·python·深度学习·机器学习·3d·ai
雪的季节17 天前
Qt Graphs 2D+3D介绍
qt·3d
CG_MAGIC17 天前
3ds Max材质编辑器:精简模式与Slate模式对比
3d·编辑器·材质·贴图·uv·建模教程
装不满的克莱因瓶17 天前
掌握3D CNN模型结构——从时空特征建模到视频理解与医学影像核心架构
人工智能·pytorch·python·深度学习·神经网络·3d·cnn
AniShort17 天前
AniShort携3D世界+3D导演台王炸组合AI短剧协作平台亮相2026横店AI短剧大会 近亿元融资赋能短剧工业化
人工智能·microsoft·3d