欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Unity貝塞爾曲線之美體驗

 更新時間:2021年10月15日 10:07:36   作者:韭本菜  
這篇文章主要帶大家體驗Unity貝塞爾曲線之美,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

最近項目中用到了貝塞爾曲線,學(xué)習(xí)完成后記錄一下自己的學(xué)習(xí)結(jié)果吧。

一階貝塞爾曲線

一階貝塞爾曲線就是一條線,我們很容易根據(jù) t 求出 t 點的位置。

P(t)=P0+(P1-P0)*t =(1-t)*P0+tP1  ;   t[ 0,1] ,且其等同于線性插值。

二階貝塞爾曲線

取平面內(nèi)三個不共線的點,AB:AC=CD:CE,這個時候BD又是一條直線,可以按照一階的貝塞爾方程來進行線性插值了。

P(B)=(1-t)*P0+tP1 ;

P(D)=(1-t)P1+tP2  ;

P(t)=(1-t)*P(B)+tP(D)

=(1-t)*((1-t)*P0+tP1)+t((1-t)P1+tP2 )

=(1-t)² *P0+2t*(1-t)*P1+t²*P2  ;t[0,1];

代碼:

public LineRenderer line_b;
public LineRenderer line_a;
public LineRenderer line_c;
 
public Transform start;
public Transform end;
public Transform c;
 
    void Start()
    {
     
    }
    void Update()
    {
 
        line_a.SetPosition(0, start.position);
        line_a.SetPosition(1, c.position);
        line_c.SetPosition(0, end.position);
        line_c.SetPosition(1, c.position);
 
       // float distance = Vector3.Distance(start.position, end.position);
        Vector3 controlPoint = c.position;
            //start.position + (start.position+ c.position).normalized * distance / 1.6f;
 
        Vector3[] bcList = GetBeizerPathPointList(start.position, controlPoint, end.position, 50);
        line_b.positionCount = bcList.Length + 1;
        line_b.SetPosition(0, start.position);
        for (int i = 0; i < bcList.Length; i++)
        {
            Vector3 v = bcList[i];
            line_b.SetPosition(i + 1, v);
        }
 
 
    }
    public static Vector3[] GetBeizerPathPointList(Vector3 startPoint, Vector3 controlPoint, Vector3 endPoint, int pointNum)
    {
        Vector3[] BeizerPathPointList = new Vector3[pointNum];
        for (int i = 1; i <= pointNum; i++)
        {
            float t = i / (float)pointNum;
            Vector3 point = GetBeizerPathPoint(t, startPoint,
                controlPoint, endPoint);
            BeizerPathPointList[i - 1] = point;
        }
        return BeizerPathPointList;
    }
 
    //貝塞爾曲線二次方公式
    private static Vector3 GetBeizerPathPoint(float t, Vector3 p0, Vector3 p1, Vector3 p2)
    {
        return (1 - t) * (1 - t) * p0 + 2 * t * (1 - t) * p1 + t * t * p2;
    }

三階貝塞爾曲線

三階貝塞爾曲線和二階其實是同一個道理,都可以按照一階的貝塞爾方程來進行線性插值。這里就直接上公式了。

P(t)=P0*(1-t)³ +3P1*t*(1-t)²+3P2*t²*(1-t)+P3*t³ ; t[0,1];

代碼

public Transform start;
public Transform end;
public Transform c0;
public Transform c1;
 
    public LineRenderer line_b;
    public LineRenderer line_a;
    public LineRenderer line_c;
    public LineRenderer line_d;
    void Start()
    {
        
    }
 
    // Update is called once per frame
    void Update()
    {
        line_a.SetPosition(0, start.position);
        line_a.SetPosition(1, c0.position);
 
        line_c.SetPosition(0, c1.position);
        line_c.SetPosition(1, c0.position);
 
        line_d.SetPosition(0, c1.position);
        line_d.SetPosition(1, end.position);
 
 
 
        Vector3[] bcList = GetBeizerPathPointList(start.position, c0.position,c1.position, end.position, 50);
        line_b.positionCount = bcList.Length + 1;
        line_b.SetPosition(0, start.position);
        for (int i = 0; i < bcList.Length; i++)
        {
            Vector3 v = bcList[i];
            line_b.SetPosition(i + 1, v);
        }
 
    }
 
    public static Vector3[] GetBeizerPathPointList(Vector3 startPoint, Vector3 controlPoint0, Vector3 controlPoint1, Vector3 endPoint, int pointNum)
    {
        Vector3[] BeizerPathPointList = new Vector3[pointNum];
        for (int i = 1; i <= pointNum; i++)
        {
            float t = i / (float)pointNum;
            Vector3 point = GetBeizerPathPoint(t, startPoint,
                controlPoint0, controlPoint1, endPoint);
            BeizerPathPointList[i - 1] = point;
        }
        return BeizerPathPointList;
    }
 
 
 
    //貝塞爾曲線三次方公式
    private static Vector3 GetBeizerPathPoint(float t, Vector3 p0, Vector3 p1, Vector3 p2,Vector3 p3)
    {
        return (1 - t) * (1 - t) * (1 - t) * p0 +
                3 * p1 * t * (1 - t) * (1 - t) +
                3 * p2 * t * t * (1 - t) +
                p3 * t * t * t;
    }

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:

相關(guān)文章

  • C# 中屬性PropertyInfo的setvalue用法說明

    C# 中屬性PropertyInfo的setvalue用法說明

    這篇文章主要介紹了C# 中屬性PropertyInfo的setvalue用法說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • 如何在C# 中查找或結(jié)束程序域中的主、子進程

    如何在C# 中查找或結(jié)束程序域中的主、子進程

    這篇文章主要介紹了如何在C# 中查找或結(jié)束程序域中的主、子進程,幫助大家更好的理解和使用c#編程語言,感興趣的朋友可以了解下
    2020-11-11
  • C#獲取真實IP地址實現(xiàn)方法

    C#獲取真實IP地址實現(xiàn)方法

    這篇文章主要介紹了C#獲取真實IP地址實現(xiàn)方法,對比了C#獲取IP地址的常用方法并實例展示了C#獲取真實IP地址的方法,非常具有實用價值,需要的朋友可以參考下
    2014-10-10
  • WPF實現(xiàn)控件拖動的示例代碼

    WPF實現(xiàn)控件拖動的示例代碼

    這篇文章主要介紹了WPF實現(xiàn)控件拖動的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-08-08
  • Unity實現(xiàn)簡單場景分層移動

    Unity實現(xiàn)簡單場景分層移動

    這篇文章主要為大家詳細介紹了Unity實現(xiàn)簡單場景分層移動,分為前景、場景、背景等,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • C#實現(xiàn)無損壓縮圖片的示例詳解

    C#實現(xiàn)無損壓縮圖片的示例詳解

    這篇文章主要為大家詳細介紹了如何利用C#實現(xiàn)無損壓縮圖片功能,文中的示例代碼講解詳細,對我們學(xué)習(xí)C#有一定的幫助,感興趣的小伙伴可以了解一下
    2022-12-12
  • C#實現(xiàn)對二維數(shù)組排序的方法

    C#實現(xiàn)對二維數(shù)組排序的方法

    這篇文章主要介紹了C#實現(xiàn)對二維數(shù)組排序的方法,實例分析了C#數(shù)組遍歷與排序的相關(guān)技巧,需要的朋友可以參考下
    2015-06-06
  • 解析C#的擴展方法

    解析C#的擴展方法

    在本文中,主要對擴展方法進行了一些規(guī)則說明、聲明方式,使用方式,以及對擴展方法的意義和擴展方法的原理進行了簡單的解答。并在本文的最后給了一個枚舉的擴展方法代碼。
    2016-12-12
  • C#對DataTable里數(shù)據(jù)排序的方法

    C#對DataTable里數(shù)據(jù)排序的方法

    在日常開發(fā)過程中,有一個DataTable集合,里面有很多字段,現(xiàn)在要求針對某一列進行排序,如果該列為數(shù)字的話,進行ASC即可實現(xiàn),但是該字段類型為string,此時排序就有點不正確了
    2013-11-11
  • C#檢測DataSet是否為空的方法

    C#檢測DataSet是否為空的方法

    這篇文章主要介紹了C#檢測DataSet是否為空的方法,涉及C#操作DataSet的技巧,非常簡單實用,需要的朋友可以參考下
    2015-04-04

最新評論