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

94 篇文章 273 订阅
4 篇文章 5 订阅

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

 

先上几张效果图:

 

 

 

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

 

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

 

 

在如上坐标系中,这条正弦曲线代表的就是函数: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();
        }
    }

 

 

 

 

 

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

 

 

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

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

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

WaveSpeed:扭动的速度

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

IsWaveing:开启与关闭

 

再贴几张效果图:

 

(正常模式)

 

(压扁模式)

 

 

-----by MeshEditor

MegaFiers是完整的网格变形,动画和变形系统,包括超过50个修改器,例如弯曲扭曲,FFD,位移,锥度等等。它们可以以任何组合堆叠,并且可以将任意数量的修改器应用于网格以实现复杂的结果。无论您的想象力如何,物体都可以拉伸,挤压或弯曲变形。或者,当对象在空间中移动时,使用空间扭曲使其自动变形。该套件的其他新增功能包括Point Cache动画支持,动态水波纹和浮动对象系统。 所有变形都可以在编辑器模式和播放模式下工作,因此在构建场景时,可以使用变形器为模型添加多样性。 MegaFiers还是变形TextMeshPro对象(Mesh和现在的UI版本)的理想选择,因此您可以用有趣的方式对文本进行动画处理。并且还可以与ProBuilder一起使用,使您可以直接在Unity中创建更多有趣的关卡。一个新功能是可以使用修改器使Sprite变形。 另一个强大的功能是我们的“网格包裹”系统,该系统允许一个网格被另一个变形和设置动画,使其非常适合服装等。该包裹系统还可以与Unity Blendshapes和蒙皮网格一起使用。 MegaWrap也已被重写为使用Jobs and Burst的速度提高了5倍以上。 MegaFiers用C#编写,并且包含所有源代码,并支持所有同时支持Burst和Jobs的Unity平台。从2019年起兼容所有版本的Unity,并且可以在IOS和Android以及VR和AR平台上使用。 MegaFiers还与所有Unity Rendering管道完全兼容。我们还将为Unity的所有新发行版不断更新资产。如果您有关于修改器的想法,请让我们知道或编写。 还包括先进的花键系统,该系统还允许路径跟随或将花键转换为网格,动态软管系统和用于履带车辆的系统。 更多详情:https://assetstore.unity.com/packages/tools/modeling/megafiers-2-188378#description
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

神码编程

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值