我正在使用以下代码段来显示默认值UIImagePickerController,但似乎iOS 13下拉关闭手势不适用于UIImagePickerController包裹在SwiftUI视图中,用户仍然可以Cancel按顺序点击默认选项卡栏项目要关闭选择器,代码:
struct ContentView: View {
@State private var showModal = false
var body: some View {
Text("Tap To show modal")
.padding()
.onTapGesture {
self.showModal.toggle()
}
.sheet(isPresented: $showModal) {
SomeUIKitView()
}
}
}
final class SomeUIKitViewControllerWrapper: UIViewControllerRepresentable {
typealias UIViewControllerType = UIImagePickerController
func makeUIViewController(context: Context) -> UIImagePickerController {
let imagePicker = UIImagePickerController()
imagePicker.sourceType = UIImagePickerController.SourceType.photoLibrary
return imagePicker
}
func updateUIViewController(_ uiViewController: UIImagePickerController, context: Context) {}
}
struct SomeUIKitView: View {
var body: some View {
SomeUIKitViewControllerWrapper()
}
}
Run Code Online (Sandbox Code Playgroud)
您可以在 SwiftUI 中构建自己的拖动。在您的情况下,您可以尝试为您的 SomeUIKitView() 视图实现它。
import SwiftUI
struct SwiftUIDragDown: View {
@State private var dragDownTreshhold: CGFloat = 50
@State private var draggedDistance: CGFloat = 0
@State private var dragDownOffsetY: CGFloat = 0
var body: some View {
Text("Drag me")
.offset(x: 0, y: dragDownOffsetY + draggedDistance)
.animation(.easeInOut(duration: 0.3))
.gesture(
DragGesture(minimumDistance: 10)
.onChanged { value in
print("dragged by" , value.translation.height)
self.draggedDistance = value.translation.height
}
.onEnded { _ in
if self.draggedDistance > self.dragDownTreshhold {
self.dragDownOffsetY = 600
} else {
self.draggedDistance = 0
self.dragDownOffsetY = 0
}
}
)
}
}
struct SwiftUIDragDown_Previews: PreviewProvider {
static var previews: some View {
SwiftUIDragDown()
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
365 次 |
| 最近记录: |