Unity做360°全景图

最近接了个用unity做全景图的活,我的想法是在unity内建一个球,将shader选为Mobile/particles/Alpha Blended,然后将做好的全景图贴上去就OK了,下面贴上一段摄像机放大缩小的代码,怕自己忘了..参考了部分网上的代码

using UnityEngine;
using System.Collections;
using UnityEngine.UI;

public class Test01 : MonoBehaviour
{
    public float moveSpeed = 1;//物体旋转速度  
    public GameObject target;

    private Vector2 oldPosition;
    private Vector2 oldPosition1;
    private Vector2 oldPosition2;


    private float distance = 0;
    private bool flag = false;
    //摄像头的位置
    private float x = 0f;
    private float y = 0f;
    //左右滑动移动速度
    public float xSpeed = 250f;
    public float ySpeed = 120f;
    //缩放限制系数
    public float yMinLimit = -360;
    public float yMaxLimit = 360;
    //是否旋转
    private bool isRotate = true;
    //计数器
    private float count = 0;

    public static Test01 _instance;
    //初始化游戏信息设置
    void Start()
    {
        _instance = this;
        Vector3 angles = transform.eulerAngles;
        x = angles.y;
        y = angles.x;
        if (GetComponent< Rigidbody >())
            GetComponent< Rigidbody >().freezeRotation = true;
    }

    

    // Update is called once per frame  
    void Update()
    {

        if (isRotate)
        {

            target.transform.Rotate(Vector3.down, Time.deltaTime * moveSpeed,Space.World);
            
        }
        if (!isRotate)
        {
            count += Time.deltaTime;
            if (count > 5)
            {
                count = 0;
                isRotate = true;
            }
        }

            //触摸类型为移动触摸
            if (Input.GetMouseButton(0))
            {
                //根据触摸点计算X与Y位置
                x += Input.GetAxis("Mouse X") * xSpeed *Time.deltaTime;
                y -= Input.GetAxis("Mouse Y") * ySpeed * Time.deltaTime;
            isRotate = false;
            }
            //判断鼠标滑轮是否输入
        float temp = Input.GetAxis("Mouse ScrollWheel");
        if (temp!=0)
        {
            if (temp>0)
            {
                // 这里的数据是根据我项目中的模型而调节的,大家可以自己任意修改
                if (distance > -15)
                {
                    distance -= 0.5f;
                }
            }
            if (temp<0)
            {
                // 这里的数据是根据我项目中的模型而调节的,大家可以自己任意修改
                if (distance < 20)
                {
                    distance += 0.5f;
                }
            }
        }

    }

    //计算距离,判断放大还是缩小。放大返回true,缩小返回false  
    bool IsEnlarge(Vector2 oP1, Vector2 oP2, Vector2 nP1, Vector2 nP2)
    {
        //old distance  
        float oldDistance = Mathf.Sqrt((oP1.x - oP2.x) * (oP1.x - oP2.x) + (oP1.y - oP2.y) * (oP1.y - oP2.y));
        //new distance  
        float newDistance = Mathf.Sqrt((nP1.x - nP2.x) * (nP1.x - nP2.x) + (nP1.y - nP2.y) * (nP1.y - nP2.y));

        if (oldDistance < newDistance)
        {
            //zoom+  
            return true;
        }
        else
        {
            //zoom-  
            return false;
        }
    }

    //每帧执行,在Update后  
    void LateUpdate()
    {
        if (target)
        {
            //重置摄像机的位置
            y = ClampAngle(y, yMinLimit, yMaxLimit);
            var rotation = Quaternion.Euler(y, x, 0);
            var position = rotation *(new Vector3(0.0f, 0.0f, -distance)) + target.transform.position;

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

    }
   
}


  • 6
    点赞
  • 63
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值