UI基礎12

weixin_33724059發表於2016-07-31

通知機制

通知中心(NSNotificationCenter)

  • 每一個應用程式都有一個通知中心(NSNotificationCenter)例項,專門負責協助不同物件之間的訊息通訊
  • 任何一個物件都可以向通知中心釋出通知(NSNotification),描述自己在做什麼。其他感興趣的物件(Observer)可以申請在某個特定通知釋出時(或在某個特定的物件釋出通知時)收到這個通知

通知(NSNotification)

  • 一個完整的通知一般包含3個屬性:
- (NSString *)name; // 通知的名稱
- (id)object; // 通知釋出者(是誰要釋出通知)
- (NSDictionary *)userInfo; // 一些額外的資訊(通知釋出者傳遞給通知接收者的資訊內容)

  • 初始化一個通知(NSNotification)物件
+ (instancetype)notificationWithName:(NSString *)aName object:(id)anObject;
+ (instancetype)notificationWithName:(NSString *)aName object:(id)anObject userInfo:(NSDictionary *)aUserInfo;
- (instancetype)initWithName:(NSString *)name object:(id)object userInfo:(NSDictionary *)userInfo;


釋出通知

  • 通知中心(NSNotificationCenter)提供了相應的方法來幫助釋出通知
- (void)postNotification:(NSNotification *)notification;

  • 釋出一個notification通知,可在notification物件中設定通知的名稱、通知釋出者、額外資訊等
- (void)postNotificationName:(NSString *)aName object:(id)anObject;
  • 釋出一個名稱為aName的通知,anObject為這個通知的釋出者
- (void)postNotificationName:(NSString *)aName object:(id)anObject userInfo:(NSDictionary *)aUserInfo;

  • 釋出一個名稱為aName的通知,anObject為這個通知的釋出者,aUserInfo為額外資訊

註冊通知監聽器

  • 通知中心(NSNotificationCenter)提供了方法來註冊一個監聽通知的監聽器(Observer)
- (void)addObserver:(id)observer selector:(SEL)aSelector name:(NSString *)aName object:(id)anObject;

  • observer:監聽器,即誰要接收這個通知
  • aSelector:收到通知後,回撥監聽器的這個方法,並且把通知物件當做引數傳入
  • aName:通知的名稱。如果為nil,那麼無論通知的名稱是什麼,監聽器都能收到這個通知
  • anObject:通知釋出者。如果為anObject和aName都為nil,監聽器都收到所有的通知

註冊通知監聽器

- (id)addObserverForName:(NSString *)name object:(id)obj queue:(NSOperationQueue *)queue usingBlock:(void (^)(NSNotification *note))block;
name:通知的名稱
obj:通知釋出者
block:收到對應的通知時,會回撥這個block
queue:決定了block在哪個操作佇列中執行,如果傳nil,預設在當前操作佇列中同步執行


取消註冊通知監聽器

  • 通知中心不會保留(retain)監聽器物件,在通知中心註冊過的物件,必須在該物件釋放前取消註冊。否則,當相應的通知再次出現時,通知中心仍然會向該監聽器傳送訊息。因為相應的監聽器物件已經被釋放了,所以可能會導致應用崩潰

  • 通知中心提供了相應的方法來取消註冊監聽器

- (void)removeObserver:(id)observer;
- (void)removeObserver:(id)observer name:(NSString *)aName object:(id)anObject;
  • 一般在監聽器銷燬之前取消註冊(如在監聽器中加入下列程式碼):
- (void)dealloc {
    //[super dealloc];  非ARC中需要呼叫此句
    [[NSNotificationCenter defaultCenter] removeObserver:self];
}

UIDevice通知

  • UIDevice類提供了一個單粒物件,它代表著裝置,通過它可以獲得一些裝置相關的資訊,比如電池電量值(batteryLevel)、電池狀態(batteryState)、裝置的型別(model,比如iPod、iPhone等)、裝置的系統(systemVersion)

  • 通過[UIDevice currentDevice]可以獲取這個單粒物件

  • UIDevice物件會不間斷地釋出一些通知,下列是UIDevice物件所釋出通知的名稱常量:

UIDeviceOrientationDidChangeNotification // 裝置旋轉
UIDeviceBatteryStateDidChangeNotification // 電池狀態改變
UIDeviceBatteryLevelDidChangeNotification // 電池電量改變
UIDeviceProximityStateDidChangeNotification // 近距離感測器(比如裝置貼近了使用者的臉部)

鍵盤通知

  • 我們經常需要在鍵盤彈出或者隱藏的時候做一些特定的操作,因此需要監聽鍵盤的狀態

  • UIKeyboardWillShowNotification // 鍵盤即將顯示

UIKeyboardDidShowNotification // 鍵盤顯示完畢
UIKeyboardWillHideNotification // 鍵盤即將隱藏
UIKeyboardDidHideNotification // 鍵盤隱藏完畢
UIKeyboardWillChangeFrameNotification // 鍵盤的位置尺寸即將發生改變
UIKeyboardDidChangeFrameNotification // 鍵盤的位置尺寸改變完畢

  • 系統發出鍵盤通知時,會附帶一下跟鍵盤有關的額外資訊(字典),字典常見的key如下:
UIKeyboardFrameBeginUserInfoKey // 鍵盤剛開始的frame
UIKeyboardFrameEndUserInfoKey // 鍵盤最終的frame(動畫執行完畢後)
UIKeyboardAnimationDurationUserInfoKey // 鍵盤動畫的時間
UIKeyboardAnimationCurveUserInfoKey // 鍵盤動畫的執行節奏(快慢)

相關文章