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

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

詳細はこちら
Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

Q&A

解決済

1回答

1543閲覧

【Android Jetpack】Room,Paging3を用いてページング処理を実装したいが、Adapterがうまく接続できない

taku-hisa

総合スコア0

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

0グッド

0クリップ

投稿2021/02/23 02:55

前提・実現したいこと

RoomとPaging3を用いた開発をしています。

1.DAOの戻り値をPagingSource<Int,item(entityクラス)>
2.Pagerにて、Flow<PagingData<item>>を取得
3.PagingDataAdapterを作成し、接続

という手順でページング処理の実装を試みましたが、
Adapterがうまく接続ができていないようです。

PagingSource型を用いたサンプルコードがネット上にあまり無く、
自力で解決を試みましたが、解決の糸口もわからない状況です。

この問題について分かる方がおられましたら、
ご教示いただけますと幸いです。

発生している問題・エラーメッセージ

エラーメッセージ

W/RecyclerView: No adapter attached; skipping layout

試したこと

1.itemDao.kt

@Query("SELECT * FROM item_table") fun getItem(): PagingSource<Int, item>

MainViewModel.kt

val getItem = dao.getItem()

2.MainActivity.kt

private fun getStream(): Flow<PagingData<item>> { return Pager( config = PagingConfig(pageSize = 10), initialKey = 0 ) { viewModel.getItem }.flow }

3.SampleDataAdapter.kt

class SampleDataAdapter(private val context: Context) : PagingDataAdapter<item, ImageViewHolder>(CALLBACK) { class ImageViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView) { val imageView: ImageView = itemView.findViewById(R.id.image) } override fun onBindViewHolder(holder: ImageViewHolder, position: Int) { //画像取得 val bufferedInputStream = BufferedInputStream(context?.openFileInput(getItem(position)?.image)) val imageResource = BitmapFactory.decodeStream(bufferedInputStream) bufferedInputStream.close() //画像表示 Glide.with(context) .load(imageResource) .error(android.R.drawable.ic_btn_speak_now) .into(holder.imageView) } override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ImageViewHolder { val itemView = View.inflate(parent.context, R.layout.card_layout, null) return ImageViewHolder(itemView) } } val CALLBACK = object : DiffUtil.ItemCallback<item>() { //略 }

※全文
https://github.com/taku-hisa/PagingTest2

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

roomVersion = '2.3.0-beta01' pagingVersion = '3.0.0-beta01'

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

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

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

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

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

guest

回答1

0

自己解決

単にrecyclerviewの設定を誤っていただけでした。

投稿2021/02/23 12:08

taku-hisa

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問