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

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

ただいまの
回答率

87.79%

UICollectionViewDelegateFlowLayoutの関数が呼び出されない

解決済

回答 1

投稿

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

score 51

UICollectionViewDelegateFlowLayoutの下記の関数が呼び出されず困っています。
delegate,dataSouce をselfにしregisterも入れているのになぜ呼ばれないのでしょうか?
3日以上悩んでいます。。。お力を貸してください。よろしくお願いします。

func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize {
//呼び出されない
        return CGSize(width: collectionView.frame.width, height: 60)
    }
    override func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
        let cell = collectionView.dequeueReusableCell(withReuseIdentifier: reuseIdentifier, for: indexPath) as! CommentCell
//呼び出されない    
        print(cell)
        return cell
    }


上記二つの関数のファイル全体です。
CommentVC.swift

import UIKit
import Firebase

private let reuseIdentifier = "CommentCell"

class CommentVC:UICollectionViewController,UICollectionViewDelegateFlowLayout{
    //MARK: - properties

    override func viewDidLoad() {
        super.viewDidLoad()

        //
        self.collectionView.delegate = self
        self.collectionView.dataSource = self

        //background color
        collectionView.backgroundColor = .white
        //navigation title
        navigationItem.title = "Comment"
        //register cell class
        collectionView?.register(CommentCell.self, forCellWithReuseIdentifier: reuseIdentifier)
        print("view did load")
    }
    // MARK: - UICollectionView

    func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize {
//呼ばれない
        return CGSize(width: collectionView.frame.width, height: 60)
    }

    override func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
//呼び出される
        return 5
    }

    override func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
        let cell = collectionView.dequeueReusableCell(withReuseIdentifier: reuseIdentifier, for: indexPath) as! CommentCell
 //呼ばれない  
        print(cell)
        return cell
    }  
}


CommentCell.swift

import UIKit

class CommentCell: UICollectionViewCell {


    let profileImageView:CustomImageView = {
        let iv = CustomImageView()
        iv.contentMode = .scaleAspectFit
        iv.clipsToBounds = true
        iv.backgroundColor = .lightGray
        return iv
    }()

    let commentLabel:UILabel = {
        let label = UILabel()
        //NSAttributedString とは、 UILabel や UITextField のテキスト(文字列)を装飾す
        let attributedText = NSMutableAttributedString(string: "name", attributes: [NSAttributedString.Key.font :UIFont.boldSystemFont(ofSize: 12)])

        attributedText.append(NSAttributedString(string: "some test comment", attributes: [
        NSAttributedString.Key.font :UIFont.systemFont(ofSize: 12)]))

        label.attributedText = attributedText

    return label
    }()


        // MARK: - Init

        override init(frame: CGRect) {
            super.init(frame: frame)
            print("conmment cell")

            addSubview(profileImageView)
            profileImageView.anchor(top: nil, left: leftAnchor, bottom: nil, right: nil, paddingTop: 0, paddingLeft: 8, paddingBottom: 0, paddingRight: 0, width: 48, height: 48)
            profileImageView.centerYAnchor.constraint(equalTo: self.centerYAnchor).isActive = true
            profileImageView.layer.cornerRadius = 48 / 2


            addSubview(commentLabel)
            commentLabel.anchor(top: nil, left: profileImageView.rightAnchor, bottom: nil, right: rightAnchor, paddingTop: 0, paddingLeft: 8, paddingBottom: 0, paddingRight: 8, width: 0, height: 0)
             commentLabel.centerYAnchor.constraint(equalTo: self.centerYAnchor).isActive = true
        }

    required init?(coder aDecoder: NSCoder) {
    fatalError("init(coder:) has not been implemented")
    }

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • 退会済みユーザー

    退会済みユーザー

    2019/09/06 22:27 編集

    UICollectionViewDelegateFlowLayoutのデリゲート先は設定してますか?
    と思ったら、collectionViewControllerですねこれ、

    キャンセル

  • yasumaro

    2019/09/07 00:11

    はい。そうです。

    キャンセル

回答 1

check解決した方法

0

collectionViewをUICollectionViewFlowLayout()で初期化していないのが原因でした。
他のviewControllerでタップ時にinstanceを生成しnavigationコントローラーで遷移する仕様でした。

 func handleCommentTapped(for cell: FeedCell) {
//ここがUICollectionViewFlowLayout()ではなくUICollectionViewLayout()になっていましたorz
        let commentVC = CommentVC(collectionViewLayout:UICollectionViewFlowLayout())
        navigationController?.pushViewController(commentVC, animated: true)

    }

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

関連した質問

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