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

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

新規登録して質問してみよう
ただいま回答率
85.47%
Firebase

Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Swift

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

iPhone

iPhoneとは、アップル社が開発・販売しているスマートフォンです。 同社のデジタルオーディオプレーヤーiPodの機能、電話機能、インターネットやメールなどのWeb通信機能の3つをドッキングした機器です。

Q&A

解決済

1回答

895閲覧

collecitomViewでアプリを立ち上げたときだけcellが表示されない

daimyon

総合スコア3

Firebase

Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Swift

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

iPhone

iPhoneとは、アップル社が開発・販売しているスマートフォンです。 同社のデジタルオーディオプレーヤーiPodの機能、電話機能、インターネットやメールなどのWeb通信機能の3つをドッキングした機器です。

0グッド

0クリップ

投稿2021/04/20 14:28

前提・実現したいこと

collectionViewを使ったアプリで、アプリを立ち上げたときだけcellが表示されません。
ほかの画面に遷移してから戻ると表示されます。

該当のソースコード

Swift

1import UIKit 2import FirebaseAuth 3import FirebaseFirestore 4import PKHUD 5 6class ViewController: UIViewController { 7 8 private var user: User? 9 private var tickets = [Ticket]() 10 let cellId = "ticketCellId" 11 12 @IBOutlet weak var headerLabel: UILabel! 13 @IBOutlet weak var headerView: UIView! 14 @IBOutlet weak var ticketCollectionView: UICollectionView! 15 @IBOutlet weak var addTicketButton: UIButton! 16 17 override func viewDidLoad() { 18 super.viewDidLoad() 19 20 setupLayout() 21 22 } 23 24 private func setupLayout() { 25 view.backgroundColor = UIColor(red: 241/255, green: 243/255, blue: 246/255, alpha: 1.0) 26 27 addTicketButton.tintColor = .red 28 addTicketButton.setTitle("", for: .normal) 29 addTicketButton.setImage(UIImage(systemName: "rectangle.badge.plus"), for: .normal) 30 addTicketButton.addTarget(self, action: #selector(tappedAddTicketButton), for: .touchUpInside) 31 32 headerView.backgroundColor = UIColor(red: 241/255, green: 243/255, blue: 246/255, alpha: 1.0) 33 34 ticketCollectionView.dataSource = self 35 ticketCollectionView.delegate = self 36 ticketCollectionView.register(UINib(nibName: "TicketCell", bundle: nil), forCellWithReuseIdentifier: cellId) 37 } 38 39 override func viewWillAppear(_ animated: Bool) { 40 super.viewWillAppear(animated) 41 42 guard let uid = Auth.auth().currentUser?.uid else { return } 43 Firestore.fetchUserFromFirestore(uid: uid) { (user) in 44 if let user = user { 45 self.user = user 46 self.headerLabel.text = "(user.name)のチケット" 47 } 48 } 49 fetchTickets() 50 ticketCollectionView.reloadData() 51 } 52 53 @objc private func tappedAddTicketButton() { 54 55 if Auth.auth().currentUser?.uid == nil { 56 let storybord: UIStoryboard = UIStoryboard(name: "Register", bundle: nil) 57 let vc = storybord.instantiateViewController(withIdentifier: "Register") as! RegisterViewController 58 let nav = UINavigationController(rootViewController: vc) 59 nav.modalPresentationStyle = .fullScreen 60 self.present(nav, animated: true, completion: nil) 61 } else { 62 let nextStoryboad: UIStoryboard = UIStoryboard(name: "AddTicket", bundle: nil) 63 let AddTicketController = nextStoryboad.instantiateViewController(withIdentifier: "AddTicket") as! AddTicketViewController 64 self.present(AddTicketController, animated: true, completion: nil) 65 } 66 } 67 68 private func fetchTickets() { 69 guard let uid = Auth.auth().currentUser?.uid else { return } 70 Firestore.fetchTicketFromFirebase(uid: uid) { (tickets) in 71 self.tickets = tickets 72 print("チケットの取得に成功") 73 } 74 } 75 76} 77 78extension ViewController: UICollectionViewDelegate, UICollectionViewDataSource, UICollectionViewDelegateFlowLayout { 79 func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int { 80 return tickets.count 81 } 82 83 func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell { 84 let cell = ticketCollectionView.dequeueReusableCell(withReuseIdentifier: cellId, for: indexPath) as! TicketCell 85 cell.layer.cornerRadius = 15 86 cell.backgroundColor = .white 87 cell.ticketItem = tickets[indexPath.row] 88 return cell 89 } 90 91 func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize { 92 let horizontalSpace: CGFloat = 30 93 let cellSize: CGFloat = self.view.frame.width / 2 - horizontalSpace 94 return .init(width: cellSize, height: cellSize * 1.2) 95 } 96}

試したこと

cellのカウントのところを数字にしたら表示されました。
tickets.countにすると表示されません。

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

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

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

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

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

daigakuse-

2021/04/20 14:59

tickets.count が0ではないことを確認済み前提のお話でよろしいでしょうか?
daimyon

2021/04/20 15:59

はい。0でないことは確認しています。
hoshi-takanori

2021/04/20 20:44

fetchTickets のコールバックは非同期で呼ばれるので、fetchTickets を呼んだ直後に reliadData しても意味なくて、コールバックの中で呼べば良いのでは。
tomato879241

2021/04/20 22:14

Completion blockを使って、データを全て読み終わった後でCollectionViewを更新する必要があります。
daigakuse-

2021/04/22 03:54

tickets.countが0ではないことを確認済みでしたら、上記2名の方がおっしゃられてる通りだと思います。 print("チケットの取得に成功") の下でtableviewをリロードしてあげれば表示されると思います! 何故そうなるのかは、swiftの非同期処理について調べれば答えは出てくるかと思います!
daimyon

2021/04/22 12:53

無事解決しました! ありがとうございます!
guest

回答1

0

自己解決

print("チケットの取得に成功")
の下でtableviewをリロードしたところ解決しました。

投稿2021/04/22 12:53

daimyon

総合スコア3

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問