Dismissing of UIImagePickerController dismisses presenting view controller also

百般思念 提交于 2020-01-01 02:44:28

问题


I am working on a project that uses tabbar system. One of the item of tabbar is JobPostingViewController. I Embed it in UINavigationController. There is a UIButton called add new job in this view controller .I implemented pushviewcontroller to go CreateJobPostViewController. There I need to add UIImagePickerController to choose the image. When i tap done button or choose an image from library it dismisses to JobPostingViewController. But it should go to the CreateJobPostViewController. Any one please help me. Thanks in advance.

You can see the issue here:

Code in JobPostingViewController

 @IBAction func openCreateJob(sender: AnyObject) {
    let vc = self.storyboard?.instantiateViewControllerWithIdentifier("CreateJobPostViewController") as! CreateJobPostViewController
    self.navigationController?.pushViewController(vc, animated: true)
}

Code in CreateJobPostViewController

   @IBAction func addImages(sender: AnyObject) {
    imagePicker.allowsEditing = false
    imagePicker.sourceType = .PhotoLibrary
    presentViewController(imagePicker, animated: true, completion: nil)
}
func imagePickerController(picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : AnyObject]) {
    picker.dismissViewControllerAnimated(true, completion: nil)
}
func imagePickerControllerDidCancel(picker: UIImagePickerController) {
    picker.dismissViewControllerAnimated(true, completion: nil)
}

回答1:


Adding Picker as subview

try to add the imagepicker as a subview to your CreateJobPostViewController insted of presenting it and then remove it from parent in the delegtes

@IBAction func openCreateJob(sender: AnyObject) {

var picker: UIImagePickerController = UIImagePickerController()
picker.delegate = self
picker.allowsEditing = false
picker.sourceType = .PhotoLibrary
self.addChildViewController(picker)
picker.didMoveToParentViewController(self)
self.view!.addSubview(picker.view!)
}

and then

 func imagePickerControllerDidCancel(picker: UIImagePickerController) {

    picker.view!.removeFromSuperview()
    picker.removeFromParentViewController()
    }

For presenting

showing picker over currentcontext with options like edit cancel choose,

use picker.modalPresentationStyle = .overCurrentContext //before presenting it

 presentViewController(picker, animated: true, completion: nil)



回答2:


Fixed the issue by setting the image picker's modalPresentationStyle to "OverCurrentContext":

picker.modalPresentationStyle = .overCurrentContext



回答3:


You could use:

picker.modalPresentationStyle = .overCurrentContext

but depending on your screen layout, it may be better to use:

picker.modalPresentationStyle = .overFullScreen

otherwise your "cancel", "retake" and "use photo" buttons may not be visible.




回答4:


I had this same problem, I solved it using the storyboard (Xcode v9.2)

1 - Go to the storyboard, where is your ViewController, select it

2 - Set Presentation as: Current Context

Note: If it does not work Current Context, select Over Current Context



来源:https://stackoverflow.com/questions/38167027/dismissing-of-uiimagepickercontroller-dismisses-presenting-view-controller-also

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!