iOS 支持毛玻璃效果修改模糊度

有时候,设计要求的毛玻璃模糊程度,系统的视图无法满足我们的需求,就需要使用UIViewPropertyAnimator 来实现了,代码如下

复制代码
//
// LBVisualEffectView.swift
//  
//
//

import SnapKit
import Foundation

class LBViewPropertyAnimator: UIViewPropertyAnimator {}

public class LBVisualEffectView: UIView {
    private var animator: LBViewPropertyAnimator?
    private var effectView = UIVisualEffectView()

    private var visualEffect: UIVisualEffect? {
        didSet {
            animator?.stopAnimation(true)
            effectView.effect = visualEffect
            buildBlurFraction(effectFraction)
        }
    }

    private var effectFraction: CGFloat?

    private var visualEffectToken: LBThemeToken.VisualEffect? {
        didSet {
            visualEffect = visualEffectToken?.literaryContent
        }
    }

    deinit {
        animator?.stopAnimation(true)
    }

    override public init(frame: CGRect) {
        super.init(frame: frame)
        render()
        makeObservation()
    }

    @available(*, unavailable)
    required init?(coder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }

    private func render() {
        addSubview(effectView)
        effectView.snp.remakeConstraints { make in
            make.edges.equalToSuperview()
        }
    }

    private func makeObservation() {
        NotificationCenter
            .default
            .addObserver(
                forName: UIApplication.willEnterForegroundNotification,
                object: nil,
                queue: .main
            ) { [weak self] _ in
                guard let self else {
                    return
                }
                animator?.stopAnimation(true)
                buildBlurFraction(effectFraction)
            }

        LBTheme.addThemeObserver(self)
    }

    public override func didMoveToWindow() {
        super.didMoveToWindow()
        buildBlurFraction(effectFraction)
    }

    @discardableResult
    public func buildVisualEffect(visualEffect: LBThemeToken.VisualEffect) -> Self {
        visualEffectToken = visualEffect
        return self
    }

    @discardableResult
    public func buildVisualEffect(style: UIBlurEffect.Style) -> Self {
        visualEffect = UIBlurEffect(style: style)
        return self
    }

    @discardableResult
    public func buildVisualEffect(blurStyle: UIBlurEffect.Style, vibrancyStyle: UIVibrancyEffectStyle) -> Self {
        visualEffect = UIVibrancyEffect(blurEffect: UIBlurEffect(style: blurStyle), style: vibrancyStyle)
        return self
    }

    @discardableResult
    public func buildBlurFraction(_ fraction: CGFloat?) -> Self {
        effectFraction = fraction
        guard let fraction, fraction >= 0, fraction <= 1 else {
            animator?.stopAnimation(true)
            return self
        }
        effectView.effect = nil
        animator?.stopAnimation(true)
        animator = nil
        animator = LBViewPropertyAnimator(duration: 0.5, curve: .linear)
        animator?.addAnimations { [weak self] in
            guard let self else {
                return
            }
            //[UIBlurEffect effectWithStyle:UIBlurEffectStyleExtraLight]
            effectView.effect = UIBlurEffect(style: .light)
        }
//        animator?.addCompletion { [weak self] _ in
//            guard let self else {
//                return
//            }
//            if let window {
//                buildBlurFraction(fraction)
//            }
//        }
//        animator?.startAnimation()
//        animator?.pauseAnimation()
        animator?.fractionComplete = fraction
        return self
    }
}

extension LBVisualEffectView: LBThemeableCustomItem {
    public func themeDidChange() {
        visualEffect = visualEffectToken?.literaryContent
    }
}

使用方法

复制代码
 private let blurView = {
        let view = LBVisualEffectView()
        view.buildVisualEffect(
            visualEffect: .createVisualEffect(light: .createBlur(style: .light), dark: .createBlur(style: .light))).buildBlurFraction(0.4)
        return view
    }()
相关推荐
人月神话-Lee15 小时前
【图像处理】卷积原理与卷积核——图像处理的核心引擎
图像处理·深度学习·ios·ai编程·swift
2501_9151063216 小时前
深入解析无源码iOS加固原理与方案,保护应用安全
android·安全·ios·小程序·uni-app·cocoa·iphone
Daniel_Coder18 小时前
iOS Widget 开发-15:Widget 性能优化指南
ios·swift·widget·widgetcenter
库奇噜啦呼20 小时前
【iOS】源码学习-dyld加载
学习·ios·cocoa
Daniel_Coder20 小时前
iOS Widget 开发-16:Widget 网络数据加载策略
ios·swift·widget·widgetcenter
美狐美颜SDK开放平台21 小时前
美颜SDK开发详解:如何优化美颜SDK在低端安卓机上的性能?
android·ios·音视频·直播美颜sdk·视频美颜sdk
Kurisu57521 小时前
FilzaCracked_4.0.0_TS.ipa2026最新官方正版免费下载 一键转存 永久更新 (看到速转存 资源随时走丢)手机版通用
ios·智能手机·电脑·巨魔
ACP广源盛139246256731 天前
iOS 27 开放 AI 生态@ACP#小型化扩展黄金风口,IX8008全面超越 ASM2806,铸就嵌入式 AI 扩展核心
人工智能·嵌入式硬件·macos·ios·计算机外设·objective-c·cocoa
人月神话Lee1 天前
【图像处理】卷积原理与卷积核——图像处理的核心引擎
ios·ai编程·图像识别
用户223586218202 天前
如何在超大型的工程中使用 Claude Code?
前端·ios·claude