简友们的精华iOS DeveloperiOS-Developer-OC

UISaerchBar偏移问题

2017-06-04  本文已影响228人  Wynter_Wang

相信很多朋友都在使用UISearchController总会遇到一些莫名其妙的问题,当然我也遇到了,下面就记录下使用UISearchController中遇到问题部分问题。

初始代码:


    UITableViewController *searchResultsController = [[UITableViewController alloc]init];
    searchResultsController.tableView.delegate = self;
    searchResultsController.tableView.dataSource = self;
    searchResultsController.tableView.estimatedRowHeight = 80;
    searchResultsController.tableView.rowHeight = UITableViewAutomaticDimension;
    self.searchController = [[UISearchController alloc] initWithSearchResultsController:searchResultsController];
    self.searchController.view.backgroundColor = [[UIColor whiteColor] colorWithAlphaComponent:0.95];
    self.searchController.searchResultsUpdater = self;
    
    UISearchBar *bar = self.searchController.searchBar;
    bar.barTintColor = [UIColor colorWithRed:239.0/255.0 green:239.0/255.0 blue:244.0/255.0 alpha:1.0];
    bar.tintColor = [UIColor blackColor];
    bar.showsBookmarkButton = YES;
    bar.translucent = YES;
    
    UIImageView *view = [[[bar.subviews objectAtIndex:0] subviews] firstObject];
    view.layer.borderColor = [UIColor colorWithRed:239.0/255.0 green:239.0/255.0 blue:244.0/255.0 alpha:1.0].CGColor;
    view.layer.borderWidth = 1;
    
    self.tableView.tableHeaderView = bar;
    

问题1:点击搜索框时searchResultsController和searchBar间隔44pt,并且点击跳转无响应,如下图:

问题1.gif

解决办法,添加代码:

    self.definesPresentationContext = YES;

效果如下:


问题1解决方法.gif

问题2:在设置导航栏为不透明时,点击搜索时searchBar偏移出屏幕

解决办法同上

问题3:在设置导航栏为不透明时,点击搜索框出现如下情况:

问题3.gif

解决办法,添加代码:

    self.extendedLayoutIncludesOpaqueBars = YES;

效果如下:


问题3解决办法.gif

属性介绍:

    // 导航栏是否为半透明
    self.navigationController.navigationBar.translucent = YES;
    // 如果在当前控制器中该属性为YES时,则将设置新的视图控制器。如果当前控制器中该属性为NO,则控制器为跟视图控制
    self.definesPresentationContext = NO;
    // 是否隐藏navigationBar
    self.searchController.hidesNavigationBarDuringPresentation = YES;
    // 延伸视图包是否含不透明的bar
    self.extendedLayoutIncludesOpaqueBars = NO;
    

引起问题的原因:

总结:

可能有些地方解释的不到位,欢迎大家指正。

上一篇下一篇

猜你喜欢

热点阅读