使用xib

时间:2018-05-06 15:07:47

标签: ios swift xib blur

我使用以下代码在视图上实现模糊效果(使用Swift 4.1,Xcode 9.3):

myXib - 加载笔尖视图并添加模糊子视图

func setup() {
    // load xib view
    Bundle.main.loadNibNamed("myXib", owner: self, options: nil)
    self.view.frame = bounds
    self.view.autoresizingMask = [.flexibleWidth, .flexibleHeight]
    self.addSubview(self.view)

    // create blur effect
    let blurEffect = UIBlurEffect(style: .light)
    let blurEffectView = UIVisualEffectView(effect: blurEffect)
    blurEffectView.frame = blurView.bounds
    blurView.translatesAutoresizingMaskIntoConstraints = false
    blurEffectView.autoresizingMask = [.flexibleWidth, .flexibleHeight]
    blurView.insertSubview(blurEffectView, at: 0)
    isBlurShowing = true
}

我使用一个简单的切换按钮来调用show()或hide()函数。

func hide() {
    blurView.isHidden = true
    blurView.alpha = 0
    isBlurShowing = false
}

func show() {
    blurView.isHidden = false
    blurView.alpha = 1
    isBlurShowing = true
}

示例myXib如下所示:

enter image description here

其中灰色区域为blurView(通常设置为“清除颜色”,此处仅设置为灰色以用于描述目的。)

对于blurView下的视图(橙色)但里面 Xib,hide()函数正常工作,但对于视图(蓝色) 下的Xib视图模糊效果依然存在。

模糊(.isHidden = false,.alpha = 1)

blur on

模糊关闭((。isHidden = true,.alpha = 0)

enter image description here

关闭时模糊效果较少,但仍然存在。 我做错了什么?

提前致谢。

1 个答案:

答案 0 :(得分:0)

好的,想通了。

问题是我在0处创建了第二个模糊层,因为我还在init函数中调用它:

override init (frame : CGRect) {
    super.init(frame: frame)
    setup()
}

required init? (coder aDecoder : NSCoder) {
    super.init(coder: aDecoder)
    setup()
}

删除后,代码运行正常。