欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

unity实现多点触控代码

程序员文章站 2023-12-12 14:55:52
这是我在论坛看到的,unity多点触控。感觉还不错,分享给大家 //用于绑定参照物对象 var target : transform; //缩放系数 var...

这是我在论坛看到的,unity多点触控。感觉还不错,分享给大家

//用于绑定参照物对象
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;
}
 
function update ()
{
  //判断触摸数量为单点触摸
  if(input.touchcount == 1)
  {
    //触摸类型为移动触摸
    if(input.gettouch(0).phase==touchphase.moved)
    {
      //根据触摸点计算x与y位置
      x += input.getaxis("mouse x") * xspeed * 0.02;
      y -= input.getaxis("mouse y") * yspeed * 0.02;
 
    }
  }
 
  //判断触摸数量为多点触摸
  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.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);
}

以上所述就是本文的全部内容了,有需要的小伙伴可以参考下

上一篇:

下一篇: