首先先说下tintColor和backgroundColor的区别
1.backgroundColor (背景颜色)
(1).默认父视图设置的背景颜色,如果子视图的背景颜色也是default那么默认透明的视图都是父视图的背景颜色
(2)背景颜色对于视图上的带有线条的内容是无法改变的;比如字体颜色
2.tintColor
(1).tintColor是描述线条轮廓的一种颜色,该颜色默认具有传递性,默认状态下最底部的视图的tintcolor会一直往上面的视图传递
(2).如果子视图改变了tintcolor那么将会和父视图的tintColor不一样;传递链从此处断开
(3).navagation的item的 tintColor和controller自带的View不是在同一层次上;改变controller的view的tintColor对navagation的tintColor没有颜色;
(4).由于,tintColor的特性,我们可以对镂空的图片(如tabbar的image和 BarButtonItem的image)进行设置tintColor就可以设置改变镂空图片的颜色
以上说明了通过tintColor设置父视图颜色就可以直接改变对应的子视图中线条和轮廓的颜色。
这里重点说的是tintColor设置镂空图片的颜色,说明是镂空图片呢?例如:下面图片中返回,电话和购物车图片就属于镂空的图片,我这里圆的黑背景是自己的view
这里可以通过设置tintColor直接吧电话和购物车图片设置成白色,其他界面有用到橘黄色的电话和购物车图片也很方便,这样就不用麻烦美工妹子多切图了,妹子瞬间对我崇拜起来了...!
大家应该都知道图片UIImage有个渲染模式
UIImageRenderingMode枚举值来设置图片的renderingMode属性。该枚举中包含下列值:
UIImageRenderingModeAutomatic // 根据图片的使用环境和所处的绘图上下文自动调整渲染模式。
UIImageRenderingModeAlwaysOriginal // 始终绘制图片原始状态,不使用Tint Color。
UIImageRenderingModeAlwaysTemplate // 始终根据Tint Color绘制图片,忽略图片的颜色信息。
看完上面的相信应该懂了,我现在设置图片渲染模式为UIImageRenderingModeAlwaysTemplate,再设置按钮的tintColor为白色,结果如图:
完美!