向使用字母部分的 iPhone 应用程序添加搜索栏?

Posted

技术标签:

【中文标题】向使用字母部分的 iPhone 应用程序添加搜索栏?【英文标题】:Adding a search bar to iPhone application that uses alphabetical sections? 【发布时间】:2012-04-08 17:36:18 【问题描述】:

我有一个使用包含产品名称的 UITableView 的应用程序,这些产品也根据它们的第一个字母分成各自的部分。

这是我的代码:

- (void)viewDidLoad

    [super viewDidLoad];

        //Initialize alphabet array
        m_Alphabet = [[NSArray alloc]initWithObjects:@"A",@"B",@"C",@"D",@"E",@"F",@"G",@"H",@"I",@"J",@"K", @"L",@"M",@"N",@"O",@"P",@"Q",@"R",@"S",@"T",@"U",@"V",@"W",@"X",@"Y",@"Z",@"Other", nil];

        //Initialize alphabet distionary of arrays
        m_AlphabetDictionary = [[NSMutableArray alloc]init];

        //Populate distionary with a mutable array for each character
        //in the alphabet (plus one "Other" category)
        for (int i = 0; i < 27; i++)
            [m_AlphabetDictionary insertObject:[[NSMutableArray alloc] init] atIndex: i];

        // The number of products in the database
        appDelegate = (AppDelegate *)[[UIApplication sharedApplication] delegate];

        NSMutableArray *tempArray = [[NSMutableArray alloc] init];

        //For each product in the appDelgates products
        for (Product *product in appDelegate.m_Products)
            if ([product.category isEqualToString:productType])

                [tempArray addObject:product];

                //firstLetter is equal to the first letter of the products name
                NSString * l_FirstLetter = [product.name substringToIndex:1];
                //convert firstString to uppercase
                l_FirstLetter = [l_FirstLetter uppercaseString];

                //The added flag ensures objects whose first letter isn't a letter
                //are added to array 26
                bool added = NO;

                for(int i=0; i<[m_Alphabet count]; i++)
                    //If the first letter of product name is equal to the letter at index i in theAlphabet
                    if ([l_FirstLetter isEqualToString:[m_Alphabet objectAtIndex:i]]) 
                        //Add product to section array for that letter
                        [[m_AlphabetDictionary objectAtIndex:i] addObject:product];

                        added = YES;
                    

                
                //If product hasn't been added to array, add it to "Others" category
                if(!added)
                    [[m_AlphabetDictionary objectAtIndex:26] addObject:product];

            
        

    //Set navigation controller title
    self.title = productType;



//Number of sections is equal to the length of the m_Alphabet array
//Letters A-Z plus "Other"
- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView 

        return [m_Alphabet count]; 


- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section 

        return [[m_AlphabetDictionary objectAtIndex:section] count]; 


- (NSArray *)sectionIndexTitlesForTableView:(UITableView *)tableView 

    return m_Alphabet; 


- (NSInteger)tableView:(UITableView *)tableView sectionForSectionIndexTitle:(NSString *)title atIndex:(NSInteger)index 

    return [m_Alphabet indexOfObject:title]; 


- (NSString *)tableView:(UITableView *)aTableView titleForHeaderInSection:(NSInteger)section

    if ([[m_AlphabetDictionary objectAtIndex:section] count]==0) 
        return nil;

    return [m_Alphabet objectAtIndex:section]; 


- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath

    NSLog(@"Cell for row");
        static NSString *CellIdentifier = @"Cell";

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

    if([self.productType isEqualToString:@"All"])
        Product *product = (Product *) [appDelegate.m_Products objectAtIndex:indexPath.row];

        cell.textLabel.text = product.name;

        // Configure the cell.
        return cell;
    
    else 

            //Instead of using appDelegate.products use the new array that will be filled
            //by the numberOfReowsInSection method
            Product *product = (Product *)[[m_AlphabetDictionary objectAtIndex:indexPath.section] objectAtIndex:indexPath.row];

            cell.textLabel.text = product.name;
            // Configure the cell.
            return cell;
    

我要做的是在我的表格视图顶部添加一个搜索栏,其行为就像 iPhone 联系人应用程序中“所有联系人”部分中的搜索栏一样。 IE。当我搜索时,所有部分都消失了,只显示搜索结果,直到搜索栏再次空白。

谁能指出我正确的方向?

谢谢,

杰克

【问题讨论】:

【参考方案1】:

看起来您需要使用UISearchDisplayController,这很可能是联系人应用程序使用的(以及邮件、地图、safari 和音乐)。它以表格视图覆盖的形式呈现,可能包含也可能不包含范围栏(您的选择),并根据搜索栏的文本过滤结果。 here 可以找到一个涉及界面构建器的简单教程,here 可以找到一个苹果示例 sans-IB。

【讨论】:

以上是关于向使用字母部分的 iPhone 应用程序添加搜索栏?的主要内容,如果未能解决你的问题,请参考以下文章

使用swift3在tableview中搜索栏和部分

搜索海量数据来自 iPhone 中的 Web Services

集成到搜索栏中的活动指示器不会显示在iPhone SDK中

在基于窗口的应用程序 iPhone 中添加标签栏和导航栏

关于向我的 iPhone 应用程序添加评论部分(不是反馈)的建议?

类似于原生联系人应用程序的粘性搜索栏和部分标题行为