untiy 物体移动旋转集锦


今天看了很多物体移动旋转的资料,比较乱,在此整理下。

 //向前移动一个单位
            transform.Translate(Vector3.forward);


当前组件旋转,旋转程度根据捕获到的鼠标移动距离
  
              transform.Rotate(0,Input.GetAxis("Mouse X") * sensitivityHor,0);

        

 float delta = Input.GetAxis("Mouse X") * sensitivityHor;
        float rotationY = transform.localEulerAngles.y + delta;

        transform.localEulerAngles = new Vector3(_rotationX, 0, 0);

 //跟随鼠标新位置 不断累积位置  设置摄像机焦点位置
        _rotationX -= Input.GetAxis("Mouse Y") * sensitivityHor;
        _rotationX = Mathf.Clamp(_rotationX, minumumVert, maxumumVert);

        transform.localEulerAngles = new Vector3(0, rotationY, 0);



charController自带碰撞检测,这里是由键盘输入获取移动距离,movement.y为设置重力,防止向上行走
 float deltaX = Input.GetAxis("Horizontal") * speed;
        float deltaZ = Input.GetAxis("Vertical") * speed;
        Vector3 movement = new Vector3(deltaX, 0,deltaZ);
        movement = Vector3.ClampMagnitude(movement, speed);
        movement.y = gravity;
        movement *= Time.deltaTime;
        //从自身坐标到世界坐标变换方向。
        movement = transform.TransformDirection(movement);
        _charController.Move(movement);


安卓端 物体根据两点触摸进行放大缩小,其中单点触摸的旋转在最后并没有进行使用

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
public class RotateAndMove : MonoBehaviour {

    // 主角  
    public Transform target;

    // 缩放系数  
    private float distance = 10.0f;

    // 左右滑动移动速度  
    private float xSpeed = 250.0f;
    private float ySpeed = 120.0f;

    // 缩放限制系数  
    private float yMinLimit = -20;
    private float yMaxLimit = 80;

    // 摄像头的位置  
    private float x = 0.0f;
    private float y = 0.0f;

    // 记录上一次手机触摸位置判断用户是在做放大还是缩小手势  
    private Vector2 oldPosition1 = new Vector2(0, 0);
    private Vector2 oldPosition2 = new Vector2(0, 0);

    //初始化游戏信息设置  
    void Start()
    {
        Debug.Log(oldPosition1);
        Vector3 angles = transform.eulerAngles;
        x = angles.y;
        y = angles.x;

    }

    void Update()
    {
        // 判断触摸数量为单点触摸  
        if (Input.touchCount == 1)
        {
            // 触摸类型为移动触摸  
            if (Input.GetTouch(0).phase == TouchPhase.Moved)
            {
                //根据触摸点计算X与Y位置  
                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)
            {
                // 计算出当前两点触摸点的位置  
                var tempPosition1 = Input.GetTouch(0).position;
                var tempPosition2 = Input.GetTouch(1).position;
                // 函数返回真为放大,返回假为缩小  
                if (isEnlarge(oldPosition1, oldPosition2, tempPosition1, tempPosition2))
                {
                    // 放大系数超过3以后不允许继续放大  
                    // 这里的数据是根据我项目中的模型而调节的,大家可以自己任意修改  
                    if (distance > 3)
                    {
                        distance -= 0.5f;
                    }
                }
                else
                {
                    // 缩小系数返回18.5后不允许继续缩小  
                    // 这里的数据是根据我项目中的模型而调节的,大家可以自己任意修改  
                    if (distance < 18.5f)
                    {
                        distance += 0.5f;
                    }
                }
                // 备份上一次触摸点的位置,用于对比  
                oldPosition1 = tempPosition1;
                oldPosition2 = tempPosition2;

            }
        }
        if (Input.GetKey(KeyCode.Escape))
        {
            Application.Quit();
        }
    }

    // 函数返回真为放大,返回假为缩小  
    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;
        }
    }

    // Update方法一旦调用结束以后进入这里算出重置摄像机的位置  
    void LateUpdate()
    {

        // target为主角,缩放旋转的参照物  
            // 重置摄像机的位置  
         //   y = ClampAngle(y, yMinLimit, yMaxLimit);
            Quaternion rotation = Quaternion.Euler(y, x, 0);
            Vector3 position =  new Vector3(0.0f, 0.0f, -distance) + target.position;
      //  Vector3 position = rotation * new Vector3(0.0f, 0.0f, -distance) + target.position;

        // transform.rotation = rotation;
        transform.position = position;
    }

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



安卓端 单点触摸情况下,根据滑动距离旋转物体。
using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class ScaleAndRotate : MonoBehaviour {
    // 左右滑动移动速度  
    private float xSpeed = 2f;
    private float ySpeed = 1f;

    // 摄像头的位置  
    private float x = 0.0f;
    private float y = 0.0f;
    void Start()
    {
    }

    void Update()
    {
        // 判断触摸数量为单点触摸  
        if (Input.touchCount == 1)
        {
            // 触摸类型为移动触摸  
            if (Input.GetTouch(0).phase == TouchPhase.Moved)
            {
                //根据触摸点计算X与Y位置  
                x = -Input.GetAxis("Mouse X") * xSpeed;
                y = Input.GetAxis("Mouse Y") * ySpeed;
                transform.Rotate(new Vector3(y, x, 0), Space.World);
                //无死角旋转
                //transform.Rotate(new Vector3(0, x, 0),Space.World);
                //   transform.Rotate(new Vector3(y, 0, 0), Space.World);
                //  gameObject.transform.RotateAround(new Vector3(0, 0, 0), new Vector3(0, 1.0f, 0),x);
                //   gameObject.transform.RotateAround(new Vector3(0, 0, 0), new Vector3(1.0f,0, 0), y);

            }
        }
    }
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

风晴03

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

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

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

打赏作者

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

抵扣说明:

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

余额充值