博客
关于我
[Unity踩坑记录] 在电脑上开发并调试触摸相关事件
阅读量:499 次
发布时间:2019-03-07

本文共 591 字,大约阅读时间需要 1 分钟。

第一次做ipad上的一些触摸操作,在电脑上测试正常,在ipad上出现了一些问题。

查找资料后进行总结如下:

 

问题分析:

  1. 触摸事件配套的输入API为Input.GetTouch,但是它无法通过鼠标点击被调用
  2. 在unity中Touch事件可以触发Mouse相关事件;但Mouse相关的操作不能触发Touch的相关事件
  3. 触摸操作可以通过Input.GetAxis(“Mouse X”)、Input.GetAxis(”Mouse Y”) (以下简称Input.GetAxis(Mouse))获取指尖移动距离

因为1造成的不便,使用了Mouse相关事件进行开发。同时2和3的出现方便了在电脑上使用Mouse进行一些触摸事件的测试,但也带来了不少麻烦:

有时在屏幕拖动使用Input.GetAxis(Mouse)会出现一些莫名其妙的大动作。

原因就在于Input.GetAxis(Mouse)的功能是对鼠标的位置进行连续取值,来计算得到移动delta值。而鼠标不论是否按下,它的位置对于程序来说是时刻已知的,所以它不会出现数值突变。

而触摸的手指却是会脱离屏幕,这时Input.GetAxis(Mouse)就会无法取值,等到下一次手指再触摸时,会与上一次离开时的坐标进行计算得到delta值,就像默认手指直接从上一次离开屏幕的点突然滑动到了这次触摸的起始点上,出现了莫名其妙的大动作。

 

参考文章

转载地址:http://wvacz.baihongyu.com/

你可能感兴趣的文章
mysql备份
查看>>
mysql备份与恢复
查看>>
mysql备份工具xtrabackup
查看>>
mysql备份恢复出错_尝试备份/恢复mysql数据库时出错
查看>>
mysql复制内容到一张新表
查看>>
mysql复制表结构和数据
查看>>
mysql复杂查询,优质题目
查看>>
MySQL外键约束
查看>>
MySQL多表关联on和where速度对比实测谁更快
查看>>
MySQL多表左右连接查询
查看>>
mysql大批量删除(修改)The total number of locks exceeds the lock table size 错误的解决办法
查看>>
mysql如何做到存在就更新不存就插入_MySQL 索引及优化实战(二)
查看>>
mysql如何删除数据表,被关联的数据表如何删除呢
查看>>
MySQL如何实现ACID ?
查看>>
mysql如何记录数据库响应时间
查看>>
MySQL子查询
查看>>
Mysql字段、索引操作
查看>>
mysql字段的细节(查询自定义的字段[意义-行列转置];UNION ALL;case-when)
查看>>
mysql字段类型不一致导致的索引失效
查看>>
mysql字段类型介绍
查看>>