1. //
  2. //  ViewController.swift
  3. //  JieUITapGestureRecognizer
  4. //
  5. //  Created by jiezhang on 14-10-4.
  6. //  Copyright (c) 2014年 jiezhang. All rights reserved.
  7. //
  8. import UIKit
  9. class ViewController: UIViewController, UIActionSheetDelegate {
  10. @IBOutlet var im: UIImageView!
  11. var lastScaleFactor : CGFloat! = 1  //放大、缩小
  12. var netRotation : CGFloat = 1;//旋转
  13. var netTranslation : CGPoint!//平移
  14. var images : NSArray = ["meinv1.jpg","mv2.jpg","mv3.jpg","mv4.jpg","mv5.jpg","mv6.jpg"]// 图片数组
  15. var imageIndex : Int = 0 //数组下标
  16. required init(coder aDecoder: NSCoder) {
  17. super.init(coder: aDecoder)
  18. netTranslation = CGPoint(x: 0, y: 0)
  19. }
  20. override func viewDidLoad() {
  21. super.viewDidLoad()
  22. var tapGesture = UITapGestureRecognizer(target: self, action: "handleTapGesture:")
  23. //设置手势点击数,双击:点2下
  24. tapGesture.numberOfTapsRequired = 2
  25. self.view.addGestureRecognizer(tapGesture)
  26. //手势为捏的姿势:按住option按钮配合鼠标来做这个动作在虚拟器上
  27. var pinchGesture = UIPinchGestureRecognizer(target: self, action: "handlePinchGesture:")
  28. self.view.addGestureRecognizer(pinchGesture)
  29. //旋转手势:按住option按钮配合鼠标来做这个动作在虚拟器上
  30. var rotateGesture = UIRotationGestureRecognizer(target: self, action: "handleRotateGesture:")
  31. self.view.addGestureRecognizer(rotateGesture)
  32. //拖手势
  33. var panGesture = UIPanGestureRecognizer(target: self, action: "handlePanGesture:")
  34. //        self.view.addGestureRecognizer(panGesture)
  35. //划动手势
  36. //右划
  37. var swipeGesture = UISwipeGestureRecognizer(target: self, action: "handleSwipeGesture:")
  38. self.view.addGestureRecognizer(swipeGesture)
  39. //左划
  40. var swipeLeftGesture = UISwipeGestureRecognizer(target: self, action: "handleSwipeGesture:")
  41. swipeLeftGesture.direction = UISwipeGestureRecognizerDirection.Left //不设置是右
  42. self.view.addGestureRecognizer(swipeLeftGesture)
  43. //长按手势
  44. var longpressGesutre = UILongPressGestureRecognizer(target: self, action: "handleLongpressGesture:")
  45. //长按时间为1秒
  46. longpressGesutre.minimumPressDuration = 1
  47. //允许15秒运动
  48. longpressGesutre.allowableMovement = 15
  49. //所需触摸1次
  50. longpressGesutre.numberOfTouchesRequired = 1
  51. self.view.addGestureRecognizer(longpressGesutre)
  52. }
  53. override func didReceiveMemoryWarning() {
  54. super.didReceiveMemoryWarning()
  55. // Dispose of any resources that can be recreated.
  56. }
  57. //双击屏幕时会调用此方法,放大和缩小图片
  58. func handleTapGesture(sender: UITapGestureRecognizer){
  59. //判断imageView的内容模式是否是UIViewContentModeScaleAspectFit,该模式是原比例,按照图片原时比例显示大小
  60. if im.contentMode == UIViewContentMode.ScaleAspectFit{
  61. //把imageView模式改成UIViewContentModeCenter,按照图片原先的大小显示中心的一部分在imageView
  62. im.contentMode = UIViewContentMode.Center
  63. }else{
  64. im.contentMode = UIViewContentMode.ScaleAspectFit
  65. }
  66. }
  67. //捏的手势,使图片放大和缩小,捏的动作是一个连续的动作
  68. func handlePinchGesture(sender: UIPinchGestureRecognizer){
  69. var factor = sender.scale
  70. if factor > 1{
  71. //图片放大
  72. im.transform = CGAffineTransformMakeScale(lastScaleFactor+factor-1, lastScaleFactor+factor-1)
  73. }else{
  74. //缩小
  75. im.transform = CGAffineTransformMakeScale(lastScaleFactor*factor, lastScaleFactor*factor)
  76. }
  77. //状态是否结束,如果结束保存数据
  78. if sender.state == UIGestureRecognizerState.Ended{
  79. if factor > 1{
  80. lastScaleFactor = lastScaleFactor + factor - 1
  81. }else{
  82. lastScaleFactor = lastScaleFactor * factor
  83. }
  84. }
  85. }
  86. //旋转手势
  87. func handleRotateGesture(sender: UIRotationGestureRecognizer){
  88. //浮点类型,得到sender的旋转度数
  89. var rotation : CGFloat = sender.rotation
  90. //旋转角度CGAffineTransformMakeRotation,改变图像角度
  91. im.transform = CGAffineTransformMakeRotation(rotation+netRotation)
  92. //状态结束,保存数据
  93. if sender.state == UIGestureRecognizerState.Ended{
  94. netRotation += rotation
  95. }
  96. }
  97. //拖手势
  98. func handlePanGesture(sender: UIPanGestureRecognizer){
  99. //得到拖的过程中的xy坐标
  100. var translation : CGPoint = sender.translationInView(im)
  101. //平移图片CGAffineTransformMakeTranslation
  102. im.transform = CGAffineTransformMakeTranslation(netTranslation.x+translation.x, netTranslation.y+translation.y)
  103. if sender.state == UIGestureRecognizerState.Ended{
  104. netTranslation.x += translation.x
  105. netTranslation.y += translation.y
  106. }
  107. }
  108. //划动手势
  109. func handleSwipeGesture(sender: UISwipeGestureRecognizer){
  110. //划动的方向
  111. var direction = sender.direction
  112. //判断是上下左右
  113. switch (direction){
  114. case UISwipeGestureRecognizerDirection.Left:
  115. println("Left")
  116. imageIndex++;//下标++
  117. break
  118. case UISwipeGestureRecognizerDirection.Right:
  119. println("Right")
  120. imageIndex--;//下标--
  121. break
  122. case UISwipeGestureRecognizerDirection.Up:
  123. println("Up")
  124. break
  125. case UISwipeGestureRecognizerDirection.Down:
  126. println("Down")
  127. break
  128. default:
  129. break;
  130. }
  131. //得到不越界不<0的下标
  132. imageIndex = imageIndex < 0 ? images.count-1:imageIndex%images.count
  133. //imageView显示图片
  134. im.image = UIImage(named: images[imageIndex] as String)
  135. }
  136. //长按手势
  137. func handleLongpressGesture(sender : UILongPressGestureRecognizer){
  138. if sender.state == UIGestureRecognizerState.Began{
  139. //创建警告
  140. var actionSheet = UIActionSheet(title: "Image options", delegate: self, cancelButtonTitle: "cancel", destructiveButtonTitle: "ok", otherButtonTitles: "other")
  141. actionSheet.showInView(self.view)
  142. }
  143. }
  144. }

注意:滑动手势和拖手势冲突,两个选一个测试,至于测试的效果自己新建一个工程来把代码加入就行

Swift基础--手势识别(双击、捏、旋转、拖动、划动、长按)的更多相关文章

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

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

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

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

  3. Swift中实现点击、双击、捏、旋转、拖动、划动、长按手势的类和方法介绍

    1.UITapGestureRecognizer 点击/双击手势 代码如下: var tapGesture = UITapGestureRecognizer(target: self, action: ...

  4. iOS手势识别的详细使用(拖动,缩放,旋转,点击,手势依赖,自定义手势)

    iOS手势识别的详细使用(拖动,缩放,旋转,点击,手势依赖,自定义手势)       1.UIGestureRecognizer介绍 手势识别在iOS上非常重要,手势操作移动设备的重要特征,极大的增加 ...

  5. ios iOS手势识别的详细使用(拖动,缩放,旋转,点击,手势依赖,自定义手势)

    iOS手势识别的详细使用(拖动,缩放,旋转,点击,手势依赖,自定义手势) 转自容芳志大神的博客:http://www.cnblogs.com/stoic/archive/2013/02/27/2940 ...

  6. iOS基础 - 手势识别 与 手势说明

    一.使用手势识别的四个步骤 1> 实例化手势识别 - (id)initWithTarget:(id)target action:(SEL)action; 2> 设置手势识别属性 3> ...

  7. swift基础:第六部分:类与对象

    http://reactnative.cn/docs/0.24/getting-started.html#content(react Native 开发文档) 互联网这个时代,你松懈一天,就会有很多很 ...

  8. swift基础:第二部分:函数和闭包

    今天本来想利用上午的时间本来打算将swift基础部分学习完的,不巧的是,后台来和我讨论用户评价的接口,讨论过后,商讨出一种可行的方案,十几分钟时间过去了,我拿到将接口介入到已经完成的页面中,完美,终于 ...

  9. Swift基础语法学习总结(转)

    Swift基础语法学习总结 1.基础  1.1) swift还是使用// 和/* */ 来注释,并且/* */允许多行注释. 1.2) swift使用print和println打印,它的传参是一个泛型 ...

随机推荐

  1. Webpack使用教程五(Babel)

    Babel是一个JavaScript编译和工具平台,使用Babel我们可以:使用新版本的JavaScript(ES6/ES2015,ES7/ES2016),尽管有些浏览器不能全部支持新特性:使用Jav ...

  2. SQL Server优化技巧之SQL Server中的"MapReduce"

    日常的OLTP环境中,有时会涉及到一些统计方面的SQL语句,这些语句可能消耗巨大,进而影响整体运行环境,这里我为大家介绍如何利用SQL Server中的”类MapReduce”方式,在特定的统计情形中 ...

  3. Zynga 开源其服务器性能监控分析工具 zPerfmon

    流年不利的社交游戏服务商Zynga近日在官方博客宣布开源zPerfmon——该工具负责监控Zynga数以千计的社交游戏服务器.zPerfmon的源代码目前已经上传至Github. 包括Facebook ...

  4. C#过滤Html标签及空格

    public static string FilterHTML(string HTMLStr) { if (!string.IsNullOrEmpty(HTMLStr)) return System. ...

  5. 微信支付接口 H5

    php微信支付若干问题记录 1.缺少参数$key0$ 此问题的可能性有几种,大致有1.timeStamp这个参数应该是string类型,默认time是int 2.确实是参数缺少  比如:prepay_ ...

  6. 大熊君说说JS与设计模式之(门面模式Facade)迪米特法则的救赎篇------(监狱的故事)

    一,总体概要 1,笔者浅谈 说起“门面”这个设计模式其实不论新老程序猿都是在无意中就已经运用到此模式了,就像我们美丽的JS程序员一样不经意就使用了闭包处理问题, function Employee(n ...

  7. python __setattr__, __getattr__, __delattr__, __call__

    python __setattr__, __getattr__, __delattr__, __call__ getattr `getattr`函数属于内建函数,可以通过函数名称获取 value = ...

  8. C#与数据库访问技术总结(十五)之 DataAdapter对象代码示例

    DataAdapter对象代码示例 下面的代码将说明如何利用DataAdapter对象填充DataSet对象. private static string strConnect=" data ...

  9. webView文本长按显示英文

    webView文本长按显示英文时,在info.plist文件中添加如下内容: <key>CFBundleLocalizations</key> <array> &l ...

  10. vs emulator for android使用

    在windows上调试android程序,可以利用hyperv虚拟化功能,微软也提供了模拟工具和android studio.eclipse的配置说明,不再累述. 关于启动vs模拟器的cmd命令: e ...