Unity中实现弧形移动

一:实现效果

Unity中实现弧形移动_经验分享



二:第一种实现方法——弧形插值

登录后复制

using UnityEngine;

public class ArcMove : MonoBehaviour
{
    public GameObject curGo;//当前物体
    public GameObject targetGo;//目标物体

    public float value;

    private void Update()
    {
        //计算中心点  
        Vector3 center = (curGo.transform.position + targetGo.transform.position) / 2;

        center -= new Vector3(0, value, 0);

        Vector3 start = curGo.transform.position - center;
        Vector3 end = targetGo.transform.position - center;

        //弧形插值  
        curGo.transform.position = Vector3.Slerp(start, end, Time.time / 200);
        curGo.transform.position += center;

        //判定是否到达目标点
        float dis = Vector3.Distance(curGo.transform.position, targetGo.transform.position);
        if (dis <= 1)
        {
            Debug.Log("到达目标点");
        }
    }
}



三:第二种实现方法——计算弧线中的夹角

登录后复制

using UnityEngine;
using System.Collections;

public class ArcMove : MonoBehaviour
{
    public GameObject curGo;//当前物体
    public GameObject targetGo;//目标物体

    public float speed = 2;//速度  
    public int rotationAngle = 60;//旋转的角度

    private float distanceToTarget;//两者之间的距离  
    private bool move = true;//是否移动

    void Start()
    {
        //计算两者之间的距离  
        distanceToTarget = Vector3.Distance(curGo.transform.position, targetGo.transform.position);

        StartCoroutine(Move());
    }

    /// <summary>
    /// 移动
    /// </summary>
    private IEnumerator Move()
    {
        //移动到目标点停止移动
        while (move)
        {
            Vector3 targetPos = targetGo.transform.position;
            targetPos.z = 0;

            //让它始终朝着目标
            curGo.transform.LookAt(targetPos);

            //计算弧线中的夹角
            float angle = Mathf.Min(1, Vector3.Distance(curGo.transform.position, targetPos) / distanceToTarget) * rotationAngle;
            curGo.transform.rotation = curGo.transform.rotation * Quaternion.Euler(Mathf.Clamp(-angle, -42, 42), 0, 0);
            float currentDist = Vector3.Distance(curGo.transform.position, targetGo.transform.position);
            if (currentDist < 0.5f)
            {
                move = false;
                Debug.Log("到达目标点");
            }
            curGo.transform.Translate(Vector3.forward * Mathf.Min(speed * Time.deltaTime, currentDist));
            yield return null;
        }
    }
}



免责声明:本文系网络转载或改编,未找到原创作者,版权归原作者所有。如涉及版权,请联系删

QR Code
微信扫一扫,欢迎咨询~

联系我们
武汉格发信息技术有限公司
湖北省武汉市经开区科技园西路6号103孵化器
电话:155-2731-8020 座机:027-59821821
邮件:tanzw@gofarlic.com
Copyright © 2023 Gofarsoft Co.,Ltd. 保留所有权利
遇到许可问题?该如何解决!?
评估许可证实际采购量? 
不清楚软件许可证使用数据? 
收到软件厂商律师函!?  
想要少购买点许可证,节省费用? 
收到软件厂商侵权通告!?  
有正版license,但许可证不够用,需要新购? 
联系方式 155-2731-8020
预留信息,一起解决您的问题
* 姓名:
* 手机:

* 公司名称:

姓名不为空

手机不正确

公司不为空