UITabelView с UISearchDisplayDelegate - PullRequest
       8

UITabelView с UISearchDisplayDelegate

1 голос
/ 03 сентября 2011

Я пытаюсь настроить простой UITableView с UISearchDisplayDelegate, но мое приложение продолжает сбой с ошибкой SIGABRT для: [self.filteredListContent removeAllObjects];

Любые идеи о том, почему это происходит

#import "SearchViewController.h"

@implementation SearchViewController

@synthesize listContent, filteredListContent;




- (void)viewDidLoad
{
    [super viewDidLoad];


    listContent = [[NSArray alloc]initWithObjects:@"hello", @"bye", nil];
    filteredListContent = [NSMutableArray arrayWithCapacity:listContent.count];

    [self.tableView reloadData];
    self.tableView.scrollEnabled = YES;


}

- (void)viewDidUnload
{
    [super viewDidUnload];
    self.listContent =nil;
    self.filteredListContent=nil;

}

-(void) dealloc {

        [super dealloc];
        [self.listContent release];
        [self.filteredListContent release];
}

- (void)viewWillAppear:(BOOL)animated
{
    [super viewWillAppear:animated];
}

- (void)viewDidAppear:(BOOL)animated
{
    [super viewDidAppear:animated];
}

- (void)viewWillDisappear:(BOOL)animated
{
    [super viewWillDisappear:animated];
}

- (void)viewDidDisappear:(BOOL)animated
{
    [super viewDidDisappear:animated];
}

- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation
{
    // Return YES for supported orientations
    return (interfaceOrientation == UIInterfaceOrientationPortrait);
}

#pragma mark - Table view data source

- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
{
    // Return the number of sections.
    return 1;
}

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
    // Return the number of rows in the section.
    if (tableView == self.searchDisplayController.searchResultsTableView)
    {
        return [self.filteredListContent count];
    }
    else
    {
        return [self.listContent count];
    }
}

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    static NSString *CellIdentifier = @"Cell";

    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
    if (cell == nil) {
        cell = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:CellIdentifier] autorelease];
    }


    NSString *label;
    if (tableView == self.searchDisplayController.searchResultsTableView)
    {
        label = [self.filteredListContent objectAtIndex:indexPath.row];
    }
    else
    {
        label = [self.listContent objectAtIndex:indexPath.row];
    }    


    cell.textLabel.text = label;    
    return cell;
}



#pragma mark - Table view delegate

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{

}



- (void)filterContentForSearchText:(NSString*)searchText 
{

    [self.filteredListContent removeAllObjects]; 
    for (NSString *string in listContent)
    {
            NSComparisonResult result = [string compare:searchText options:(NSCaseInsensitiveSearch|NSDiacriticInsensitiveSearch) range:NSMakeRange(0, [searchText length])];
            if (result == NSOrderedSame)
            {
                [self.filteredListContent addObject:string];
            }

    }
}
- (BOOL)searchDisplayController:(UISearchDisplayController *)controller shouldReloadTableForSearchString:(NSString *)searchString
{
    [self filterContentForSearchText:searchString];
    return YES;

}
- (BOOL)searchDisplayController:(UISearchDisplayController *)controller shouldReloadTableForSearchScope:(NSInteger)searchOption
{
    [self filterContentForSearchText:[self.searchDisplayController.searchBar text]];
    return YES;

}

заголовочный файл

#import <UIKit/UIKit.h>

@interface SearchViewController : UITableViewController<UISearchDisplayDelegate, UISearchBarDelegate>  {
    NSArray                       *listContent;
    NSMutableArray        *filteredListContent;

}

@property (nonatomic, retain) NSArray *listContent;
@property (nonatomic, retain) NSMutableArray *filteredListContent;



@end

1 Ответ

1 голос
/ 03 сентября 2011

Заменить

filteredListContent = [NSMutableArray arrayWithCapacity:listContent.count];

с

self.filteredListContent = [NSMutableArray arrayWithCapacity:listContent.count];

или

filteredListContent = [[NSMutableArray alloc] initWithCapacity:listContent.count];

Это потому, что когда вы обращаетесь к своей переменной напрямую, retain не вызывается. Всегда используйте self. обозначение.

...