###前提・実現したいこと
UIPickerView
とUIAlertAction
を利用して、画像をサーバーにアップロードする仕組みを作っています。
そこでまずライブラリとカメラで撮影したものをUIImageView
に表示するものを作りました。
カメラ撮影したものはカメラロールに保存しようと思いコードを書いたのですが、
このままではライブラリから読み込んだものも再度保存してしまいます。
カメラで撮影したものとライブラリで選択したものを区別する方法
もしくは別の保存方法についてご教授願いたいです。
###画像の選択後のコード(抜粋)
Swift
1func imagePickerController(picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : AnyObject]) { 2 let image = info[UIImagePickerControllerOriginalImage] 3 imageView.image = image as? UIImage 4 UIImageWriteToSavedPhotosAlbum((image as? UIImage)!, nil, nil, nil) 5 imagePicker.dismissViewControllerAnimated(true, completion: nil) 6 }
###コード全文
Swift
1import UIKit 2 3class ViewController: UIViewController, UIImagePickerControllerDelegate, UINavigationControllerDelegate { 4 5 @IBOutlet weak var imageView: UIImageView! 6 7 private var imagePicker = UIImagePickerController() 8 9 override func viewDidLoad() { 10 super.viewDidLoad() 11 12 imagePicker.delegate = self 13 imagePicker.allowsEditing = false 14 } 15 16 override func didReceiveMemoryWarning() { 17 super.didReceiveMemoryWarning() 18 // Dispose of any resources that can be recreated. 19 } 20 21 func imagePickerController(picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : AnyObject]) { 22 let image = info[UIImagePickerControllerOriginalImage] 23 imageView.image = image as? UIImage 24 UIImageWriteToSavedPhotosAlbum((image as? UIImage)!, nil, nil, nil) 25 imagePicker.dismissViewControllerAnimated(true, completion: nil) 26 } 27 28 @IBAction func picturePicker(sender: UIButton) { 29 let alert: UIAlertController = UIAlertController(title: nil, message: nil, preferredStyle: UIAlertControllerStyle.ActionSheet) 30 let picker: UIAlertAction = UIAlertAction(title: "ライブラリから選択", style: UIAlertActionStyle.Default, handler: { 31 (action: UIAlertAction!) -> Void in 32 self.selectPicker() 33 }) 34 let camera: UIAlertAction = UIAlertAction(title: "カメラで撮影", style: UIAlertActionStyle.Default, handler: { 35 (action: UIAlertAction!) -> Void in 36 self.takePicture() 37 }) 38 let cancel: UIAlertAction = UIAlertAction(title: "キャンセル", style: UIAlertActionStyle.Cancel, handler: nil) 39 alert.addAction(picker) 40 alert.addAction(camera) 41 alert.addAction(cancel) 42 43 presentViewController(alert, animated: true, completion: nil) 44 } 45 46 func selectPicker() { 47 if UIImagePickerController.isSourceTypeAvailable(UIImagePickerControllerSourceType.PhotoLibrary) { 48 imagePicker.sourceType = UIImagePickerControllerSourceType.PhotoLibrary 49 self.presentViewController(imagePicker, animated: true, completion: nil) 50 } 51 } 52 53 func takePicture() { 54 if UIImagePickerController.isSourceTypeAvailable(UIImagePickerControllerSourceType.Camera) { 55 imagePicker.sourceType = UIImagePickerControllerSourceType.Camera 56 self.presentViewController(imagePicker, animated: true, completion: nil) 57 } 58 } 59 60}
###試したこと
didFinishPickingMediaWithInfo
のinfo
の中身を見てみたのですが、
特段区別ができるものは見当たりませんでした。
###補足情報(言語/FW/ツール等のバージョンなど)
・Xcode7.3.1
・Swift2.2
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。