Android實(shí)現(xiàn)的RecyclerView適配器
這個(gè)適配器我珍藏已久(近兩年), 不斷看到別人發(fā)適配器相關(guān)的文章, 但我總覺得沒我的好用, 所以今日拿出來分享(宣傳)一下, 歡迎各位指正不足.
源碼地址: GitHub
功能 無需繼承 Adapter, 無需判斷 item 類型. 支持頁頭和頁腳. 支持自動(dòng)展示空數(shù)據(jù)界面. 通過 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 = adapterclass 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 實(shí)現(xiàn)并繼承繼承抽象類 AbsViewHolder, 并在改類中設(shè)置布局和綁定 View, 數(shù)據(jù).
AbsViewHolder 代表一種 Item 類型, 其中泛型 T 為該 Item 對(duì)應(yīng)的實(shí)體類
類 SuperAdapter 的作用Adapter 構(gòu)造器
public SuperAdapter(List<Object> data)
綁定 ViewHolder 到實(shí)體類型
public void addViewHolderForType(Class<?> type, Class<? extends AbsViewHolder> holder)
設(shè)置 Item 點(diǎn)擊事件
public void setOnItemClickListener(OnItemClickListener listener) public interface OnItemClickListener{ void onItemClick(View v, Object itemData, int position); }類 AbsViewHolder 的作用
每個(gè) AbsViewHolder 表示一種 item 類型.
構(gòu)造器, 必須重寫帶參數(shù)構(gòu)造器, 否則無法使用, parent 與 Adapter#onCreateViewHolder 中 parent 一致
public AbsViewHolder(@NonNull ViewGroup parent)
創(chuàng)建 Item 時(shí)調(diào)用 onCreate 方法, 其中 parent 是該 item 的容器布局
public abstract void onCreate(@NonNull ViewGroup parent);
綁定數(shù)據(jù)
public abstract void onBindData(@NonNull T data, int position); Sample
設(shè)置 Adapter
var data:List<Any>...val adapter = SuperAdapter(data)// 綁定數(shù)據(jù)類到 ViewHolderadapter.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實(shí)現(xiàn)的RecyclerView適配器的詳細(xì)內(nèi)容,更多關(guān)于RecyclerView 適配器的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. HTTP協(xié)議常用的請(qǐng)求頭和響應(yīng)頭響應(yīng)詳解說明(學(xué)習(xí))2. XML入門的常見問題(三)3. XML在語音合成中的應(yīng)用4. HTML5實(shí)戰(zhàn)與剖析之觸摸事件(touchstart、touchmove和touchend)5. Vue如何使用ElementUI對(duì)表單元素進(jìn)行自定義校驗(yàn)及踩坑6. HTML DOM setInterval和clearInterval方法案例詳解7. 不要在HTML中濫用div8. XML 非法字符(轉(zhuǎn)義字符)9. CSS清除浮動(dòng)方法匯總10. jscript與vbscript 操作XML元素屬性的代碼
