IOS 开发之swift中手势的实例详解
发布时间 - 2026-01-11 03:12:53 点击率:次IOS 开发之swift中手势的实例详解

手势操作主要包括如下几类
| 手势 | 属性 | 说明 |
|---|---|---|
| 点击 UITapGestureRecognizer | numberOfTapsRequired:点击的次数;numberOfTouchesRequired:点击时有手指数量 | 设置属性 numberOfTapsRequired 可以实现单击,或双击的效果 |
| 滑动 UISwipeGestureRecognizer | direction:滑动方向 | direction 滑动方向分为上Up、下Down、左Left、右Right |
| 拖动 UIPanGestureRecognizer | 在拖动过程中,通过方法 translationInView 获取拖动时的位移 | |
| 长按 UILongPressGestureRecognizer | minimumPressDuration:长按最少时间 | |
| 旋转 UIRotationGestureRecognizer | ||
| 缩放 UIPinchGestureRecognizer |
注意:手势效果在实施过程中,存在几种状态:
* Began
* Ended
* Cancelled
* Failed
* Possible
手势效果图
代码示例
// 点击
let label = UILabel(frame: CGRectMake(10.0, 10.0, (self.view.frame.size.width - 10.0 * 2), 60.0))
self.view.addSubview(label)
label.backgroundColor = UIColor.lightGrayColor()
label.text = "手势操作-单指单击手势";
label.adjustsFontSizeToFitWidth = true
label.textAlignment = .Center;
// 添加手势
let tapRecognizer = UITapGestureRecognizer(target: self, action: Selector("tapClick:"))
tapRecognizer.numberOfTapsRequired = 1
tapRecognizer.numberOfTouchesRequired = 1
label.userInteractionEnabled = true
label.addGestureRecognizer(tapRecognizer)
// 手势响应方法
func tapClick(recognizer:UITapGestureRecognizer)
{
let label:UILabel = recognizer.view as! UILabel
label.textColor = UIColor.redColor()
}
// 滑动
let label = UILabel(frame: CGRectMake(10.0, 10.0, (self.view.frame.size.width - 10.0 * 2), 60.0))
self.view.addSubview(label)
label.backgroundColor = UIColor.lightGrayColor()
label.text = "手势操作-左滑手势";
label.adjustsFontSizeToFitWidth = true
label.textAlignment = .Center;
// 添加手势
let swipeLeftRecognizer = UISwipeGestureRecognizer(target: self, action: Selector("swipeLeftClick:"))
swipeLeftRecognizer.direction = .Left
swipeLeftRecognizer.numberOfTouchesRequired = 1
label.userInteractionEnabled = true
label.addGestureRecognizer(swipeLeftRecognizer)
// 手势响应方法
func swipeLeftClick(recognizer:UISwipeGestureRecognizer)
{
let label = recognizer.view
label!.backgroundColor = UIColor.orangeColor()
}
// 拖动
let label = UILabel(frame: CGRectMake(10.0, 10.0, 100.0, 100.0))
self.view.addSubview(label)
label.backgroundColor = UIColor.lightGrayColor()
label.text = "手势操作-拖动手势";
label.adjustsFontSizeToFitWidth = true
label.textAlignment = .Center;
// 添加手势
let panRecognizer = UIPanGestureRecognizer(target: self, action: Selector("panClick:"))
label.userInteractionEnabled = true
label.addGestureRecognizer(panRecognizer)
var pointValue:CGPoint! = CGPointZero // 移动
// 手势响应方法
func panClick(recognizer:UIPanGestureRecognizer)
{
let label:UILabel = recognizer.view as! UILabel
let point = recognizer.translationInView(label)
print("pan point = \(point)")
// 移动
label.transform = CGAffineTransformMakeTranslation(point.x + self.pointValue.x, point.y + self.pointValue.y)
if recognizer.state == .Began
{
label.backgroundColor = UIColor.yellowColor()
self.view.bringSubviewToFront(label)
}
else if recognizer.state == .Ended
{
label.backgroundColor = UIColor.lightGrayColor()
self.pointValue.x += point.x
self.pointValue.y += point.y
}
}
// 缩放
let label = UILabel(frame: CGRectMake(10.0, 10.0, 200.0, 200.0))
self.view.addSubview(label)
label.backgroundColor = UIColor.lightGrayColor()
label.text = "手势操作-捏合手势";
label.adjustsFontSizeToFitWidth = true
label.textAlignment = .Center;
// 添加手势
let pinchRecognizer = UIPinchGestureRecognizer(target: self, action: Selector("pinchClick:"))
label.userInteractionEnabled = true
label.addGestureRecognizer(pinchRecognizer)
// 手势响应方法
var scaleValue:CGFloat! = 1.0 // 缩放
func pinchClick(recognizer:UIPinchGestureRecognizer)
{
let label:UILabel = recognizer.view as! UILabel
let scale = recognizer.scale;
if scale > 1.0
{
// 放大
label.transform = CGAffineTransformMakeScale(self.scaleValue + scale - 1.0, self.scaleValue + scale - 1.0)
}
else
{
// 缩小
label.transform = CGAffineTransformMakeScale(self.scaleValue * scale, self.scaleValue * scale)
}
if recognizer.state == .Began
{
label.backgroundColor = UIColor.greenColor()
self.view.bringSubviewToFront(label)
}
else if recognizer.state == .Ended
{
label.backgroundColor = UIColor.lightGrayColor()
if scale > 1.0
{
self.scaleValue = self.scaleValue + scale - 1.0;
}
else
{
self.scaleValue = self.scaleValue * scale
}
}
}
// 旋转
let label = UILabel(frame: CGRectMake(10.0, 10.0, 200.0, 200.0))
self.view.addSubview(label)
label.backgroundColor = UIColor.lightGrayColor()
label.text = "手势操作-旋转手势";
label.adjustsFontSizeToFitWidth = true
label.textAlignment = .Center;
// 添加手势
let rotationRecognizer = UIRotationGestureRecognizer(target: self, action: Selector("ratotionClick:"))
label.userInteractionEnabled = true
label.addGestureRecognizer(rotationRecognizer)
var rotationValue:CGFloat! = 1.0 // 旋转
// 手势响应方法
func ratotionClick(recognizer:UIRotationGestureRecognizer)
{
let label:UILabel = recognizer.view as! UILabel
let rotation = recognizer.rotation
label.transform = CGAffineTransformMakeRotation(rotation + self.rotationValue)
if recognizer.state == .Began
{
label.backgroundColor = UIColor.greenColor()
self.view.bringSubviewToFront(label)
}
else if recognizer.state == .Ended
{
label.backgroundColor = UIColor.lightGrayColor()
self.rotationValue = self.rotationValue + rotation
}
}
// 长按
let label = UILabel(frame: CGRectMake(10.0, 10.0, (self.view.frame.size.width - 10.0 * 2), 60.0))
self.view.addSubview(label)
label.backgroundColor = UIColor.lightGrayColor()
label.text = "手势操作-长按手势";
label.adjustsFontSizeToFitWidth = true
label.textAlignment = .Center;
// 添加手势
let pressRecognizer = UILongPressGestureRecognizer(target: self, action: Selector("pressClick:"))
pressRecognizer.minimumPressDuration = 3.0
label.userInteractionEnabled = true
label.addGestureRecognizer(pressRecognizer)
// 手势响应方法
func pressClick(recognizer:UILongPressGestureRecognizer)
{
let label:UILabel = recognizer.view as! UILabel
if recognizer.state == .Began
{
let alertView = UIAlertView(title: nil, message: "长按响应", delegate: nil, cancelButtonTitle: "知道了")
alertView.show()
label.backgroundColor = UIColor.orangeColor()
self.view.bringSubviewToFront(label)
}
else if recognizer.state == .Ended
{
label.backgroundColor = UIColor.lightGrayColor()
}
}
如有疑问请留言或者到本站社区交流讨论,感谢阅读希望能帮助到大家,谢谢大家对本站的支持!
# swift中手势
# IOS
# 手势的开发
# Swift
# 手势的实例
# IOS开发Swift 与 OC相互调用详解
# iOS Swift利用UICollectionView实现无限轮播功能(原理)详解
# iOS开发中Swift逃逸闭包知识
# iOS Swift控制器转场动画示例代码
# iOS Swift读取本地json文件报错的解决方法
# iOS Swift 值类型与引用类型使用区别基础详解
# 拖动
# 单击
# 过程中
# 如有
# 希望能
# 几种
# 双击
# 可以实现
# 谢谢大家
# 主要包括
# 为上
# 几类
# 疑问请
# 知道了
# cpp
# brush
# true
# label
# Ended
# Began
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
如何在新浪SAE免费搭建个人博客?
Android中Textview和图片同行显示(文字超出用省略号,图片自动靠右边)
Laravel队列任务超时怎么办_Laravel Queue Timeout设置详解
Laravel怎么进行数据库事务处理_Laravel DB Facade事务操作确保数据一致性
Win11怎么设置默认图片查看器_Windows11照片应用关联设置
Laravel如何编写单元测试和功能测试?(PHPUnit示例)
HTML5打空格有哪些误区_新手常犯的空格使用错误【技巧】
Laravel如何实现API速率限制?(Rate Limiting教程)
悟空识字如何进行跟读录音_悟空识字开启麦克风权限与录音
使用Dockerfile构建java web环境
Laravel如何处理跨站请求伪造(CSRF)保护_Laravel表单安全机制与令牌校验
Laravel怎么实现搜索高亮功能_Laravel结合Scout与Algolia全文检索【实战】
edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】
Laravel如何使用Eloquent进行子查询
想要更高端的建设网站,这些原则一定要坚持!
Laravel的契約(Contracts)是什么_深入理解Laravel Contracts与依赖倒置
原生JS实现图片轮播切换效果
浅述节点的创建及常见功能的实现
HTML5建模怎么导出为FBX格式_FBX格式兼容性及导出步骤【指南】
Windows11怎样设置电源计划_Windows11电源计划调整攻略【指南】
,在苏州找工作,上哪个网站比较好?
非常酷的网站设计制作软件,酷培ai教育官方网站?
常州企业网站制作公司,全国继续教育网怎么登录?
Laravel Eloquent访问器与修改器是什么_Laravel Accessors & Mutators数据处理技巧
如何挑选高效建站主机与优质域名?
香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南
轻松掌握MySQL函数中的last_insert_id()
Laravel队列由Redis驱动怎么配置_Laravel Redis队列使用教程
Laravel的.env文件有什么用_Laravel环境变量配置与管理详解
弹幕视频网站制作教程下载,弹幕视频网站是什么意思?
Laravel怎么集成Vue.js_Laravel Mix配置Vue开发环境
香港服务器建站指南:外贸独立站搭建与跨境电商配置流程
Windows10电脑怎么查看硬盘通电时间_Win10使用工具检测磁盘健康
网站制作企业,网站的banner和导航栏是指什么?
电视网站制作tvbox接口,云海电视怎样自定义添加电视源?
详解Huffman编码算法之Java实现
如何在Windows环境下新建FTP站点并设置权限?
node.js报错:Cannot find module 'ejs'的解决办法
JavaScript数据类型有哪些_如何准确判断一个变量的类型
Windows Hello人脸识别突然无法使用
Laravel如何发送系统通知?(Notification渠道示例)
Laravel如何使用Blade模板引擎?(完整语法和示例)
齐河建站公司:营销型网站建设与SEO优化双核驱动策略
香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧
Win11怎么查看显卡温度 Win11任务管理器查看GPU温度【技巧】
微博html5版本怎么弄发超话_超话进入入口及发帖格式要求【教程】
Python自动化办公教程_ExcelWordPDF批量处理案例
活动邀请函制作网站有哪些,活动邀请函文案?
JavaScript模板引擎Template.js使用详解
湖南网站制作公司,湖南上善若水科技有限公司做什么的?

