안드로이드 앱 개발

RecyclerView의 click, itemClickListener 사용방법 - Kotlin 본문

안드로이드앱/RecyclerView

RecyclerView의 click, itemClickListener 사용방법 - Kotlin

스텝바이스텝안드로이드 2021. 3. 26. 00:24

참고

리사이클러뷰 아이템 클릭 이벤트 처리. (RecyclerView Item Click Event) :: 개발자를 위한 레시피 (tistory.com)

 

리사이클러뷰 아이템 클릭 이벤트 처리. (RecyclerView Item Click Event)

1. 리사이클러뷰(RecyclerView) 아이템 클릭. 지난 글 [안드로이드 리사이클러뷰 기본 사용법. (Android RecyclerView)]와 [안드로이드 리사이클러뷰 사용 예제. (Android RecyclerView Example)]에서 리사이클러..

recipes4dev.tistory.com

 

먼저, Recyclerview는 listview나 gridview처럼

직접 뷰에 setOnItemClickListenr나 setOnLongItemClickListener를 붙여줄 수가 없었다.

 

결론만 정리하면

Adapter 코드의 ViewHolder에서 itemView에 onClickListener를 달아야 한다. (Long일경우 LongClickListnenr)

 

class ViewHolder(binding: RvItemMemoBinding) : RecyclerView.ViewHolder(binding.root){
        var binding: RvItemMemoBinding

        fun bind(memoData: MemoData){

            binding.memoTitle.text = memoData.memoTitle
            binding.memoDate.text = memoData.memoDate
            binding.memoContent.text = memoData.memoContent

        }

        init {
            this.binding = binding

            //item Click Listener
            binding.memoItemCardview.setOnClickListener(View.OnClickListener {
                val pos = adapterPosition
                Log.d("click", pos.toString() + " : click!")
            })

            //item LongClick Listener
            binding.memoItemCardview.setOnLongClickListener(View.OnLongClickListener {
                val pos = adapterPosition
                Log.d("click", pos.toString() + " : Long click!")
                return@OnLongClickListener true
            })

        }
    }

위는 viewBinding을 사용해서 itemView가 아닌 binding.cardview(rv의 item 최상위 뷰)에 클릭 리스너를 달아줬다.

position은 'pos'라는 변수를 생성해서

java에서는 getAdapterPosition, Kotlin에서는 adapterPosition을 사용해서 지정해주어서 사용하면 된다.

 

 

==================================Upgrade=====================================

 

Adapter에서 클릭메소드를 처리하다 보니

다양한 기능을 구현하는데, 어려움을 겪었다.

따라서, adapter에서 clickListener를 추상화 메소드로 만든뒤

adapter를 생성한 fragment나 activity에서

override해서 다양한 기능을 사용할 수 있게 했다.

 

class RvMemoAdapter: RecyclerView.Adapter<RvMemoAdapter.ViewHolder> {

    interface ItemClick{ //인터페이스
        fun onClick(view: View, position: Int)
    }

    var itemClick: ItemClick? = null 
    
    ....생략
    
    override fun onBindViewHolder(holder: RvMemoAdapter.ViewHolder, position: Int) {
        holder.bind(data!![position])
        if (itemClick != null){
            holder?.binding.memoItemCardview.setOnClickListener(View.OnClickListener {
                itemClick?.onClick(it, position)
            })
        }
    }
    
 	....생략
 
}

 

fragment나 activity에서 override

adapter = RvMemoAdapter(memoDataList) //adapter 생성

//override
adapter!!.itemClick = object : RvMemoAdapter.ItemClick{
            override fun onClick(view: View, position: Int) {
                val intent = Intent(context, ActivityCreateMemo::class.java)
                startActivity(intent)
            }

        }