TintColor的介绍与使用

首先先说下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为白色,结果如图:

完美!

你可能感兴趣的:(TintColor的介绍与使用)