質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.52%

  • Swift

    7221questions

    Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

  • Swift 2

    1331questions

    Swift 2は、Apple社が独自に開発を行っている言語「Swift」のアップグレード版です。iOSやOS X、さらにLinuxにも対応可能です。また、throws-catchベースのエラーハンドリングが追加されています。

Photos.frameworkでアルバムを指定して写真を保存したい

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 1,008

dd6

score 8

前提・実現したいこと

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ページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • fuzzball

    2017/01/16 09:59

    コードは ``` で囲って下さい。

    キャンセル

  • dd6

    2017/01/22 21:25

    回答ありがとうございます。はじめての投稿でよく分かっていませんでした。

    キャンセル

回答 1

checkベストアンサー

0

array literalじゃダメ、って言ってるような気がするので、一度変数に入れてみて下さい。

let assets = [assetPlaceholder]
albumChangeRequest!.addAssets(assets)

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/01/22 21:29

    回答ありがとうございます。
    albumChangeRequest!.addAssets()は[assetPlaceholder]の配列のままではダメなんですね。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.52%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

  • 受付中

    iosアプリ開発(Swift使用)について質問です。

    アプリ上で携帯端末内に保存されている画像一覧を開いてそれを選択した時に、その画像のURL(sample.png的な)を取得する方法を教えてください。

  • 解決済

    NSUserDefaultに画像を格納したいのですができません・

    テキストデータはNSUserDefaultに格納できたのですが、画像ができません。 画像をライブラリーから選択して、指定のimageviewに表示させることはできました。

  • 解決済

    [swift]画像アップロードについて

    こんばんは。 現在簡単な画像アップロードアプリを作成しようと考えております。 先に画像アップロード部分のみを実装したいと考えており、参考サイトより作業しているのですが、use 

  • 解決済

    swiftにて画像アップロード(サーバ上へ)

    以前に質問した内容に近いのですが、またご教授いただければ幸いです。 下記のサイトを参考にしながら、ファイルのアップロードをしたいと考えております。 【Swift】Swift

  • 解決済

    Swiftでの画面遷移について

    イタリックテキストいつもお世話になっております。 Swift3での画面遷移でうまく動かないので質問させてください。 やりたいことは、Photoボタンが押された後にUIIma

  • 解決済

    tableview section でエラー

    コードimport UIKit class ViewController: UIViewController, UITableViewDelegate, UITableViewD

  • 解決済

    signal SIGABRT

    import UIKit import CoreData class ViewController: UIViewController, UITableViewDataSourc

  • 受付中

    カメラアクセスと写真のアップロードができない

    作ったアプリでカメラアクセスと写真のアップロードができません。 Xcodeから自分のiPhoneでエミュレータを起動したのですが Camera access ボタンとPhoto

同じタグがついた質問を見る

  • Swift

    7221questions

    Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

  • Swift 2

    1331questions

    Swift 2は、Apple社が独自に開発を行っている言語「Swift」のアップグレード版です。iOSやOS X、さらにLinuxにも対応可能です。また、throws-catchベースのエラーハンドリングが追加されています。