iOS中的UISearchBar搜索框組件基礎(chǔ)使用指南
UISearchBar也是iOS開發(fā)常用控件之一,點進去看看里面的屬性barStyle、text、placeholder等等。但是這些屬性顯然不足矣滿足我們的開發(fā)需求。比如:修改placeholder的顏色、修改UISearchBar上面的UITextfield的背景顏色、修改UITextfield上面的照片等等。
為了實現(xiàn)上述的需求,最好寫一個UISearchBar的子類就叫LSSearchBar吧
LSSearchBar.h如下:
#import <UIKit/UIKit.h>
@interface LSSearchBar : UISearchBar
@end
LSSearchBar.m如下:
#import "LSSearchBar.h"
@implementation LSSearchBar
- (void)layoutSubviews {
[super layoutSubviews];
//通過遍歷self.subviews找到searchField
UITextField *searchField;
NSUInteger numViews = [self.subviews count];
for(int i = 0; i < numViews; i++) {
if([[self.subviews objectAtIndex:i] isKindOfClass:[UITextField class]]) {
searchField = [self.subviews objectAtIndex:i];
}
}
//如果上述方法找不到searchField,那就試試下面的方法吧
if (searchField == nil) {
NSArray *arraySub = [self subviews];
UIView *viewSelf = [arraySub objectAtIndex:0];
NSArray *arrayView = [viewSelf subviews];
for(int i = 0; i < arrayView.count; i++) {
if([[arrayView objectAtIndex:i] isKindOfClass:[UITextField class]]) {
searchField = [arrayView objectAtIndex:i];
}
}
}
if(!(searchField == nil)) {
//設(shè)置顏色
searchField.textColor = [UIColor whiteColor];
//設(shè)置背景顏色
[searchField setBackground: [UIImage imageNamed:@"searchbar"] ];
[searchField setBorderStyle:UITextBorderStyleNone];
//設(shè)置placeholder的顏色
[searchField setValue:[UIColor whiteColor] forKeyPath:@"_placeholderLabel.textColor"];
//設(shè)置searchField上的照片
UIImage *image = [UIImage imageNamed:@"search"];
UIImageView *iView = [[UIImageView alloc] initWithImage:image];
iView.frame = CGRectMake(0, 0, 15, 15);
searchField.leftView = iView;
}
}
@end
修改UISearchBar背景顏色
ISearchBar是由兩個subView組成的,一個是UISearchBarBackGround,另一個是UITextField. 要IB中沒有直接操作背景的屬性。方法是直接將 UISearchBarBackGround移去
seachBar=[[UISearchBar alloc] init];
seachBar.backgroundColor=[UIColor clearColor];
for (UIView *subview in seachBar.subviews){
if ([subview isKindOfClass:NSClassFromString(@"UISearchBarBackground")]) {
[subview removeFromSuperview];
break;
}
}
UISearchBar文字顏色改變
1. 在iOS的7訪問文本字段,你必須在水平重申更多。更改您的代碼像這樣
for (UIView *subView in self.searchBar.subviews)
{
for (UIView *secondLevelSubview in subView.subviews){
if ([secondLevelSubview isKindOfClass:[UITextField class]])
{
UITextField *searchBarTextField = (UITextField *)secondLevelSubview;
//set font color here
searchBarTextField.textColor = [UIColor blackColor];
break;
}
}
}
或可以設(shè)置的tintcolor適用于關(guān)鍵在search bar。 使用tintColor至著色前景 使用barTintColor要著色的欄背景。 在iOS系統(tǒng)V7.0,的UIView的子類派生的基類行為tintColor。見tintColor在為UIView的水平 蘋果文件
2. 可以通過設(shè)置文字的顏色
[[UITextField appearanceWhenContainedIn:[UISearchBar class], nil] setTextColor:[UIColor blueColor]];
3. 雖然這是真的,UIAppearance協(xié)議是一個“公開的API,”這不是真的,UITextField的支持這一點。 如果你看一看UITextField.h并查找字符串“UI_APPEARANCE_SELECTOR”,你會看到它有這個字符串的任何實例。如果你看的UIButton CodeGo.net,你會發(fā)現(xiàn)不少-這些都是由該UIAppearance API正式支持的屬性。這是眾所周知的,UITextField的是不支持的UIAppearance API,所以在桑迪普的答案代碼并不總是可行的,它實際上不是最好的方法。 這是帖子的鏈接: 正確的做法是-遍歷子視圖(或子視圖主要用于IOS7的子視圖)和手動設(shè)置。否則,您將有不可靠的結(jié)果。但你可以創(chuàng)建一個類別的UISearchBar并添加setTextColor:(*的UIColor)示例:
- (void)setTextColor:(UIColor*)color
{
for (UIView *v in self.subviews)
{
if([Environment isVersion7OrHigher]) //checks UIDevice#systemVersion
{
for(id subview in v.subviews)
{
if ([subview isKindOfClass:[UITextField class]])
{
((UITextField *)subview).textColor = color;
}
}
}
else
{
if ([v isKindOfClass:[UITextField class]])
{
((UITextField *)v).textColor = color;
}
}
}
}
自定義UISearchBar的背景圖
- (void)layoutSubviews {
UITextField *searchField;
NSUInteger numViews = [self.subviews count];
for(int i = 0; i < numViews; i++) {
if([[self.subviews objectAtIndex:i] isKindOfClass:[UITextField class]]) {
searchField = [self.subviews objectAtIndex:i];
}
}
if(!(searchField == nil)) {
searchField.textColor = [UIColor whiteColor];
[searchField.leftView setHidden:YES];
[searchField setBackground: [UIImage imageNamed:@"SearchBarBackground.png"] ];
[searchField setBorderStyle:UITextBorderStyleNone];
}
[super layoutSubviews];
}
相關(guān)文章
iOS中tableView cell分割線的一些設(shè)置技巧
在項目開發(fā)中我們會常常遇到tableView 的cell分割線顯示不全,左邊會空出一截像素,更有甚者想改變系統(tǒng)的分割線,下面通過這篇文章來一起學(xué)習(xí)學(xué)習(xí)在iOS中tableView cell分割線的一些設(shè)置技巧,需要的朋友可以參考借鑒,下面來一起看看吧。2017-05-05
iOS UISegmentControl實現(xiàn)自定義分欄效果
這篇文章主要為大家詳細介紹了iOS UISegmentControl實現(xiàn)自定義分欄效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03
iOS中導(dǎo)航欄pop返回時出現(xiàn)黑塊問題的解決方法
在iOS開發(fā)的工作當(dāng)中,Push和Pop經(jīng)常用于界面之間的跳轉(zhuǎn)和返回。下面這篇文章主要給大家介紹了關(guān)于iOS中導(dǎo)航欄pop返回時出現(xiàn)黑塊問題的解決方法,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面來一起看看吧。2017-10-10
深入講解iOS開發(fā)中的UIViewController
這篇文章主要介紹了iOS開發(fā)中的UIViewController,其中以UIViewController作為著重講解,需要的朋友可以參考下2015-09-09
iOS 簡約日歷控件EBCalendarView的實現(xiàn)代碼
本篇文章主要介紹了iOS 簡約日歷控件EBCalendarView的實現(xiàn)代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-05-05

