iOS 手势大全
//系统自动调用
//一个UITouch代表一根手指 按住option变成两根手指
//虽然是两个手指,但只执行一次触摸事件
- (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 {} 取消触摸手势
//获取任意手指
UITouch * touch = [touches anyObject];
//手指触摸的View
NSLog(@"touch.view:%@",touch.view);
//点击次数
NSLog(@"点击次数:%ld",touch.tapCount);
//当前手指的位置
CGPoint currentPonit = [touch locationInView:touch.view];
//上一次手指所处的位置
CGPoint previousPonit = [touch previousLocationInView:touch.view];
事件产生和传递的过程:
当发生触摸事件的时候,先传递给UIApplication,以队列结构接收事件。传递给主窗口,主窗口传递给控制器的UIView,遍历UIView的子视图,寻找最合适的UIView来接收。
响应者链:
该类的上一级如果是UIView,子视图处理事件,如果处理不了,找他的父视图。
该类的上一级如果是UIViewController,则是由所属的控制器来处理。
//返回最合适的UIView
- (UIView *)hitTest:(CGPoint)point withEvent:(UIEvent *)event {}
//判断当前的点在不在View上
- (BOOL)pointInside:(CGPoint)point withEvent:(UIEvent *)event {
return YES;
}
self.imageView.userInteractionEnabled = NO;
//无法响应事件的3种情况:
//1、当userInteractionEnabled未开启
//2、当hidden属性为YES
//3、当alpha属性为0时
//将以YellowView为坐标系的点,转化为以button为坐标系的点 self = yellowView
CGPoint buttonPoint = [self convertPoint:point toView:self.button];
这个函数的用处是判断当前的点击或者触摸事件的点是否在当前的view中。
它被hitTest:withEvent:调用,
- (BOOL)pointInside:(CGPoint)point withEvent:(UIEvent *)event; // default returns YES if point is in bounds
4、手机摇一摇
//事件的种类
- (void)motionBegan:(UIEventSubtype)motion withEvent:(nullable UIEvent *)event {
if (motion == UIEventSubtypeMotionShake) {
NSLog(@"摇一摇");
}
}
5、**Gesture手势
UIGestureRecognizerState:
开始: UIGestureRecognizerStateBegan
改变: UIGestureRecognizerStateChanged
结束: UIGestureRecognizerStateEnded
取消: UIGestureRecognizerStateCancelled
失败: UIGestureRecognizerStateFailed,
//同时使用两个手势 捏合 旋转
- (BOOL)gestureRecognizer:(UIGestureRecognizer *)gestureRecognizer shouldRecognizeSimultaneouslyWithGestureRecognizer:(UIGestureRecognizer *)otherGestureRecognizer {
return YES;
}
UITapGestureRecognizer * tap1 = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(tapAction1:)];
//点击一次便触发
tap1.numberOfTapsRequired = 1;
[self.imageView addGestureRecognizer:tap1];
UITapGestureRecognizer * tap2 = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(tapAction2:)];
//双击一次便触发
tap2.numberOfTapsRequired = 2;
[self.imageView addGestureRecognizer:tap2];
//如果tap2成功执行,让tap1失败
[tap1 requireGestureRecognizerToFail:tap2];
[self.imageView addGestureRecognizer:longGesture];
(3)轻扫手势 Swipe
UISwipeGestureRecognizer * swipeGesture = [[UISwipeGestureRecognizer alloc] initWithTarget:self action:@selector(swipeAction:)];
//设置轻扫方向
swipeGesture.direction = UISwipeGestureRecognizerDirectionLeft;
[self.imageView addGestureRecognizer:swipeGesture];
UIPinchGestureRecognizer * pinchGesture = [[UIPinchGestureRecognizer alloc] initWithTarget:self action:@selector(pinchAction:)];
pinchGesture.delegate = self;
[self.imageView addGestureRecognizer:pinchGesture];
self.pin = pinchGesture;
//对应事件
- (void)pinchAction:(UIPinchGestureRecognizer *)pin {
self.imageView.transform = CGAffineTransformScale(self.imageView.transform, pin.scale, pin.scale);
//复位
pin.scale = 1;
}
(5)旋转事件 Rotation
UIRotationGestureRecognizer * rotationGesture = [[UIRotationGestureRecognizer alloc] initWithTarget:self action:@selector(rotationAction:)];
rotationGesture.delegate = self;
[self.imageView addGestureRecognizer:rotationGesture];
//对应事件
- (void)rotationAction:(UIRotationGestureRecognizer *)rotation {
self.imageView.transform = CGAffineTransformRotate(self.imageView.transform, rotation.rotation);
//复位
rotation.rotation = 0;
}
(6)拖动手势 Pan
UIPanGestureRecognizer * panGesture = [[UIPanGestureRecognizer alloc] initWithTarget:self action:@selector(panAction:)];
[self.imageView addGestureRecognizer:panGesture];
//对应事件
- (void)panAction:(UIPanGestureRecognizer *)pan {
//获取拖动的偏移量
CGPoint ponit = [pan translationInView:self.view];
self.imageView.center = CGPointMake(self.imageView.center.x + ponit.x, self.imageView.center.y + ponit.y);
//复位
[pan setTranslation:CGPointZero inView:self.imageView];
}
iOS 手势大全的更多相关文章
- 墙裂推荐 iOS 资源大全
这是个精心编排的列表,它包含了优秀的 iOS 框架.库.教程.XCode 插件.组件等等. 这个列表分为以下几个部分:框架( Frameworks ).组件( Components ).测试( Tes ...
- iOS 资源大全整理
这是个精心编排的列表,它包含了优秀的 iOS 框架.库.教程.XCode 插件.组件等等. 这个列表分为以下几个部分:框架( Frameworks ).组件( Components ).测试( Tes ...
- ios手势
iOS 手势操作:拖动.捏合.旋转.点按.长按.轻扫.自定义 大 中 小 1.UIGestureRecognizer 介绍 手势识别在 iOS 中非常重要,他极大地提高了移动设备的使用便捷性. i ...
- iOS手势学习UIGestureRecognizer & cocos2d 手势推荐
iOS手势学习UIGestureRecognizer & cocos2d 手势推荐 手势识别类型: UILongPressGestureRecognizer // 长按UIPanGestur ...
- iOS手势处理
iOS手势处理 iOS手势有着如下几种: UITapGestureRecognizer UIPinchGestureRecognizer UIRotationGestureRecognizer UIS ...
- iOS github大全 & iOS7的学习blog
iOS github大全 :有600多个iOS各方面的开源库,并分类了 一天天学习iOS7 :每天学习一点iOS7的新特性
- iOS 手势识别器概述
手势识别器 iOS 手势识别器(UIGestureRecognizer) 点击手势(UITapGestureRecognizer) 滑动手势(UISwipeGestureRecognizer) 旋转手 ...
- swift 实现iOS手势密码、指纹密码、faceID
本博客包含了如何实现iOS手势密码.指纹密码.faceID全步骤,包括了完整的代码. 先附上demo地址https://github.com/Liuyubao/LYBTouchID,支持swift3. ...
- iOS手势解锁、指纹解锁--Swift代码
一.手势密码 1. 1.1.用UIButton组成手势的节点. 1.2.当手指接触屏幕时,调用重写的 touchesBegan:withEvent方法(在touchesBegan里调用setNeeds ...
随机推荐
- .NET文件上传的大小限制配置
<system.web> <!--maxRequestLength单位是Kb--> <httpRuntime maxRequestLength="20971 ...
- How Tomcat Works(十)
本文接下来分析tomcat的日志记录器,日志记录器是用来记录消息的组件,在tomcat中,日志记录器需要与某个servlet容器相关连:在org.apache.catalina.logger包下,to ...
- uva 542 - France '98(概率)
题目链接:uva 542 - France '98 题目大意:有16支球队比赛,给出16支球队的名称,然后给出16*16的表格,g[i][j] 表示i队胜j队的概率,问说16支球队获得总冠军的概率. ...
- A*算法为什么是最优的
图搜索的A*算法有两种情况: hn是可采纳的,但是不是满足一致性 如果满足一致性,A*算法的实现要简单一些:即使不检查closed节点的状态重复,也能得到最优的结果 下面是证明最优性的一些关键点: 1 ...
- Castle IOC容器内幕故事(下)
主要内容 1.ComponentModelBuilder 和 Contributors 2.Contributors分析 3.Handles分析 4.ComponentActivator分析 一.Co ...
- PING的原理以及ICMP协议
主要内容: 1.ping的原理以及工作过程 2.ICMP协议 3.ICMP的应用:ping,traceroute 1.ping的原理以及工作过程 ping的原理 ping 程序是用来探测主机到主机 ...
- JQuery 弹出层,始终显示在屏幕正中间
1.让层始终显示在屏幕正中间: 样式代码: .model{ position: absolute; z-index: 1003; width:320px; height:320px; text-ali ...
- 纯CSS打造Flow-Steps导航
几个要点: 1.三角箭头效果是用border实现的,详细的可以google下CSS 三角 2.IE6下不支持border-color:transparent(透明),解决方法是先将其设置为一个不常用的 ...
- 【摘要】获得HTML元素的绝对位置
function findAbsolutePosition(obj) { var curleft = curtop = 0; if (obj.offsetParent) { do { curleft ...
- Android上的SQLLite性能分析
也许有人还不知道,Android 是有一些内建的 类库支持 SQL Lite 数据库的操作.他提供了一个很好的方式在 Android 上组织少量的数据.不管怎样,在使用这些类库的时候有一些陷阱是需要注 ...