自定义UISearchBar

Posted apologize的ios学习足迹

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了自定义UISearchBar相关的知识,希望对你有一定的参考价值。

先上系统默认的UISearchBar,然后用KVO修改

UISearchBar *searchBar = [[UISearchBar alloc]initWithFrame:_topView.bounds];
searchBar.placeholder = @"请输入您要搜索的商品";

效果为:

技术分享

①将取消按钮cancle改为“取消”

-(void)searchBarTextDidBeginEditing:(UISearchBar *)searchBar{
    searchBar.showsCancelButton = YES;
    for(UIView *view in  [[[searchBar subviews] objectAtIndex:0] subviews]) {
        if([view isKindOfClass:[NSClassFromString(@"UINavigationButton") class]]) {
            UIButton * cancel =(UIButton *)view;
            [cancel setTitle:@"取消" forState:UIControlStateNormal];
            [cancel setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal];
            cancel.titleLabel.font = [UIFont systemFontOfSize:14];
        }
    }
}

效果为

技术分享

 

②修改searchbar背景色

UIView *backView = [[UIView alloc]initWithFrame:searchBar.bounds];
backView.backgroundColor = [UIColor colorWithRed:37/255.0 green:205/255.0 blue:120/255.0 alpha:1];
[searchBar insertSubview:backView atIndex:1];

技术分享

 

③设置searchbar输入框背景颜色及删减符号mode

UITextField *searchField = [searchBar valueForKey:@"_searchField"];
searchField.backgroundColor = [UIColor colorWithWhite:0.0 alpha:0.1];
searchField.clearButtonMode = UITextFieldViewModeNever;

技术分享

技术分享

 

④修改searchbar输入框的文字和占位符文字颜色

UITextField *searchField = [searchBar valueForKey:@"_searchField"];
searchField.textColor = [UIColor whiteColor];
[searchField setValue:[UIColor whiteColor] forKeyPath:@"_placeholderLabel.textColor"];

技术分享

 

⑤修改放大镜图标

UITextField *searchField = [searchBar valueForKey:@"_searchField"];
UIImageView *iconView = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"icon_search"]];
iconView.frame = CGRectMake(0, 0, 15 , 15);
searchField.leftView = iconView;

技术分享

以上是关于自定义UISearchBar的主要内容,如果未能解决你的问题,请参考以下文章

如何判断自定义 UISearchBar 中的 UITableView 是不是被触摸?

在 Swift 4 中自定义 UISearchBar

自定义UISearchBar外观

未在自定义 UISearchBar 中获取过滤器数据

UISearchBar 的自定义 InputView 在 iOS7 中不起作用

自定义 UISearchbar