I wanna custom the UISearchBar control to a style as showed in the picture below:
First I should remove the background view, then find out the UITextfiled in UISearchBar, extend the frame of UITextfiled and remove the boarder of it.
Here is my code :
UITextField *searchField;
NSUInteger numViews = [self.subviews count];
for(int i = 0; i != numViews; i++) {
if([[self.subviews objectAtIndex:i] isKindOfClass:[UITextField class]]) { //conform?
searchField = [self.subviews objectAtIndex:i];
}
}
if(!(searchField == nil)) {
[searchField setBorderStyle:UITextBorderStyleNone];
searchField.frame = self.frame; //modify the frame
}
[[self.subviews objectAtIndex:0]removeFromSuperview]; //remove the background.
The result is the boarder of the UITextField is still there. :(
My question is : 1.Why can not I modify the appearance of the UITextField of UISearchBar?
2.How to remove the boarder of UITextfield in UISearchBar.
Thanks very much!
Subclass UISearchBar and override layoutSubViews to remove the search bar background and the text field border subviews:
I'm not certain about this, however I suspect the only way you're going to be able to achieve a
UISearchBar
like that of the one in your image is to create a new subclass ofUISearchBar
. Using that you could set it up to look exactly like the one in your image.This post may be of some help to you if you decide to go down the route of subclassing.