我们在使用UITextView和UITextField的时候,可以通过它们的inputAccessoryView属性给输入时呼出的键盘加一个附属视图,通常是UIToolBar,用于回收键盘。

但是当我们要操作的视图不是UITextView或UITextField的时候,inputAccessoryView就变成了readonly的。

这时我们如果还想再加inputAccessoryView,按API中的说法,就需要新建一个该视图的子类,并重新声明inputAccessoryView属性为readwrite的。比如我们要实现点击一个tableView的一行时,呼出一个UIPickerView,并且附加一个用于回收PickerView的toolbar。因此我们自建一个UITableViewCell类,并声明inputAccessoryView和inputView为readwrite的,并且重写它们的get方法,这样在某个tableviewcell变成第一响应者时,它就会自动呼出inputView和inputAccessoryView;

ios   inputAccessoryView,inputView关系_新建

1 @interface MyTableViewCell : UITableViewCell<UIPickerViewDelegate,UIPickerViewDataSource>2 {3     UIToolbar *_inputAccessoryView;4     UIPickerView *_inputView;5 }6 @property(strong,nonatomic,readwrite) UIToolbar *inputAccessoryView;7 @property(strong,nonatomic,readwrite) UIPickerView *inputView;8 @end

ios   inputAccessoryView,inputView关系_新建

.m中的get方法:

ios   inputAccessoryView,inputView关系_新建

 1 -(UIToolbar *)inputAccessoryView 
 2 { 
 3     if(!_inputAccessoryView) 
 4     { 
 5         UIToolbar *toolBar = [[UIToolbar alloc]initWithFrame:CGRectMake(0, 0, 320, 44)]; 
 6 //        UIBarButtonItem *right = [[UIBarButtonItem alloc]initWithBarButtonSystemItem:UIBarButtonItem target:self action:@selector(dodo)]; 
 7         UIBarButtonItem *right = [[UIBarButtonItem alloc]initWithBarButtonSystemItem:UIBarButtonSystemItemDone target:self action:@selector(dodo)]; 
 8         toolBar.items = [NSArray arrayWithObject:right]; 
 9         return toolBar;
 10     }
 11     return _inputAccessoryView;
 12 }
 13 -(UIPickerView *)inputView
 14 {
 15     if(!_inputView)
 16     {
 17       UIPickerView *  pickView = [[UIPickerView alloc]initWithFrame:CGRectMake(0, 200, 320, 200)];
 18         pickView.delegate =self;
 19         pickView.dataSource = self;
 20         pickView.showsSelectionIndicator = YES;
 21         return pickView;
 22     }
 23     return _inputView;
 24 }
 25 -(void)dodo
 26 {
 27     [self resignFirstResponder];
 28 }
 29 - (NSInteger)numberOfComponentsInPickerView:(UIPickerView *)pickerView
 30 {
 31     return 1;
 32 }
 33 - (NSString *)pickerView:(UIPickerView *)pickerView titleForRow:(NSInteger)row forComponent:(NSInteger)component
 34 {
 35     return [NSString stringWithFormat:@"%d",row];
 36 }
 37 // returns the # of rows in each component..
 38 - (NSInteger)pickerView:(UIPickerView *)pickerView numberOfRowsInComponent:(NSInteger)component
 39 {
 40     return 5;
 41 }

ios   inputAccessoryView,inputView关系_新建

但是这时运行后还是没有反应,最后在一个网页中查到这样的话:

What is the best, we aren't limited to use this feature on UITextFields only. Because of fact that UIView inherits from UIResponder, we can attach this behaviour to all views, for example to a button or a table cell. To do that we have to override canBecomeFirstRespondermethod in our subclass. For example, the UIButton subclass implementation can look like this:

canBecomeFirstResponder方法
-(BOOL)canBecomeFirstResponder
{    return YES;
}

但是这时运行是还是没有反应,最后我只好在代码中当cell被选中时,手动把它变成第一响应者。(难道cell被选中时不是第一响应者?)

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
    UITableViewCell *cell = [tableView cellForRowAtIndexPath:indexPath];
    [cell becomeFirstResponder];
}

运行结果:

ios   inputAccessoryView,inputView关系_新建_05