Android 는 RecyclerView 로 아이콘 드래그 정렬 및 삭제 관 리 를 실현 합 니 다.

1.효과 도

2.기본 적 인 기능
편집 되 지 않 은 상태 에서 아이콘 을 클릭 하여 점프 할 수 있 습 니 다.
편집 상태 에서 드래그,추가,삭제 작업 을 할 수 있 습 니 다.
추 가 된 것 은 다시 추가 할 수 없습니다.
3.실현 의 사고
두 개의 RecyclerView 로 이 루어 지고 두 개의 데이터 원본 을 유지 하 며 윗부분 은 자주 사용 되 며 최대 8 개 까지 넣 을 수 있 습 니 다.아 랫 부분 은 전부 적용.
1.모든 아이콘 의 상 태 를 매 거 진 Option 으로 표시 합 니 다.

//        
enum class Option {
 ADD, REMOVE, NONE
}
2.편집 상태 일 때 ItemTouchHelper 대상 을 만 들 고 attch 를 RecyclerView 에

if (enable) {
 itemTouchHelper.attachToRecyclerView(binding.rvApps)
} 
그 중에서 ItemTouchHelper.Callback 인 터 페 이 스 를 실현 하 는 onMove()함수 에서 사용자 가 손 을 들 었 음 을 나타 내 고 아이콘 위치 가 변경 되 었 습 니 다.이때 인터페이스 에 있 는 아이콘 의 순 서 를 Adapter 의 데이터 원본 으로 동기 화 합 니 다.

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.아이콘 이 위 에서 삭제 되 었 을 때 아래 에 추가 하고 추가 가능 한 상태 로 다시 설정 해 야 합 니 다.

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 로 가세 요.
이상 은 안 드 로 이 드 가 RecyclerView 로 아이콘 드래그 정렬 과 삭제 관 리 를 실현 하 는 상세 한 내용 입 니 다.안 드 로 이 드 가 아이콘 드래그 정렬 과 삭제 관 리 를 실현 하 는 데 관 한 자 료 는 저희 의 다른 관련 글 을 주목 하 세 요!

좋은 웹페이지 즐겨찾기