UIButton事件響應(yīng)區(qū)域的研究

最近因?yàn)轫?xiàng)目需求,需要仿照微信語音聊天界面渔嚷,就研究了一下UIButton的事件響應(yīng)进鸠。“按住說話”形病,“松開結(jié)束”客年,“向上移動(dòng),取消發(fā)送”這種邏輯漠吻,一看使用UIButton的響應(yīng)事件做應(yīng)該最簡(jiǎn)單量瓜。可是嘗試過使用UIButton的響應(yīng)事件UIControlEventTouchUpInside等響應(yīng)事件區(qū)域的朋友可能就不會(huì)這樣認(rèn)為了途乃。下面是我對(duì)UIButton響應(yīng)事件區(qū)域的詳細(xì)研究绍傲。
UIButton響應(yīng)事件:

UIControlEventTouchUpInside
UIControlEventTouchUpOutside
UIControlEventTouchDragInside                                   
UIControlEventTouchDragOutside                                  
UIControlEventTouchDragEnter                                    
UIControlEventTouchDragExit

先說結(jié)論:事件UpInside和UpOutside的切換的臨界值為70;事件DragInside和DragOutside的切換的臨界值為70耍共;事件DragEnter和DragExit的切換的臨界值為70唧取。可能蘋果覺得人的手指比較小划提,所以事件的邊界值設(shè)置多出了70個(gè)像素。所以如果要想自定義這個(gè)臨界值邢享,可以參考下面的代碼(主要邏輯:計(jì)算手指的位置和超出button的距離)鹏往。

貼上代碼:
CGFloat const kBoundsExtension = 10.f;

// create button
    UIButton *button = [UIButton new];
    [self.view addSubview:button];
    button.frame = CGRectMake(0, 0, 100, 40);
    button.center = self.view.center;
    [button setTitle:@"按鈕" forState:UIControlStateNormal];
    button.backgroundColor = [UIColor lightGrayColor];
    
    // add actions
    [button addTarget:self action:@selector(buttonTouchUp:withEvent:) forControlEvents:UIControlEventTouchUpInside];
    [button addTarget:self action:@selector(buttonTouchUp:withEvent:) forControlEvents:UIControlEventTouchUpOutside];
    [button addTarget:self action:@selector(buttonDrag:withEvent:) forControlEvents:UIControlEventTouchDragInside];
    [button addTarget:self action:@selector(buttonDrag:withEvent:) forControlEvents:UIControlEventTouchDragOutside];
// upinside / upoutside
- (void)buttonTouchUp:(UIButton *)sender withEvent:(UIEvent *)event {
    UITouch *touch = [[event allTouches] anyObject];
    CGRect outerBounds = CGRectInset(sender.bounds, -1 * kBoundsExtension, -1 * kBoundsExtension);
    BOOL touchOutside = !CGRectContainsPoint(outerBounds, [touch locationInView:sender]);
    if (touchOutside) {
        // UIControlEventTouchUpOutside
        NSLog(@"----UpOutside");
    } else {
        // UIControlEventTouchUpInside
        NSLog(@"----UpInside");
    }
}

// dragin / dragout / dragEnter / dragExit
- (void)buttonDrag:(UIButton *)sender withEvent:(UIEvent *)event {
    UITouch *touch = [[event allTouches] anyObject];
    CGRect outerBounds = CGRectInset(sender.bounds, -1 * kBoundsExtension, -1 * kBoundsExtension);
    BOOL touchOutside = !CGRectContainsPoint(outerBounds, [touch locationInView:sender]);
    if (touchOutside) {
        BOOL previewTouchInside = CGRectContainsPoint(outerBounds, [touch previousLocationInView:sender]);
        if (previewTouchInside) {
            NSLog(@"----DragExit");
            // UIControlEventTouchDragExit
        } else {
            // UIControlEventTouchDragOutside
            NSLog(@"----DragOutside");
        }
    } else {
        BOOL previewTouchOutside = !CGRectContainsPoint(outerBounds, [touch previousLocationInView:sender]);
        if (previewTouchOutside) {
            // UIControlEventTouchDragEnter
            NSLog(@"----DragEnter");
        } else {
            // UIControlEventTouchDragInside
            NSLog(@"----DragInside");
        }
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市骇塘,隨后出現(xiàn)的幾起案子伊履,更是在濱河造成了極大的恐慌,老刑警劉巖款违,帶你破解...
    沈念sama閱讀 216,997評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件唐瀑,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡插爹,警方通過查閱死者的電腦和手機(jī)哄辣,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,603評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門请梢,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人力穗,你說我怎么就攤上這事毅弧。” “怎么了当窗?”我有些...
    開封第一講書人閱讀 163,359評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵够坐,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我崖面,道長(zhǎng)元咙,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,309評(píng)論 1 292
  • 正文 為了忘掉前任巫员,我火速辦了婚禮庶香,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘疏遏。我一直安慰自己脉课,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,346評(píng)論 6 390
  • 文/花漫 我一把揭開白布财异。 她就那樣靜靜地躺著倘零,像睡著了一般。 火紅的嫁衣襯著肌膚如雪戳寸。 梳的紋絲不亂的頭發(fā)上呈驶,一...
    開封第一講書人閱讀 51,258評(píng)論 1 300
  • 那天,我揣著相機(jī)與錄音疫鹊,去河邊找鬼袖瞻。 笑死,一個(gè)胖子當(dāng)著我的面吹牛拆吆,可吹牛的內(nèi)容都是我干的聋迎。 我是一名探鬼主播,決...
    沈念sama閱讀 40,122評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼枣耀,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼霉晕!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起捞奕,我...
    開封第一講書人閱讀 38,970評(píng)論 0 275
  • 序言:老撾萬榮一對(duì)情侶失蹤牺堰,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后颅围,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體伟葫,經(jīng)...
    沈念sama閱讀 45,403評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,596評(píng)論 3 334
  • 正文 我和宋清朗相戀三年院促,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了筏养。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片斧抱。...
    茶點(diǎn)故事閱讀 39,769評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖撼玄,靈堂內(nèi)的尸體忽然破棺而出夺姑,到底是詐尸還是另有隱情,我是刑警寧澤掌猛,帶...
    沈念sama閱讀 35,464評(píng)論 5 344
  • 正文 年R本政府宣布盏浙,位于F島的核電站,受9級(jí)特大地震影響荔茬,放射性物質(zhì)發(fā)生泄漏废膘。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,075評(píng)論 3 327
  • 文/蒙蒙 一慕蔚、第九天 我趴在偏房一處隱蔽的房頂上張望丐黄。 院中可真熱鬧,春花似錦孔飒、人聲如沸灌闺。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,705評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽桂对。三九已至,卻和暖如春鸠匀,著一層夾襖步出監(jiān)牢的瞬間蕉斜,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,848評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工缀棍, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留宅此,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,831評(píng)論 2 370
  • 正文 我出身青樓爬范,卻偏偏與公主長(zhǎng)得像父腕,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子青瀑,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,678評(píng)論 2 354

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

  • 1侣诵,點(diǎn)擊事件和touch事件的關(guān)系 自定義UIButton并在其中重寫以下方法: 添加UIButton并監(jiān)聽UIC...
    喵子G閱讀 6,875評(píng)論 3 15
  • 好奇觸摸事件是如何從屏幕轉(zhuǎn)移到APP內(nèi)的?困惑于Cell怎么突然不能點(diǎn)擊了狱窘?糾結(jié)于如何實(shí)現(xiàn)這個(gè)奇葩響應(yīng)需求?亦或是...
    Lotheve閱讀 57,066評(píng)論 51 599
  • 在iOS開發(fā)中經(jīng)常會(huì)涉及到觸摸事件财搁。本想自己總結(jié)一下蘸炸,但是遇到了這篇文章,感覺總結(jié)的已經(jīng)很到位尖奔,特此轉(zhuǎn)載搭儒。作者:L...
    WQ_UESTC閱讀 6,009評(píng)論 4 26
  • 一穷当、簡(jiǎn)介 <<UIButton(按鈕) : 既能顯示文字,又能顯示圖片淹禾,還能隨時(shí)調(diào)整內(nèi)部圖片和文字的位置馁菜,實(shí)現(xiàn)了監(jiān)...
    無邪8閱讀 5,650評(píng)論 0 2
  • 國(guó)家電網(wǎng)公司企業(yè)標(biāo)準(zhǔn)(Q/GDW)- 面向?qū)ο蟮挠秒娦畔?shù)據(jù)交換協(xié)議 - 報(bào)批稿:20170802 前言: 排版 ...
    庭說閱讀 10,965評(píng)論 6 13