相机照片选择不适用于Swift

时间:2017-01-19 20:09:53

标签: ios swift function camera uiimagepickercontroller

当用户拍摄照片并点击使用照片按钮时,为什么不调用第二个功能?该视图被驳回,但打印语句不起作用且函数未被调用。

@IBAction func openCamera(_ sender: UIBarButtonItem)
    {
        if UIImagePickerController.isSourceTypeAvailable(UIImagePickerControllerSourceType.camera) {
            let imagePicker = UIImagePickerController()
            imagePicker.delegate = self
            imagePicker.sourceType = UIImagePickerControllerSourceType.camera;
            imagePicker.allowsEditing = false
            self.present(imagePicker, animated: true, completion: nil)
        }
    }

func imagePickerController(picker: UIImagePickerController, didFinishPickingImage image: UIImage!, editingInfo: [NSObject : AnyObject]!) {
        print("made it")
        createImage(image: image)
        self.dismiss(animated: true, completion: nil);
    }

1 个答案:

答案 0 :(得分:1)

使用Swift 3,这就是我所拥有的。我的代码意味着有(1)一个选择视图控制器,它使用UIImagePickerController来使用相机或从相机胶卷中选择,然后(2)编辑视图控制器的续集我删除了按钮的代码,如我没有使用IB。

class SelectViewController: UIViewController {

    // selection and pass to editor

    let picker = ImagePickerController()
    var image = UIImage()

    override func viewDidLoad() {
        super.viewDidLoad()
        picker.delegate = self
    }

extension SelectViewController: UIImagePickerControllerDelegate, UINavigationControllerDelegate {

    // MARK: Camera App

    func openCameraApp() {
        if UIImagePickerController.availableCaptureModes(for: .rear) != nil {
            picker.allowsEditing = false
            picker.sourceType = UIImagePickerControllerSourceType.camera
            picker.cameraCaptureMode = .photo
            picker.modalPresentationStyle = .fullScreen
            present(picker,
                    animated: true,
                    completion: nil)
        } else {
            noCamera()
        }
    }
    func noCamera(){
        let alertVC = UIAlertController(
            title: "No Camera",
            message: "Sorry, this device has no camera",
            preferredStyle: .alert)
        let okAction = UIAlertAction(
            title: "OK",
            style:.default,
            handler: nil)
        alertVC.addAction(okAction)
        present(
            alertVC,
            animated: true,
            completion: nil)
    }

    // MARK: Photos Albums

    func showImagePicker() {
        picker.allowsEditing = false
        picker.sourceType = .photoLibrary
        present(picker,
                animated: true,
                completion: nil)
        picker.popoverPresentationController?.sourceView = self.view
    }
    func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : Any]) {
        let chosenImage = info[UIImagePickerControllerOriginalImage] as! UIImage
        image = chosenImage
        self.performSegue(withIdentifier: "ShowEditView", sender: self)
        dismiss(animated: true, completion: nil)
    }
    func imagePickerControllerDidCancel(_ picker: UIImagePickerController) {
        dismiss(animated: false, completion: nil)
    }

    // MARK: Seque to EditViewController

    override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
        if segue.identifier == "ShowEditView" {
            if let vc = segue.destination as? EditViewController {
                vc.image = image
            }
        }
    }

}

如果您没有转到另一个VC,请删除 .performSegue 调用以及最终MARK:符号下面的代码。 (相机/所选图像位于图像 var。)