UIResponder详解

UIResponder Class Reference

Managing the Responder Chain

  1. 1.- (UIResponder *)nextResponder  
返回接收者的下一个相应,如果没有就返回nil

UIResponder类不自动存储和设置下一个响应者,而是默认返回nil。子类必须override这个方法来设置下一个响应者。

UIView实现了这个方法,因为可以返回管理这个UIView的UIViewController或者它的父类;

UIViewController实现了这个方法,返回UIViewController的View的父View;

UIWindow发挥UIApplication对象;

UIApplication返回nil

  1. 2.- (BOOL)isFirstResponder  
判断一个对象是否是第一响应者。
  1. 3.- (BOOL)canBecomeFirstResponder  
判断一个对象是否可以成为第一响应者。默认返回NO。

如果一个响应对象通过这个方法返回YES,那么它成为了第一响应对象,并且可以接收触摸事件和动作消息。

子类必须overrider这个方法才可以成为第一响应者。

You must not send this message to a view that is not currently attached to the view hierarchy. The result is undefined.

  1. 3.- (BOOL)becomeFirstResponder  
如果接收者接受了第一响应者的状态就返回YES,拒绝了这个状态就返回NO。默认返回YES。

子类可以override这个方法来更新状态或者执行一些行为,比如高亮选中项。

一个响应对象只有当前响应者可以放弃第一响应者状态,并且新的响应者可以成为第一响应者,才能成为第一响应对象。

  1. 4.- (BOOL)canResignFirstResponder  
如果一个对象可以放弃对象响应者就返回YES。默认返回YES。
  1. 5.- (BOOL)resignFirstResponder  
默认实现返回YES,放弃第一响应状态。子类可以override这个方法来更新状态或者执行一些行为,比如取消高亮选中项。

如果返回NO,拒绝放弃第一响应状态。

如果你override这个方法,必须调用父类的实现[super resignFirstResponder].

Managing Input Views

  1. 1.@property (readonly, retain) UIView *inputView  
当一个对象变成第一响应者的时候显示的View

This property is typically used to replace the system-supplied keyboard that is presented for UITextField and UITextView objects.

UITextField和UITextView如果设置了inputView那么在 becomeFirstResponder时不会显示键盘,而现实自定义的inputView;如果设置了inputAccessoryView那么在 becomeFirstResponder时会在键盘的顶端显示自定义的inputAccessoryView。

  1. 2.@property (readonly, retain) UIView *inputAccessoryView  

This property is typically used to attach an accessory view to the system-supplied keyboard that is presented for UITextField and UITextView objects.

  1. 3.- (void)reloadInputViews  
当对象成为第一响应者的时候更新inputView和accessoryView。

Responding to Touch Events

  1. 1.- (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event  
通知接收者当一个或多个手指在UIView或UIWindow上点下了。
将消息转发给下一个响应者,将消息发送给父类,不要将消息直接传递给下一个响应者。

如果你override这个方法而没有调用super..,你必须同样override其它响应触摸事件的方法,你要是空实现就好。

默认是不支持多点触摸的,如果想要响应多点触摸,你只要吧UIView的 multipleTouchEnabled 属性设置为YES即可。

  1. 2.- (void)touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event  
手指移动
  1. 3.- (void)touchesEnded:(NSSet *)touches withEvent:(UIEvent *)event  
手指抬起
  1. 4.- (void)touchesCancelled:(NSSet *)touches withEvent:(UIEvent *)event  
当收到一个系统干扰需要取消触摸事件时才会调用该方法,这种系统干扰往往会引起应用程序长时间没有响应或者一个View从window上移除了。
当收到touchesCancelled:withEvent:消息的时候需要清除所有通过touchesBegan:withEvent:创建的内容。

Responding to Motion Events

  1. 1.- (void)motionBegan:(UIEventSubtype)motion withEvent:(UIEvent *)event  
通知接收者一个动作开始了。
当一个动作开始了和结束了的时候iOS才会通知接收者。it doesn’t report individual shakes. 接收者必须是接收动作事件的第一响应者。
  1. 2.- (void)motionEnded:(UIEventSubtype)motion withEvent:(UIEvent *)event  
通知接收者一个动作结束了。
  1. 3.- (void)motionCancelled:(UIEventSubtype)motion withEvent:(UIEvent *)event  
一个动作被取消了。雷同- (void)touchesCancelled:(NSSet *)touches withEvent:(UIEvent *)event

Responding to Remote-Control Events

  1. 1.- (void)remoteControlReceivedWithEvent:(UIEvent *)event  
接收到一个远程控制事件。比如耳机控制。
允许传递远程控制事件,必须调用UIApplication的beginReceivingRemoteControlEvents方法;关闭远程控制,调用endReceivingRemoteControlEvents。

Getting the Undo Manager

  1. 1.@property(readonly) NSUndoManager *undoManager  
返回在响应链中最近的共享undo manager。
默认的,每个应用程序的window都有一个undo manager:a shared object for managing undo and redo operations.然而,在响应链中任何对象的类都有它们自己的undo manager,

Validating Commands

  1. 1.- (BOOL)canPerformAction:(SEL)action withSender:(id)sender  

YES if the the command identified by action should be enabled or NO if it should be disabled. Returning YES means that your class can handle the command in the current context.

posted @ 2014-01-29 16:16  菁菁工作室  阅读(500)  评论(0编辑  收藏  举报