iOS UISearchController样式全面设置
Q: 如果想要做到上图所示的搜索框需要怎么设置?
搜索框的样式设置都是基于 UISearchController 的 searchBar 也就是 UISearchBar 设置的。
但是 UISearchBar 并没有提供多少自定义设置。 图标相关的设置也主要是系统提供的几种简单样式。
而iOS11和iOS11以下的搜索框由于样式不一样,很多属性的设置不尽相同。
所以这篇文章就是对怎么修改 UISearchController 样式的梳理
首先 UISearchController 主要是对 UISearchBar 的封装,而 UISearchBar 又包含了 UITextField 和 UINavigationButton (取消按钮)
有两种方法可以获取,KVC或者遍历子视图。
我们这里采用KVC,效率比较高。
这里我们讨论三种图标的设置
如果设置了bookmark,在没有输入的时候显示bookmark,输入的时候显示清除按钮
这三种图标都可以通过以下方法来设置。
除此之外也可以获取具体的UI组件来设置
如果是想用默认的图片但只是想改变其颜色的话,
以修改放大镜颜色为例。
这里我们定义一个属性,然后通过属性监测器来应用到图片上。这里我们取的是在文章开头定义的 searchField 。然后取它的左视图 UIImageView 来修改。
可以通过获取原图片然后修改图片的。
其它图标的修改请参考文末附的源码。
这部分的设置都是跟 UISearchField 的一样
通过设置 searchField 的 tintColor 即可修改光标颜色
修改 searchBar 的 tintColor 也可以达到效果,因为子视图的 tintColor 会自动继承父级视图。
但是设置 searchBar 的 tintColor 还会修改取消按钮的颜色。如果你想要他们同一个颜色话,直接设置 seachBar 更好。
iOS11以下的直接设置 searchField?.backgroundColor 即可。
而iOS11的要设置
取消按钮就是在输入的时候显示的cancel按钮。只要设置 showsCancelButton 即可。
而如果要自定义这个按钮的话,我们采用的也是遍历子视图获取到这个按钮的方法。
然后在 searchBar 的代理事件的 searchBarShouldBeginEditing 或者 searchBarDidBeginEditing 中调用即可。
其它还有一些细节的设置可以参考下面的源码
源码 已经提交到Github上了。
并且简化了所有的属性和代理方法。
欢迎大家来提交问题和分支。
如果觉得有帮助的话记得给颗星:P
2024-09-04 广告