Android用RecyclerView實(shí)現(xiàn)圖標(biāo)拖拽排序以及增刪管理
在非編輯狀態(tài)下可以直接點(diǎn)擊圖標(biāo)進(jìn)行跳轉(zhuǎn)在編輯狀態(tài)可以拖拽、添加、刪除操作已被添加過的不能再次添加
3. 實(shí)現(xiàn)的思路用兩個RecyclerView實(shí)現(xiàn),同時維護(hù)兩個數(shù)據(jù)源,上部是常用應(yīng)用,最多可以放8個;下部是全部應(yīng)用。
1. 每個應(yīng)用圖標(biāo)的狀態(tài)用枚舉Option表示// 當(dāng)前的操作狀態(tài)enum class Option { ADD, REMOVE, NONE}2. 在處于編輯狀態(tài)時創(chuàng)建ItemTouchHelper對象并attch到RecyclerView上
if (enable) { itemTouchHelper.attachToRecyclerView(binding.rvApps)}
其中,在實(shí)現(xiàn)ItemTouchHelper.Callback接口的onMove() 函數(shù)中,此時表示用戶已經(jīng)抬手,而圖標(biāo)位置已經(jīng)發(fā)生了變動,此時將界面上圖標(biāo)的順序同步回Adapter的數(shù)據(jù)源中:
val newData = mutableListOf<Pair<String, Int>>()commonAppsAdapter.data.forEachIndexed { index, _ -> val holder = recyclerView.findViewHolderForAdapterPosition(index) as AppsHolder newData.add(Pair(holder.funcUrl, index))}for (i in newData) { val sameFuncIndex = commonAppsAdapter.data.indexOfFirst { i.first == it.uid } Collections.swap(commonAppsAdapter.data, i.second, sameFuncIndex)}3. 當(dāng)應(yīng)用圖標(biāo)從上部被刪除時,需要將其添加到下部,并將其重新設(shè)為可添加狀態(tài)
commonAppsAdapter.onRemoveBtnClickListener = object : OnRemoveBtnClickListener { override fun onClick(view: View, appBean: AppBean) { val theSameElementIndex = allAppsAdapter.data.indexOfFirst { it.uid == appBean.uid } if (theSameElementIndex < 0) return allAppsAdapter.data[theSameElementIndex].option = AppBean.Companion.Option.ADD allAppsAdapter.notifyItemChanged(theSameElementIndex) }}
源碼請前往Github
以上就是Android用RecyclerView實(shí)現(xiàn)圖標(biāo)拖拽排序以及增刪管理的詳細(xì)內(nèi)容,更多關(guān)于Android 實(shí)現(xiàn)圖標(biāo)拖拽排序以及增刪管理的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. Nginx+php配置文件及原理解析2. Intellij IDEA 2019 最新亂碼問題及解決必殺技(必看篇)3. Android Manifest中meta-data擴(kuò)展元素?cái)?shù)據(jù)的配置與獲取方式4. java中throws實(shí)例用法詳解5. CSS3實(shí)現(xiàn)動態(tài)翻牌效果 仿百度貼吧3D翻牌一次動畫特效6. 關(guān)于HTML5的img標(biāo)簽7. Android自定義View實(shí)現(xiàn)掃描效果8. PHP5.0正式發(fā)布 不完全兼容PHP4 新增多項(xiàng)功能9. css3溢出隱藏的方法10. ASP.NET MVC獲取多級類別組合下的產(chǎn)品
