У меня есть VC, который я инициализирую, и в нем есть View
.В View
есть UITableView
, UIButton
и UIImage
.
. Я неожиданно связывался с атрибутами кнопок, когда:
Assertion failure in -[UITableView _createPreparedCellForGlobalRow:withIndexPath:]
Последальнейшее копание было связано с тем, что мой код:
UINib *animCellNib = [UINib nibWithNibName:@"IoUISEAnimationDetailListingCell" bundle:nil];
[animationDetailsTableView registerNib:animCellNib forCellReuseIdentifier:@"AnimationDetailListingCell"];
не выполнялся.Дальнейшее копание, обнаруженное в верхней части моего viewDidLoad
метода, привело к инициализации tableView
.Итак, из моего следа имени метода вы можете видеть, что он начинается с numberOfSectionsInTableView
.Хотя это происходит только в несколько строк в моем viewDidLoad
2011-10-12 15:43:42.113 io[5052:11903] <IoUISEAnimationDetailsViewController: 0x764c460> - initWithNibName:bundle:
2011-10-12 15:43:42.116 io[5052:11903] <IoUISEAnimationDetailsViewController: 0x764c460> - viewDidLoad
Current language: auto; currently objective-c
2011-10-12 15:43:49.017 io[5052:11903] <IoUISEAnimationDetailsViewController: 0x764c460> - numberOfSectionsInTableView:
2011-10-12 15:43:49.017 io[5052:11903] <IoUISEAnimationDetailsViewController: 0x764c460> - tableView:titleForHeaderInSection:
2011-10-12 15:43:49.017 io[5052:11903] <IoUISEAnimationDetailsViewController: 0x764c460> - tableView:titleForFooterInSection:
2011-10-12 15:43:49.017 io[5052:11903] <IoUISEAnimationDetailsViewController: 0x764c460> - tableView:numberOfRowsInSection:
2011-10-12 15:43:49.017 io[5052:11903] <IoUISEAnimationDetailsViewController: 0x764c460> - tableView:cellForRowAtIndexPath:
2011-10-12 15:43:49.017 io[5052:11903] *** Assertion failure in -[UITableView _createPreparedCellForGlobalRow:withIndexPath:], /SourceCache/UIKit_Sim/UIKit-1912.3/UITableView.m:6072
2011-10-12 15:43:49.018 io[5052:11903] *** Terminating app due to uncaught exception 'NSInternalInconsistencyException', reason: 'UITableView dataSource must return a cell from tableView:cellForRowAtIndexPath:'
В методе viewDidLoad
через некоторое время после установки saveButton.titleLabel.lineBreakMode
и до saveButton setBackgroundImage:newImage
он переходит к методу numberOfSectionsInTableView
.
Поскольку мой код для registerNib: forCellReuseIdentifier:
указан после кода кнопки, перо ячейки не зарегистрировано, поэтому мой dequeueReusableCellWithIdentifier
возвращает ноль и вылетает.
Любые советы о том, почему это происходит?
Вот код для viewDidLoad
:
- (void)viewDidLoad {
if (IoUIDebug & IoUIDebugSelectorNames) {
NSLog(@"%@ - %@", [self description], NSStringFromSelector(_cmd) );
}
[super viewDidLoad];
// Create an Empty Tableview and steal its Background.
//set our background to it
UITableView *tv = [[UITableView alloc] initWithFrame:self.view.frame style:UITableViewStyleGrouped];
UIView *backgroundView = tv.backgroundView;
[self.view addSubview:backgroundView];
[tv release];
// CGRect backgroundFrame = CGRectMake(0, 0, self.view.frame.size.width, self.view.frame.size.height);
//[backgroundView setFrame:backgroundFrame];
[self.view sendSubviewToBack:backgroundView];
saveButton.contentVerticalAlignment = UIControlContentVerticalAlignmentCenter;
saveButton.contentHorizontalAlignment = UIControlContentHorizontalAlignmentCenter;
saveButton.titleLabel.textAlignment = UITextAlignmentCenter;
saveButton.titleLabel.lineBreakMode = UILineBreakModeCharacterWrap;
[saveButton setTitle:NSLocalizedStringFromTable(@"Save Animation Label",@"ScreenEditor",@"Save Animation Label") forState:UIControlStateNormal];
[saveButton setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
saveButton.titleLabel.font = [UIFont boldSystemFontOfSize:17];
UIImage *newImage = [[UIImage imageNamed:@"BlueButtonSmall.png"] stretchableImageWithLeftCapWidth:12.0 topCapHeight:0.0];
[saveButton setBackgroundImage:newImage forState:UIControlStateNormal];
UIImage *newPressedImage = [[UIImage imageNamed:@"BlueButtonSmallPressed.png"] stretchableImageWithLeftCapWidth:12.0 topCapHeight:0.0];
[saveButton setBackgroundImage:newPressedImage forState:UIControlStateHighlighted];
// in case the parent view draws with a custom color or gradient, use a transparent color
saveButton.backgroundColor = [UIColor clearColor];
if (UIAppDelegate.ioMainViewController.currentDeployment.readOnlyMode == NO) { // Only setup for the long press if the deployment is editable..
instructionLabel.text = NSLocalizedStringFromTable(@"Animation Details Instructions", @"ScreenEditor", @"");
} else {
instructionLabel.text = NSLocalizedStringFromTable(@"Locked Message", @"Configuration",@"");
}
IoCDElementAnimation * currentAnimation = UIAppDelegate.ioMainViewController.currentElementAnimation;
if (currentAnimation) {
newAnimation = currentAnimation;
selectedSysCDAnimation = currentAnimation.sysAnimation;
selectedIoCDTag = currentAnimation.tag;
animationSaved = YES;
} else {
selectedSysCDAnimation = nil;
selectedIoCDTag = nil;
animationSaved = NO;
}
UINib *animCellNib = [UINib nibWithNibName:@"IoUISEAnimationDetailListingCell" bundle:nil];
[animationDetailsTableView registerNib:animCellNib forCellReuseIdentifier:@"AnimationDetailListingCell"];
// set our TableView Background to clear so we can see our new background
[animationDetailsTableView setBackgroundView:nil];
[animationDetailsTableView setBackgroundColor:[UIColor clearColor]];
[self refreshContents:nil];
[self setupOrientation:[[UIApplication sharedApplication] statusBarOrientation]];
[self.view setNeedsLayout];
}
В этом методе dequeueReusableCellWithIdentifier:
возвращает ноль.Не удалось найти идентификатор AnimationDetailListingCell, поскольку код registerNib
в viewDidLoad
еще не запущен.Казалось бы, все viewDidLoad
должны быть запущены до того, как они начнут инициализировать представление таблицы, верно?
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
if (IoUIDebug & IoUIDebugSelectorNames) {
NSLog(@"%@ - %@", [self description], NSStringFromSelector(_cmd) );
}
UITableViewCell *cell;
cell = [animationDetailsTableView dequeueReusableCellWithIdentifier:@"AnimationDetailListingCell"];
// cell at this point in nil!
[self configureCell:cell atIndexPath:indexPath];
return cell;
}