大佬教程收集整理的这篇文章主要介绍了swift3 – 使用用户定义的运行时属性的UIView阴影,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
如果我使用代码,它似乎完全正常,如下所示.
func formatView(view: UIView,cornerRadius: Bool) { if (cornerRadius) {view.layer.cornerRadius = 12 } view.layer.shadowColor = UIColor.black.cgColor view.layer.shadowOffset = CGSize.zero view.layer.shadowRadius = 3 view.layer.shadowOpacity = 0.3 }
但是当我使用用户定义的运行时属性尝试它时,它不再显示.这些是我目前正在使用的.
唯一奇怪的是,如果我删除了layer.shadowColor属性,那么它似乎再次起作用.但我无法控制颜色.它似乎默认为黑色,但如果我决定选择灰色,我将无法改变它.
您可以通过创建允许通过Interface Builder设置代理颜色的类别来解决此问题:
extension CALayer { var borderUIColor: UIColor { set { self.borderColor = newValue.cgColor } get { return UIColor(cgColor: self.borderColor!) } } }
但更好的方法是使用IBDesignable而不是用户定义的运行时属性,它更清楚.
您可以通过在项目中添加一个名为UIViewExtentions.swift的新swift文件(或者只是将其粘贴到任何文件中)来完成此操作:
import UIKit @IBDesignable extension UIView { @IBInspectable var borderColor:UIColor? { set { layer.borderColor = newValue!.cgColor } get { if let color = layer.borderColor { return UIColor(cgColor:color) } else { return nil } } } @IBInspectable var borderWidth:CGFloat { set { layer.borderWidth = newValue } get { return layer.borderWidth } } @IBInspectable var cornerRadius:CGFloat { set { layer.cornerRadius = newValue clipsToBounds = newValue > 0 } get { return layer.cornerRadius } } }
然后,这将在Interface Builder中为Utilities Panel中的每个按钮,imageView,标签等提供.属性检查员:
现在,如果您在Attributes Inspector中设置值并回顾用户定义的运行时属性,您将看到它们会自动归档给您!
编辑:@H_403_34@有关更多信息,请参阅:http://nshipster.com/ibinspectable-ibdesignable/
以上是大佬教程为你收集整理的swift3 – 使用用户定义的运行时属性的UIView阴影全部内容,希望文章能够帮你解决swift3 – 使用用户定义的运行时属性的UIView阴影所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。