스팀 앱 개발기 #69 - 태그 화면에 데이터 바인딩 적용steemCreated with Sketch.

시작하며...

지난 포스트에서는 태그 화면을 구성하는 레이아웃을 작성했구요. 오늘은 그것과 데이터를 연결하기 위한 데이터 바인딩을 구현해 보겠습니다.


작업 개요

  • UI 모듈의 build.gradle 수정
  • PostItemListAdapter 클래스 정의
  • DataBindingUtil 오브젝트 클래스 정의
  • fragment_tags 레이아웃의 RecyclerView 뷰에 바인딩 적용

UI 모듈의 build.gradle 수정

레이아웃의 RecyclerView 뷰와 포스트 리스트를 바인딩 해야 하는데요. 여기서 BindingAdapter가 필요하구요. 이를 위해서는 build.gradle 파일에 kotlin-kapt 플러그인을 추가해야 합니다.

plugins {
    id 'com.android.application'
    id 'org.jetbrains.kotlin.android'
    id 'kotlin-kapt'
}

//...

PostItemListAdapter 클래스 정의

RecyclerView 뷰에 포스트 리스트를 보여주기 위해서는 뷰와 리스트를 이어주는 어댑터 클래스가 필요합니다.

class PostItemListAdapter : RecyclerView.Adapter<PostItemListAdapter.PostItemListViewHolder>() {

    val postItemList = mutableListOf<PostItem>()

    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): PostItemListViewHolder {
        return PostItemListViewHolder(LayoutPostItemBinding.inflate(
            LayoutInflater.from(parent.context),
            parent,
            false
        ))
    }

    override fun onBindViewHolder(holder: PostItemListViewHolder, position: Int) {
        try {
            holder.bind(postItemList[position])
        }
        catch (e: IndexOutOfBoundsException) {
            e.printStackTrace()
        }
    }

    override fun getItemCount(): Int = postItemList.size

    fun setList(list: List<PostItem>) {
        this.postItemList.apply {
            clear()
            addAll(list)
        }
        notifyDataSetChanged()
    }

    inner class PostItemListViewHolder(
        private val binding: LayoutPostItemBinding
    ) : RecyclerView.ViewHolder(binding.root) {
        fun bind(postItem: PostItem) {
            binding.postItem = postItem
        }
    }

}

DataBindingUtil 오브젝트 클래스 정의

@BindingAdapter("속성이름") 애노테이션을 이용하면, 레이아웃의 뷰에 'app:속성이름'으로 속성을 추가할 수 있습니다. 아래 코드의 bind 함수가 그렇고요. 1번째 파라메터는 적용할 뷰를, 2번째 파라메터에는 해당 속성의 값을 의미합니다. 아래 코드에서는 recyclerView 뷰에 postItemList 리스트를 적용한다는 의미이죠. 그러면 PostItemListAdapter 클래스 안에 정의된 바인딩에 의해 자동으로 RecyclerView 뷰가 업데이트 됩니다.

object DataBindingUtil {

    @BindingAdapter("postItemList")
    fun bind(recyclerView: RecyclerView?, postItemList: List<PostItem>?) {
        (recyclerView?.adapter as PostItemListAdapter)?.let {
            if (null != postItemList) {
                it.setList(postItemList)
            }
        }
    }

}

fragment_tags 레이아웃의 RecyclerView 뷰에 바인딩 적용

위 bind 함수를 정의하였으므로 androidx.recyclerview.widget.RecyclerView 뷰에 app:postItemList 속성을 아래와 같이 정의할 수 있습니다.

<androidx.recyclerview.widget.RecyclerView
    android:id="@+id/list_post_item"
    android:layout_width="match_parent"
    android:layout_height="0dp"
    app:postItemList="@{viewModel.rankedPosts}"
    app:layout_constraintTop_toBottomOf="@id/radiogroup_sort"
    app:layout_constraintBottom_toBottomOf="parent"
    tools:listitem="@layout/layout_post_item" />

GitHub Commit

https://github.com/netrance/dorian-steem-apps/commit/35eabb6f882b378396a6a5984f86643c748099d4


지난 스팀 앱 개발기

Sort:  
 2 years ago 

[광고] STEEM 개발자 커뮤니티에 참여 하시면, 다양한 혜택을 받을 수 있습니다.

Upvoted! Thank you for supporting witness @jswit.

Coin Marketplace

STEEM 0.18
TRX 0.14
JST 0.029
BTC 57893.29
ETH 3130.56
USDT 1.00
SBD 2.44