Android實現(xiàn)的RecyclerView適配器
這個適配器我珍藏已久(近兩年), 不斷看到別人發(fā)適配器相關(guān)的文章, 但我總覺得沒我的好用, 所以今日拿出來分享(宣傳)一下, 歡迎各位指正不足.
源碼地址: GitHub
功能
- 無需繼承 Adapter, 無需判斷 item 類型.
- 支持頁頭和頁腳.
- 支持自動展示空數(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 = 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 實現(xiàn)并繼承繼承抽象類 AbsViewHolder, 并在改類中設(shè)置布局和綁定 View, 數(shù)據(jù).
AbsViewHolder 代表一種 Item 類型, 其中泛型 T 為該 Item 對應(yīng)的實體類
類 SuperAdapter 的作用
Adapter 構(gòu)造器
public SuperAdapter(List<Object> data)
綁定 ViewHolder 到實體類型
public void addViewHolderForType(Class<?> type, Class<? extends AbsViewHolder> holder)
設(shè)置 Item 點擊事件
public void setOnItemClickListener(OnItemClickListener listener) public interface OnItemClickListener{ void onItemClick(View v, Object itemData, int position); }
類 AbsViewHolder 的作用
每個 AbsViewHolder 表示一種 item 類型.
構(gòu)造器, 必須重寫帶參數(shù)構(gòu)造器, 否則無法使用, parent 與 Adapter#onCreateViewHolder 中 parent 一致
public AbsViewHolder(@NonNull ViewGroup parent)
創(chuàng)建 Item 時調(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ù)類到 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實現(xiàn)的RecyclerView適配器的詳細(xì)內(nèi)容,更多關(guān)于RecyclerView 適配器的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
TextView長按復(fù)制的實現(xiàn)方法(總結(jié))
下面小編就為大家?guī)硪黄猅extView長按復(fù)制的實現(xiàn)方法(總結(jié))。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-04-04詳解Android app自動更新總結(jié)(已適配9.0)
這篇文章主要介紹了詳解Android app自動更新總結(jié)(已適配9.0),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04Android Studio多渠道打包、自定義打包APK名稱
Android Studio為我們提供了簡便的方法,可以多渠道打包,一次打包所有的渠道包。這篇文章主要介紹了Android Studio多渠道打包、自定義打包APK名稱,需要的朋友可以參考下2018-01-01詳解Android應(yīng)用中preference首選項的編寫方法
這篇文章主要介紹了Android應(yīng)用中preference首選項的編寫方法,或許Apple將其翻譯為'偏好設(shè)置'更直觀些,即用戶對應(yīng)用的一些個性化調(diào)整菜單,需要的朋友可以參考下2016-04-04Android studio實現(xiàn)滑動開關(guān)
這篇文章主要為大家詳細(xì)介紹了Android studio實現(xiàn)滑動開關(guān),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-03-03Android學(xué)習(xí)筆記之Shared Preference
在之前遇到有個需求是要改settings里面自動轉(zhuǎn)屏的首選項,于是就學(xué)習(xí)了下Shared Preference。Shared Preference是一種簡單的、輕量級的鍵/值對機制,用于保存原始應(yīng)用程序數(shù)據(jù),最常見的就是首選項2013-09-09