1

我有这样的图像在此处输入图像描述

我想使用 SwiftUI 将它分成两部分。留下我可以访问的 2 个单独的图像。但是我不知道如何将原件分成顶部和底部。这两个部分必须对齐才能创建原始图像。

上图: 在此处输入图像描述

底部图片: 在此处输入图像描述

我尝试使用几何阅读器读取高度和宽度并返回一半高度的图像,但这两个图像不喜欢这样。

GeometryReader { geo in
    image
       .frame(width: geo.width, height: geo.height / 2, alignment: .center)
       .clipped()
}
4

1 回答 1

2

这里有一种方法:使用clipped()修饰符。


在此处输入图像描述


struct ContentView: View {
    
    @State private var spacing: CGFloat = CGFloat()
    @State private var imageSize: CGSize = CGSize()
    
    var body: some View {
        
        let image = Image(systemName: "star")
            .resizable()
            .scaledToFit()
            .frame(width: 200, height: 200, alignment: .center)
            .background(Color.yellow)
            .cornerRadius(10.0)
            .background(GeometryReader { proxy in Color.clear.onAppear() { imageSize = proxy.size } })
        
        
        return ZStack {
            
            VStack(spacing: spacing) {
                
                image.frame(width: imageSize.width, height: imageSize.height/2, alignment: .top).clipped()
                
                image.frame(width: imageSize.width, height: imageSize.height/2, alignment: .bottom).clipped()
            }
            
            VStack { Spacer(); Slider(value: $spacing,in: 0.0...100.0) }
            
        }
        .padding()
        .compositingGroup()
        .shadow(radius: 10.0)
        
    }
}
于 2021-04-14T23:09:45.823 回答