繁体   English   中英

Swift @ IBDesignable / @ IBInspectable UIView样式

[英]Swift @IBDesignable/@IBInspectable UIView styling

我正在尝试对表格单元格原型中的UIView进行样式设置,使其具有阴影以及更多样式自定义,但是由于某些原因,在构建项目时未应用更改。

我在单独的文件CustomView.swift有下一个代码

import UIKit

@IBDesignable
class CustomView: UIView {



    @IBInspectable var cornerRadius: CGFloat = 0 {
        didSet {
            layer.cornerRadius = cornerRadius
            layer.masksToBounds = cornerRadius > 0
        }
    }

    @IBInspectable var shadowOpacity: Float = 0 {
        didSet {
            layer.shadowOpacity = shadowOpacity
        }
    }

    @IBInspectable var shadowRadius: CGFloat = 0 {
        didSet {
            layer.shadowRadius = shadowRadius
        }
    }

    @IBInspectable var shadowOffset: CGSize = CGSize(width: 0.0, height: 0.0) {
        didSet {
            layer.shadowOffset = shadowOffset
        }
    }

    @IBInspectable var shadowColor: UIColor? = UIColor(red: 157/255, green: 157/255, blue: 157/255, alpha: 1.0) {
        didSet {
            layer.shadowColor = shadowColor?.cgColor
        }
    }

}

我看到Xcode 9的“属性检查器”中的字段 Xcode 9的“属性检查器”

但是构建它之后,基本上没有应用更改,我看不到阴影。

最有趣的是,我使用相同的方法来自定义文本字段和按钮,并且此代码适用于UIButton/UITextField但不适用于UIView

有人知道为什么它不适用于UIView吗?

任何帮助,不胜感激。

谢谢。

检查您的代码:

layer.masksToBounds = cornerRadius > 0

更改为:

layer.masksToBounds = false

并且还要确保您的clipsToBounds在以下代码中都设置为false

clipsToBounds = false

或像这样在情节提要中:

在此处输入图片说明

请更新功能

@IBInspectable
    var cornerRadius: CGFloat = 0 {
        didSet {
            layer.cornerRadius = cornerRadius
        }
    }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM