首先新建一个基于Sigle view Application的项目,名为GestureTest;我的项目结构如下:

往viewController.xib文件里拖动一个imageView,并使覆盖整个屏幕,改动属性为:

viewController.h文件:

[cpp]viewplaincopy

1.     #import <UIKit/UIKit.h>

2.

3.     @interface ViewController : UIViewController{

4.         IBOutlet UIImageView *imageView;

5.     }

6.     @property (nonatomic,retain)IBOutlet UIImageView *imageView;

7.     @end

并使xib文件里的imageView与之连接;

然后是viewController.m文件的实现部分:

[cpp]viewplaincopy

1.     @synthesize imageView;

2.

3.     CGFloat lastScaleFactor=1;//放大、缩小

4.     CGFloat  netRotation;//旋转

5.     CGPoint netTranslation;//平衡

6.     NSArray *images;//图片数组

7.     int imageIndex=0;//数组下标

8.

9.     - (void)viewDidLoad

10.   {

11.       //1、创建手势实例,并连接方法handleTapGesture,点击手势

12.       UITapGestureRecognizer *tapGesture=[[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(handleTapGesture:)];

13.       //设置手势点击数,双击:点2下

14.       tapGesture.numberOfTapsRequired=2;

15.       // imageView添加手势识别

16.       [imageView addGestureRecognizer:tapGesture];

17.       //释放内存

18.       [tapGesture release];

19.

20.       //2、手势为捏的姿势:按住option按钮配合鼠标来做这个动作在虚拟器上

21.       UIPinchGestureRecognizer *pinchGesture=[[UIPinchGestureRecognizer alloc]initWithTarget:self action:@selector(handlePinchGesture:)];

22.       [imageView addGestureRecognizer:pinchGesture];//imageView添加手势识别

23.       [pinchGesture release];

24.

25.       //3、旋转手势:按住option按钮配合鼠标来做这个动作在虚拟器上

26.       UIRotationGestureRecognizer *rotateGesture=[[UIRotationGestureRecognizer alloc]initWithTarget:self action:@selector(handleRotateGesture:)];

27.       [imageView addGestureRecognizer:rotateGesture];

28.       [rotateGesture release];

29.

30.       //4、拖手势

31.       UIPanGestureRecognizer *panGesture=[[UIPanGestureRecognizer alloc]initWithTarget:self action:@selector(handlePanGesture:)];

32.      // [imageView addGestureRecognizer:panGesture];

33.       [panGesture release];

34.

35.       //5、划动手势

36.       images=[[NSArray alloc]initWithObjects:@"cell.jpg",@"heihua.jpg",@"xuanyi.jpg", nil];

37.       //右划

38.       UISwipeGestureRecognizer *swipeGesture=[[UISwipeGestureRecognizer alloc]initWithTarget:self action:@selector(handleSwipeGesture:)];

39.       [imageView addGestureRecognizer:swipeGesture];

40.       [swipeGesture release];

41.       //左划

42.       UISwipeGestureRecognizer *swipeLeftGesture=[[UISwipeGestureRecognizer alloc]initWithTarget:self action:@selector(handleSwipeGesture:)];

43.       swipeGesture.direction=UISwipeGestureRecognizerDirectionLeft;//不设置黑夜是右

44.       [imageView addGestureRecognizer:swipeLeftGesture];

45.       [swipeLeftGesture release];

46.

47.       //6、长按手势

48.       UILongPressGestureRecognizer *longpressGesutre=[[UILongPressGestureRecognizer alloc]initWithTarget:self action:@selector(handleLongpressGesture:)];

49.       //长按时间为1秒

50.       longpressGesutre.minimumPressDuration=1;

51.       //允许15秒中运动

52.       longpressGesutre.allowableMovement=15;

53.       //所需触摸1次

54.       longpressGesutre.numberOfTouchesRequired=1;

55.       [imageView addGestureRecognizer:longpressGesutre];

56.       [longpressGesutre release];

57.

58.       [super viewDidLoad];

59.       // Do any additional setup after loading the view, typically from a nib.

60.   }

61.   //双击屏幕时会调用此方法,放大和缩小图片

62.   -(IBAction)handleTapGesture:(UIGestureRecognizer*)sender{

63.       //判断imageView的内容模式是否是UIViewContentModeScaleAspectFit,该模式是原比例,按照图片原时比例显示大小

64.       if(sender.view.contentMode==UIViewContentModeScaleAspectFit){

65.           //把imageView模式改成UIViewContentModeCenter,按照图片原先的大小显示中心的一部分在imageView

66.           sender.view.contentMode=UIViewContentModeCenter;

67.       }else{

68.           sender.view.contentMode=UIViewContentModeScaleAspectFit;

69.       }

70.   }

71.   //捏的手势,使图片放大和缩小,捏的动作是一个连续的动作

72.   -(IBAction)handlePinchGesture:(UIGestureRecognizer*)sender{

73.       //得到sender捏手势的大小

74.       CGFloat factor=[(UIPinchGestureRecognizer*)sender scale];

75.       if(factor>1){

76.           //图片放大

77.           sender.view.transform=CGAffineTransformMakeScale(lastScaleFactor+(factor-1), (lastScaleFactor+(factor-1)));

78.

79.       }else{

80.           //缩小

81.           sender.view.transform=CGAffineTransformMakeScale(lastScaleFactor*factor, lastScaleFactor*factor);

82.

83.       }

84.       //状态是否结束,如果结束保存数据

85.       if(sender.state==UIGestureRecognizerStateEnded){

86.           if(factor>1){

87.               lastScaleFactor+=(factor-1);

88.           }else{

89.               lastScaleFactor*=factor;

90.           }

91.       }

92.   }

93.   //旋转手势

94.   -(IBAction)handleRotateGesture:(UIGestureRecognizer*)sender{

95.       //浮点类型,得到sender的旋转度数

96.       CGFloat rotation=[(UIRotationGestureRecognizer*)sender rotation];

97.       //旋转角度CGAffineTransformMakeRotation

98.       CGAffineTransform transform=CGAffineTransformMakeRotation(rotation+netRotation);

99.       //改变图像角度

100.      sender.view.transform=transform;

101.      //状态结束,保存数据

102.      if(sender.state==UIGestureRecognizerStateEnded){

103.          netRotation+=rotation;

104.      }

105.

106.  }

107.  //拖手势

108.  -(IBAction)handlePanGesture:(UIGestureRecognizer*)sender{

109.      //得到拖的过程中的xy坐标

110.      CGPoint translation=[(UIPanGestureRecognizer*)sender translationInView:imageView];

111.      //平移图片CGAffineTransformMakeTranslation

112.      sender.view.transform=CGAffineTransformMakeTranslation(netTranslation.x+translation.x, netTranslation.y+translation.y);

113.      //状态结束,保存数据

114.      if(sender.state==UIGestureRecognizerStateEnded){

115.          netTranslation.x+=translation.x;

116.          netTranslation.y+=translation.y;

117.      }

118.

119.  }

120.  //划动手势

121.  -(IBAction)handleSwipeGesture:(UIGestureRecognizer*)sender{

122.      //划动的方向

123.      UISwipeGestureRecognizerDirection direction=[(UISwipeGestureRecognizer*) sender direction];

124.      //判断是上下左右

125.      switch (direction) {

126.          case UISwipeGestureRecognizerDirectionUp:

127.              NSLog(@"up");

128.              break;

129.          case UISwipeGestureRecognizerDirectionDown:

130.              NSLog(@"down");

131.              break;

132.          case UISwipeGestureRecognizerDirectionLeft:

133.              NSLog(@"left");

134.              imageIndex++;//下标++

135.              break;

136.          case UISwipeGestureRecognizerDirectionRight:

137.              NSLog(@"right");

138.              imageIndex--;//下标--

139.              break;

140.          default:

141.              break;

142.      }

143.      //得到不越界不<0的下标

144.      imageIndex=(imageIndex<0)?([images count]-1):imageIndex%[images count];

145.      //imageView显示图片

146.      imageView.image=[UIImage imageNamed:[images objectAtIndex:imageIndex]];

147.

148.  }

149.  //长按手势

150.  -(IBAction)handleLongpressGesture:(UIGestureRecognizer*)sender{

151.      //创建警告

152.      UIActionSheet *actionSheet=[[UIActionSheet alloc]initWithTitle:@"Image options" delegate:self cancelButtonTitle:nil destructiveButtonTitle:nil otherButtonTitles:@"Save Image",@"Copy", nil];

153.      //当前view显示警告

154.      [actionSheet showInView:self.view];

155.      [actionSheet release];

156.  }

157.  -(void)dealloc{

158.      [images release];

159.      [imageView release];

160.      [super dealloc];

161.  }

iphone手势识别(双击、捏、旋转、拖动、划动、长按)UITapGestureRecognizer相关推荐

  1. iphone练习之手势识别(双击、捏、旋转、拖动、划动、长按)UITapGestureRecognizer...

    首先新建一个基于Sigle view Application的项目,名为GestureTest;我的项目结构如下: 往viewController.xib文件里拖动一个imageView,并使覆盖整个 ...

  2. iPhone开发之UIImageView左右划动切换图片

    上下划动可以用类似的方法实现: #import <UIKit/UIKit.h>@interface Abstruct : UIViewController <UIScrollView ...

  3. Swift开发:仿Clear手势操作(拖拽、划动、捏合)UITableView

    2019独角兽企业重金招聘Python工程师标准>>> 这是一个完全依靠手势的操作ToDoList的演示,功能上左划删除,右划完成任务,拖拽调整顺序,捏合张开插入. 项目源码: ht ...

  4. Android 自定义控件之圆形页面指示器CirclePageIndicator带划动效果

    Android 自定义控件之圆形页面指示器CirclePageIndicator带划动效果 前言 感谢 效果图 目标 流程 自定义属性 自定义默认属性 自定义接口 创建控件类继承View 声明属性变量 ...

  5. 划动浮空岛_划动浮空岛攻略轻松通关要点详解

    划动浮空岛攻略轻松通关要点详解,玩家在游戏中一定要注意自己的移动位置,同时我们需要了解自己的各种装置,这个才是最关键的.下面的攻略就为玩家详细的介绍一些获得高分和通关的技巧,这些都是最重要的.想要了解 ...

  6. UITableView实现划动删除

    先前的准备工作: 第一步,准备好数据源. #import <UIKit/UIKit.h> @interface UITableCellSwapDeleteViewController : ...

  7. iPhone或让国内运营商划地为牢

    iPhone或让国内运营商划地为牢<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office&qu ...

  8. [html] 如何禁止移动端的左右划动手势?

    [html] 如何禁止移动端的左右划动手势? html{touch-action:none;touch-action:pan-y;} 个人简介 我是歌谣,欢迎和大家一起交流前后端知识.放弃很容易, 但 ...

  9. iphone竖屏视频旋转_如何在iPhone上旋转视频

    iphone竖屏视频旋转 We all know that feeling: you record a video on your iPhone in portrait mode, and then ...

  10. iphone竖屏视频旋转_在Linux上从iPhone旋转视频

    iphone竖屏视频旋转 iPhone is nice to take videos. However, one headache is the video may be rotated by 90 ...

最新文章

  1. mysql复习增删改查
  2. 吴恩达《Machine Learning》精炼笔记 6:关于机器学习的建议
  3. linux中怎么添加附属组,Linux中如何使用附属属组创建文件
  4. 使用Flow快速开发Teams小应用
  5. C和指针之字符串实现my_strrchr(char *str, int ch)的函数
  6. 【渝粤教育】广东开放大学 数据采集技术 形成性考核 (29)
  7. windows nginx c++读取请求数据_轻松应对百万并发的Nginx,搞懂LinuxC/C++这些技术栈升职加薪...
  8. 手把手教你理解卷积神经网络
  9. 【LeetCode】【HOT 100】2. 两数相加
  10. 气体管道管径及流量对照表_建筑用管道产品常见技术质量问答汇总
  11. python turtle画小狗_python-turtle-画雪花
  12. 中国省市县地区代码一览表
  13. hls解密key获取失败_请求帮助。M3U8里的加密key无法下载。
  14. Spring Cloud微服务实战_PDF电子书下载 高清 带索引书签目录_翟永超(著)
  15. 手机死机短信 死机,狂震,黑屏短信下载,能让mtk手机震动黑屏死机
  16. Docker-day1-安装+使用+常用镜像命令
  17. 怎样删除手机自带软件?
  18. jbox弹窗_jbox很好的弹出层 很好的弹出层 - 下载 - 搜珍网
  19. 利用SPI驱动12864液晶
  20. 用VBA生成PDF Adobe Acrobat and VBA – An Introduction

热门文章

  1. matlab进行预测误差过大,神经网络预测误差太大怎么办,如何看预测结果
  2. js map根据value获取key
  3. 创建服务器站点的步骤,如何自己建立网站 基本步骤和流程有哪些
  4. maven的生命周期,插件介绍(二)
  5. css圣杯模式的HTML代码,三种方式实现圣杯布局
  6. Java 微信图片上传素材管理
  7. 爬虫学习——初步了解爬虫
  8. Php开发Dlp加密,DLP与文档透明加密 后防泄露时代之争
  9. 信息技术前言讲座报告
  10. ZUI————对话框闪退问题