微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何在 SwiftUI 中剪辑背景模糊

如何解决如何在 SwiftUI 中剪辑背景模糊

我想有一个半透明的模糊叠加视图,但模糊会产生模糊的边缘,我希望它能够清晰地勾勒出叠加形状,即剪裁它。

struct TestBlur : View {
    var body : some View {
        HStack {
            vstack {
                Spacer()
                Text("Hello World")
                Spacer()
            }
            .frame(width: 128)
            .background(Color.red.opacity(0.5).blur(radius: 16).clipShape(Rectangle()))
            Spacer()
        }
        .background(Color.yellow)
    }
}

enter image description here

我希望红色叠加层的边缘像这样:

enter image description here

本质上,我希望红色视图模糊其下方的任何内容并具有锐利的边缘:

enter image description here

使用@Asperi 的 BackgroundBlurView 也不起作用,没有完成模糊(也许我没有正确使用):

    var body : some View {
        ZStack {
            vstack {
                ForEach(0..<40) { i in
                    Text("ABCDEFGHIKLMnopQRSTUVWXYZ ABCDEFGHIKLMnopQRSTUVWXYZ ABCDEFGHIKLMnopQRSTUVWXYZ ABCDEFGHIKLMnopQRSTUVWXYZ ABCDEFGHIKLMnopQRSTUVWXYZ ")
                }
                .rotationEffect(Angle.init(degrees: 0))
            }
            .opacity(0.9)
            .background(Color.yellow)
            
            HStack {
                // Trying to make the below vstack have a semi-transparent background and blur all content below it
                // but the vstack needs to have a sharp edge,not fuzzy.
                vstack {
                    Spacer()
                    Text("Hello World")
                    Spacer()
                }
                .frame(width: 128)
                .background(Color.red.opacity(0.5))
                .background(BackgroundBlurView().opacity(0.8))
                Spacer()
            }
        }
    }

struct BackgroundBlurView: UIViewRepresentable {
    func makeUIView(context: Context) -> UIView {
        let view = UIVisualEffectView(effect: UIBlurEffect(style: .light))
        dispatchQueue.main.async {
            view.superview?.superview?.backgroundColor = .clear
        }
        return view
    }

    func updateUIView(_ uiView: UIView,context: Context) {}
}

看起来像这样(没有模糊):

enter image description here

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。