Swift 如何为提示从gallery或camera roll拍照的按钮创建alertview?

Swift 如何为提示从gallery或camera roll拍照的按钮创建alertview?,swift,ios9,uialertview,Swift,Ios9,Uialertview,我正在使用swift的更新版本。在ios9中,我想不支持alertview。那么,我如何实现此警报,要求从gallery或camera roll拍摄照片呢?UIAlertView仍然可以使用,但从iOS 8开始就不推荐使用。显示警报的首选方式是将UIAlertController与UIAlertControllerStyleAlert样式一起使用 import UIKit class AccountViewController: UIViewController,UINavigationCon

我正在使用swift的更新版本。在ios9中,我想不支持alertview。那么,我如何实现此警报,要求从gallery或camera roll拍摄照片呢?

UIAlertView
仍然可以使用,但从iOS 8开始就不推荐使用。显示警报的首选方式是将
UIAlertController
UIAlertControllerStyleAlert
样式一起使用

import UIKit

class AccountViewController: UIViewController,UINavigationControllerDelegate, UIImagePickerControllerDelegate {

@IBOutlet weak var imageView: UIImageView!

@IBOutlet weak var chooseButton: UIButton!

let imagePicker = UIImagePickerController()

@IBOutlet weak var mySwitch: UISwitch!
@IBOutlet weak var myStatus: UILabel!
@IBAction func mySwitchTapped(sender: AnyObject) {

 updateSwitchStatus()

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

    self.navigationController!.navigationBarHidden = true
    self.view.backgroundColor = UIColor.whiteColor()

    // Do any additional setup after loading the view.
}

override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()
    // Dispose of any resources that can be recreated.
}

func updateSwitchStatus(){

    if mySwitch.on{

        myStatus.textColor = UIColor(colorLiteralRed: 0.142, green: 0.742, blue: 0.146, alpha: 1.00)
       myStatus.text = "I'M ONLINE"

    }    
    else{

        myStatus.textColor = UIColor(colorLiteralRed: 0.896, green: 0.085, blue: 0.000, alpha: 1.00)
        myStatus.text = "I'M OFFLINE"
    }
}
@IBAction func shootPhoto() {
    imagePicker.allowsEditing = false
    imagePicker.sourceType = UIImagePickerControllerSourceType.Camera
    imagePicker.cameraCaptureMode = .Photo
    imagePicker.modalPresentationStyle = .FullScreen
    presentViewController(imagePicker,
        animated: true,
        completion: nil)
}

   @IBAction func btnClicked(){

    if (UIImagePickerController.isSourceTypeAvailable(UIImagePickerControllerSourceType.SavedPhotosAlbum)){
        print("Button capture")
        imagePicker.delegate = self
        imagePicker.sourceType = UIImagePickerControllerSourceType.SavedPhotosAlbum;
        imagePicker.allowsEditing = false

        self.presentViewController(imagePicker, animated: true, completion: nil)
    }
}

func imagePickerController(picker: UIImagePickerController, didFinishPickingImage image: UIImage, editingInfo: NSDictionary) {
    self.dismissViewControllerAnimated(true, completion: {()-> Void in

        })

    imageView.image = image

}

“图像不是从摄影机辊加载的。@阿齐莫夫我已经检查过了,应该可以工作了。”。你允许应用程序访问它吗?它正在工作。。非常感谢@azimov
    let alertController = UIAlertController(title: "Alert title", message: "Alert Message", preferredStyle: .Alert)

    let cameraRollAction = UIAlertAction(title: "Camera Roll", style: .Default) { (action) in
        self.imagePicker.delegate = self
        self.imagePicker.sourceType = UIImagePickerControllerSourceType.SavedPhotosAlbum;
        self.imagePicker.allowsEditing = false
        self.presentViewController(self.imagePicker, animated: true, completion: nil)
    }
    alertController.addAction(cameraRollAction)

    let takePictureAction = UIAlertAction(title: "Take a picture", style: .Default) { (action) in
        self.imagePicker.allowsEditing = false
        self.imagePicker.sourceType = UIImagePickerControllerSourceType.Camera
        self.imagePicker.cameraCaptureMode = .Photo
        self.imagePicker.modalPresentationStyle = .FullScreen
        self.presentViewController(self.imagePicker,
            animated: true,
            completion: nil)
    }
    alertController.addAction(takePictureAction)

    let cancelAction = UIAlertAction(title: "Cancel", style: .Cancel) { (action) in
    }
    alertController.addAction(cancelAction)

    self.presentViewController(alertController, animated: true) {
    }