博客
关于我
[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 查询数据库所有表的字段信息
查看>>
【Java基础】什么是面向对象?
查看>>
mysql 查询,正数降序排序,负数升序排序
查看>>
MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
查看>>
mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
查看>>
mysql 死锁(先delete 后insert)日志分析
查看>>
MySQL 死锁了,怎么办?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 添加列,修改列,删除列
查看>>
mysql 添加索引
查看>>
MySQL 添加索引,删除索引及其用法
查看>>
mysql 状态检查,备份,修复
查看>>
MySQL 用 limit 为什么会影响性能?
查看>>
MySQL 用 limit 为什么会影响性能?有什么优化方案?
查看>>
MySQL 用户权限管理:授权、撤销、密码更新和用户删除(图文解析)
查看>>
mysql 用户管理和权限设置
查看>>
MySQL 的 varchar 水真的太深了!
查看>>
mysql 的GROUP_CONCAT函数的使用(group_by 如何显示分组之前的数据)
查看>>
MySQL 的instr函数
查看>>