前言

	NS_CLASS_AVAILABLE_IOS(3_2)  @interface UIGestureRecognizer : NSObject
@available(iOS 3.2, *) public class UIGestureRecognizer : NSObject // 点击(轻点)
NS_CLASS_AVAILABLE_IOS(3_2) @interface UITapGestureRecognizer : UIGestureRecognizer
@available(iOS 3.2, *) public class UITapGestureRecognizer : UIGestureRecognizer // 长按(按住不放)
NS_CLASS_AVAILABLE_IOS(3_2) @interface UILongPressGestureRecognizer : UIGestureRecognizer
@available(iOS 3.2, *) public class UILongPressGestureRecognizer : UIGestureRecognizer // 旋转(两个手指进行旋转)
NS_CLASS_AVAILABLE_IOS(3_2) @interface UIRotationGestureRecognizer : UIGestureRecognizer
@available(iOS 3.2, *) public class UIRotationGestureRecognizer : UIGestureRecognizer // 捏合(两个手指,缩放手势)
NS_CLASS_AVAILABLE_IOS(3_2) @interface UIPinchGestureRecognizer : UIGestureRecognizer
@available(iOS 3.2, *) public class UIPinchGestureRecognizer : UIGestureRecognizer // 拖动(移动速度较慢)
NS_CLASS_AVAILABLE_IOS(3_2) @interface UIPanGestureRecognizer : UIGestureRecognizer
@available(iOS 3.2, *) public class UIPanGestureRecognizer : UIGestureRecognizer // 滑动(快速移动)
NS_CLASS_AVAILABLE_IOS(3_2) @interface UISwipeGestureRecognizer : UIGestureRecognizer
@available(iOS 3.2, *) public class UISwipeGestureRecognizer : UIGestureRecognizer

1、tapGesture 点击手势

1.1 tapGesture 的创建

  • Objective-C

    	// 实例化点击手势对象
    UITapGestureRecognizer *tapGesture = [[UITapGestureRecognizer alloc] initWithTarget:self
    action:@selector(tapClick:)]; // 向 imageView 添加点击手势
    [imageView addGestureRecognizer:tapGesture];
  • Swift

    	// 实例化点击手势对象
    let tapGesture:UITapGestureRecognizer = UITapGestureRecognizer(target: self,
    action: #selector(UiGestureRecognizer.tapClick(_:))) // 向 imageView 添加点击手势
    imageView?.addGestureRecognizer(tapGesture)

1.2 tapGesture 的设置

  • Objective-C

    	// 设置点击次数
    /*
    默认为 1:单击,为 2 时为双击
    */
    singleTapGesture.numberOfTapsRequired = 1; // 设置触摸点数
    /*
    默认为 1,单个手指触摸
    */
    singleTapGesture.numberOfTouchesRequired = 1; // 单双击共存
    /*
    设置单击手势与双击手势共存,当没有检测到双击手势或检测双击手势失败时单击手势才有效
    */
    [singleTapGesture requireGestureRecognizerToFail:doubleTapGesture]; // 获取点击的视图
    /*
    剪取点击的视图,附带点击手势一起剪取
    */
    UIView *tapView = tapGesture.view; // 获取点击的图片
    /*
    复制点击的图片,附带点击手势一起复制
    */
    UIImage *tapImage = ((UIImageView *)tapGesture.view).image;
  • Swift

    	// 设置点击次数
    /*
    默认为 1:单击,为 2 时为双击
    */
    singleTapGesture.numberOfTapsRequired = 1 // 设置触摸点数
    /*
    默认为 1,单个手指触摸
    */
    singleTapGesture.numberOfTouchesRequired = 1 // 单双击共存
    /*
    设置单击手势与双击手势共存,当没有检测到双击手势或检测双击手势失败时单击手势才有效
    */
    singleTapGesture.requireGestureRecognizerToFail(doubleTapGesture) // 获取点击的视图
    /*
    剪取点击的视图,附带点击手势一起剪取
    */
    let tapView:UIView = tapGesture.view! // 获取点击的图片
    /*
    复制点击的图片,附带点击手势一起复制
    */
    let tapImage:UIImage = (tapGesture.view! as! UIImageView).image!

1.3 自定义触摸响应事件处理

  • Objective-C

    	- (void)tapClick:(UITapGestureRecognizer *)tapGesture {
    
    	}
  • Swift

    	func tapClick(tapGesture:UITapGestureRecognizer) {
    
    	}

2、longPressGesture 长按手势

2.1 longPressGesture 的创建

  • Objective-C

    	// 实例化长按手势对象
    UILongPressGestureRecognizer *longPressGesture = [[UILongPressGestureRecognizer alloc] initWithTarget:self
    action:@selector(longPressClick:)]; // 向 imageView 添加长按手势
    [imageView addGestureRecognizer:longPressGesture];
  • Swift

    	// 实例化长按手势对象
    let longPressGesture:UILongPressGestureRecognizer = UILongPressGestureRecognizer(target: self,
    action: #selector(UiGestureRecognizer.longPressClick(_:))) // 向 imageView 添加长按手势
    imageView?.addGestureRecognizer(longPressGesture)

2.2 longPressGesture 的设置

  • Objective-C

    	// 获取手势状态
    UIGestureRecognizerState state = longPressGesture.state; // 长按手势开始
    if (longPressGesture.state == UIGestureRecognizerStateBegan) { } // 长按手势触发结束
    if (longPressGesture.state == UIGestureRecognizerStateEnded) { }
  • Swift

    	// 获取手势状态
    let state:UIGestureRecognizerState = longPressGesture.state // 长按手势开始
    if longPressGesture.state == UIGestureRecognizerState.Began { } // 长按手势触发结束
    if longPressGesture.state == UIGestureRecognizerState.Ended { }

2.3 自定义触摸响应事件处理

  • Objective-C

    	- (void)longPressClick:(UILongPressGestureRecognizer *)longPressGesture {
    
    	}
  • Swift

    	func longPressClick(longPressGesture:UILongPressGestureRecognizer) {
    
    	}

3、rotationGesture 旋转手势

3.1 rotationGesture 的创建

  • Objective-C

    	// 实例化旋转手势对象
    UIRotationGestureRecognizer *rotationGesture = [[UIRotationGestureRecognizer alloc] initWithTarget:self
    action:@selector(rotationClick:)]; // 向 imageView 添加旋转手势
    [imageView addGestureRecognizer:rotationGesture];
  • Swift

    	// 实例化旋转手势对象
    let rotationGesture:UIRotationGestureRecognizer = UIRotationGestureRecognizer(target: self,
    action: #selector(UiGestureRecognizer.rotationClick(_:))) // 向 imageView 添加旋转手势
    imageView?.addGestureRecognizer(rotationGesture)

3.2 rotationGesture 的设置

  • Objective-C

    	// 获取旋转角度
    /*
    rotation 获取到的为弧度,1 度 = PI/180 弧度
    */
    CGFloat rotation = rotationGesture.rotation * 180 * M_1_PI; // 图片旋转
    /*
    lastRotation 为之前的角度
    */
    imageView.transform = CGAffineTransformMakeRotation(lastRotation + rotationGesture.rotation); // 旋转手势触发结束
    if (rotationGesture.state == UIGestureRecognizerStateEnded) { lastRotation += rotationGesture.rotation;
    }
  • Swift

    	// 获取旋转角度
    /*
    rotation 获取到的为弧度,1 度 = PI/180 弧度
    */
    let rotation:CGFloat = rotationGesture.rotation * 180 * CGFloat(M_1_PI) // 图片旋转
    /*
    lastRotation 为之前的角度
    */
    imageView?.transform = CGAffineTransformMakeRotation(lastRotation + rotationGesture.rotation) // 旋转手势触发结束
    if rotationGesture.state == UIGestureRecognizerState.Ended { lastRotation += rotationGesture.rotation
    }

3.3 自定义触摸响应事件处理

  • Objective-C

    	// 用模拟器时需按住 option 键
    - (void)rotationClick:(UIRotationGestureRecognizer *)rotationGesture { }
  • Swift

    	// 用模拟器时需按住 option 键
    func rotationClick(rotationGesture:UIRotationGestureRecognizer) { }

4、pinchGesture 捏合手势

4.1 pinchGesture 的创建

  • Objective-C

    	// 实例化捏合手势对象
    UIPinchGestureRecognizer *pinchGesture = [[UIPinchGestureRecognizer alloc] initWithTarget:self
    action:@selector(pinchClick:)]; // 向 imageView 添加捏合手势
    [imageView addGestureRecognizer:pinchGesture];
  • Swift

    	// 实例化捏合手势对象
    let pinchGesture:UIPinchGestureRecognizer = UIPinchGestureRecognizer(target: self,
    action: #selector(UiGestureRecognizer.pinchClick(_:))) // 向 imageView 添加捏合手势
    imageView?.addGestureRecognizer(pinchGesture)

4.2 pinchGesture 的设置

  • Objective-C

    	// 获取缩放倍数
    CGFloat scale = pinchGesture.scale; // 图片缩放
    imageView.transform = CGAffineTransformMakeScale(pinchGesture.scale, pinchGesture.scale);
    imageView.bounds = CGRectMake(0, 0, imageView.bounds.size.width * pinchGesture.scale,
    imageView.bounds.size.height * pinchGesture.scale); // 还原缩放倍数
    [pinchGesture setScale:1];
  • Swift

    	// 获取缩放倍数
    let scale:CGFloat = pinchGesture.scale // 图片缩放
    imageView?.transform = CGAffineTransformMakeScale(pinchGesture.scale, pinchGesture.scale)
    imageView?.bounds = CGRectMake(0, 0, imageView!.bounds.size.width * pinchGesture.scale,
    imageView!.bounds.size.height * pinchGesture.scale) // 还原缩放倍数
    pinchGesture.scale = 1

4.3 自定义触摸响应事件处理

  • Objective-C

    	// 用模拟器时需按住 option 键
    - (void)pinchClick:(UIPinchGestureRecognizer *)pinchGesture { }
  • Swift

    	// 用模拟器时需按住 option 键
    func pinchClick(pinchGesture:UIPinchGestureRecognizer) { }

5、panGesture 拖动手势

5.1 panGesture 的创建

  • Objective-C

    	// 实例化拖拽手势对象
    UIPanGestureRecognizer *panGesture = [[UIPanGestureRecognizer alloc] initWithTarget:self
    action:@selector(panClick:)]; // 向 imageView 添加拖拽手势
    [imageView addGestureRecognizer:panGesture];
  • Swift

    	// 实例化拖拽手势对象
    let panGesture:UIPanGestureRecognizer = UIPanGestureRecognizer(target: self,
    action: #selector(UiGestureRecognizer.panClick(_:))) // 向 imageView 添加拖拽手势
    imageView?.addGestureRecognizer(panGesture)

5.2 panGesture 的设置

  • Objective-C

    	// 获取手势位置
    CGPoint currentPoint = [panGesture locationInView:self.view]; // 图片移动
    imageView.center = currentPoint;
  • Swift

    	// 获取手势位置
    let currentPoint:CGPoint = panGesture.locationInView(self.view) // 图片移动
    imageView?.center = currentPoint

5.3 自定义触摸响应事件处理

  • Objective-C

    	- (void)panClick:(UIPanGestureRecognizer *)panGesture {
    
    	}
  • Swift

    	func panClick(panGesture:UIPanGestureRecognizer) {
    
    	}

6、swipeGesture 滑动手势

6.1 swipeGesture 的创建

  • Objective-C

    	// 实例化滑动手势对象
    UISwipeGestureRecognizer *swipeGesture = [[UISwipeGestureRecognizer alloc] initWithTarget:self
    action:@selector(swipeClick:)]; // 设置滑动方向,默认为 0:向右滑动
    swipeGesture.direction = UISwipeGestureRecognizerDirectionLeft | UISwipeGestureRecognizerDirectionRight; // 向 imageView 添加拖拽手势
    [imageView addGestureRecognizer:swipeGesture];
  • Swift

    	// 实例化滑动手势对象
    let swipeGesture:UISwipeGestureRecognizer = UISwipeGestureRecognizer(target: self,
    action: #selector(UiGestureRecognizer.swipeClick(_:))) // 设置滑动方向,默认为 0:向右滑动
    swipeGesture.direction = [.Left, .Right] // 向 imageView 添加拖拽手势
    imageView?.addGestureRecognizer(swipeGesture)

6.2 swipeGesture 的设置

  • Objective-C

    	// 获取滑动方向
    UISwipeGestureRecognizerDirection direction = swipeGesture.direction;
  • Swift

    	// 获取滑动方向
    let direction:UISwipeGestureRecognizerDirection = swipeGesture.direction

6.3 自定义触摸响应事件处理

  • Objective-C

    	- (void)swipeClick:(UISwipeGestureRecognizer *)swipeGesture {
    
    	}
  • Swift

    	func swipeClick(swipeGesture:UISwipeGestureRecognizer) {
    
    	}

iOS - UIGestureRecognizer的更多相关文章

  1. iOS UIGestureRecognizer与UIMenuController(内容根据iOS编程)

    UIGestureRecognizer 对象会截取本应由视图处理的触摸事件.当某个UIGestureRecognizer对象识别出特定的手势后,就会向指定的对象发送指定的消息.iOS SDK默认提供若 ...

  2. XamarinForm Effects 调用事件

    原文地址 在Xamarin.Forms控件中实现底层多点触控跟踪. 一个effect可以定义和调用一个事件,在底层本地视图中发出信号的变化.这篇文章演示如何实现底层多点触控跟踪,以及如何生成信号触摸活 ...

  3. iOS基础篇(十七)——UIGestureRecognizer用法

    UIGestureRecognizer(手势识别)在iOS 中非常重要,他极大地提高了移动设备的使用便捷性: 在3.2之前是主要使用的是由UIResponder而来的如下4种方式: - (void)t ...

  4. 点击事件touches与ios的手势UIGestureRecognizer

    .h文件 @property (weak,nonatomic) IBOutlet UILabel *messageLabel;@property (weak,nonatomic) IBOutlet U ...

  5. UIGestureRecognizer ios手势识别温习

    1.UIGestureRecognizer介绍 手势识别在iOS上非常重要,手势操作移动设备的重要特征,极大的增加了移动设备使用便捷性. iOS系统在3.2以后,为方便开发这使用一些常用的手势,提供了 ...

  6. [BS-25] IOS中手势UIGestureRecognizer概述

    IOS中手势UIGestureRecognizer概述 一.概述 iPhone中处理触摸屏的操作,在3.2之前是主要使用的是由UIResponder而来的如下4种方式: - (void)touches ...

  7. iOS手势学习UIGestureRecognizer & cocos2d 手势推荐

    iOS手势学习UIGestureRecognizer & cocos2d 手势推荐 手势识别类型: UILongPressGestureRecognizer  // 长按UIPanGestur ...

  8. ios的手势操作之UIGestureRecognizer浅析

    转载地址:http://blog.csdn.net/likendsl/article/details/7554150 每一个手势的实现例子,可参考下面网址:http://www.cnblogs.com ...

  9. iOS手势UIGestureRecognizer的使用及手势冲突的解决办法【转】

    转自:iOS开发中的手势体系——UIGestureRecognizer分析及其子类的使用 关于手势的一篇很好的帖子,转载过来免得丢失.你可能最感兴趣的是手势间的互斥处理,那么就搜索 4.手势间的互斥处 ...

随机推荐

  1. Java遍历Map的3种方式

    package test; import java.util.Collection; import java.util.HashMap; import java.util.Map; import ja ...

  2. jython学习笔记3

    1.os.environ["HOME"] 为什么这句话在我的STS中打印不出东西,还报错 Method Description close() Close file fileno( ...

  3. & jobs fg Ctrl+z bg

    -l选项,jobs命令可以显示后台正在运行的任务的进程号信息: ctrl+l组合键:将放在前台的任务挂起: bg命令将挂起的任务放在后台继续运行 [xiluhua@vm-xiluhua][~]$ sl ...

  4. Java获取字符串编码方式

    直接下载吧: http://files.cnblogs.com/files/xiluhua/BytesEncodingDetectTool.rar

  5. HDU 2444:The Accomodation of Students(二分图判定+匹配)

    http://acm.hdu.edu.cn/showproblem.php?pid=2444 题意:给出边,判断这个是否是一个二分图,并求最大匹配. 思路:先染色法求出是否是一个二分图,然后再匈牙利求 ...

  6. spring mvc+myBatis配置详解

    一.spring mvc Spring框架(框架即:编程注解+xml配置的方式)MVC是Spring框架的一大特征,Spring框架有三大特征(IOC(依赖注入),AOP(面向切面),MVC(建模M- ...

  7. [ios][opengles]OpenGL ES基础知识简介

    参考: http://www.cnblogs.com/shangdahao/archive/2011/11/05/2233587.html 3D变换:模型,视图,投影与Viewport: http:/ ...

  8. Cocos2dx中的opengl使用(一)简单介绍

    引擎提供了CCGLProgram类来处理着色器相关操作,对当前绘图程序进行了封装,其中使用频率最高的应该是获取着色器程序的接口:const GLuint getProgram(); 该接口返回了当前着 ...

  9. css3 简单动画

    <script> <!-- var x,y,n=0,ny=0,rotINT,rotYINT function rotateDIV() { x=document.getElementB ...

  10. Android Handler Message总结

    http://blog.csdn.net/caesardadi/article/details/8473777 当应用程序启动时,会开启一个主线程(也就是UI线程),由她来管理UI,监听用户点击,来响 ...