在设备上 运行 时,SwiftUI onDrag 不显示预览图像
SwiftUI onDrag does not show preview image when running on device
我注意到自 iOS 13.4 以来可用的 SwiftUI 中的拖放功能存在问题。使用 .onDrag 和 .onDrop 修饰符的拖放操作在模拟器中运行良好,但在真实设备(iPhone 和 iPad)上,您只会看到透明的矩形,而不是拖动时的视图视图。
有人有办法在拖动视图时获得正确的预览图像吗?
struct MainView: View {
@State var isDropTarget = false
var body: some View {
VStack{
Image(systemName: "doc.text")
.font(.system(size: 40))
.frame(width: 150, height: 150)
.onDrag { return NSItemProvider(object: "TestString" as NSString) }
Color.orange
.opacity(isDropTarget ? 0.5 : 1)
.onDrop(of: ["public.text"], isTargeted: $isDropTarget) { items in
for item in items {
if item.canLoadObject(ofClass: NSString.self) {
item.loadObject(ofClass: String.self) { str, _ in
print(str ?? "nil")
}
}
}
return true
}
}
}
虽然 iOS 15 在我的测试中没有修复这个错误,但有一个新的 API 允许您指定要显示的预览 View
:onDrag(_:preview:) .您可以重新创建被拖动的视图,在本例中是您的 Image
,用于预览。
我注意到自 iOS 13.4 以来可用的 SwiftUI 中的拖放功能存在问题。使用 .onDrag 和 .onDrop 修饰符的拖放操作在模拟器中运行良好,但在真实设备(iPhone 和 iPad)上,您只会看到透明的矩形,而不是拖动时的视图视图。
有人有办法在拖动视图时获得正确的预览图像吗?
struct MainView: View {
@State var isDropTarget = false
var body: some View {
VStack{
Image(systemName: "doc.text")
.font(.system(size: 40))
.frame(width: 150, height: 150)
.onDrag { return NSItemProvider(object: "TestString" as NSString) }
Color.orange
.opacity(isDropTarget ? 0.5 : 1)
.onDrop(of: ["public.text"], isTargeted: $isDropTarget) { items in
for item in items {
if item.canLoadObject(ofClass: NSString.self) {
item.loadObject(ofClass: String.self) { str, _ in
print(str ?? "nil")
}
}
}
return true
}
}
}
虽然 iOS 15 在我的测试中没有修复这个错误,但有一个新的 API 允许您指定要显示的预览 View
:onDrag(_:preview:) .您可以重新创建被拖动的视图,在本例中是您的 Image
,用于预览。