创建NSFetchRequest
以传递给我的NSFetchedResultsController
时,我将fetchLimit属性设置为3.
现在最初看起来效果很好。我可以以任何方式修改前三个返回的对象,这些对象会改变它们的顺序,并且它们都会正确地重新洗牌。当我要么改变一个最初落在前三个之外的对象时会出现问题,现在将它带入前三个,或者只是添加一个新对象以便它出现在前三个中。
我期望发生的事情:插入的物体将其余部分向下推,一个从底部掉落。
实际发生了什么:插入的对象将其余部分向下推,记录数增加到4 ?!
任何人都可以解释这一点,或者我应该如何解决这个问题?
答案 0 :(得分:7)
我已经取得了一些进展,基本上忽略numberOfObjects
并返回我希望表固定的实际长度。这在controller:didChangeObject:...
中需要一些技巧,但到目前为止似乎有效。
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
return kTableSize;
//return [[[self.fetchedResultsController sections] objectAtIndex:section] numberOfObjects];
}
- (void)controller:(NSFetchedResultsController *)controller didChangeObject:(id)anObject atIndexPath:(NSIndexPath *)indexPath forChangeType:(NSFetchedResultsChangeType)type newIndexPath:(NSIndexPath *)newIndexPath
{
UITableView *tableView = self.myTableView;
switch(type) {
case NSFetchedResultsChangeInsert:
// Only modify table if insert will effect visible rows
if (newIndexPath.row < kTableSize) {
// Delete last row to maintain fixed length
[tableView deleteRowsAtIndexPaths:[NSArray arrayWithObject:[NSIndexPath indexPathForRow:(kTableSize - 1) inSection:newIndexPath.section]] withRowAnimation:UITableViewRowAnimationAutomatic];
[tableView insertRowsAtIndexPaths:[NSArray arrayWithObject:newIndexPath] withRowAnimation:UITableViewRowAnimationAutomatic];
}
break;
case NSFetchedResultsChangeDelete:
// Only modify table if delete will effect visible rows
if (indexPath.row < kTableSize) {
[tableView deleteRowsAtIndexPaths:[NSArray arrayWithObject:indexPath] withRowAnimation:UITableViewRowAnimationAutomatic];
// Insert extra row to maintain fixed length
[tableView insertRowsAtIndexPaths:[NSArray arrayWithObject:[NSIndexPath indexPathForRow:(kTableSize - 1) inSection:newIndexPath.section]] withRowAnimation:UITableViewRowAnimationAutomatic];
}
break;
case NSFetchedResultsChangeUpdate:
// Only modify table if update will effect visible rows
if (indexPath.row < kTableSize) {
[tableView reloadRowsAtIndexPaths:[NSArray arrayWithObject:indexPath] withRowAnimation:UITableViewRowAnimationAutomatic];
}
break;
case NSFetchedResultsChangeMove:
// Only modify table if move will effect visible rows
if ((indexPath.row < kTableSize) || (newIndexPath.row < kTableSize)) {
// Delete old row or last row of table
if (indexPath.row < kTableSize) {
[tableView deleteRowsAtIndexPaths:[NSArray arrayWithObject:indexPath] withRowAnimation:UITableViewRowAnimationAutomatic];
} else {
[tableView deleteRowsAtIndexPaths:[NSArray arrayWithObject:[NSIndexPath indexPathForRow:(kTableSize - 1) inSection:newIndexPath.section]] withRowAnimation:UITableViewRowAnimationAutomatic];
}
// Insert new row or a row at bottom of table
if (newIndexPath.row < kTableSize) {
[tableView insertRowsAtIndexPaths:[NSArray arrayWithObject:newIndexPath] withRowAnimation:UITableViewRowAnimationAutomatic];
} else {
[tableView insertRowsAtIndexPaths:[NSArray arrayWithObject:[NSIndexPath indexPathForRow:(kTableSize - 1) inSection:newIndexPath.section]] withRowAnimation:UITableViewRowAnimationAutomatic];
}
}
break;
}
}
还需要注意tableView:cellForRowAtIndexPath:
以确保我们不会尝试访问一个对象,如果对象的数量少于表长度,则该对象不存在。