Я сортирую UITableView с помощью предиката с NSFetchedResultsController. Но, когда я делаю изменения в подробном представлении и сохраняю его, объект, который я изменил, сразу же помещается в его новое место в UITableView.Обновление Delay UITableView при обновлении NSFetchedResultsController из-за NSManagedObjectContext save
У меня есть кнопки вверх/вниз, похожие на вид сообщения в Mail. Такое поведение нарушает порядок элементов, и я хотел бы отложить это изменение до тех пор, пока пользователь не вернется к причинам UITableView по UX. Я применил методы NSFetchedResultsControllerDelegate в UITableViewController. Есть ли простой/умный способ сделать это?
Редактирование: Ниже перечислены методы NSFetchedResultsControllerDelegate, реализованные в UITableViewController.
- (void)controllerWillChangeContent:(NSFetchedResultsController *)controller {
[self.tableView beginUpdates];
}
- (void)controller:(NSFetchedResultsController *)controller didChangeSection:(id <NSFetchedResultsSectionInfo>)sectionInfo
atIndex:(NSUInteger)sectionIndex forChangeType:(NSFetchedResultsChangeType)type {
switch(type) {
case NSFetchedResultsChangeInsert:
[self.tableView insertSections:[NSIndexSet indexSetWithIndex:sectionIndex]
withRowAnimation:UITableViewRowAnimationFade];
break;
case NSFetchedResultsChangeDelete:
[self.tableView deleteSections:[NSIndexSet indexSetWithIndex:sectionIndex]
withRowAnimation:UITableViewRowAnimationFade];
break;
}
}
- (void)controller:(NSFetchedResultsController *)controller didChangeObject:(id)anObject
atIndexPath:(NSIndexPath *)indexPath forChangeType:(NSFetchedResultsChangeType)type
newIndexPath:(NSIndexPath *)newIndexPath {
UITableView *tableView = self.tableView;
switch(type) {
case NSFetchedResultsChangeInsert:
[tableView insertRowsAtIndexPaths:[NSArray arrayWithObject:newIndexPath]
withRowAnimation:UITableViewRowAnimationFade];
break;
case NSFetchedResultsChangeDelete:
[tableView deleteRowsAtIndexPaths:[NSArray arrayWithObject:indexPath]
withRowAnimation:UITableViewRowAnimationFade];
break;
case NSFetchedResultsChangeUpdate:
[self configureCell:[tableView cellForRowAtIndexPath:indexPath]
atIndexPath:indexPath];
break;
case NSFetchedResultsChangeMove:
[tableView deleteRowsAtIndexPaths:[NSArray arrayWithObject:indexPath]
withRowAnimation:UITableViewRowAnimationFade];
[tableView insertRowsAtIndexPaths:[NSArray arrayWithObject:newIndexPath]
withRowAnimation:UITableViewRowAnimationFade];
break;
}
}
- (void)controllerDidChangeContent:(NSFetchedResultsController *)controller {
[self.tableView endUpdates];
}
Это звучит странно для меня. Можете ли вы опубликовать некоторый код, относящийся к обновлению подробного представления и некоторого кода UITableView? – vodkhang
Настройка происходит, когда пользовательский UIControl изменяет состояние, контроллер представления подробностей уведомляется через KVO, будет изменять объект NSManagedObject и запускать сохранение в NSManagedObjectContext. Когда NSManagedObjectContext сохраняет, я думаю, что он уведомляет NSFetchedResultsController, что все изменилось. Затем NSFetchedResultsController сообщает делегату, что изменилось. У меня есть методы NSFetchedResultsControllerDelegate, которые я реализовал в контроллере табличного представления выше. Спасибо – Simon