zoukankan      html  css  js  c++  java
  • unity3d 镜头随触屏移动

    js

    #pragma strict
    
    //用于绑定参照物对象   
    var target : Transform;   
    //缩放系数   
    var distance = 10.0;   
    //左右滑动移动速度   
    var xSpeed = 250.0;   
    var ySpeed = 120.0;   
    //缩放限制系数   
    var yMinLimit = -20;   
    var yMaxLimit = 80;   
    //摄像头的位置   
    var x = 0.0;   
    var y = 0.0;   
    //记录上一次手机触摸位置判断用户是在左放大还是缩小手势   
    private var oldPosition1 : Vector2;   
    private var oldPosition2 : Vector2;   
       
       
    //初始化游戏信息设置   
    function Start () {   
        var angles = transform.eulerAngles;   
        x = angles.y;   
        y = angles.x;   
       
        // Make the rigid body not change rotation   
        if (rigidbody)   
            rigidbody.freezeRotation = true;   
    }   
       
       var newobject:Transform; 
       
    function Update ()    
    {   
        //判断触摸数量为单点触摸   
        if(Input.touchCount == 1)   
        {   
            //触摸类型为移动触摸   
            if(Input.GetTouch(0).phase==TouchPhase.Moved)   
            {   
                //根据触摸点计算X与Y位置   
                x += Input.GetAxis("Mouse X") * xSpeed * 0.01;   
                y -= Input.GetAxis("Mouse Y") * ySpeed * 0.01;   
    
                //按镜头距离调整位置和方向
                var rotation = Quaternion.Euler(-y, x, 0);
                transform.rotation = rotation;
                   
            }   
        }   
           
        //判断触摸数量为多点触摸   
        if(Input.touchCount >1 )   
        {   
                var n:Transform = Instantiate(newobject,transform.position,transform.rotation);
                var fwd:Vector3 = transform.TransformDirection(Vector3.forward);
                n.rigidbody.AddForce(fwd*2800);
        
        
            //前两只手指触摸类型都为移动触摸   
            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.5;       
                        }    
                    }else   
                    {   
                        //缩小洗漱返回18.5后不允许继续缩小   
                        //这里的数据是根据我项目中的模型而调节的,大家可以自己任意修改   
                        if(distance < 18.5)   
                        {   
                            distance += 0.5;   
                        }   
                    }   
                //备份上一次触摸点的位置,用于对比   
                oldPosition1=tempPosition1;   
                oldPosition2=tempPosition2;   
            }   
        }   
    }   
       
       
       
    //函数返回真为放大,返回假为缩小   
    function isEnlarge(oP1 : Vector2,oP2 : Vector2,nP1 : Vector2,nP2 : Vector2) : boolean   
    {   
        //函数传入上一次触摸两点的位置与本次触摸两点的位置计算出用户的手势   
        var leng1 =Mathf.Sqrt((oP1.x-oP2.x)*(oP1.x-oP2.x)+(oP1.y-oP2.y)*(oP1.y-oP2.y));   
        var 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方法一旦调用结束以后进入这里算出重置摄像机的位置   
    function LateUpdate () {   
          
        //target为我们绑定的箱子变量,缩放旋转的参照物   
        if (target) {          
               
            //重置摄像机的位置   
            y = ClampAngle(y, yMinLimit, yMaxLimit);   
            var rotation = Quaternion.Euler(y, x, 0);   
            var position = rotation * Vector3(0.0, 0.0, -distance) + target.position;   
               
            //transform.rotation = rotation;   
            //transform.position = position;   
        }   
    }   
       
       
    static function ClampAngle (angle : float, min : float, max : float) {   
        if (angle < -360)   
            angle += 360;   
        if (angle > 360)   
            angle -= 360;   
        return Mathf.Clamp (angle, min, max);   
    }   
  • 相关阅读:
    项目结队开发---NABC分析(成员)
    梦断代码读后感(二)
    梦断代码读后感(一)
    首尾相连的循环数组求其子数组最大值
    子数组求和之大数溢出
    梦断代码读后感——终结
    软件工程结对开发——一维最大子数组求和溢出问题
    结对开发——求环形一维数组最大子数组的和
    结对开发——电梯调度问题需求分析
    软件工程——求二维数组所有子矩阵的和的最大值
  • 原文地址:https://www.cnblogs.com/ADaii/p/3854390.html
Copyright © 2011-2022 走看看