首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >UIVisualEffectView上的圆角半径

UIVisualEffectView上的圆角半径
EN

Stack Overflow用户
提问于 2015-03-13 17:59:16
回答 4查看 11.6K关注 0票数 34

嗨,我想知道是否有可能在UIVisualEffectView上设置转角半径?下面是我尝试过的代码:

代码语言:javascript
复制
@IBOutlet var blurView: UIVisualEffectView!

var blurLayer : CALayer{
    return blurView.layer
}
override func viewDidLoad() {
    super.viewDidLoad()
    setUpLayer()
    // Do any additional setup after loading the view.
}

func setUpLayer(){
    blurLayer.cornerRadius = 50
}

代码语言:javascript
复制
@IBOutlet var blurView: UIVisualEffectView!

override func viewDidLoad() {
    super.viewDidLoad()
    blurView.layer.cornerRadius = 50
    // Do any additional setup after loading the view.
}

它们都不起作用。

EN

回答 4

Stack Overflow用户

发布于 2015-07-26 18:16:23

在@theMonster建议之后,我发布了一个评论。

代码语言:javascript
复制
override func viewDidLoad() {
    super.viewDidLoad()
    blurView.layer.cornerRadius = 50
    blurView.clipsToBounds = true
}
票数 60
EN

Stack Overflow用户

发布于 2018-07-17 00:39:42

在情节提要中,在用户定义的运行时属性layer.cornerRadius = 8layer.masksToBounds = true中添加两个参数

或者在代码中

代码语言:javascript
复制
@IBOutlet var blurView: UIVisualEffectView! {
    didSet {
        blurView.layer.cornerRadius = 8
        blurView.layer.masksToBounds = true
    }
}
票数 8
EN

Stack Overflow用户

发布于 2015-07-26 05:45:23

子类UIVisualEffectView

代码语言:javascript
复制
class PSORoundedVisualEffectView : UIVisualEffectView{

    override func layoutSubviews() {
        super.layoutSubviews()
        updateMaskLayer()
    }

    func updateMaskLayer(){
        let shapeLayer = CAShapeLayer()
        shapeLayer.path = UIBezierPath(roundedRect: self.bounds, cornerRadius: 10).CGPath
        self.layer.mask = shapeLayer
    }
}

将UIBezierPath替换为所需的任意形状。

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29029335

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档