在设备上 运行 时,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 允许您指定要显示的预览 ViewonDrag(_:preview:) .您可以重新创建被拖动的视图,在本例中是您的 Image,用于预览。