您好,登錄后才能下訂單哦!
這篇文章主要講解了“Android如何實現RecyclerView適配器”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Android如何實現RecyclerView適配器”吧!
源碼地址: GitHub
無需繼承 Adapter, 無需判斷 item 類型.
支持頁頭和頁腳.
支持自動展示空數據界面.
通過 Kotlin 的 lambda 大量縮減代碼.
支持全局 Item 類型
支持 diff 刷新
添加依賴
implementation "com.dengzii.adapter:$latestVersion"
通過 lambda 快速使用, 這里就快速綁定了四種 item 的布局.
adapter.setEnableEmptyView(true, SuperAdapter.Empty()) adapter.addViewHolderForType<SuperAdapter.Empty>(R.layout.item_empty){ onBindData { _, _ -> findView<View>(R.id.bt_refresh).setOnClickListener { // refresh your data } } } adapter.setHeader("This is header", R.layout.item_header) { onBindData { data, _ -> findView<TextView>(R.id.tv_title).text = data } } adapter.setFooter(listOf("This", "is", "footer"), R.layout.item_section) { onBindData { data, _ -> findView<TextView>(R.id.tv_title).text = data.joinToString(" ") } } adapter.addViewHolderForType<Header>(R.layout.item_header) { val title = findView<TextView>(R.id.tv_title) val content by lazyFindView<TextView>(R.id.tv_content) onBindData { data, _ -> title.text = data.title content.text = data.content } }
或者不使用 lambda
val adapter = SuperAdapter(listOf("Item 1", "Item 2", "Item 3")) adapter.addViewHolderForType(String::class.java, ItemViewHolder::class.java) recyclerView.layoutManager = LinearLayoutManager(this) recyclerView.adapter = adapter class ItemViewHolder(parent: ViewGroup) : AbsViewHolder<String>(parent) { private lateinit var mTextView:TextView override fun onCreate(parent: ViewGroup) { mTextView = TextView(context) mTextView.layoutParams = getLayoutParam( ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT ) setContentView(mTextView) } override fun onBindData(data: String, position: Int) { mTextView.text = data } }
無需繼承 SuperAdapter, 但需要為每種 Item 實現并繼承繼承抽象類 AbsViewHolder, 并在改類中設置布局和綁定 View, 數據.
AbsViewHolder 代表一種 Item 類型, 其中泛型 T 為該 Item 對應的實體類
Adapter 構造器
public SuperAdapter(List<Object> data)
綁定 ViewHolder 到實體類型
public void addViewHolderForType(Class<?> type, Class<? extends AbsViewHolder> holder)
設置 Item 點擊事件
public void setOnItemClickListener(OnItemClickListener listener) public interface OnItemClickListener{ void onItemClick(View v, Object itemData, int position); }
每個 AbsViewHolder 表示一種 item 類型.
構造器, 必須重寫帶參數構造器, 否則無法使用, parent 與 Adapter#onCreateViewHolder 中 parent 一致
public AbsViewHolder(@NonNull ViewGroup parent)
創建 Item 時調用 onCreate 方法, 其中 parent 是該 item 的容器布局
public abstract void onCreate(@NonNull ViewGroup parent);
綁定數據
public abstract void onBindData(@NonNull T data, int position);
設置 Adapter
var data:List<Any> ... val adapter = SuperAdapter(data) // 綁定數據類到 ViewHolder adapter.addViewHolderForType(Item::class.java, ItemViewHolder::class.java) adapter.addViewHolderForType(Header::class.java, HeaderViewHolder::class.java) adapter.addViewHolderForType(Section::class.java, SectionViewHolder::class.java) adapter.setOnItemClickListener(object : SuperAdapter.OnItemClickListener { override fun onItemClick(v: View?, itemData: Any?, position: Int) { } }) recyclerView.layoutManager = LinearLayoutManager(this) recyclerView.adapter = adapter
繼承 AbsViewHolder
class ItemViewHolder(parent: ViewGroup) : AbsViewHolder<Item>(parent) { private lateinit var mTvTitle: TextView private lateinit var mTvContent: TextView private lateinit var mIvImage:ImageView override fun onCreate(parent: ViewGroup) { setContentView(R.layout.item_item) mTvTitle = findViewById(R.id.tv_title) mTvContent = findViewById(R.id.tv_content) mIvImage = findViewById(R.id.iv_img) } override fun onBindData(data: Item, position: Int) { mTvTitle.text = data.title mTvContent.text = data.content mIvImage.setImageResource(data.img) } }
感謝各位的閱讀,以上就是“Android如何實現RecyclerView適配器”的內容了,經過本文的學習后,相信大家對Android如何實現RecyclerView適配器這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。