SwiftUI: как получить maxHeight представления / содержимого HostingController по заданной ширине?
Я пытаюсь получить maxHeigth UIHostingController-View/Content и знать только ширину. Я хочу создать PDF-документ на основе моего представления. Все работает нормально, но я не знаю, как получить maxHeight представления / содержимого, поэтому PDF-файл знает, сколько страниц "длинно" у моего представления / содержимого.
func exportToPDF() {
let pdfName = "document"
let documentDirectory = FileManager.default.urls(for: .documentDirectory, in: .userDomainMask).first!
let outputFileURL = documentDirectory.appendingPathComponent("\(pdfName).pdf")
let printView = ProjectDetailView(viewModel: viewModel)
let pdfVC = UIHostingController(rootView: printView)
//Render the view behind all other views
let rootVC = UIApplication.shared.windows.first?.rootViewController
rootVC?.addChild(pdfVC)
rootVC?.view.insertSubview(pdfVC.view, at: 0)
let height: CGFloat = ???? <- **Needed Height by given width of 8.5 * 72.0**
let width: CGFloat = 8.5 * 72.0
pdfVC.view.frame = CGRect(x: 0, y: 0, width: width, height: height)
let numberOfPagesThatFitVertically = Int(ceil(height / 842))
//Render the PDF
let pdfRenderer = UIGraphicsPDFRenderer(bounds: CGRect(x: 0, y: 0, width: 8.5 * 72.0, height: height))
do {
try pdfRenderer.writePDF(to: outputFileURL, withActions: { (context) in
for indexVertical in 0 ..< numberOfPagesThatFitVertically
{
let offsetVerticalFloat = CGFloat(indexVertical) * 842
let offsetVertical = CGRect(x: 0, y: -offsetVerticalFloat, width: 8.5 * 72.0, height: 842)
context.beginPage(withBounds: offsetVertical, pageInfo: ["Page" : indexVertical])
pdfVC.view.layer.render(in: context.cgContext)
}
})
self.fileURL = outputFileURL
}catch {
// self.showError = true
print("Could not create PDF file: \(error)")
}
pdfVC.removeFromParent()
pdfVC.view.removeFromSuperview()
}
Обновление: после вы найдете ProjectDetailView (вид для печати, для которого мне нужна высота)
struct ProjectDetailView: View {
@ObservedObject var viewModel = DetailViewModel(db: Project())
var body: some View {
VStack{
Form{
ImageView(image: viewModel.image, systemImageName: "photo", systemImageSize: 50, height: 250, circle: false )
Section{
Text(viewModel.number)
Text(viewModel.status)
}
Section {
Text(viewModel.company)
}
Section(header: Text("Addresse")) {
HStack{
VStack(alignment: .leading){
Text(viewModel.street)
Text(viewModel.city)
}
}
}
}
}
.navigationBarTitle(Text("\(viewModel.projectname)"), displayMode: .inline)
}
}
1 ответ
Решение
Вот возможный подход:
let width: CGFloat = 8.5 * 72.0
let height: CGFloat = pdfVC.view.sizeThatFits(
CGSize(width: width, height: .greatestFiniteMagnitude)).height