首页 > 其他分享 >Unity插件 - MeshEditor(十一) 模型正弦扭曲特效

Unity插件 - MeshEditor(十一) 模型正弦扭曲特效

时间:2022-12-13 15:05:23浏览次数:79  
标签:插件 WaveMold vertices FixedAxis Waveing MeshEditor WaveDirection Unity &&


更新日期:2020年4月23日。
Github源码:​​​[点我获取源码]​

 

先上几张效果图:

Unity插件 - MeshEditor(十一) 模型正弦扭曲特效_Unity

 

Unity插件 - MeshEditor(十一) 模型正弦扭曲特效_i++_02

 

 

OK,进入今天的正题吧,插一个正弦函数的话题进来:

 

首先,正弦函数曲线,如下:

 

Unity插件 - MeshEditor(十一) 模型正弦扭曲特效_Unity_03

 

在如上坐标系中,这条正弦曲线代表的就是函数:y = a * sin(x) 中所有的点(x, y)所组成的曲线。

 

那么所表达的意思就是:随着x的值线性变化,y的值会在两个固定值之间来回变化,而这个固定值的大小由a来决定。

 

假定我们的模型左右方向是X轴,上下方向是Y轴,前后方向是Z轴,想让模型实现第一张图中的效果,就是把Z轴当做正弦函数中的y(在固定值间变化),把Y轴当做正弦函数中的x(值线性变化)。

 

我们将正弦函数:y = a * sin(x) 中的x和y替换:

 

 

vertice.z = WaveRange * Mathf.Sin(vertice.y + _weight);

 

 

提供一个_weight参数,使其在0到2π间变化,这样的话就能保持我们正弦函数中的x在2π区间中变化,众所周知正弦曲线上每一个2π长度的距离内y值构成一个来回,所以这样我们的运动才会连贯。

 

也就是说,随着vertice.y的变化(不同顶点的y坐标自然有的不同),产生一种扭曲变化的值并赋值给vertice.z,便达到了我们想要的效果。

 

这里的WaveRange为正弦函数中的系数a,它的值将决定y值的变化区间,也就是我们的模型正弦运动的幅度。

 

总之思路就这么简单,贴一下代码:

准备工作:

 

/// <summary>
/// 准备
/// </summary>
void WaveReady()
{
_2PI = Mathf.PI * 2;
_weight = 0;
_isCanWave = true;

if (FixedAxis == WaveDirection.X && WaveAxis == WaveDirection.Y && WaveMold == WaveType.entity)
{
Waveing = MarginWaveEntityXY;
}
else if (FixedAxis == WaveDirection.X && WaveAxis == WaveDirection.Y && WaveMold == WaveType.Squash)
{
Waveing = MarginWaveSquashXY;
}
else if (FixedAxis == WaveDirection.X && WaveAxis == WaveDirection.Z && WaveMold == WaveType.entity)
{
Waveing = MarginWaveEntityXZ;
}
else if (FixedAxis == WaveDirection.X && WaveAxis == WaveDirection.Z && WaveMold == WaveType.Squash)
{
Waveing = MarginWaveSquashXZ;
}
else if (FixedAxis == WaveDirection.Y && WaveAxis == WaveDirection.X && WaveMold == WaveType.entity)
{
Waveing = MarginWaveEntityYX;
}
else if (FixedAxis == WaveDirection.Y && WaveAxis == WaveDirection.X && WaveMold == WaveType.Squash)
{
Waveing = MarginWaveSquashYX;
}
else if (FixedAxis == WaveDirection.Y && WaveAxis == WaveDirection.Z && WaveMold == WaveType.entity)
{
Waveing = MarginWaveEntityYZ;
}
else if (FixedAxis == WaveDirection.Y && WaveAxis == WaveDirection.Z && WaveMold == WaveType.Squash)
{
Waveing = MarginWaveSquashYZ;
}
else if (FixedAxis == WaveDirection.Z && WaveAxis == WaveDirection.X && WaveMold == WaveType.entity)
{
Waveing = MarginWaveEntityZX;
}
else if (FixedAxis == WaveDirection.Z && WaveAxis == WaveDirection.X && WaveMold == WaveType.Squash)
{
Waveing = MarginWaveSquashZX;
}
else if (FixedAxis == WaveDirection.Z && WaveAxis == WaveDirection.Y && WaveMold == WaveType.entity)
{
Waveing = MarginWaveEntityZY;
}
else if (FixedAxis == WaveDirection.Z && WaveAxis == WaveDirection.Y && WaveMold == WaveType.Squash)
{
Waveing = MarginWaveSquashZY;
}

if (Waveing == null)
{
_isCanWave = false;
}
}

Y轴方向扭曲,其他轴类似:

 

 

/// <summary>
/// X轴为固定轴,以Y轴方向扭曲(正常)
/// </summary>
void MarginWaveEntityXY()
{
Vector3[] vertices = _vertices.Clone() as Vector3[];
for (int i = 0; i < vertices.Length; i++)
{
vertices[i].y += WaveRange * Mathf.Sin(vertices[i].x + _weight);
}

_mesh.vertices = vertices;
}
/// <summary>
/// X轴为固定轴,以Y轴方向扭曲(扁平)
/// </summary>
void MarginWaveSquashXY()
{
Vector3[] vertices = _vertices.Clone() as Vector3[];
for (int i = 0; i < vertices.Length; i++)
{
vertices[i].y = WaveRange * Mathf.Sin(vertices[i].x + _weight);
}

_mesh.vertices = vertices;
}

持续变化:

 

 

/// <summary>
/// 分量变化
/// </summary>
void Weighting()
{
if (_weight < _2PI)
{
_weight += Time.deltaTime * WaveSpeed;
}
else
{
_weight = 0;
}
}

void Update ()
{
if (_isCanWave && _isWaveing)
{
Weighting();
Waveing();
}
}

 

 

 

 

 

那么,属性面板大概就是这样:

 

Unity插件 - MeshEditor(十一) 模型正弦扭曲特效_MeshEditor_04

 

FixedAxis:固定轴,正弦函数中的x分量

WaveAxis:扭动轴,正弦函数中的y分量

WaveMold:模式,Entity(正常),squash(模型压成面片)

WaveSpeed:扭动的速度

WaveRange:扭动的幅度(为0则停止扭动)

IsWaveing:开启与关闭

 

再贴几张效果图:

 

(正常模式)

Unity插件 - MeshEditor(十一) 模型正弦扭曲特效_赋值_05

 

(压扁模式)

Unity插件 - MeshEditor(十一) 模型正弦扭曲特效_i++_06

 

 

-----by MeshEditor

标签:插件,WaveMold,vertices,FixedAxis,Waveing,MeshEditor,WaveDirection,Unity,&&
From: https://blog.51cto.com/u_15911199/5934140

相关文章

  • 【Unity】 HTFramework框架(三十九)UI的数据驱动模式,MVVM
    更新日期:2020年10月24日。Github源码:​​​[点我获取源码]​​​Gitee源码:​​[点我获取源码]​​索引​​UI的数据驱动模式​​​​使用​​​​数据模型​​​​Bindabl......
  • Unity UGUI无限列表(Infinite List)
    更新日期:2020年10月16日。Github源码:​​​[点我获取源码]​​索引​​InfiniteList​​​​使用​​​​创建InfiniteListScrollRect​​​​InfiniteListScrollRect参数......
  • Unity - 粒子系统跟随路径移动
    对于最新版的粒子系统ParticleSystem,要让其跟随路径移动,无非就是借用其自身的API直接为每个粒子设置速度。看一下最终的效果图:编辑器为了能在场景中更方便的编辑路径,我们要......
  • 【Unity】 HTFramework框架(三十七)Inspector自定义序列化检视器
    更新日期:2020年8月21日。Github源码:​​​[点我获取源码]​​​Gitee源码:​​[点我获取源码]​​索引​​Inspector自定义序列化检视器​​​​使用​​​​Dropdown下拉......
  • 【Unity】 HTFramework框架(三十六)AssetsMaster资源管理器,做资产的主人
    更新日期:2020年8月13日。Github源码:​​​[点我获取源码]​​​Gitee源码:​​[点我获取源码]​​索引​​AssetsMaster​​​​使用AssetsMaster​​​​打开AssetsMaster......
  • Unity 多物体混合动画、值变动画控制器
    索引​​前言​​​​示例​​​​1、4个Cube的联动动画​​​​2、UGUIText文本动画​​​​3、UGUIImage图片动画​​​​4、物体消隐动画​​​​使用与解析​​​​1......
  • Unity实现在白板上绘画涂鸦
    前言有段时间没有更新博客了,不知道应该写些什么,太简单感觉没有记录的必要,太难自己都没能理解,不知道如何下手。回归初心,记录自己想记录的东西。需要实现一个白板绘画的功能,......
  • Unity 使用拖尾渲染器模拟简易的管道流体
    关于管道流体关于管道流体,最佳的解决方案肯定是UV动画无疑,在网上看过很多例子几乎都是这样的,毕竟用实时流体计算的话开销确实太大,用粒子系统的话又苦于难以表现出流体的粘稠......
  • Unity UGUI图文混排源码(三) -- 动态表情
    这里是根据图文混排源码(二)进一步修改的,其他链接也不贴了,就贴一个链接就好了,第一次看这文章的同学可以先去看看其他几篇文章1.首先来一个好消息,在最新版本的图文混排中,终于......
  • 如何安装ES的IK分词器插件?
    1.更新yum等资源sudoyumupdate-ysudorpm-ivh​http://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm​sudorpm-ivhhttps://kojipkgs.fedora......