前の画面のUICollectionViewでタップされた写真のデータを画面遷移先で取得し、その写真に関する情報を表示させる。
こんにちは、質問失礼致します。
現在Firebaseを使用してSNSアプリを作成しており、ユーザーによって投稿されたデータを元に写真をUICollectionViewで表示し、そのセルがタップされた時にその写真に関するデータを取得したいと考えています。
そこで質問なのですが、UICollectionViewでタップされた後の遷移先の画面でInstagramのいいねボタンの機能を実装すると考えると遷移先の画面で表示するデータは一つなのですがUITableViewを使用した方がいいのでしょうか?
この遷移先の画面を普通のUIViewControllerで実装したところ、いいねボタンをタップした時にボタンをタップしたユーザーの情報が格納される配列に格納し、すでにタップずみなら配列から削除をしていたのですが、ボタンがタップされた時に画面が更新されないので2度3度いいねが出来てしまったりという様なバグが発生してしまいました。なのでUITableViewにUIを表示してボタンがタップされる度に tableView.reloadData
で画面を更新すれば解決すると考えたのですが他にいい方法はありますでしょうか?
またUITableViewを使用して表示をした方がいいという意見であれば、どの部分で画面遷移前の画面からデータを取得して遷移後の画面でデータを表示するかの部分を教えていただけるとありがたいです。
### コード
swift
1 2import UIKit 3import Firebase 4import FirebaseAuth 5import FirebaseDatabase 6 7class SharePhotoUpViewController: UIViewController { 8 9 @IBOutlet weak var profielNameLabel: UILabel! 10 @IBOutlet weak var imageView: UIImageView! 11 @IBOutlet weak var fightButton: UIButton! 12 @IBOutlet weak var commentButton: UIButton! 13 @IBOutlet weak var dateLabel: UILabel! 14 @IBOutlet weak var moreCountLabel: UILabel! 15 @IBOutlet weak var captionTextView: UITextView! 16 // 変数photoInformationに前の画面でUICollectionViewでタップされた画像の情報を取得する 17 var photoInformation: PostData! 18 let formatter = DateFormatter() 19 var label = UILabel() 20 21 22 override func viewDidLoad() { 23 super.viewDidLoad() 24 25 label.font = UIFont.systemFont(ofSize: 20) 26 label.text = photoInformation?.name 27 28 imageView.image = photoInformation.image 29 profielNameLabel.text = photoInformation?.name 30 formatter.dateFormat = "yyyy/MM/dd HH:mm" 31 let dateString = formatter.string(from: photoInformation.date!) 32 dateLabel.text = dateString 33 captionTextView.text = "(label.text!) (photoInformation.caption!)" 34 35 if photoInformation.isLiked { 36 let buttonImage = UIImage(named: "FireWhite48.png") 37 self.fightButton.setImage(buttonImage, for: .normal) 38 } else { 39 let buttonImage = UIImage(named: "FireRed48.png") 40 self.fightButton.setImage(buttonImage, for: .normal) 41 } 42 43 // Do any additional setup after loading the view. 44 } 45 46 override func didReceiveMemoryWarning() { 47 super.didReceiveMemoryWarning() 48 // Dispose of any resources that can be recreated. 49 } 50 51 override func viewWillAppear(_ animated: Bool) { 52 self.reloadInputViews() 53 } 54 55 56 @IBAction func handleFightButton(_ sender: Any) { 57 print("DEBUG_PRINT: moreボタンがタップされました") 58 let postData = photoInformation! 59 60 // Firebaseに保存するデータの準備 61 if let uid = Auth.auth().currentUser?.uid { 62 if postData.isLiked { // isLikedには初期値でfalseが設定ずみ 63 // すでにfightをしていた場合はいいねを解除をするためにIDを削除する 64 // 変数indexにすでにいいねをしていた場合に-1をするために-1を初期化の時点で格納する 65 var index = -1 66 // for文でloopさせながらpostDataのlikesの中の値を取り出す 67 for likeID in postData.likes { 68 // もしlikesの中の値が格納されているlikeIDの中に現在ログインしているuidがあった場合 69 if likeID == uid { 70 index = postData.likes.index(of: likeID)! 71 break 72 } 73 } 74 postData.likes.remove(at: index) 75 } else { 76 // もしmoreをしていなかった場合、appendメソッドでlikesの配列の中に地震のuidを追加する 77 postData.likes.append(uid) 78 } 79 // 増えたlikesをFirebaseに保存する 80 // childメソッドでConst.PostPathを指定して、childメソッドで投稿情報のidを指定する 81 let postRef = Database.database().reference().child(Const.PostPath).child(postData.id!) 82 let likes = ["likes": postData.likes] 83 postRef.updateChildValues(likes) 84 85 } 86 } 87 88 override func prepare(for segue: UIStoryboardSegue, sender: Any?) { 89 // もしコメントボタンをタップした時はshareButtonSegueで画面遷移をする 90 if segue.identifier == "shareButtonSegue" { 91 let shareCommentViewController: ShareCommentViewController = segue.destination as! ShareCommentViewController 92 print("DEBUG_PRINT: handleCommentActionがタップされました") 93 // 画面遷移時に表示されているデータをshareCommentViewControllerの変数に格納する 94 shareCommentViewController.photoInformation = photoInformation 95 } 96 } 97 98} 99
試したこと
遷移先のUIViewControllerにUITableViewを配置し、UITableViewCellのxibファイルを作成し、 register
メソッドで呼び出し、 ViewDidLoad
メソッドでxibファイルのインスタンスを使ってUI部品に値を格納したが全てのOutlet部品にnilが入ってしまいました。
補足情報(FW/ツールのバージョンなど)
Xcode Version 9.3.1
よろしくお願い致します。
追加コード
override func viewWillDisappear(_ animated: Bool) { let postData = photoInformation! if let uid = Auth.auth().currentUser?.uid { if buttonStatus != true { print("DEBUG_PRINT: buttonStatusがtrueじゃなかったら") // 変数indexにすでにいいねをしていた場合に-1をするために-1を初期化の時点で格納する var index = -1 // for文でloopさせながらpostDataのlikesの中の値を取り出す for likeID in postData.likes { if likeID == uid { print("DEBUG_PRINT: もし配列の中に自身のuidが存在していたら削除する") index = postData.likes.index(of: likeID)! postData.likes.remove(at: index) break } else { print("DEBUG_PRINT: 配列の中に自身のuidが存在していなかったので何もしない") // ここの処理がうまくいかない } } } else { print("DEBUG_PRINT: buttonStatusがtrueだったら") for likeID in postData.likes { if likeID == uid { print("DEBUG_PRINT: もしも既に配列の中にuidが存在していたら") return } else { print("DEBUG_PRINT: 配列の中に自身のuidが存在しないので配列に追加する") postData.likes.append(uid) } } } // 増えたlikesをFirebaseに保存する // childメソッドでConst.PostPathを指定して、childメソッドで投稿情報のidを指定する let postRef = Database.database().reference().child(Const.PostPath).child(postData.id!) let likes = ["likes": postData.likes] postRef.updateChildValues(likes) } }
回答2件
あなたの回答
tips
プレビュー