- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的问题如何从 QLThumbnailGenerator.shared.generateRepresentations(for: ... ) 返回 cgImage?
我的挂断/尝试(代码如下)我的尝试有一个函数(第 13 行),它返回 ListView 条目(第 39 行)的 CGImage。我尝试使用空的 CGImage(第 18 行),但它的初始化参数令人困惑,并且对于简单的缩略图来说似乎过多。我可能会错误地处理这个问题。
注释使用 CGImage,因此相同的代码可以同时适用于 iOS 和 MacOS Catalyst。 (在 WWDC 2019 第 719 场 session 上看到了这一点。)我尝试过但未能从以下位置收集答案: -https://developer.apple.com/documentation/quicklookthumbnailing/creating_quick_look_thumbnails_to_preview_files_in_your_app -https://forums.developer.apple.com/message/375807
道歉/感谢感谢您的耐心等待,因为答案可能很明显,而且我的词汇量可能不够。我愚蠢的大脑在没有一点实践经验的情况下就忽略了讲座,所以我从零编程知识开始了第一个应用程序作为隔离爱好。之后我会回到理论讲座。
ResultsView.swift
import SwiftUI
import MobileCoreServices
import Combine
import QuickLookThumbnailing
import CoreImage
import UIKit
struct ResultsView: View {
@EnvironmentObject var parsedScreeningData: ParsedScreeningData
@EnvironmentObject var search: Search
func generateThumbnail(ofThis: String) -> CGImage {
let url = self.search.libraryFolder.appendingPathComponent(ofThis)
let size: CGSize = CGSize(width: 68, height: 88)
let request = QLThumbnailGenerator.Request(fileAt: url, size: size, scale: (UIScreen.main.scale), representationTypes: .all)
let generator = QLThumbnailGenerator.shared
var image = CGImage()
generator.generateRepresentations(for: request) { (thumbnail, type, error) in
DispatchQueue.main.async {
if thumbnail == nil || error != nil {
assert(false, "Thumbnail failed to generate")
} else {
image = thumbnail!.cgImage
}
}
}
return image
}
var body: some View {
VStack{
List(search.searchResults) { datum in
HStack {
Image(self.generateThumbnail(ofThis: datum.PDFname), scale: (UIScreen.main.scale), label: Text("PDF"))
Text("File: \(datum.PDFname)")
Text("Cell line: \(self.parsedScreeningData.parsedScreeningData[datum.termFoundIndex].misidentifiedCellLine)")
.padding(.trailing, 10)
.padding(.leading, 10)
Spacer()
Image(systemName: "eyeglasses").foregroundColor(ColorManager.iconGreen)
} // HStack
} // List
}// Vstack
.colorMultiply(ColorManager.beigeMedium)
.padding(.trailing, 0)
.padding(.leading, 0)
.listStyle(GroupedListStyle())
} // body
} // ResultsView struct
struct ResultsView_Previews: PreviewProvider {
static var previews: some View {
ResultsView().environmentObject(ParsedScreeningData()).environmentObject(Search())
}
}
最佳答案
缩略图生成是异步的,因此它需要一些包装 View ,该 View 等待生成的 util 缩略图显示一些 stub 占位符,并在缩略图准备就绪时进行更新。
这是可能的解决方案
List(search.searchResults) { datum in
HStack {
ThumbnailImageView(url: self.search.libraryFolder.appendingPathComponent(datum.PDFname))
Text("File: \(datum.PDFname)")
// ... other your code here
struct ThumbnailImageView: View {
let url: URL
@State private var thumbnail: CGImage? = nil
var body: some View {
Group {
if thumbnail != nil {
Image(self.thumbnail!, scale: (UIScreen.main.scale), label: Text("PDF"))
} else {
Image(systemName: "photo") // << any placeholder
.onAppear(perform: generateThumbnail) // << here !!
}
}
}
func generateThumbnail() {
let size: CGSize = CGSize(width: 68, height: 88)
let request = QLThumbnailGenerator.Request(fileAt: url, size: size, scale: (UIScreen.main.scale), representationTypes: .all)
let generator = QLThumbnailGenerator.shared
generator.generateRepresentations(for: request) { (thumbnail, type, error) in
DispatchQueue.main.async {
if thumbnail == nil || error != nil {
assert(false, "Thumbnail failed to generate")
} else {
DispatchQueue.main.async { // << required !!
self.thumbnail = thumbnail!.cgImage // here !!
}
}
}
}
}
}
关于swiftui - 如何从 QLThumbnailGenerator 正确返回图像? ( swift 用户界面),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61829416/
我的问题如何从 QLThumbnailGenerator.shared.generateRepresentations(for: ... ) 返回 cgImage? 我的挂断/尝试(代码如下)我的尝试
我是一名优秀的程序员,十分优秀!