IOS 開發(fā)之swift中手勢的實例詳解
IOS 開發(fā)之swift中手勢的實例詳解
手勢操作主要包括如下幾類
| 手勢 | 屬性 | 說明 |
|---|---|---|
| 點擊 UITapGestureRecognizer | numberOfTapsRequired:點擊的次數(shù);numberOfTouchesRequired:點擊時有手指數(shù)量 | 設(shè)置屬性 numberOfTapsRequired 可以實現(xiàn)單擊,或雙擊的效果 |
| 滑動 UISwipeGestureRecognizer | direction:滑動方向 | direction 滑動方向分為上Up、下Down、左Left、右Right |
| 拖動 UIPanGestureRecognizer | 在拖動過程中,通過方法 translationInView 獲取拖動時的位移 | |
| 長按 UILongPressGestureRecognizer | minimumPressDuration:長按最少時間 | |
| 旋轉(zhuǎn) UIRotationGestureRecognizer | ||
| 縮放 UIPinchGestureRecognizer |
注意:手勢效果在實施過程中,存在幾種狀態(tài):
* 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)
// 手勢響應(yīng)方法
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)
// 手勢響應(yīng)方法
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 // 移動
// 手勢響應(yīng)方法
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)
// 手勢響應(yīng)方法
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
}
}
}
// 旋轉(zhuǎn)
let label = UILabel(frame: CGRectMake(10.0, 10.0, 200.0, 200.0))
self.view.addSubview(label)
label.backgroundColor = UIColor.lightGrayColor()
label.text = "手勢操作-旋轉(zhuǎn)手勢";
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 // 旋轉(zhuǎn)
// 手勢響應(yīng)方法
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)
// 手勢響應(yīng)方法
func pressClick(recognizer:UILongPressGestureRecognizer)
{
let label:UILabel = recognizer.view as! UILabel
if recognizer.state == .Began
{
let alertView = UIAlertView(title: nil, message: "長按響應(yīng)", delegate: nil, cancelButtonTitle: "知道了")
alertView.show()
label.backgroundColor = UIColor.orangeColor()
self.view.bringSubviewToFront(label)
}
else if recognizer.state == .Ended
{
label.backgroundColor = UIColor.lightGrayColor()
}
}
如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
IOS用AFN發(fā)送字符串形式的Json數(shù)據(jù)給服務(wù)器實例
本篇文章主要介紹了IOS用AFN發(fā)送字符串形式的Json數(shù)據(jù)給服務(wù)器實例,具有一定的參考價值,感興趣的小伙伴們可以參考一下。2017-04-04
iOS ScrollView實現(xiàn)自動布局的方法(適用Swift 3.0 )
傳說中有一個美工ios開發(fā)者在遇到這個問題的時候特意跑到蘋果總部去咨詢?nèi)绾螌crollview進(jìn)行自動布局。當(dāng)然大家不用去了,下面這篇文章就來給大家介紹關(guān)于iOS ScrollView實現(xiàn)自動布局的方法,文中的語法同樣也適用Swift 3.0 ,需要的朋友可以參考下。2017-12-12
iOS開發(fā)中使用FMDB來使程序連接SQLite數(shù)據(jù)庫
這篇文章主要介紹了iOS開發(fā)中使用FMDB來使程序連接SQLite數(shù)據(jù)庫,SQLite是一個簡單的嵌入式數(shù)據(jù)庫,非常適合輕量級使用,需要的朋友可以參考下2015-11-11
IOS 開發(fā)之網(wǎng)絡(luò)圖片輪播圖的實現(xiàn)
這篇文章主要介紹了IOS 開發(fā)之網(wǎng)絡(luò)圖片輪播圖的實現(xiàn)的相關(guān)資料,希望通過此文大家能夠掌握輪播圖的實現(xiàn),需要的朋友可以參考下2017-09-09
iOS使用NSURLConnection實現(xiàn)斷點續(xù)傳下載
這篇文章主要為大家詳細(xì)介紹了iOS使用NSURLConnection實現(xiàn)斷點續(xù)傳下載,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-04-04

