Swift - 有没有办法在相机处于活动状态时呈现AlertController?

时间:2017-02-28 02:59:26

标签: ios swift swift3 uiimagepickercontroller

我使用的是Swift 3,Xcode 8.2。

我目前有一个应用程序,我让用户打开相机拍照。打开相机后,我希望在那里出现一个警告框,为用户提供一些信息。用户可以点击"完成"在控制再次返回相机之前。

这是我的代码:

func openCameraAction() {


    // Check if the camera is available on the device as a source type
    if UIImagePickerController.isSourceTypeAvailable(UIImagePickerControllerSourceType.camera) {

        // declare a variable of image picker controller
        let imagePicker = UIImagePickerController()

        // set its delegate, set its source type
        imagePicker.delegate = self
        imagePicker.sourceType = UIImagePickerControllerSourceType.camera

        // tell our image picker to not edit a captured picture
        // which means that we won’t get the black screen with
        // a square frame right after taking a photo.
        imagePicker.allowsEditing = false

        // present the camera controller, it will show up from the
        // bottom of the screen, which is the default iOS animation
        // for opening new screens.
        self.present(imagePicker, animated: true, completion: nil)


    }
}

func displayInstructions() {

    let instructionController = UIAlertController(title: "Photo Instructions", message: "Some instruction here", preferredStyle: .alert)

    let actionDone = UIAlertAction(title: "Done", style: .cancel) { (action:UIAlertAction) in
        //This is called when the user presses the done button.
        print("You've pressed the done button");
    }


    //Add the buttons
    instructionController.addAction(actionDone)

    //Present the instruction controller
    self.present(instructionController, animated: true, completion: nil)
}

我已尝试在completion中设置openCameraAction字段来调用方法displayInstruction,但很快意识到我不允许以嵌套的方式呈现内容。我相信礼物必须从根视图控制器级别发生,对吗?

  

尝试介绍......   ......他的观点不在窗口   层次!

但是,有什么办法可以达到这个效果吗?做某种嵌套礼物?

感谢您的帮助。

修改

我看了另一个问题,我仍然有点困惑。我从其他一个答案中抓取了一段代码,并且很难弄清楚如何集成到我的代码中。

        var rootViewController = UIApplication.shared.keyWindow?.rootViewController
        if let navigationController = rootViewController as? UINavigationController {
            rootViewController = navigationController.viewControllers.first
        }
        if let tabBarController = rootViewController as? UITabBarController {
            rootViewController = tabBarController.selectedViewController
        }
        rootViewController?.present(alertController, animated: true, completion: nil)

我是否将上述代码包含在openCameraActiondisplayInstruction函数中?

1 个答案:

答案 0 :(得分:1)

您必须在UIAlertController上展示UIImagePickerController。 我修改了你的代码。见下面的代码。

func openCameraAction() 
{
    // Check if the camera is available on the device as a source type
    if UIImagePickerController.isSourceTypeAvailable(UIImagePickerControllerSourceType.camera) 
    {

        // declare a variable of image picker controller
        let imagePicker = UIImagePickerController()

        // set its delegate, set its source type
        imagePicker.delegate = self
        imagePicker.sourceType = UIImagePickerControllerSourceType.camera

        // tell our image picker to not edit a captured picture
        // which means that we won’t get the black screen with
        // a square frame right after taking a photo.
        imagePicker.allowsEditing = false

        // present the camera controller, it will show up from the
        // bottom of the screen, which is the default iOS animation
        // for opening new screens.
        self.present(imagePicker, animated: true, completion: { 

          let instructionController = UIAlertController(title: "Photo Instructions", message: "Some instruction here", preferredStyle: .alert)

          let actionDone = UIAlertAction(title: "Done", style: .cancel)  {(action:UIAlertAction) in
            //This is called when the user presses the done button.
            print("You've pressed the done button");
          }

          //Add the buttons
          instructionController.addAction(actionDone)

          //Present the instruction controller
          imagePicker.present(instructionController, animated: true, completion: nil)

       })
   }
}

我试过上面的代码。它工作正常。试试吧!