UIGestureRecognize手勢

UIGestureRecognizer : 手勢識別器

手勢識別器是一個抽象類, 特殊的觸摸事件. 我們不使用它本身,而是使用它的子類
  • 平移 : UIPanGestureRecognizer
  • 輕掃 : UISwipeGestureRecognizer
  • 長按 : UILongPressGestureRecognizer
  • 捏合 : UIPinchGestureRecognizer
  • 旋轉(zhuǎn) : UIRotationGestureRecognizer
  • 輕拍 : UITapGestureRecognizer
首先, 在視圖控制器中創(chuàng)建一個UIView, 接下來的手勢識別器都會添加到該視圖上進行操作.
 UIView *Myview = [[MyView alloc] initWithFrame:CGRectMake(100, 100, 100, 100)];
 Myview.backgroundColor = [UIColor orangeColor];
 [self.view addSubview:Myview];```

######接下來, 初始化響應(yīng)的手勢, 并設(shè)置手勢觸發(fā)的方法, 實現(xiàn)響應(yīng)的效果.

#####1. 輕拍手勢

//1. 初始化輕拍手勢對象, 并設(shè)置輕拍時觸發(fā)的方法
UITapGestureRecognizer *tap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(tapAction:)];
//2. 設(shè)置手勢相關(guān)屬性
//輕拍的次數(shù)
tap.numberOfTapsRequired = 1;
tap.numberOfTouchesRequired = 1;
//3. 將手勢到view對象上
[Myview addGestureRecognizer:tap];```

2. 輕掃手勢
//1. 初始化輕掃手勢對象, 并設(shè)置輕掃時觸發(fā)的方法
UISwipeGestureRecognizer *swipe = [[UISwipeGestureRecognizer alloc] initWithTarget:self action:@selector(swipeAction:)];
//2. 輕掃方向( | :表示兩個方向都可以)
#輕掃手勢的默認輕掃方向是向右的, 若需要向左掃描時也能觸發(fā)向右的掃描方法, 需要指定掃描方向為以下屬性:
swipe.direction = UISwipeGestureRecognizerDirectionRight | UISwipeGestureRecognizerDirectionLeft;
//3. 添加手勢到view對象上
[Myview addGestureRecognizer:swipe];```

#####3. 平移手勢

//1. 初始化平移手勢對象, 并設(shè)置平移時觸發(fā)的方法
UIPanGestureRecognizer *pan = [[UIPanGestureRecognizer alloc] initWithTarget:self action:@selector(panAction:)];
//2. 將平移手勢添加到View視圖上
[Myview addGestureRecognizer:pan];```

4. 捏合手勢
//1. 創(chuàng)建捏合手勢, 并設(shè)置捏合時觸發(fā)的方法
UIPinchGestureRecognizer *pinch = [[UIPinchGestureRecognizer alloc] initWithTarget:self action:@selector(pinchAction:)];
//2. 添加捏合手勢到view視圖上   
[Myview addGestureRecognizer:pinch];```
    
    
#####5. 旋轉(zhuǎn)手勢

//1. 創(chuàng)建旋轉(zhuǎn)手勢, 并設(shè)置旋轉(zhuǎn)時觸發(fā)的方法
UIRotationGestureRecognizer *rotation = [[UIRotationGestureRecognizer alloc] initWithTarget:self action:@selector(rotationAction:)];
//2. 添加手勢到view視圖上
[Myview addGestureRecognizer:rotation];```


<i>注意: 以上多種手勢, 例如輕拍手勢, 我們可以設(shè)置他的輕拍次數(shù), 分別觸發(fā)不同的事件, 但這并沒有那么容易實現(xiàn), 因為模擬器無法分辨輕拍次數(shù), 當(dāng)你輕拍一次的時候, 它默認就會認為應(yīng)該觸發(fā)輕拍次數(shù)為一次的事件.另外, 手勢之間也會發(fā)生沖突, 例如輕拍手勢和輕掃手勢, 模擬器無法分辨. 所以在添加手勢的時候, 盡量避免發(fā)生沖突</i>

第三部分: 實現(xiàn)手勢觸發(fā)的方法
1. 輕拍事件
- (void)tapAction:(UITapGestureRecognizer *)sender{
    //通過觸發(fā)輕拍事件, 改變View的背景樣色
    sender.view.backgroundColor = [UIColor randomColor];
    
}```
#####2. 輕掃事件
  • (void)swipeAction:(UISwipeGestureRecognizer *)sender{

    sender.view.backgroundColor = [UIColor randomColor];
    }```

3. 平移事件
- (void)panAction:(UIPanGestureRecognizer *)sender{
    
    //平移 偏移
    CGPoint point = [sender translationInView:sender.view];
    
    //三個參數(shù)
    //會根據(jù)上次移動過的位置, 繼續(xù)平移
    //參數(shù)一: 代表當(dāng)前位置   參數(shù)二 : 代表移動的x值  參數(shù)三 : 代表移動的Y值
    sender.view.transform = CGAffineTransformTranslate(sender.view.transform, point.x, point.y);
    
    //增量置為 0(避免疊加)
    [sender setTranslation:CGPointZero inView:sender.view];
    
}```

#####4. 捏合事件
  • (void)pinchAction:(UIPinchGestureRecognizer *)sender{

    //兩個參數(shù)的方法: 每次縮放都會從原始大小開始
    //------------------------------------------------------

    //每次縮放從上一次縮放的大小開始
    sender.view.transform = CGAffineTransformScale(sender.view.transform, sender.scale, sender.scale);

    //設(shè)置縮放比例 1 : 是正常比例 < 1 : 縮小 >1 : 放大
    sender.scale = 1;

}```

5. 旋轉(zhuǎn)事件
- (void)rotationAction:(UIRotationGestureRecognizer *)sender{
    
    sender.view.transform = CGAffineTransformRotate(sender.view.transform, sender.rotation);
    
    //清除增量
    sender.rotation = 0;
    
}```
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末跃捣,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子夺蛇,更是在濱河造成了極大的恐慌疚漆,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,490評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異娶聘,居然都是意外死亡闻镶,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,581評論 3 395
  • 文/潘曉璐 我一進店門丸升,熙熙樓的掌柜王于貴愁眉苦臉地迎上來铆农,“玉大人,你說我怎么就攤上這事狡耻《掌剩” “怎么了?”我有些...
    開封第一講書人閱讀 165,830評論 0 356
  • 文/不壞的土叔 我叫張陵夷狰,是天一觀的道長岭皂。 經(jīng)常有香客問我,道長孵淘,這世上最難降的妖魔是什么蒲障? 我笑而不...
    開封第一講書人閱讀 58,957評論 1 295
  • 正文 為了忘掉前任歹篓,我火速辦了婚禮瘫证,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘庄撮。我一直安慰自己背捌,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,974評論 6 393
  • 文/花漫 我一把揭開白布洞斯。 她就那樣靜靜地躺著毡庆,像睡著了一般。 火紅的嫁衣襯著肌膚如雪烙如。 梳的紋絲不亂的頭發(fā)上么抗,一...
    開封第一講書人閱讀 51,754評論 1 307
  • 那天,我揣著相機與錄音亚铁,去河邊找鬼蝇刀。 笑死,一個胖子當(dāng)著我的面吹牛徘溢,可吹牛的內(nèi)容都是我干的吞琐。 我是一名探鬼主播,決...
    沈念sama閱讀 40,464評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼然爆,長吁一口氣:“原來是場噩夢啊……” “哼站粟!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起曾雕,我...
    開封第一講書人閱讀 39,357評論 0 276
  • 序言:老撾萬榮一對情侶失蹤奴烙,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體缸沃,經(jīng)...
    沈念sama閱讀 45,847評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡恰起,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,995評論 3 338
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了趾牧。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片检盼。...
    茶點故事閱讀 40,137評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖翘单,靈堂內(nèi)的尸體忽然破棺而出吨枉,到底是詐尸還是另有隱情,我是刑警寧澤哄芜,帶...
    沈念sama閱讀 35,819評論 5 346
  • 正文 年R本政府宣布貌亭,位于F島的核電站,受9級特大地震影響认臊,放射性物質(zhì)發(fā)生泄漏圃庭。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,482評論 3 331
  • 文/蒙蒙 一失晴、第九天 我趴在偏房一處隱蔽的房頂上張望剧腻。 院中可真熱鬧,春花似錦涂屁、人聲如沸书在。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,023評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽儒旬。三九已至,卻和暖如春帖族,著一層夾襖步出監(jiān)牢的瞬間栈源,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,149評論 1 272
  • 我被黑心中介騙來泰國打工竖般, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留甚垦,地道東北人。 一個月前我還...
    沈念sama閱讀 48,409評論 3 373
  • 正文 我出身青樓捻激,卻偏偏與公主長得像制轰,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子胞谭,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,086評論 2 355

推薦閱讀更多精彩內(nèi)容