티스토리 뷰

반응형

리스트뷰 ListView 

ListView는 뷰들을 세로방향으로 스크롤이 가능하도록 디스플레이한다. 조금 더 유연한 활용을 위해서는 RecyclerView를 사용한다. 

먼저, 리스트를 디스플레이하기 위해서는 xml파일에 listView를 추가한다. 

<ListView
      android:id="@+id/list_view"
      android:layout_width="match_parent"
      android:layout_height="match_parent" />

 

ListView는 본인 안에 담길 뷰의 내용이나 형식을 모르기 때문에 ListAdapter에게 필요한 뷰들을 요청한 후 그려낸다.  setAdapter(android.widget.ListAdapter)를 통해서 어댑터와 리스트를 연결할 수 있다.  

 

리스트뷰를 사용하면 반복되는 목록을 일일이 그리지 않아도 손쉽게 만들 수 있어서 편하다.

 

 

코드

ListAdapter.kt - getView안의 코드들은 각 뷰 하나마다 작동함

layout_listview.xml - 뷰 하나의 레이아웃 

class ListAdapter (val context: Context, val array: Array<String>) : BaseAdapter() {

    override fun getView(position: Int, convertView: View?, parent: ViewGroup?): View {

        val view: View = LayoutInflater.from(context).inflate(R.layout.layout_listview, null)

        val check = view.findViewById<TextView>(R.id.part_tv_bplv)
        check.text = array[position]


        return view
    }

    override fun getItem(position: Int): Any {

        return array[position]
    }

    override fun getItemId(position: Int): Long {

        return position
    }

    override fun getCount(): Int {

        return array.size
    }

}

 

MainActivity.kt - 어댑터가 리스트뷰에 전달할 데이터를 추가하고, 리스트뷰를 어댑터와 연결해준다.

activity_main.xml - 리스트뷰를 그릴 곳

class MainActivity : AppCompatActivity() {

    lateinit var listAdapter: ListAdapter

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

		// 리스트뷰에 그리고 싶은 데이터
        val arr = arrayOf()
        
        listAdapter = ListAdapter(this, arr)
        front_listview.adapter = listAdapter

    }

}

 

 

 

참고

안드로이드 공식 개발문서

developer.android.com/reference/android/widget/ListView

 

ListView  |  Android 개발자  |  Android Developers

 

developer.android.com

 

반응형