tintColor是iOS7以后,UIView新增的属性,这个属性定义了一个非默认的着色颜色值,其值的设置会影响到以视图为根视图的整个视图层次结构。tintColor属性在iOS开发中,主要运用于app图标、导航栏、按钮等一些控件上,以获取一些有意思的视觉效果。
默认情况下,一个视图的tintColor是为nil的,这意味着视图将使用父视图的tint color值。当我们指定了一个视图的tintColor后,这个色值会自动传播到视图层次结构(以当前视图为根视图)中所有的子视图上。如果系统在视图层次结构中没有找到一个非默认的tintColor值,则会使用系统定义的颜色值(蓝色,RGB值为[0,0.478431,1],我们可以在IB中看到这个颜色)。因此,这个值总是会返回一个颜色值,即我们没有指定它。
与tintColor属性相关的还有个tintAdjustmentMode属性,它是一个枚举值,定义了tint color的调整模式。其声明如下:
var tintAdjustmentMode: UIViewTintAdjustmentMode
枚举UIViewTintAdjustmentMode的定义如下:
case Automatic//视图的着色调整模式与父视图一致
case Normal//视图的tintColor属性返回完全未修改的视图着色颜色
case Dimmed//视图的tintColor属性返回一个去饱和度的、变暗的视图着色颜色
因此,当tintAdjustmentMode属性设置为Dimmed时,tintColor的颜色值会自动变暗。而如果我们在视图层次结构中没有找到默认值,则该值默认是Normal。
与tintColor相关的还有一个tintColorDidChange方法,其声明如下:
functintColorDidChange()
这个方法会在视图的tintColor或tintAdjustmentMode属性改变时自动调用。另外,如果当前视图的父视图的tintColor或tintAdjustmentMode属性改变时,也会调用这个方法。我们可以在这个方法中根据需要去刷新我们的视图。
另外,我们在子视图CustomView中重写了tintColorDidChange方法,以监听tintColor的变化,以更新我们的自定义视图,其实现如下:
override functintColorDidChange() {
tintColorLabel.textColor = self.tintColor
tintColorBlock.backgroundColor =self.tintColor
}
所以方框和”Tint color label”颜色是跟着子视图的tintColor来变化的,而子视图的tintColor又是继承自父视图的。
在上面这个示例中,比较有意思的是还是对图片的处理。对图像的处理比较简单粗暴,对一个像素而言,如果它的alpha值为1的话,就将它的颜色设置为tint color;如果不为1的话,则设置为透明的。示例中的忍者头像就是这么处理的。不过我们需要设置图片的imageWithRenderingMode属性为AlwaysTemplate,这样渲染图片时会将其渲染为一个模板而忽略它的颜色信息,如代码所示:
var shinobiHead= UIImage(named: "shinobihead")
//设置渲染模式
shinobiHead =shinobiHead?.imageWithRenderingMode(.AlwaysTemplate)
小结
如果我们想指定整个App的tint color,则可以通过设置window的tint color。这样同一个window下的所有子视图都会继承此tint color。
当弹出一个alert或者action sheet时,iOS7会自动将后面视图的tint
color变暗。此时,我们可以在自定义视图中重写tintColorDidChange方法来执行我们想要的操作。
有些复杂控件,可以有多个tint
color,不同的tint color控件不同的部分。如上面提到的UIProgressView,又如navigation bars, tab bars, toolbars, search
bars, scope bars等,这些控件的背景着色颜色可以使用barTintColor属性来处理。
以上就是iOS7中Tint Color属性的一些用法,可能整理的还不是很全面,但是在我们日常的app开发中对这个属性的基本使用还是都有概括到,希望能对正在研究这个属性的你有所帮助。
来源:南峰子的技术博客