2013-05-16 2 views
1

У меня есть UITableView с основными данными.deleteRowsAtIndexPaths замораживает UITableView

Когда я вставляю новые записи или обновляю существующую запись, все идет хорошо, а UITableView обновляется автоматически, но когда я удаляю запись, UITableView зависает до перезагрузки UIView.

Кто-нибудь знает, что происходит не так?

- (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:@[newIndexPath] withRowAnimation:UITableViewRowAnimationFade]; 
      break; 

     case NSFetchedResultsChangeDelete: 
      [tableView deleteRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationFade]; 
      break; 

     case NSFetchedResultsChangeUpdate: 
      [tableView reloadRowsAtIndexPaths:[NSArray arrayWithObject:indexPath] withRowAnimation:UITableViewRowAnimationFade]; 

      break; 

     case NSFetchedResultsChangeMove: 
      [tableView deleteRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationFade]; 
      [tableView insertRowsAtIndexPaths:@[newIndexPath] withRowAnimation:UITableViewRowAnimationFade]; 
      break; 
    } 
} 

- (void)controllerDidChangeContent:(NSFetchedResultsController *)controller 
{ 
    [self.tableView endUpdates]; 
} 

код, где я удалить запись и сохраняет контекст

- (void)refreshData 
{ 
    dispatch_queue_t fetchQ = dispatch_queue_create("Data Fetch", NULL); 
    dispatch_async(fetchQ, ^{ 

     // here I delete some records    

     dispatch_async(dispatch_get_main_queue(), ^(void) { 
      [self saveContext]; 
     }); 
    }); 
} 
- (void)saveContext 
{ 
    NSError *error = nil; 
    NSManagedObjectContext *managedObjectContext = self.managedObjectContext; 
    if (managedObjectContext != nil) { 
     if ([managedObjectContext hasChanges] && ![managedObjectContext save:&error]) { 
      // Replace this implementation with code to handle the error appropriately. 
      // abort() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development. 
      NSLog(@"Unresolved error %@, %@", error, [error userInfo]); 
      abort(); 
     } 
    } 
} 
+0

Вы пробовали обновления self.tableview end в случае удаления строки. Это может привести к анимации. Просто мысль –

+0

Звучит так, как будто ваши начальные и endUpdates не могут быть вызваны попарно. Пробовали ли вы регистрировать каждый вызов для них рядом с оператором, а затем видеть в журнале, если они происходят в правильном порядке и попарно? – NSSplendid

+0

@NSSplendid Когда я устанавливаю несколько точек останова, он попадает в контроллерWillChangeContent. Затем он удаляет deleteRowsAtIndexPaths. Конец в конце попадает на контроллерDidChangeContent. Это похоже на правильный порядок. – robbert0

ответ

0

Когда я удалить очередь диспетчерская все работает отлично.

Смежные вопросы