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

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

ただいまの
回答率

88.92%

RealmSwiftでindexPath.rowを使いたい

解決済

回答 1

投稿

  • 評価
  • クリップ 1
  • VIEW 207

kururinnya

score 25

ツイートしてある数だけ表示したいです。
タイトルの通り、indexPath.rowを使いたいのですが、
Results<Tweet>?にはクラスや構造体があるので、.selfを付けなければならないと知りました。
こうすると、メタタイプとなってしまい、

Value of type 'Results<Tweet>?.Type' has no subscripts

と出ました。as? Results<Tweet>? としてもダメでした。

let tweetObject = type(of: tweets[indexPath.row])

type(of:)を使ってみても、

Expression type '(_) -> _' is ambiguous without more context

と出てしまいました。

.selfを付けなかったUser作成のときは簡単にできたのですが、構造体や、enumを使うと、どうしても.Typeとなってしまい、
コンパイルができません。

オブジェクトを引き出して表示したいだけなのですが、キャストしてもResult<Tweet>.Typeと出て、完全にお手上げです。

どなたか対処法をご存知の方、どうかご教授よろしくお願いします。

   private var user: Results<User>!
    private var tweets = Results<Tweet>?.self {
        didSet { collectionView.reloadData() }
    }

    init(user: Results<User>!) {
        self.user = user
        super.init(collectionViewLayout: UICollectionViewFlowLayout())
    }
override func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
        let realm = try! Realm()
        let tweetObject = realm.objects(Tweet.self)
        return tweetObject.count
    }

    override func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
        let cell = collectionView.dequeueReusableCell(withReuseIdentifier: reuseIdentifier, for: indexPath) as! TweetCell
        let tweetObject = tweets[indexPath.row]
        cell.tweets = tweetObject
        return cell
    }
class User: Object {

    @objc dynamic var id: Int = 0
    @objc dynamic var fullname: String = ""
    @objc dynamic var username: String = ""
    @objc dynamic var profileText: String = ""
    @objc dynamic var profileImage: Data? = nil
    var tweets = List<Tweet>()

    override static func primaryKey() -> String? {
        return "id"
    }

}

class Tweet: Object {

    @objc dynamic var tweetId: Int = 0
    @objc dynamic var caption: String = ""
    @objc dynamic var timestamp: Date!
    @objc dynamic var retweetCount: Int = 0
    @objc dynamic var likes: Int = 0
    let users = LinkingObjects(fromType: User.self, property: "tweets")

    override static func primaryKey() -> String? {
        return "tweetId"
    }

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

checkベストアンサー

0

Realm の Resutls は Array に変換できるので、
読み込んだタイミングで変換するのはどうでしょうか?

    // Tweet の配列にしています
    private var tweets: [Tweet] = [Tweet]() {
        didSet { 
            collectionView.reloadData() 
        }
    }

    override func viewDidLoad() {
        super.viewDidLoad()
        // Realm からデータの読み込みを行います
        let realm = try! Realm()

        // 読み込みのタイミングで配列に変換
        tweets = Array(realm.objects(Tweet.self))
    }

    override func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
        // 保持している `Tweet` の配列の要素数を返す
        return tweets.count
    }

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2020/07/14 12:26

    tweets: [Tweet] = [Tweet]() はTweetクラスを配列で初期化している、ということでしょうか?
    realm でクラスを初期化すると空になってしまうのではないでしょうか?

    キャンセル

  • 2020/07/14 12:47

    すみません、変数 tweets を全く使っていないコードになっていたので修正しました 🙇‍♂️
    通常 Realm から読み込むような処理は viewDidLoad で行うべきかなと思ったので、その辺りも修正しました。

    そうですね。
    おっしゃる通り最初に Tweet 型の空の配列で変数 tweets 初期化しています。
    「Realm からデータを取り出して Result から Tweet 型の配列に変換したものを再度変数 tweets に代入して CollectionView をリロードさせる」というのが期待する動作かなと思ったのでこのようにしました。

    キャンセル

  • 2020/07/14 12:51

    詳しい説明ありがとうございました!
    コンパイルは通ったので、とりあえずやってみます。

    キャンセル

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

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

関連した質問

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