Я реализовал это следующим образом, используя рекомендации Marcus выше (я новичок в этом, поэтому это может быть не лучший подход). У меня есть сегментный контроллер с тремя вариантами «open», «in progress» и «closed».
В ViewController.h создайте iVar для каждой из ваших опций сегмента и один iVar для основного контроллера, который будет хранить текущий контроллер.
@property (nonatomic, retain) NSFetchedResultsController *fetchedResultsController;
@property (nonatomic, retain) NSFetchedResultsController *inprogressFetchedResultsController;
@property (nonatomic, retain) NSFetchedResultsController *openFetchedResultsController;
@property (nonatomic, retain) NSFetchedResultsController *closedFetchedResultsController;
В ViewController.m вам необходимо создать методы для отложенной загрузки этих контроллеров, поэтому у меня есть три в общей сложности. Они в основном одинаковы, кроме предиката и cacheName, я только показал один ниже.
- (NSFetchedResultsController *)closedFetchedResultsController
{
if (_closedFetchedResultsController != nil) {
return _closedFetchedResultsController;
}
NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
// Edit the entity name as appropriate.
NSEntityDescription *entity = [NSEntityDescription entityForName:@"Ticket" inManagedObjectContext:self.managedObjectContext];
[fetchRequest setEntity:entity];
// Set the batch size to a suitable number.
[fetchRequest setFetchBatchSize:20];
// Edit the sort key as appropriate.
NSSortDescriptor *sortDescriptor = [[NSSortDescriptor alloc] initWithKey:@"priority.name" ascending:NO];
NSArray *sortDescriptors = @[sortDescriptor];
[fetchRequest setSortDescriptors:sortDescriptors];
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"status = 'Closed'"];
[fetchRequest setPredicate:predicate];
NSFetchedResultsController *aFetchedResultsController = [[NSFetchedResultsController alloc] initWithFetchRequest:fetchRequest managedObjectContext:self.managedObjectContext sectionNameKeyPath:@"priority.name" cacheName:@"ClosedTickets"];
aFetchedResultsController.delegate = self;
self.closedFetchedResultsController = aFetchedResultsController;
NSError *error = nil;
if (![self.closedFetchedResultsController performFetch:&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();
}
return _closedFetchedResultsController;
}
Создание IBAction для сегмента, так что при его изменении она изменяет контроллер надуманных результатов и перезагружает таблицу.
- (IBAction)statusChanged:(id)sender {
switch (self.segmentControl.selectedSegmentIndex) {
case 0:
self.fetchedResultsController = self.inprogressFetchedResultsController;
break;
case 1:
self.fetchedResultsController = self.openFetchedResultsController;
break;
case 2:
self.fetchedResultsController = self.closedFetchedResultsController;
break;
default:
break;
}
[self.tableView reloadData];
}
Всё!
N.B. Я также добавил эту строку к моему методу ViewDidLoad, чтобы он сначала загрузил правильный параметр в fetchedResultsController.
self.fetchedResultsController = self.inprogressFetchedResultsController;
Я не могу не сказать, что, как вы, кто-то, кто так много дает сообществу, я совершенно удивлен тем, что вы нашли время, чтобы ответить на такие вопросы, как моя. Миллион спасибо! –
Маркус, какой был бы самый чистый способ реализовать это? Если бы у вас было три сегмента, для этого потребовалось бы три FRC, и было бы не очень красиво иметь все эти операторы 'switch() case:' в коде таблицы. Возможно, создайте «typedef enum» с метками, соответствующими отдельным сегментам, затем добавьте FRC в NSArray в классе по соответствующим индексам? Тогда все, что вам нужно сделать, это ссылаться на что-то вроде '[self.frcArray objectAtIndex: [segControl selectedSegmentIndex]]', где в противном случае был бы случай 'switch(). Или есть более чистый способ сделать это? –
имеют их как iVars и имеют 'currentFRC' iVar. Когда сегментированный элемент управления задействован, вы переключаете то, что указывает «currentFRC», и сообщают, что tableView перезагружается. Все остальное говорит с 'currentFRC' и имеет проверки в ваших методах делегатов, чтобы они игнорировали любые сообщения, которые не относятся к' currentFRC'. –