部分切断了SwiftUI视图的快照

本教程将介绍部分切断了SwiftUI视图的快照的处理方法,这篇教程是从别的地方看到的,然后加了一些国外程序员的疑问与解答,希望能对你有所帮助,好了,下面开始学习吧。

部分切断了SwiftUI视图的快照 教程 第1张

问题描述

我尝试使用HWS: How to convert a SwiftUI view to an image中的代码从SwiftUI视图(快照)创建UIImage

我得到以下结果,很明显是不正确的,因为图片被截断了。

编码:

struct ContentView: View {
 @State private var savedImage: UIImage?

 var textView: some View {
  Text("Hello, SwiftUI")
.padding()
.background(Color.blue)
.foregroundColor(.white)
.clipShape(Capsule())
 }

 var body: some View {
  ZStack {
VStack(spacing: 100) {
 textView

 Button("Save to image") {
  savedImage = textView.snapshot()
 }
}

if let savedImage = savedImage {
 Image(uiImage: savedImage)
  .border(Color.red)
}
  }
 }
}
extension View {
 func snapshot() -> UIImage {
  let controller = UIHostingController(rootView: self)
  let view = controller.view

  let targetSize = controller.view.intrinsicContentSize
  view?.bounds = CGRect(origin: .zero, size: targetSize)
  view?.backgroundColor = .clear

  let renderer = UIGraphicsImageRenderer(size: targetSize)

  return renderer.image { _ in
view?.drawHierarchy(in: controller.view.bounds, afterScreenUpdates: true)
  }
 }
}

看起来快照的原始视图比应有的位置低,但我不确定。我怎么修复此问题?


编辑

我们发现这个问题并不发生在iOS 14上,而只发生在iOS 15上。所以问题是.怎么针对iOS 15修复此问题?

推荐答案

我最近也注意到了这个问题。我在不同的模拟器(例如,iPhone8和iPhone13Pro)上进行了测试,发现偏移量似乎总是状态栏高度的一半。因此,我怀疑当您在内部调用drawHierarchy(in:afterScreenUpdates:)时,SwiftUI总是将安全区域插入考虑在内。

因此,我使用edgesIgnoringSafeArea(_:)视图修饰符修改了View扩展中的snapshot()函数,它起作用了:

extension View {
 func snapshot() -> UIImage {
  let controller = UIHostingController(rootView: self.edgesIgnoringSafeArea(.all))
  let view = controller.view

  let targetSize = controller.view.intrinsicContentSize
  view?.bounds = CGRect(origin: .zero, size: targetSize)
  view?.backgroundColor = .clear

  let renderer = UIGraphicsImageRenderer(size: targetSize)

  return renderer.image { _ in
view?.drawHierarchy(in: controller.view.bounds, afterScreenUpdates: true)
  }
 }
}

好了关于部分切断了SwiftUI视图的快照的教程就到这里就结束了,希望趣模板源码网找到的这篇技术文章能帮助到大家,更多技术教程可以在站内搜索。