在这种情况下,您需要指定使用哪个特征集合来解析动态颜色。
self.traitCollection.performAsCurrent { self.layer.borderColor = UIColor(named: "testColor")?.cgColor}
要么
更长的答案self.layer.borderColor = UIColor(named: "testColor")?.resolvedColor(with: self.traitCollection).cgColor
在
cgColordynamic上调用方法时
UIColor,它需要解析动态颜色的值。可以通过参考当前特征集来完成
UITraitCollection.current。
当调用某些方法的重写时,UIKit将设置当前特征集合,尤其是:
- UIView
- 画()
- layoutSubviews()
- traitCollectionDidChange()
- tintColorDidChange()
- UIViewController
- viewWillLayoutSubviews()
- viewDidLayoutSubviews()
- traitCollectionDidChange()
- UIPresentationController
- containerViewWillLayoutSubviews()
- containerViewDidLayoutSubviews()
- traitCollectionDidChange()
但是,在这些方法的替代范围之外,当前特征集不必设置为任何特定值。因此,如果您的代码未覆盖这些方法之一,而您想解析一种动态颜色,则您有责任告诉我们要使用的特征集。
(这是因为可以覆盖
userInterfaceStyle任何视图或视图控制器的特征,因此即使将设备设置为亮模式,您也可能拥有处于暗模式的视图。)
您可以通过使用UIColor方法直接解析动态颜色来实现
resolvedColor(with:)。或使用UITraitCollection方法
performAsCurrent,然后将用于解析颜色的代码放入闭包中。上面的简短答案显示了两种方式。
您也可以将代码移入这些方法之一。在这种情况下,我认为您可以将其放入
layoutSubviews()。如果执行此 *** 作,则当明/暗样式更改时,它将自动被调用,因此您无需执行其他任何 *** 作。参考
WWDC 2019,在iOS中实现黑暗模式
从19:00开始,我讨论了动态色彩的解析方式,然后在23:30,我举了一个示例,说明如何
CALayer像您一样将边框颜色设置为动态颜色。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)