初识UISearchBar
2015-11-10 本文已影响1567人
芝麻绿豆
基本属性
- barStyle
UIBarStyleDefault
UIBarStyleBlack
UIBarStyleBlackOpaque
UIBarStyleBlackTranslucent
data:image/s3,"s3://crabby-images/0cfc5/0cfc54625d012a1ec5811aecccf9c7da0ca2d295" alt=""
-
placeholder:占位字符
-
prompt:标题
-
tintColor:光标颜色
- 设置背景图片
[searchBar setBackgroundImage:[UIImage imageNamed:@"infocollectClickImage"]];
data:image/s3,"s3://crabby-images/a3751/a3751cdafe656c6ac7404464f33103c7dd7fa2a9" alt=""
- 设置搜索框的背景图片
[searchBar setSearchFieldBackgroundImage:[UIImage imageNamed:@"infocollectClickImage"] forState:UIControlStateNormal];
data:image/s3,"s3://crabby-images/1f4d0/1f4d0f1ab5d9068d1111291fae730b8841780f20" alt=""
-
searchBar.showsSearchResultsButton = YES;
- 取消按钮
searchBar.showsCancelButton = YES;
[searchBar setShowsCancelButton:YES animated:YES];
data:image/s3,"s3://crabby-images/5067c/5067c355d799b746b659ebebd7d1fcb0f60b4ebd" alt=""
- 搜索框内的图片
[searchBar setImage:[UIImage imageNamed:@"search-search-icon"] forSearchBarIcon:UISearchBarIconSearch state:UIControlStateNormal];
data:image/s3,"s3://crabby-images/f1aa3/f1aa323bb9919a464aa976ae6f65c1a874570e56" alt=""
设置cancel/取消按钮
1.利用系统的运行时(Runtime)机制设置:
UIButton *btn = [[UIButton alloc] init];
btn.titleLabel.textAlignment = NSTextAlignmentCenter;
[btn setTitle:@"123" forState:UIControlStateNormal];
[btn setTitleColor:[UIColor redColor] forState:UIControlStateNormal];
[searchBar setValue:btn forKeyPath:@"cancelButton"];
运行结果:达不到需求,需要调整按钮和搜索框的位置;
data:image/s3,"s3://crabby-images/b81e6/b81e62cc1fec687e983c6c976f989a459ed407d8" alt=""
2.遍历UISearchBar的子控件,设置里面的button;
[searchBar setShowsCancelButton:YES animated:YES];
for ( id searchView in [[[searchBar subviews] lastObject]subviews])
{
YANLog(@"%@",[searchView class]);
if ([[searchView class] isSubclassOfClass: NSClassFromString(@"UINavigationButton")]) {
YANLog(@"%@",[searchView class]);
UIButton *cancelBtn = (UIButton *)searchView;
//[cancelBtn setTitleColor:[UIColor redColor] forState:UIControlStateNormal];
[cancelBtn setTitle:nil forState:UIControlStateNormal];
[cancelBtn setBackgroundImage:[UIImage imageNamed:@"AppIcon29x29"] forState:UIControlStateNormal];
}
}
-
该方法如果设置title,设置titleColor与BackgroundImage将失效;字体的颜色将显示为系统的默认颜色;
-
所以该方法只适合设置按钮的颜色和背景图片;文字只能显示cancel或者取消;
-
可以将项目配置设置为支持中文,字体将显示为取消;
项目配置方法
项目配置方法
注意点:
显示cancel按钮的方法要写在自定义按钮方法前面
3.利用appearance
设置:
该方法不仅可以设置文字、颜色,还可以设置字体大小;
NSMutableDictionary *attr = [NSMutableDictionary dictionary];
attr[NSFontAttributeName] = [UIFont systemFontOfSize:13];
attr[NSForegroundColorAttributeName] = [UIColor redColor];
[[UIBarButtonItem appearanceWhenContainedIn:[UISearchBar class] , nil] setTitle:@"N"];
[[UIBarButtonItem appearanceWhenContainedIn:[UISearchBar class], nil] setTitleTextAttributes:attr forState:UIControlStateNormal];
运行结果:
data:image/s3,"s3://crabby-images/ccd46/ccd4681e22280ba342bc663e3a2113101028cc41" alt=""
注意点:
data:image/s3,"s3://crabby-images/69d6e/69d6eec36f1852d290a3cf48e77a983850ca80f8" alt=""
补充:
方法2与方法3基本可以满足需求;若修改太多,可以Textfile与button自定义一个搜索框;
而且方法2与3可以结合使用:
data:image/s3,"s3://crabby-images/a3a53/a3a53848ca4bfe1ff905511152af51514e0bc5ad" alt=""