带有Prev / Next的UIToolbar在多个分段的tableview故事板中使用多个文本字段

时间:2013-06-19 12:49:06

标签: uitableview storyboard uitextfield uitoolbar

我需要帮助添加逻辑来获取静态表视图单元格部分索引。

我有一个带有2个部分的纯静态UITableView,每个部分有2个带有文本字段的单元格。

我实现了一个代码,用于向键盘添加带有prev / next / done butoons的工具栏。

如果文本字段位于第0部分,则上一个/下一个工作,但是当点击下一个转到第1部分中的下一个文本字段时,应用程序崩溃。

我应该在哪里放置" if条件"检查文本域所在的部分?

这是我的.h文件

#import <UIKit/UIKit.h>

@interface TextFieldTVCViewController : UITableViewController <UITextFieldDelegate, UIAlertViewDelegate>

@property(strong, nonatomic) IBOutlet UITextField *dep1TextField;
@property(strong, nonatomic) IBOutlet UITextField *arr1TextField;
@property(strong, nonatomic) IBOutlet UITextField *dep2TextField;
@property(strong, nonatomic) IBOutlet UITextField *arr2TextField;

@property(strong, nonatomic) IBOutlet UIToolbar *keyboardToolbar;
@property(strong, nonatomic) IBOutlet UIBarButtonItem *toolbarActionButton;

@property(strong, nonatomic) NSArray *textFields;

- (IBAction) closeKeyboard;
- (IBAction) nextField;
- (IBAction) prevField;

@end

这是我的.m文件

#import "TextFieldTVCViewController.h"

@interface TextFieldTVCViewController ()

@end

@implementation TextFieldTVCViewController

@synthesize dep1TextField, dep2TextField, arr1TextField, arr2TextField;
@synthesize keyboardToolbar, toolbarActionButton;
@synthesize textFields;


- (void)viewDidLoad
{
 [super viewDidLoad];
 textFields = [[NSArray alloc] initWithObjects:dep1TextField, arr1TextField, dep2TextField, arr2TextField, nil];

}

- (void) textFieldDidBeginEditing:(UITextField *)textField{
[textField setInputAccessoryView:keyboardToolbar];
for (int i=0; i<[textFields count]; i++) {
    if ([textFields objectAtIndex:i]==textField) {
        if (i==[textFields count]-1) {
            toolbarActionButton.title =@"Done";
            [toolbarActionButton setStyle:UIBarButtonItemStyleDone];
        }
            [self.tableView scrollToRowAtIndexPath:[NSIndexPath indexPathForRow:i inSection:0] atScrollPosition:UITableViewScrollPositionMiddle animated:YES];
    }
}
}

- (IBAction) closeKeyboard{
for(UITextField *t in textFields){
    if ([t isEditing]) {
        [t resignFirstResponder];
        break;
    }
}
}

- (IBAction) nextField{
for (int i=0; i<[textFields count]; i++) {

    if ([[textFields objectAtIndex:i] isEditing] && i!=[textFields count]-1) {
        [[textFields objectAtIndex:i+1] becomeFirstResponder];
        if (i+1==[textFields count]-1) {
            [toolbarActionButton setTitle:@"Done"];
            [toolbarActionButton setStyle:UIBarButtonItemStyleDone];
        }else {
            [toolbarActionButton setTitle:@"Close"];
            [toolbarActionButton setStyle:UIBarButtonItemStyleBordered];
        }

        [self.tableView scrollToRowAtIndexPath:[NSIndexPath indexPathForRow:i+1 inSection:0] atScrollPosition:UITableViewScrollPositionMiddle animated:YES];


        break;
    }
}

}

- (IBAction) prevField{
for (int i=0; i<[textFields count]; i++) {
    if ([[textFields objectAtIndex:i] isEditing] && i!=0) {
        [[textFields objectAtIndex:i-1] becomeFirstResponder];
        [toolbarActionButton setTitle:@"Close"];
        [self.tableView scrollToRowAtIndexPath:[NSIndexPath indexPathForRow:i-1 inSection:0] atScrollPosition:UITableViewScrollPositionMiddle animated:YES];
        [toolbarActionButton setStyle:UIBarButtonItemStyleBordered];

        break;
    }
}
}
@end

该网站我从工具栏中获取了代码:

http://idebuggerman.blogspot.com/2010/08/uitoolbar-for-keyboard-with.html?showComment=1371639814883

由于

1 个答案:

答案 0 :(得分:0)

我认为你保留一组文本字段的方法不是很干净。它导致代码非常复杂,你必须迭代很多,这很容易出错。

相反,请使用枚举标记文本字段。在“标签”下的故事板中插入适当的数字。在您的实施文件之上,定义您的字段。

typedef enum { 
   Dep1Field = 100, Arr1Field,
   Dep2Field,       Arr2Field, 
   NumberOfFields
} TableFields;

现在,您可以轻松识别委托回调和方法中的文本字段。我建议在ivar中保留对已编辑文本字段的引用。您可以在标准的UITextField委托回调中设置它。

@implementation ViewController {
    UITextField *_textFieldBeingEdited;
}
//...

“下一个”和“上一个”逻辑现在很容易:

// next
if (textFieldBeingEdited && textFieldBeingEdited.tag < NumberOfFields-1) {
    [textFieldBeingEdited resignFirstResponder];
    UITextField *nextTextField = 
         (UITextField*)[self.view viewWithTag:textFieldBeingEdited.tag+1];
    [nextTextField becomeFirstResponder]; 
}