关键点1:在unity中touch事件同时也会触发GetMouseButton事件,有时候可能会给你带来方便,但是如果没有意识到这个问题的话,也很可能给你带来很大的麻烦。
关键点2:触摸操作也可以使用Input.GetAxis("MouseX")(或"MouseY",下同,略去不写)来判断指尖移动的距离,虽然这点很方便,但是这样就带来了另外两个问题,见关键点3和4;
关键点3:Input.GetAxis("MouseX")取得的值与Input.GetTouch(0).deltaPosition的取值有一些细微但是很重要的差别:
使用Input.GetAxis("Mouse X"),没有任何问题;
使用deltaPosition同样没有任何问题,因为这就是为触摸操作而设计的。
关键点4:实践中发现在直观感觉差不多的滑动过程(分别用鼠标拖动和手指拖动)中,Input.GetTouch(0).deltaPosition.x的值总是比Input.GetAxis("Mouse X")取得的值要大很多,分析可能是手机屏幕dpi比较大的原因,因此在实践中为了获取直观感受差不多的旋转速度,要分别调试旋转加成系数。
总结一下:不要使用一条代码判断两种情况,最好分开,做一个单选(可以使用Enum),要么鼠标操作,要么触摸操作,分别使用最合适的判断和函数,并分别调试旋转加成系数
事件回顾:
在写一个惯性拖动旋转的脚本的时候,为在pc和Android平台上都能使用(即用鼠标和触摸都能控制),我使用了如下的判断语句:
if(Input.GetMouseButton(0) || (Input.touchCount>0&& Input.GetTouch(0).phase == TouchPhase.Moved)
来判断鼠标按下或者手指按下,并用Input.GetAxis(“MouseX”)来获取拖动的值,期望能够一次判断两种情况,分别适应不同平台的操作。在pc上使用鼠标操作没有任何问题,但是在android上触摸操作时出现了问题。经过多次测试并查阅资料,发现原来触摸操作也可以触发Input.GetMouseButton(0)的事件,这就引发了前述关键点3>2)>a 中的问题。
惯性旋转物体脚本:
usingUnityEngine;
usingSystem.Collections;
//操作方式
public enumControlType{
mouseControl,
touchControl,
}
public classRotateTarget: MonoBehaviour
{
publicControlType controlType;
public Transform rotTarget;
//旋转速度加成系数
public float rotSpeedScalar;
private float currentSpeed = 0;
void Update()
{
if(controlType==ControlType.mouseControl)
{
//鼠标操作
if(Input.GetMouseButton(0))
{
//拖动时速度
//鼠标或手指在该帧移动的距离*deltaTime为手指移动的速度,此处为Input.GetAxis("MouseX") / Time.deltaTime
//不通帧率下lerp的第三个参数(即混合比例)也应根据帧率而不同--
//考虑每秒2帧和每秒100帧的情况,如果此参数为固定值,那么在2帧的情况下,一秒后达到目标速度的0.75,而100帧的情况下,一秒后则基本约等于目标速度
currentSpeed = Mathf.Lerp(currentSpeed, Input.GetAxis("Mouse X") /Time.deltaTime,0.5f*Time.deltaTime);
} else
{
//放开时速度
currentSpeed = Mathf.Lerp(currentSpeed, 0,0.5f*Time.deltaTime);
}
}
elseif(controlType==ControlType.touchControl)
{
//触摸操作
if (Input.touchCount > 0&& Input.GetTouch(0).phase == TouchPhase.Moved)
{
//在安卓设备上也可以用MouseX,根据实验,touch[0].deltaPosition.x的值总是比Mouse X的值大很多,所以此处使用MouseX
currentSpeed= Mathf.Lerp(currentSpeed, Input.GetAxis("MouseX")/Time.deltaTime,0.5f*Time.deltaTime);
} else
{
//放开时速度
currentSpeed = Mathf.Lerp(currentSpeed, 0,0.5f*Time.deltaTime);
}
}
rotTarget.Rotate(Vector3.down, Time.deltaTime * currentSpeed *rotSpeedScalar);
}
}
原文地址:http://blog.sina.com.cn/s/blog_4148e8630101velz.html