真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

ios開發(fā)

IOS學(xué)習(xí)可以先從基礎(chǔ)開始,以后會(huì)介紹寫內(nèi)容吧

為回民等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計(jì)制作服務(wù),及回民網(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為成都網(wǎng)站建設(shè)、做網(wǎng)站、回民網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠(chéng)的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!

這篇文章想跟大家分享的主旨是iOS捕獲用戶事件的各種情況,以及內(nèi)部封裝的一些特殊事件。

我們先從UIButton談起,UIButton大家使用的太多了,他特殊的地方就在于其內(nèi)置的普通Default/高亮Highlighted/選擇Selected/可用Enable的幾個(gè)狀態(tài)(UIControlState)。其次就是SDK內(nèi)部已經(jīng)為我們封裝了以下用戶事件:

ios 開發(fā)

那么他看起來并不像N叉樹,但是不代表者不是一顆N叉樹,當(dāng)我們項(xiàng)目復(fù)雜之后,這個(gè)View可不可以有多個(gè)UIButton節(jié)點(diǎn)?所以他就是一棵樹。

實(shí)際上我們要把這棵樹寫完整,應(yīng)該還要算上UIButton的UILabel和UIImageView,因?yàn)樗麄円彩荱IReponder的子類。這里先不考慮了。

我們對(duì)UIButton來講,他此時(shí)若是葉節(jié)點(diǎn),那么這時(shí)我們針對(duì)他所在的響應(yīng)鏈來說,他在他之前的響應(yīng)者就應(yīng)該是我們controller的view(樹中的葉節(jié)點(diǎn)比父節(jié)點(diǎn)永遠(yuǎn)更優(yōu)先被分發(fā)事件,但是并不是說他就能在時(shí)間上先響應(yīng),我們下面講為什么)。所以我們嘗試在任意地方打印這個(gè)Button的nextReponder對(duì)象。nextResponder對(duì)象是UIReponder類的實(shí)例方法,它會(huì)返回任意對(duì)象在樹中的上一個(gè)響應(yīng)者實(shí)例:

[cpp]viewplaincopyprint?
  1. NSLog(@"%@",_testButton.nextResponder);

NSLog(@"%@",_testButton.nextResponder);

控制臺(tái)輸出消息:

2013-09-2103:40:25.989響應(yīng)鏈[614:60b]>


我們可以根據(jù)這個(gè)UIView的尺寸來得知,他就是我們唯一的控制器中的那個(gè)UIView。

接下來我們?cè)俅蛴∠逻@個(gè)UIView的下一個(gè)響應(yīng)者是誰:

[cpp]viewplaincopyprint?
  1. NSLog(@"%@",_testButton.nextResponder.nextResponder);

NSLog(@"%@",_testButton.nextResponder.nextResponder);

輸出:

2013-09-2103:45:03.914響應(yīng)鏈[621:60b]

依次看,接著加一個(gè)nextResponder:

2013-09-2103:50:49.428響應(yīng)鏈[669:60b](null)

為什么這里ViewController沒有父親呢?

注意這句代碼我是寫在ViewDidLoad中,而我們知道這個(gè)方法的生命周期比較早,所以我們換個(gè)地方寫或者延遲一段時(shí)間再打印,兩種方法都可以得到結(jié)果(由此可以推理出我們響應(yīng)者樹的構(gòu)造過程是在ViewDidLoad周期中來完成的,這個(gè)函數(shù)會(huì)將當(dāng)前實(shí)例的構(gòu)成的響應(yīng)者子樹合并到我們整個(gè)根樹中):

2013-09-2103:53:47.304響應(yīng)鏈[681:60b];layer=>

再繼續(xù)往上追朔:

[cpp]viewplaincopyprint?
  1. doubledelayInSeconds=2.0;

  2. dispatch_time_tpopTime=dispatch_time(DISPATCH_TIME_NOW,(int64_t)(delayInSeconds*NSEC_PER_SEC));

  3. dispatch_after(popTime,dispatch_get_main_queue(),^(void){

  4. NSLog(@"%@",_testButton.nextResponder.nextResponder.nextResponder.nextResponder);

  5. });

 double delayInSeconds = 2.0;
    dispatch_time_t popTime = dispatch_time(DISPATCH_TIME_NOW, (int64_t)(delayInSeconds * NSEC_PER_SEC));
    dispatch_after(popTime, dispatch_get_main_queue(), ^(void){
         NSLog(@"%@",_testButton.nextResponder.nextResponder.nextResponder.nextResponder);
    });
   

2013-09-2103:56:22.043響應(yīng)鏈[690:60b]

再加一個(gè):

2013-09-2103:56:51.186響應(yīng)鏈[696:60b]

那么我們的appDelegate還有沒有父節(jié)點(diǎn)?

2013-09-2103:57:22.588響應(yīng)鏈[706:60b](null)

沒有了,注意,一個(gè)從葉節(jié)點(diǎn)開始分發(fā)的事件,最多也就只能分發(fā)到我們的AppDelegate了!

這個(gè)樹形結(jié)構(gòu)在我們的項(xiàng)目中尤為重要,舉個(gè)栗子,如果我們想在一個(gè)view中重寫UITouchEvent的4個(gè)方法,并且不影響他的父視圖也響應(yīng)這些事件,就要注意你重寫的方式了,比如我們?cè)赩iewController中重寫touchBegan如下:

[cpp]viewplaincopyprint?
  1. -(void)touchesBegan:(NSSet*)toucheswithEvent:(UIEvent*)event

  2. {

  3. NSLog(@"ViewController接收到觸摸事件");

  4. }

-(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event
{
    NSLog(@"ViewController接收到觸摸事件");
}

在appDelegate的中同樣也寫上這一段:

[cpp]viewplaincopyprint?
  1. -(void)touchesBegan:(NSSet*)toucheswithEvent:(UIEvent*)event

  2. {

  3. NSLog(@"appDelegate接收到觸摸事件");

  4. }

-(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event
{
    NSLog(@"appDelegate接收到觸摸事件");
}


那么究竟是誰被觸發(fā)呢?

2013-09-2104:02:49.405響應(yīng)鏈[743:60b]ViewController接收到觸摸事件

這個(gè)很好理解,我剛剛也說了,viewController明顯是appDelegate的子節(jié)點(diǎn),他有事件分發(fā)的優(yōu)先權(quán)。如果我們想兩個(gè)地方都觸發(fā)呢?這里super一下就可以了:

[cpp]viewplaincopyprint?
  1. -(void)touchesBegan:(NSSet*)toucheswithEvent:(UIEvent*)event

  2. {

  3. [supertouchesBegan:toucheswithEvent:event];

  4. NSLog(@"ViewController接收到觸摸事件");

  5. }

-(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event
{
    [super touchesBegan:touches withEvent:event];
    NSLog(@"ViewController接收到觸摸事件");
}
輸出:

2013-09-2104:07:26.206響應(yīng)鏈[749:60b]appDelegate接收到觸摸事件

2013-09-2104:07:26.208響應(yīng)鏈[749:60b]ViewController接收到觸摸事件

注意看時(shí)間戳,appDelegate雖然優(yōu)先級(jí)別不如ViewController,但是他響應(yīng)的時(shí)間上面足足比ViewController早了0.002秒,我這里試了幾次,都是相差0.002秒。

那么我們分析一下這里的響應(yīng)者鏈?zhǔn)窃鯓庸ぷ鞯?

用戶手指觸摸到了UIView上,由于我們沒有重寫UIView的UITouchEvent,所以他里面和super執(zhí)行的一樣的,將該事件繼續(xù)分發(fā)到UIViewController;

UIViewController的TouchBegan被我們重寫了,如果我們不super,那么我們?cè)谶@里寫響應(yīng)代碼。事件到這里就不繼續(xù)分發(fā)了??上攵?,UIViewController祖先節(jié)點(diǎn):UIWindow,UIApplication,AppDelegate都無權(quán)被分發(fā)此事件。

如果我們super了TouchBegan,那么此次觸摸事件由

ViewController分發(fā)給UIWindow,

UIWindow繼而分發(fā)給UIApplication,

UIApplication再分發(fā)給AppDelegate,

于是我們?cè)赩iewController和appDelegate的touchBegan方法中都捕獲到了這次事件。

到這里大家應(yīng)該對(duì)這個(gè)響應(yīng)者樹有一個(gè)很好的理解了吧?

接下來我們?cè)僬務(wù)劦谝豁憫?yīng)者,和UIButton上的事件分發(fā)。


網(wǎng)頁名稱:ios開發(fā)
鏈接地址:http://weahome.cn/article/gcidig.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部