UIKit:如何将多个 CALayer 混合到一个视图层中?

问题描述

我想将几个子层混合成一个层。 如果我只是将我的修改分配给视图层,它工作正常:

testView.layer.cornerRadius = 15.0
testView.layer.shadowColor = UIColor.yellow.withAlphaComponent(1.0).cgColor
testView.layer.shadowOpacity = 1.0
testView.layer.shadowRadius = 24.0
testView.layer.shadowOffset = .zero
testView.backgroundColor = .white

enter image description here

然后,我尝试了这个:

testView.layer.cornerRadius = 15.0
// sl1
let layer1 = CALayer()
layer1.shadowColor = UIColor.yellow.withAlphaComponent(1.0).cgColor
layer1.shadowOpacity = 1.0
layer1.shadowRadius = 24.0
layer1.shadowOffset = .zero
// sl2
let layer2 = CALayer()
layer2.shadowColor = UIColor.red.withAlphaComponent(1.0).cgColor
layer2.shadowOpacity = 1.0
layer2.shadowRadius = 24.0
layer2.shadowOffset = .zero
// sublayers
let layer = CALayer()
testView.layer.sublayers = [layer1,layer2]
testView.backgroundColor = .white

但现在这是我得到的结果

enter image description here

现在白色视图周围没有阴影。为什么会发生这种情况?

感谢您的帮助

解决方法

你的代码的主要问题是你的层没有任何大小。因此,例如您看不到阴影,因为图层本身在左上角的大小为零,因此没有任何东西可以投射任何阴影。

在创建图层后立即为其赋予 frame 是您的工作!通常这与超层的 bounds 相同。但是请记住,与视图不同的是,当调整视图或超级图层的大小时,子图层不会。因此,如果您不采取措施纠正它,子层可能会停止正确“适合”其上层。