返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C#实现贝塞尔曲线的方法
  • 513
分享到

C#实现贝塞尔曲线的方法

2024-04-02 19:04:59 513人浏览 独家记忆
摘要

本文实例为大家分享了C#实现贝塞尔曲线的具体代码,供大家参考,具体内容如下 话不多直接上代码 public TransfORM[] controlPoints; //曲线的控制点 ,

本文实例为大家分享了C#实现贝塞尔曲线的具体代码,供大家参考,具体内容如下

话不多直接上代码

public TransfORM[] controlPoints; //曲线的控制点 ,最少三个,起点,弧度点,终点
    public GameObject codeGameObject; //要动的物体

    private int _segmentNum = 50; //运动物体过程分的段数
    private int numIndex = 1;
    
void Start()
    {
        moveGameObject(2);
    }

void moveGameObject(float time)
    {
        numIndex = 1;
        InvokeRepeating("setInterval", 0, time/50);
    }

void setInterval()
    {
        int nodeIndex = 0;
        float t = numIndex / (float)_segmentNum;
        Vector3 pixel = CalculateCubicBezierPoint(t, controlPoints[nodeIndex].position,
            controlPoints[nodeIndex + 1].position, controlPoints[nodeIndex + 2].position);
        codeGameObject.gameObject.transform.position= pixel;
        numIndex++;

        if(numIndex> _segmentNum)
        {
            CancelInvoke("setInterval");
        }
    }
Vector3 CalculateCubicBezierPoint(float t, Vector3 p0, Vector3 p1, Vector3 p2)
    {
        float u = 1 - t;
        float tt = t * t;
        float uu = u * u;

        Vector3 p = uu * p0;
        p += 2 * u * t * p1;
        p += tt * p2;

        return p;
    }

项目里的截图:

运行就可以看到球在三个方块之间移动的曲线了

第二种方案使用DOTweenPath


    public float PlaySendFlyAnim(GameObject prop, Vector3 sendPos, Vector3 endP, float fHeight, float time)
    {
        float fTime = 0.0f;
        if (prop == null)
        {
            return fTime;
        }
        
        Vector3 startP = sendPos;
        prop.transform.position = startP;

        float x = Mathf.Min(startP.x, endP.x) + Mathf.Abs(startP.x - endP.x) / 2f;
        float y = Mathf.Min(startP.y, endP.y) + Mathf.Abs(startP.y - endP.y) / 2f;
        float z = startP.z;
        Vector3 midP = new Vector3(x, y, z);
        double length = Math.Sqrt(Math.Pow(sendPos.x - midP.x, 2) + Math.Pow(sendPos.y - midP.y, 2));
        //midP.x = fHeight / (float)length * (sendPos.x - midP.x) + midP.x;
        //midP.y = fHeight / (float)length * (sendPos.y - midP.y) + midP.y;
        int rangeRadomNum = UnityEngine.Random.Range(0, 2);
        if(rangeRadomNum == 1)
        {
            midP.x = fHeight / (float)length * (endP.x - midP.x) + midP.x;
            midP.y = endP.y;
        }
        else
        {
            midP.y = fHeight / (float)length * (endP.y - midP.y) + midP.y;
            midP.x = endP.x;
        }
        //fTime = 2.0f;
        fTime = time;
        List<Vector3> arrRecPos = new List<Vector3>();

        arrRecPos.Add(startP);
        arrRecPos.Add(midP);
        arrRecPos.Add(endP);
        prop.transform.DOPath(arrRecPos.ToArray(), fTime, PathType.CatmullRom, PathMode.Full3D).SetEase(Ease.Linear);

        return fTime;
    }
/// <param name="sendPos"> 玩家头像位置</param>
    /// <param name="endP">筛子停止位置</param>
    /// <param name="i">筛子大小</param>
    /// <param name="radian">弧度</param>
    /// <param name="time">时间</param>
    /// <returns></returns>
    public float PlayAddFriendAnim(Vector3 sendPos, Vector3 endP,int i,int radian = 0, float time = 1.5f)
    {
        GameObject shaizi = this.transform.Find("shaizi_anmi4_0").gameObject;
        shaizi.GetComponent<Animator>().enabled = true;

        SpriteRenderer _shaizhiV = shaizi.GetComponent<SpriteRenderer>();
        float fTime = PlaySendFlyAnim(shaizi, sendPos, endP, radian, time);

        DOTween.Sequence().AppendInterval(fTime).AppendCallback(() =>
        {
            if (shaizi != null)
            {
                shaizi.GetComponent<Animator>().enabled = false;
                _shaizhiV.sprite = shaiziData[i-1];
                StartCoroutine(Destroyshaizi(shaizi));
            }
        });

        return fTime;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: C#实现贝塞尔曲线的方法

本文链接: https://lsjlt.com/news/139496.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • C#实现贝塞尔曲线的方法
    本文实例为大家分享了C#实现贝塞尔曲线的具体代码,供大家参考,具体内容如下 话不多直接上代码 public Transform[] controlPoints; //曲线的控制点 ,...
    99+
    2024-04-02
  • iOS实现贝塞尔曲线动画
    本文实例为大家分享了iOS实现贝塞尔曲线动画的具体代码,供大家参考,具体内容如下 效果如图: 仿美人相机,手势滑动隐藏顶部view。为了方便讲解,将屏幕分为几个区域,如图: 在拖...
    99+
    2022-06-04
    iOS 贝塞尔曲线
  • AS3贝塞尔曲线类
    贝塞尔曲线被广泛用于塔防类的游戏,当然一些特殊的缓动效果有些 也用 到这个 , 目前 这个没必要我们担心 , TweenMax 为我们提供了这些功能. package com.ainy.benz { import flash.geo...
    99+
    2023-01-31
    塞尔 曲线
  • canvas如何实现高阶贝塞尔曲线
    这篇文章主要介绍canvas如何实现高阶贝塞尔曲线,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!为什么需要一个试验场?在绘制复杂的高阶贝塞尔曲线时无法知道自己需要的曲线的控制点的精确位置。在试验场中进行模拟,可以实时...
    99+
    2023-06-09
  • android实现贝塞尔曲线之波浪效果
    本文实例为大家分享了android实现贝塞尔曲线之波浪效果的具体代码,供大家参考,具体内容如下 1 前言 为了给我以前的博客填坑,这章讲解贝塞尔曲线的几个常用的应用: 1.波浪效果2...
    99+
    2024-04-02
  • js基于div丝滑实现贝塞尔曲线
    目录引言分析实现布局如何计算y的偏移量Math.sin() 和 Math.cos()正弦曲线余弦曲线计算更多信息完善剩余完成跑马灯制作贝塞尔曲线简单封装一下方法完整示例styleSC...
    99+
    2024-04-02
  • canvas如何仿写贝塞尔曲线
    这篇文章给大家分享的是有关canvas如何仿写贝塞尔曲线的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。效果图:html<canvas id="mycan...
    99+
    2024-04-02
  • Unity贝塞尔曲线之美体验
    最近项目中用到了贝塞尔曲线,学习完成后记录一下自己的学习结果吧。 一阶贝塞尔曲线 一阶贝塞尔曲线就是一条线,我们很容易根据 t 求出 t 点的位置。 P(t)=P0+(P1-P...
    99+
    2024-04-02
  • Android自定义view贝塞尔曲线
    本文实例为大家分享了Android自定义view贝塞尔曲线,供大家参考,具体内容如下 贝塞尔曲线 以一个简单的贝塞尔曲线为例,二阶曲线原理 贝塞尔曲线很多功能都会用到,比如小火箭发...
    99+
    2024-04-02
  • Android用Canvas绘制贝塞尔曲线
    用Canvas画贝塞尔曲线,要画贝塞尔曲线首先了解贝塞尔曲线: 由于用计算机画图大部分时间是操作鼠标来掌握线条的路径,与手绘的感觉和效果有很大的差别。即使是一位精明的画师能轻松绘出各...
    99+
    2024-04-02
  • Android自定义View绘制贝塞尔曲线的方法
    本文实例为大家分享了Android自定义View绘制贝塞尔曲线的具体代码,供大家参考,具体内容如下 在平面内任选 3 个不共线的点,依次用线段连接。 在第一条线段上任选一个点 D。计...
    99+
    2024-04-02
  • Android通过交互实现贝塞尔曲线的绘制
    目录前言获取触控位置交互绘制实现绘制代码运行效果总结前言 之前几篇我们介绍了贝塞尔曲线的原理、绘制曲线和动效实现,这些都是代码预设好的,如果我们要根据需要自行绘制曲线,就需要使用交互...
    99+
    2024-04-02
  • Android中贝塞尔曲线的绘制方法示例代码
           贝塞尔曲线,很多人可能不太了解,什么叫做贝塞尔曲线呢?这里先做一下简单介绍:贝塞尔曲线也可以叫做贝济埃...
    99+
    2022-06-06
    示例 方法 贝塞尔 贝塞尔曲线 Android
  • HTML5 Canvas如何绘制贝塞尔曲线
    这篇文章给大家分享的是有关HTML5 Canvas如何绘制贝塞尔曲线的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 贝塞尔曲线 :它可以是二次和三次方的形式,一般用于绘制复杂而...
    99+
    2024-04-02
  • Android使用贝塞尔曲线画心形
    本文实例为大家分享了Android使用贝塞尔曲线画心形的具体代码,供大家参考,具体内容如下 一开始我只是想画个圆,可画着画着就成了心形,那就将错就错 1. 创建一个Activity ...
    99+
    2024-04-02
  • android中贝塞尔曲线的应用示例
    前言: 贝塞尔曲线又称贝兹曲线,它的主要意义在于无论是直线或曲线都能在数学上予以描述。最初由保罗·德卡斯特里奥(Paul de Casteljau)于1959年运用德卡斯特里奥...
    99+
    2022-06-06
    示例 贝塞尔 贝塞尔曲线 Android
  • android 通过贝塞尔曲线 实现爱心点赞功能
    android 通过贝塞尔曲线 实现爱心点赞功能:   ValueAnimatior: 核心功能:     已知起点p0, 终p3,中间点 p1、p2  通过贝塞尔曲线 计算路...
    99+
    2022-06-06
    爱心 贝塞尔 贝塞尔曲线 Android
  • Android Path绘制贝塞尔曲线实现QQ拖拽泡泡
    这两天学习了使用Path绘制贝塞尔曲线相关,然后自己动手做了一个类似QQ未读消息可拖拽的小气泡,效果图如下: 最终效果图 接下来一步一步的实现整个过程。 基本原理 其实就是使...
    99+
    2022-06-06
    path 贝塞尔 贝塞尔曲线 Android
  • 怎么用android实现贝塞尔曲线之波浪效果
    这篇文章主要介绍“怎么用android实现贝塞尔曲线之波浪效果”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么用android实现贝塞尔曲线之波浪效果”文章能帮助大家解决问题。1 前言贝塞尔曲线的...
    99+
    2023-07-02
  • Android自定义View绘制贝塞尔曲线实现流程
    目录前言二阶贝塞尔曲线三阶贝塞尔曲线前言 对于Android开发,实现贝塞尔曲线还是比较方便的,有对应的API供你调用。由于一阶贝塞尔曲线就是一条直线,实际没啥多大用处,因此,下面主...
    99+
    2022-11-13
    Android 贝塞尔曲线 Android 贝塞尔曲线实现方法
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作