Locking a UISearchBar to the top of a UITableView like Game Center

后端 未结 7 2034
梦毁少年i
梦毁少年i 2020-12-02 06:33

There\'s this cool feature in the UITableViews in Game Center and the search bars they have at their tops. Unlike apps where the search bar is placed in the table header vie

相关标签:
7条回答
  • 2020-12-02 06:59

    There's one more step if you want to fully emulate the search bars in Game Center.

    If you start with friedenberg's excellent answer, as well as followben's modification for iOS 6+ mentioned in the comments, you still need to adjust the functionality when the search bar itself is active.

    In Game Center, the search bars will scroll with the table as you scroll down, but will remain fixed below the navigation bar when you attempt to scroll up past the boundaries of the table. However, when the search bar is active and search results are being displayed, the search bar no longer scrolls with the table; it remains fixed in place below the navigation bar.

    Here's the complete code (for iOS 6+) for implementing this. (If you're targeting iOS 5 or below, you don't need to wrap the UISearchBar in a UIView)

    CustomTableViewController.m

    - (void)viewDidLoad
    {
        UISearchBar *searchBar = [[UISearchBar alloc] init];
        ...
        UIView *tableHeaderView = [[UIView alloc] initWithFrame:searchBar.frame];
        [tableHeaderView addSubview:searchBar];
    
        [self.tableView setTableHeaderView:tableHeaderView];
    }
    
    - (void)scrollViewDidScroll:(UIScrollView *)scrollView
    {
        UISearchBar *searchBar = self.tableView.tableHeaderView.subviews.lastObject;
        CGRect searchBarFrame = searchBar.frame;
    
        /*
         * In your UISearchBarDelegate implementation, set a boolean flag when
         * searchBarTextDidBeginEditing (true) and searchBarTextDidEndEditing (false)
         * are called.
         */
    
        if (self.inSearchMode)
        {
            searchBarFrame.origin.y = scrollView.contentOffset.y;
        }
        else
        {
            searchBarFrame.origin.y = MIN(0, scrollView.contentOffset.y);
        }
    
        searchBar.frame = searchBarFrame;
    }
    
    - (void)searchBarTextDidBeginEditing:(UISearchBar *)searchBar
    {
        self.inSearchMode = YES;
    }
    
    - (void)searchBarTextDidEndEditing:(UISearchBar *)searchBar
    {
        self.inSearchMode = NO;
    }
    

    Voilà! Now, when the search bar is inactive it will move with the table, and remain fixed when attempting to move beyond the table boundaries. When active, it will remain fixed in place, just like in Game Center.

    0 讨论(0)
提交回复
热议问题