我使用的是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)
我是否将上述代码包含在openCameraAction
或displayInstruction
函数中?
答案 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)
})
}
}
我试过上面的代码。它工作正常。试试吧!