Não tenho certeza se esse é um problema específico do SwiftUI. De qualquer forma, eu tenho um UIImagePickerController que implementei em uma exibição SwiftUI usando o UIViewControllerRepresentableProtocol:
struct ContentView: View {
@State var showCameraView = false
@State var showImagePicker = false
@State var UserImage = Image("user")
var body: some View {
VStack {
UserImage
.resizable()
.frame(width: 200, height: 200)
.scaledToFit()
.background(Color.gray)
.cornerRadius(200)
.clipped()
Button(action: {self.showImagePicker = true}) {
Text("Choose from camera roll")
}
.padding(.top, 10)
}
.sheet(isPresented: $showImagePicker) {
ImagePicker(showImagePicker: self.$showImagePicker, pickedImage: self.$UserImage)
}
}
}
struct ImagePicker: UIViewControllerRepresentable {
@Binding var showImagePicker: Bool
@Binding var pickedImage: Image
func makeCoordinator() -> ImagePicker.Coordinator {
Coordinator(self)
}
func makeUIViewController(context: UIViewControllerRepresentableContext<ImagePicker>) -> UIImagePickerController {
let imagePicker = UIImagePickerController()
imagePicker.delegate = context.coordinator
return imagePicker
}
func updateUIViewController(_ uiViewController: UIImagePickerController, context: UIViewControllerRepresentableContext<ImagePicker>) {
return
}
class Coordinator: NSObject, UIImagePickerControllerDelegate, UINavigationControllerDelegate {
var parent: ImagePicker
init(_ imagePicker: ImagePicker) {
self.parent = imagePicker
}
func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [UIImagePickerController.InfoKey : Any]) {
let uiImage = info[UIImagePickerController.InfoKey.originalImage] as! UIImage
parent.pickedImage = Image(uiImage: uiImage)
parent.showImagePicker = false
}
func imagePickerControllerDidCancel(_ picker: UIImagePickerController) {
parent.showImagePicker = false
}
}
}
Funciona bem ao escolher imagens que não são capturadas pela câmera do dispositivo. No entanto, toda vez que eu escolho uma imagem que foi tirada pela própria câmera, parece que o modificador .aspectRatio não é aplicado porque as dimensões da imagem carregada estão distorcidas nesse caso. Alguém vê algo errado no meu código ou conhece uma solução?
Teve o mesmo problema. Usei uma versão modificada da proposta por @ninjahamster, onde simplesmente não redimensionei a imagem. Qualquer outra solução é bem-vinda.
fonte
Eu encontrei o mesmo problema. Eu não sabia que faltava o SwiftUI !! Agora apliquei a solução alternativa do ninjahamster.
Meu código aqui, caso alguém precise de alguma referência. Veja as alterações em func
didFinishPickingMediaWithInfo
.fonte