Photos.frameworkでアルバムを指定して写真を保存したい
解決済
回答 1
投稿
- 評価
- クリップ 0
- VIEW 2,137
前提・実現したいこと
UIImagePickerControllerで撮影し、UITextFieldで指定したアルバムに写真を保存したいと思い、
https://iphone-app-tec.com/ios/camera.html
http://ja.stackoverflow.com/questions/17776/指定したアルバム内への画像の保存方法について
などを参考に下記のようにしてみたのですが
発生している問題・エラーメッセージ
albumChangeRequest!.addAssets([assetPlaceholder])のところにContextual type 'NSFastEnumeration' cannot be used with array literalのエラーが出て解決方法がわかりません。
該当のソースコード
import UIKit
import Photos
class ViewController: UIViewController, UIImagePickerControllerDelegate, UINavigationControllerDelegate{
@IBOutlet var cameraView : UIImageView!
@IBOutlet var btnCameraStart : UIButton!
@IBOutlet var btnSavePic : UIButton!
@IBOutlet var btnAlbum : UIButton!
@IBOutlet var titleTextField: UITextField!
@IBOutlet var label : UILabel!
override func viewDidLoad() {
super.viewDidLoad()
label.text = "Tap the [Start] to take a picture"
}
// カメラの撮影開始
@IBAction func cameraStart(_ sender : AnyObject) {
let sourceType:UIImagePickerControllerSourceType = UIImagePickerControllerSourceType.camera
// カメラが利用可能かチェック
if UIImagePickerController.isSourceTypeAvailable(UIImagePickerControllerSourceType.camera){
// インスタンスの作成
let cameraPicker = UIImagePickerController()
cameraPicker.sourceType = sourceType
cameraPicker.delegate = self
self.present(cameraPicker, animated: true, completion: nil)
}
else{
label.text = "error"
}
}
// 撮影が完了時した時に呼ばれる
func imagePickerController(_ imagePicker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : Any]) {
if let pickedImage = info[UIImagePickerControllerOriginalImage] as? UIImage {
cameraView.contentMode = .scaleAspectFit
cameraView.image = pickedImage
}
//閉じる処理
imagePicker.dismiss(animated: true, completion: nil)
label.text = "Tap the [Save] to save a picture"
}
// 撮影がキャンセルされた時に呼ばれる
func imagePickerControllerDidCancel(_ picker: UIImagePickerController) {
picker.dismiss(animated: true, completion: nil)
label.text = "Canceled"
}
// 写真を保存
@IBAction func savePic(_ sender : AnyObject) {
let image:UIImage! = cameraView.image
if image != nil {
//保存確認
let alertController: UIAlertController = UIAlertController(title: "保存確認", message: "本当に保存してよいですか?", preferredStyle: .alert)
//保存確認->cancel
let cancelAction: UIAlertAction = UIAlertAction(title: "キャンセル", style: .cancel) { action -> Void in
print("Pushed CANCEL")
}
alertController.addAction(cancelAction)
//保存確認->保存
let saveAction: UIAlertAction = UIAlertAction(title: "保存", style: .default) { action -> Void in
print("save")
//アルバム名を指定する
let albumTitle = self.titleTextField.text
var theAlbum: PHAssetCollection?
// アルバムを検索
let result =
PHAssetCollection.fetchAssetCollections(with: PHAssetCollectionType.album, subtype: PHAssetCollectionSubtype.any, options: nil)
result.enumerateObjects({(object, index, stop) in
if let theCollection = object as? PHAssetCollection,
theCollection.localizedTitle == albumTitle
{
theAlbum = theCollection
}
})
// アルバムにイメージを保存
if let anAlbum =
theAlbum {
PHPhotoLibrary.shared().performChanges({
let createAssetRequest = PHAssetChangeRequest.creationRequestForAsset(from: image!)
let assetPlaceholder = createAssetRequest.placeholderForCreatedAsset!
let albumChangeRequest = PHAssetCollectionChangeRequest(for: anAlbum)
albumChangeRequest!.addAssets([assetPlaceholder])
}, completionHandler:
nil)
print("save image into the Album.")
}
}
alertController.addAction(saveAction)
present(alertController, animated: true, completion: nil)
}
else{
label.text = "image Failed !"
}
}
// 書き込み完了結果の受け取り
func image(_ image: UIImage, didFinishSavingWithError error: NSError!, contextInfo: UnsafeMutableRawPointer) {
print("1")
if error != nil {
print(error.code)
label.text = "Save Failed !"
}
else{
label.text = "Save Succeeded"
}
}
// アルバムを表示
@IBAction func showAlbum(_ sender : AnyObject) {
let sourceType:UIImagePickerControllerSourceType = UIImagePickerControllerSourceType.photoLibrary
if UIImagePickerController.isSourceTypeAvailable(UIImagePickerControllerSourceType.photoLibrary){
// インスタンスの作成
let cameraPicker = UIImagePickerController()
cameraPicker.sourceType = sourceType
cameraPicker.delegate = self
self.present(cameraPicker, animated: true, completion: nil)
label.text = "Tap the [Start] to save a picture"
}
else{
label.text = "error"
}
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
}
試したこと
Contextual type 'NSFastEnumeration' cannot be used with array literalのエラーについて調べたのですが、エラーの意味がわからず、解決に至っていません。コードに間違っているところがあるのでしょうか。
補足情報(言語/FW/ツール等のバージョンなど)
Swift3 Xcode8.2.1です。よろしくお願いします。
-
気になる質問をクリップする
クリップした質問は、後からいつでもマイページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
クリップを取り消します
-
良い質問の評価を上げる
以下のような質問は評価を上げましょう
- 質問内容が明確
- 自分も答えを知りたい
- 質問者以外のユーザにも役立つ
評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。
質問の評価を上げたことを取り消します
-
評価を下げられる数の上限に達しました
評価を下げることができません
- 1日5回まで評価を下げられます
- 1日に1ユーザに対して2回まで評価を下げられます
質問の評価を下げる
teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。
- プログラミングに関係のない質問
- やってほしいことだけを記載した丸投げの質問
- 問題・課題が含まれていない質問
- 意図的に内容が抹消された質問
- 過去に投稿した質問と同じ内容の質問
- 広告と受け取られるような投稿
評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。
質問の評価を下げたことを取り消します
この機能は開放されていません
評価を下げる条件を満たしてません
質問の評価を下げる機能の利用条件
この機能を利用するためには、以下の事項を行う必要があります。
- 質問回答など一定の行動
-
メールアドレスの認証
メールアドレスの認証
-
質問評価に関するヘルプページの閲覧
質問評価に関するヘルプページの閲覧
checkベストアンサー
0
array literal
じゃダメ、って言ってるような気がするので、一度変数に入れてみて下さい。
let assets = [assetPlaceholder]
albumChangeRequest!.addAssets(assets)
投稿
-
回答の評価を上げる
以下のような回答は評価を上げましょう
- 正しい回答
- わかりやすい回答
- ためになる回答
評価が高い回答ほどページの上位に表示されます。
-
回答の評価を下げる
下記のような回答は推奨されていません。
- 間違っている回答
- 質問の回答になっていない投稿
- スパムや攻撃的な表現を用いた投稿
評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。
15分調べてもわからないことは、teratailで質問しよう!
- ただいまの回答率 88.22%
- 質問をまとめることで、思考を整理して素早く解決
- テンプレート機能で、簡単に質問をまとめられる
質問への追記・修正、ベストアンサー選択の依頼
fuzzball
2017/01/16 09:59
コードは ``` で囲って下さい。
dd6
2017/01/22 21:25
回答ありがとうございます。はじめての投稿でよく分かっていませんでした。