Средство выбора изображений не обрезает изображение для меня правильно (быстро) (firebase) - PullRequest
0 голосов
/ 26 мая 2020

У меня есть средство выбора изображений, и после выбора изображения оно должно быть загружено в мое хранилище Firebase. Теперь у меня одна проблема: почему-то все изображения не обрезаются правильно.

Я потерял какой-то код, потому что это единственное, о чем я мог подумать, поскольку я уже получил picker.allowsEditing = true

Картинка загружается правильно, но не так, как я собирался ее обрезать. Появляется "окно обрезки", но оно не сохраняется должным образом.

Вот мой код:

import UIKit
import Firebase

class editViewController: UIViewController  {

    @IBOutlet var pfp: UIImageView!

    var fireImage: UIImage? = nil

    override func viewDidLoad() {
        super.viewDidLoad()
        setupPfp()
    }

    func setupPfp(){
        pfp.layer.cornerRadius = pfp.frame.height/2
        pfp.clipsToBounds = true
        pfp.isUserInteractionEnabled = true
        let tapGesture = UITapGestureRecognizer(target: self, action: #selector(presentPicker))
        pfp.addGestureRecognizer(tapGesture)
    }

    @objc func presentPicker(){
        let picker = UIImagePickerController()
        picker.sourceType = .photoLibrary
        picker.allowsEditing = true
        picker.delegate = self
        self.present(picker, animated: true, completion: nil)

    }

    func uploadToFirebase(){

        guard let imageSelected = self.fireImage else {
            print("Image is nil")
            return
        }

        guard let imageData = imageSelected.jpegData(compressionQuality: 0.5) else {
            return
        }

        let storageRef = Storage.storage().reference(forURL: "gs://lidjd-9dad5.appspot.com")
        let storageProfileRef = storageRef.child("profileImages").child(Auth.auth().currentUser!.uid)
        let metadata = StorageMetadata()
        let db = Firestore.firestore()
        let userID = Auth.auth().currentUser!.uid
        let docRef = db.collection("users").document(userID)
        metadata.contentType = "image/jpeg"
        storageProfileRef.putData(imageData, metadata: metadata) { (storageMetaData, error) in
            if error != nil{
                print(error!.localizedDescription)
                return
            }
            storageProfileRef.downloadURL { (url, error) in
                if let metaImageUrl = url?.absoluteString{
                    print(metaImageUrl)
                    docRef.updateData([
                        "profileimage": metaImageUrl
                    ]){ err in
                    if let err = err {
                        print("Error updating document: \(err)")
                    } else {
                        print("Profile Image successfully updated")
                        }}
                }
            }
        }


    }

}

extension editViewController: UIImagePickerControllerDelegate, UINavigationControllerDelegate{

    func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [UIImagePickerController.InfoKey : Any]) {
        if let imageSelected = info[UIImagePickerController.InfoKey.editedImage] as? UIImage {
            fireImage = imageSelected
            pfp.image = imageSelected
        }

        if let imageOriginal = info[UIImagePickerController.InfoKey.originalImage] as? UIImage {
            fireImage = imageOriginal
            pfp.image = imageOriginal
        }

        picker.dismiss(animated: true, completion: nil)
        uploadToFirebase()

    }

}

1 Ответ

2 голосов
/ 26 мая 2020

Выберите один из них .. в вашем текущем коде вы всегда используете исходное изображение

  extension editViewController: UIImagePickerControllerDelegate, UINavigationControllerDelegate{

        func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [UIImagePickerController.InfoKey : Any]) {
            if let imageSelected = info[UIImagePickerController.InfoKey.editedImage] as? UIImage {
                fireImage = imageSelected
                pfp.image = imageSelected
            }

            else if let imageOriginal = info[UIImagePickerController.InfoKey.originalImage] as? UIImage {
                fireImage = imageOriginal
                pfp.image = imageOriginal
            }

            picker.dismiss(animated: true, completion: nil)
            uploadToFirebase()

        }

    }
...