Unity 移动端Touch Camera旋转+缩放(FOV)+Lerp插值平滑实现

声明解释:target为围绕目标点(实现自身旋转挂自身即可),xSpeed,ySpeed.为旋转速度.yMinLimit,yMaxLimit,为上下旋转限制._lerpspeed,为插值速度(可理解为:值越大 延迟越小)

直接上代码.代码为本人项目需求实现: 有具体需求请适当修改

using UnityEngine;

using System.Collections;
using System.IO;
using UnityEngine.UI;
public class FingerController : MonoBehaviour
{
    public Transform target;

    private float distance = 0f; 
    private float _camerafov;
    private float xSpeed = 40f;
    private float ySpeed = 30f;

    private float yMinLimit = -90;
    private float yMaxLimit = 80;

    private float x = 0.0f;
    private float y = 0.0f;
   private float _lerpspeed = 5f;

    private Vector2 oldPosition1 = new Vector2(0, 0);
    private Vector2 oldPosition2 = new Vector2(0, 0);


    public Text txt;
    void Start()
    {
        // Debug.Log(oldPosition1);  
        Vector3 angles = transform.eulerAngles;
        x = angles.y;
        y = angles.x;
        _camerafov = Camera.main.fieldOfView;
    }

    void Update()
    {
        // 判断触摸数量为单点触摸  
        if (Input.touchCount == 1)
        {
            if (Input.GetTouch(0).phase == TouchPhase.Moved)
            {
                x += Input.GetAxis("Mouse X") * xSpeed * 0.02f ;
                y -= Input.GetAxis("Mouse Y") * ySpeed * 0.02f ;
            }
        }

        if (Input.touchCount > 1)
        {
            if (Input.GetTouch(0).phase == TouchPhase.Moved && Input.GetTouch(1).phase == TouchPhase.Moved)
            {

                //计算出当前两点触摸点的位置
                Vector2 tempPosition1 = Input.GetTouch(0).position;
                Vector2 tempPosition2 = Input.GetTouch(1).position;

                // 改变相机FOV值 实现放大缩小
                if (isEnlarge(oldPosition1, oldPosition2, tempPosition1, tempPosition2))
                {
                    _camerafov -= 80f * Time.deltaTime;
                    if (_camerafov <= 40f)
                    {
                        _camerafov = 40;

                    }
                    Camera.main.fieldOfView = _camerafov;
                }
                else
                {
                    _camerafov += 80f * Time.deltaTime;

                    if (_camerafov >= 95f)
                    {
                        _camerafov = 95f;
                    }
                    Camera.main.fieldOfView = _camerafov;

                }
                oldPosition1 = tempPosition1;
                oldPosition2 = tempPosition2;

            }
        }    
    }

    bool isEnlarge(Vector2 oP1, Vector2 oP2, Vector2 nP1, Vector2 nP2) // 函数判断放大缩小手势
    {
        // 取平方根
        float leng1 = Mathf.Sqrt((oP1.x - oP2.x) * (oP1.x - oP2.x) + (oP1.y - oP2.y) * (oP1.y - oP2.y));
        float leng2 = Mathf.Sqrt((nP1.x - nP2.x) * (nP1.x - nP2.x) + (nP1.y - nP2.y) * (nP1.y - nP2.y));

        if (leng1 < leng2)
        {
            // 放大手势  
            return true;
        }
        else
        {
            // 缩小手势  
            return false;
        }
    }
    void LateUpdate()
    {
        if (target)
        {
            y = ClampAngle(y, yMinLimit, yMaxLimit);
            Quaternion rotation = Quaternion.Euler(y, x, 0);

            //transform.rotation = rotation;

            // 插值运算
            transform.rotation = Quaternion.Lerp(transform.rotation,rotation,Time.deltaTime * _lerpspeed);

        }

    }

    static float ClampAngle(float angle, float min, float max)
    {
        if (angle < -90)
            angle = -90;
        if (angle > 80)
            angle = 80;
        return Mathf.Clamp(angle, min, max);

    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值