今天,是2016年的最后一天了,明天就是2017年了。回想这一年好像做的最多的就是两件事了,一件是旅游,接下来一件不用说,你们也能猜到,就是撸代码了。额,好吧,这一年好像过挺单调的,希望自己在2017年能。。。。。。O(∩_∩)O~,呵呵。
OK,切入我们的正题,今天小谈一下UIView中tintColor属性。为什么要谈这个属性呢?因为tintColor属性是iOS7以后,UIView新添加的属性,并且这个属性还是稍微有点特殊的,因为它具有传递性。举个例子,当我们用xib或者storyboard拖一个UIButton进入面板后,会发现UIButton的颜色为蓝色,可能有人会问为什么是这个颜色呢? 这是因为,默认情况下,一个视图的tintColor为nil,它会使用父视图tintColor属性的值。当我们为指定视图tintColor属性赋值以后,这个色值会自动传播到视图层次结构(以当前视图为根视图)中所有的子视图上。如果在视图层次结构中没有找到一个非默认的tintColor值,则会使用系统定义的颜色-蓝色,所以这就是为什么我们拖一个button后显示的是蓝色了。如图所示:
那么问题来了,系统提供的默认的tintColor的默认颜色,我们可以修改吗?当然,如果我们用的storyboard的话,可以在入口控制器的 File Inspector 中修改一下 Global Tint ,如图所示
可能有人会问用xib和代码怎么修改呢?xib上修改全局tintColor的属性还真没有找到,有知道的可以给我留下言哈。虽然xib不知怎么修改,我们可以通过代码进行修改的,最简单的情况是你可以通过一行代码来给整个APP指定一个颜色主题:[[UIApplication sharedApplication] keyWindow].tintColor = [UIColor orangeColor];
接下来,我们来通过一个小Demo验证一下,tintColor颜色的性质。首先,我们通过storyboard拖一个UIView为view1进入主面板上,然后拖一个UIButton为button1的按钮作为view1的子视图,接着再拖一个UIView为view2的视图放在view1的上面,使view2与button1为兄弟关系(即在同一个父视图上),然后在拖进一个UIButton为button2的按钮作为view2的子视图,如图所示:
现在,由于 view1和view2 的 tintColor 都没有明确指定, 所以它们的 tintColor 都会继承自最顶层的 UIWindow颜色,也就是蓝色。接着我们修改view1的tintColor的颜色为redColor,然后看下效果,如图所示:
通过对比可以发现view1上button1的颜色和view2上button2的颜色都变成了redColor,这可以说明,当我们指定了一个视图的tintColor后,这个色值会自动传递到这个视图子视图的上。接下来,我们再修改一下view2的tintcolor的为yellowColor,看下效果,如图所示:
观察上图可以看出,button2的tintColor变成view2设置的yellowColor。通过上面两幅图的对比可以发现,对一个视图来说, 如果没有设置它的tintColor,那么它会默认使用父视图的tintColor,如果设置了这个视图的tintColor, 那么它就会把这个tintColor传递给没有设置tintColor的子视图。除此之外,与tintColor相关的还有个UIViewTintAdjustmentMode类型的tintAdjustmentMode属性,它是一个枚举类型的属性,定义tintColor属性的调整模式,其中UIViewTintAdjustmentModeAutomatic表示视图的着色调整模式与父视图一致, UIViewTintAdjustmentModeNormal表示视图的tintColor属性返回完全未修改的视图着色颜色,UIViewTintAdjustmentModeDimmed表示视图的tintColor属性返回一个去饱和度的、变暗的视图着色。当tintAdjustmentMode属性设置为Dimmed时,tintColor的颜色值会自动变暗。而如果我们在视图层次结构中没有找到默认值,则该值默认是Normal。
与tintColor相关的还有一个tintColorDidChange方法,这个方法会在视图的tintColor或tintAdjustmentMode属性改变时自动调用。另外,如果当前视图的父视图的tintColor或tintAdjustmentMode属性改变时,也会调用这个方法。