🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Swift

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

Q&A

解決済

1回答

1005閲覧

DKImagePickerで画像を複数選択後、画面表示させたい

konakizzi_mk

総合スコア21

Swift

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

0グッド

0クリップ

投稿2021/02/04 10:02

前提・実現したいこと

DKImagePickerControllerを使って複数選択後、選択した画像を表示したい。
DKImagePickerControllerこちらをローカルにcloneし実際に動作確認&ソースコードを参考し最小限の機能を実現させるため、以下のように書いてみました。しかし、選択した画像は表示されないので、何が足りていないのかご教示いただきたいです。

ソースコード

Swift

1import UIKit 2import DKImagePickerController 3 4class PictureViewController: UIViewController, UICollectionViewDelegate, UICollectionViewDataSource { 5 6 var assets:[DKAsset]? 7 8 @IBOutlet weak var collectionView: UICollectionView! 9 10 11 override func viewDidLoad() { 12 super.viewDidLoad() 13 } 14 @IBAction func tapButton(_ sender: Any) { 15 let pickerController = DKImagePickerController() 16 pickerController.didSelectAssets = { [unowned self] (assets: [DKAsset]) in 17 self.updateAssets(assets: assets) 18 } 19 present(pickerController, animated: true, completion: nil) 20 } 21 func updateAssets(assets:[DKAsset]){ 22 self.assets = assets 23 self.collectionView.reloadData() 24 } 25 26 func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int { 27 return self.assets!.count ?? 0 28 } 29 30 func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell { 31 let asset = self.assets![indexPath.row] 32 var cell: UICollectionViewCell? 33 var imageView: UIImageView? 34 35 if asset.type == .photo { 36 cell = collectionView.dequeueReusableCell(withReuseIdentifier: "CellImage", for: indexPath) 37 imageView = cell?.contentView.viewWithTag(1) as? UIImageView 38 } 39 if let cell = cell, let imageView = imageView { 40 let layout = collectionView.collectionViewLayout as! UICollectionViewFlowLayout 41 let tag = indexPath.row + 1 42 cell.tag = tag 43 asset.fetchImage(with: layout.itemSize.toPixel(), completeBlock: { image, info in 44 if cell.tag == tag { 45 imageView.image = image 46 } 47 }) 48 } 49 return cell! 50 } 51 52}

補足情報(FW/ツールのバージョンなど)

Xcode 12.4

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

要因として一番考えられるのは、

Swift

1 override func viewDidLoad() { 2 super.viewDidLoad() 3 collectionView.dataSource = self 4 }

のように、collectionView.dataSource が設定されてないパターンだと思います。
StoryBoard でも設定可能で、その場合はコードで記述する必要はないのですが、もし設定していないのであればどちらかの方法で設定する必要があります。

ちなみに、DataSource が正しく設定されていれば、

Swift

1 func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int { 2 return self.assets!.count ?? 0 3 }

の部分で実行時エラーとなって落ちると思います(そもそも、コンパイル以前に該当行に黄色い Warning が出るはずです)。

ここは、正しくは

Swift

1 func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int { 2 return self.assets?.count ?? 0 3 }

となります。

これらを設定しても表示されないのであれば、CollectionView Cell に UIImageView を載せていない上、tag1 に設定していない可能性があるかと思います。

このあたりをチェックされてはいかがでしょうか。

投稿2021/02/05 04:26

TsukubaDepot

総合スコア5086

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

konakizzi_mk

2021/02/05 04:51

回答ありがとうございます! "collectionView.dataSource = self "の1行を追加しただけで、画像表示できました! フワッとしか理解できていないので、もう少しソースコード解析していきます、今後とも何卒よろしくお願い致します????‍♀️
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問