gpt4 book ai didi

swift - 如何使用界面生成器向 View 添加阴影?

转载 作者:行者123 更新时间:2023-11-28 15:31:30 25 4
gpt4 key购买 nike

我读到要实现这一点需要@IBInspectable@IBDesignable,我已经让它适用于cornerRadius .唉,我的尝试对影子参数不起作用。我的代码如下:

@IBDesignable class DesignableView: UIView {}

extension UIView {
@IBInspectable var shadowRadius: CGFloat {
get {
return layer.shadowRadius
}
set {
layer.shadowRadius = newValue
}
}
@IBInspectable var shadowOffset: CGSize {
get {
return layer.shadowOffset
}
set {
layer.shadowOffset = newValue
}
}
@IBInspectable var shadowColor: UIColor? {
get {
var color: UIColor? = nil
if let cgColor = layer.shadowColor {
color = UIColor(cgColor: cgColor)
}
return color
}
set {
layer.shadowColor = newValue?.cgColor
}
}
@IBInspectable var cornerRadius: CGFloat { // This works, but not the ones above
get {
return layer.cornerRadius
}
set {
layer.cornerRadius = newValue
layer.masksToBounds = (newValue > 0)
}
}
}

然后我在界面构建器中添加一个 View 并将其设置为 DesignableView。之后我可以自由更改 cornerRadius 并且它会相应更新,但不会更新阴影参数。它们在界面构建器中可见,但操纵这些值不会改变视觉效果;甚至在编译之后和在应用程序中运行时也不行。

我错过了什么?

编辑:我在这个问题的答案的帮助下检测到错误。要使其工作,请添加 shadowOpacity(并在 Interface builder 中将其设置为 1)

@IBInspectable var shadowOpacity: Float {
get {
return layer.shadowOpacity
}
set {
layer.shadowOpacity = newValue
}
}

并从 cornerRadius 中移除 layer.masksToBounds = (newValue > 0)

最佳答案

你错过了:

yourView.layer.shadowOpacity = 1

关于swift - 如何使用界面生成器向 View 添加阴影?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44690692/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com