前言

	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. grep、egrep、fgrep

    grep: global search regular expression and printing

  2. The reference to entity “idNo” must end with the ';' delimiter 异常处理

    解决方案很简单,就是把配置项值中用到"&"的地方改成"&".原因是sax解析的类库在读取文件的时候是根据转义后的格式进行读取的,遇到" ...

  3. javascript对象(1)

    Array对象 创建语法:new Array();new Array(size);new Array(element0,element,element3,……,elementn); 具有的属性:con ...

  4. ACM题目————马拦过河卒

    题目描述 棋盘上A点有一个过河卒,需要走到目标B点.卒行走的规则:可以向下.或者向右.同时在棋盘上C点有一个对方的马,该马所在的点和所有跳跃一步可达的点称为对方马的控制点.因此称之为“马拦过河卒”. ...

  5. android bluetooth蓝牙移植

    http://blog.csdn.net/zhengmeifu/article/details/7705172 前段时间移植神念系统需要使用到bluetooth功能,现将移植过程中碰到的问题简要列一下 ...

  6. java静态块

    一般情况下,如果有些代码必须在项目启动的时候就执行的时候,需要使用静态代码块,这种代码是主动执行的 静态代码块的初始化顺序  class Parent{ static String name = &q ...

  7. 20150625_Andriod_02_ListView2_多条目显示_选中

    android listview 参考地址: http://www.cnblogs.com/zhengbeibei/archive/2013/05/14/3078805.html  http://xy ...

  8. 安装nginx python uwsgi环境 以及模拟测试

    uwsgi帮助文档: http://uwsgi-docs-cn.readthedocs.io/zh_CN/latest/WSGIquickstart.html http://uwsgi-docs.re ...

  9. EF中限制字段显示长度

    在EF中有些添加的字段 文本显示超多文字,想截取显示又没有截取功能. 怎么办? 我们可以在EF中类的属性中设置 你想限制这个用户名只能有10个字符长度 public String UserName { ...

  10. bmp格式图片文件读取

    C++读取bmp图片 #include <windows.h> #include <stdio.h> #include <stdlib.h> #include &l ...