IOS touch event animation 转动的风车
最近开始学习IOS的开发,师兄给我提出一个需求:实现一个可拖动的转盘。师兄提示我说利用touch event和UIView animation。经过一两天的折腾边学边做,算是实现了基本功能。这里写写加深自己的印象。
要求是这样的:在屏幕上显示一个圆盘,如果没有干扰的时候匀速转动,当手指触碰屏幕的时候转盘要跟随手指的运动而转动。我的思路是这样的:用一个NSTimer来控制转盘(UIImageView),每隔一段时间调用一个转动的动画(每次转动一个小角度),这样就可以达到匀速转动的效果。动画用UIView animation 来实现,在animation里面通过设置Trasform属性来转动。
匀速转动的问题解决了,接下来就要解决响应手势的问题。google了一下发现了GestureRecognizer类,于是开始采用TapGestureRecognizer,SwipeGestureRecognizer,和PanGestureRecognizer来响应手指的运动。Tap对应点击,Swipe对应在屏幕上的滑动,pan则对应拖动的动作。我在imageView上面添加了这几个GestureRecognizer,然后为每一个Recognizer编写对应的处理事件。然后我遇到了几个问题,一个是事件无法按照我的预期去响应,尤其是拖动,根本一塌糊涂。还有一个就是,我对于如何使用PanGestureRecognizer没有思路。后来问问师兄,师兄提醒说试试UIView 的touch event,所以我就开始了新的摸索。
看了一下资料以后发现其实用touch event处理更简洁,使用touch event要覆盖UIView的四个方法:
- (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event;
手指刚刚触摸屏幕的时候触发的事件
- (void)touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event;
手指在屏幕上移动是会不断触发这个事件
- (void)touchesEnded:(NSSet *)touches withEvent:(UIEvent *)event;
手指离开后触发的事件
- (void)touchesCancelled:(NSSet *)touches withEvent:(UIEvent *)event;
触摸正常结束前,某个系统事件(例如有电话打进来)打断了触摸过程
在这是时间里面都有一个对象NSSet,这个set里面包含了一组UITouch对象至少一个,而每一个就对应这个一个手指的状态,也就是说touch event是可以同时记录多个手指触摸的状态的。UITouch 里面记录了当前屏幕被触摸的位置,有了这个就可以实现之前说到的拖动功能了。
大体思路是这样的,当touch开始时会触发touchesBegan事件,在这里面我记录下开始的位置startPoint,然后手指移动以后会触发touchesMoved事件,在这个事件里面得到当前位置endPoint,这样的话就得到了两个点再加上view的中心center就有了三个点,三个点构成的两条直线line1(startPoint,center) line2(endPoint,center),求出两条直线的夹角就可以知道需要转动的角度了。得出角度以后再用两条直线的到角确定转到的方向(顺时针,逆时针)。每一次转动后startPoint=endPoint继续move,直到touchesEnded就是最后的位置了。难点主要是数值计算,比较麻烦,要注意斜率不存在的情况。还有一个要注意的就是精度问题,当startPoint和endPoint相差很小的时候我是不处理的,设定一个伐值,当两点之间的距离大于一定值时才进行转动。避免了float由于数值太小导致的精度丢失,以及不必要的微小运动。
IOS学习笔记,欢迎指正错误。XCode项目代码:http://pan.baidu.com/share/link?shareid=2625688121&uk=4245725234
IOS touch event animation 转动的风车的更多相关文章
- Html5 touch event
HTML5 for the Mobile Web: Touch Events POSTED BY RUADHAN - 15 AUG 2013 See also... Touch-friendly Dr ...
- Touch Event
转自: http://hi.baidu.com/masaiui/item/971775e8b316238bc10d754b 参考: http://hedgehogking.com/?p=55 ...
- MonkeyRunner 连续两次点击报“Error sending touch event”
最近用monkeyrunner做自动化测试,遇到连续两次点击,第二次点击就会报错“Error sending touch event”. 具体做法如下: device.touch(234,112, ' ...
- iOS Touch ID 身份认证
iOS Touch ID 身份认证 iOS 8 及以后录了指纹的设备可以使用 touch ID 进行身份认证,指纹符合录入的指纹才能认证成功. 步骤 导入 LocalAuthentication 框架 ...
- taro 小程序 & touch event 转换 bug
taro 小程序 & touch event 转换 bug before after 事件处理 https://nervjs.github.io/taro/docs/event.html#do ...
- iOS touch事件单击双击区分响应
如果您的 iPhone 应用里有个 view,既有单击操作又有双击操作.用户双击 view 时,总是先执行一遍单击的操作再执行双击的操作.所以直接判断时就会发现不能直接进入双击操作.下面是区分 tou ...
- (转)iOS动画Core Animation
文章转载:http://blog.sina.com.cn/s/blog_7b9d64af0101b8nh.html 在iOS中动画实现技术主要是:Core Animation. Core Animat ...
- iOS UIKit:animation
@import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css); @import url(/ ...
- iOS --- Touch ID指纹解锁
https://www.cnblogs.com/ljmaque/p/TouchID.html 最近在项目中刚好用到了TouchId指纹解锁功能,之前也没有接触过,立马百度看看究竟是要如何使用,发现其实 ...
随机推荐
- POJ 3176-Cow Bowling(DP||记忆化搜索)
Cow Bowling Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 14210 Accepted: 9432 Desc ...
- 常用批处理命令总结3之Find和FindStr
原文:常用批处理命令总结3之Find和FindStr find 作用:从文件中收索字符串 格式:find 参数 "字符串" 路径\文件名 参数: /V 显示所有未包含指定字符串的行 ...
- ftk学习记录(IME文章)
[声明:版权全部,欢迎转载.请勿用于商业用途. 联系信箱:feixiaoxing @163.com] 前面说的是全屏设置,还是请大家看一下效果图. watermark/2/text/aHR0cDovL ...
- 全局scope与Isolate scope通信
AngularJS 全局scope与Isolate scope通信 在项目开发时,全局scope 和 directive本地scope使用范围不够清晰,全局scope与directive本地scope ...
- 快速构建Windows 8风格应用21-构建简单媒体播放器
原文:快速构建Windows 8风格应用21-构建简单媒体播放器 本篇博文主要介绍如何构建一个简单的媒体播放器. <快速构建Windows 8风格应用20-MediaElement>博文中 ...
- atitit.ajax bp dwr 3.该票据安排使用的流量汇总 VO9o.....
atitit.ajax bp dwr 3.该票据安排使用的流量汇总 VO9o..... 1. 安装配置 1 1.1. 下载 dwr.jar 1M 1 1.2. 配置注解方式..web.xml 1 2 ...
- 使用 C# 进行 Outlook 2007 编程
原文:使用 C# 进行 Outlook 2007 编程 探讨如何使用 C# 编程语言生成 Outlook 识别的应用程序和 Outlook 外接程序. 请从"Add References&q ...
- javascript面向对象2
原文:javascript面向对象2 首先我们先创建一个对象 var user = Object(); user.name = "张三"; user.age = 20; user. ...
- Tabs - 选项卡插件
接上篇Tabs - 选项卡插件 其中12)Yet (E)Another Tab Interface没有依赖任何javascript框架,以作补充 9)Flipping C ...
- 建立Ftp站点
建立Ftp站点步骤: 1.首先创建一个用户 我的电脑右键->管理->本地用户和组->用户->“右键”新建用户->输入用户名和密码再点创建就行了! 2.其次是在C盘新建文件 ...