Создание blurView с четким вырезом

Я создаю наложение BlurView с четким прямоугольником в середине. Мой код до сих пор достиг противоположного, то есть clearView с вырезом размытия посередине.

Я адаптировал свои шаги из следующих постов, я ценю, если кто-нибудь может указать мне в правильном направлении.

Быстрая маска слоя круга над UIView

CALayer с прозрачным отверстием в нем

let blurView = UIVisualEffectView(frame: CGRect(x: 0, y: 0, width: self.view.frame.width, height: self.view.frame.height))
blurView.effect = UIBlurEffect(style: UIBlurEffectStyle.dark)

let scanLayer = CAShapeLayer()
scanLayer.path = CGPath(rect: scanRect, transform: nil)

view.addSubview(blurView)
blurView.layer.addSublayer(scanLayer)
blurView.layer.mask = scanLayer

1 ответ

Решение

Вы можете сделать это так

    let scanLayer = CAShapeLayer()

    let scanRect = CGRect.init(x: 100, y: 100, width: 200, height: 100)

    let outerPath = UIBezierPath(rect: scanRect)

    let superlayerPath = UIBezierPath.init(rect: blurView.frame)
    outerPath.usesEvenOddFillRule = true
    outerPath.append(superlayerPath)
    scanLayer.path = outerPath.cgPath
    scanLayer.fillRule = kCAFillRuleEvenOdd
    scanLayer.fillColor = UIColor.black.cgColor

    view.addSubview(blurView)
    blurView.layer.mask = scanLayer
Другие вопросы по тегам