テーブルビュー内の各セルの間に線を入れたい場合は、 'grouped'スタイルを使用します - Interface BuilderのAttributes InspectorのTable Viewタブを参照してください。各グループのメンバーには、それらの間に行があります。
プログラムでUIViewを追加する代わりに、UITableViewCellsを使用することを検討しましたか?このようなXIBには、ラベルとテキストフィールド+垂直ラインを簡単に追加できます。 UITableView対応方法
// Customize the appearance of table view cells.
- (UITableViewCell *)tableView:(UITableView *)aTableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
PersonDetailCellViewController *cell = (PersonDetailCellViewController*)[aTableView dequeueReusableCellWithIdentifier:CELL_KEY_VALUE_ID];
if(cell == nil) {
NSArray* topLevelObjects = [[NSBundle mainBundle]loadNibNamed:@"PersonDetailCellView" owner:nil options:nil];
for(id currentObject in topLevelObjects) {
if([currentObject isKindOfClass:[UITableViewCell class]]) {
cell = (PersonDetailCellViewController*)currentObject;
cell.valueTextField.backgroundColor = [UIColor clearColor];
cell.valueTextField.borderStyle = UITextBorderStyleNone;
cell.selectionStyle = UITableViewCellSelectionStyleGray;
if([Language sharedLanguage].rightToLeft) {
// set the alignment right because we are flipping the whole available text field, not just the area which actually has text
cell.keyLabel.textAlignment = UITextAlignmentRight;
cell.valueTextField.textAlignment = UITextAlignmentLeft;
// flip cell contents
cell.contentView.layer.transform = CATransform3DMakeRotation(M_PI, 0.0f, 1.0f, 0.0f);
// flip text back so that readable
cell.keyLabel.layer.transform = CATransform3DMakeRotation(M_PI, 0.0f, 1.0f, 0.0f);
cell.valueTextField.layer.transform = CATransform3DMakeRotation(M_PI, 0.0f, 1.0f, 0.0f);
}
cell.selectionStyle = UITableViewCellSelectionStyleGray;
break;
}
}
}
cell.keyLabel.text = [keys objectAtIndex:indexPath.section];
cell.valueTextField.placeholder = [hints objectAtIndex:indexPath.section];
cell.valueTextField.delegate = cell;
if(indexPath.section == 0) {
cell.valueTextField.text = self.name;
} else if(indexPath.section == 1) {
cell.valueTextField.text = self.mobile;
} else if(indexPath.section == 2) {
cell.valueTextField.text = self.home;
}
if(indexPath.section == 1) {
cell.valueTextField.keyboardType = UIKeyboardTypePhonePad;
} else {
cell.valueTextField.keyboardType = UIKeyboardTypeDefault;
}
// open keyboard
if(indexPath.section == 0) {
[cell.valueTextField becomeFirstResponder];
} else {
[cell.valueTextField resignFirstResponder];
}
cell.delegate = self;
cell.index = indexPath.section;
return cell;
}
敬具、トーマスと
@protocol PersonDetailCellViewControllerDelegate
-(void)didUpdateTextField:(int)index withText:(NSString*)text;
@end
@interface PersonDetailCellViewController : UITableViewCell <UITextFieldDelegate> {
IBOutlet UILabel* keyLabel;
IBOutlet UITextField* valueTextField;
int index;
id<PersonDetailCellViewControllerDelegate> delegate;
}
@property (nonatomic, retain) IBOutlet UILabel* keyLabel;
@property (nonatomic, retain) IBOutlet UITextField* valueTextField;
@property (nonatomic, retain) id<PersonDetailCellViewControllerDelegate> delegate;
@property (nonatomic, assign) int index;
@end
と
@implementation PersonDetailCellViewController
@synthesize keyLabel, valueTextField, delegate, index;
- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string {
if(delegate) {
[delegate didUpdateTextField:index withText:[textField.text stringByReplacingCharactersInRange:range withString:string]];
}
return YES;
}
- (BOOL)textFieldShouldClear:(UITextField *)textField {
return YES;
}
- (BOOL)textFieldShouldReturn:(UITextField *)textField {
return YES;
}
@end
:これは、次のコードで私のために本当によく働きます。
THanks Thomas。私はすでにグループ化されたセルを使用しています。私は連絡先のアドレスセルが動作する方法をエミュレートしようとしています。連絡先アドレスで再生すると、1つのセルが使用されていることが示唆されます。プラス - 連絡先の編集と同様に、私は各行に複数のフィールドを使用しています。 – drekka