The Recycler Adapter

我们同样需要一个RecyclerView的Adapter。之前我在我博客中讨论过RecyclerView,如果你以前没有使用过,它可能会有所帮助。

RecyclerView中所使用到的布局现在只需要一个TextView,我会手动去创建这个简单的文本列表。增加一个名为ForecastListAdapter.kt的Kotlin文件,包括如下代码:

  1. class ForecastListAdapter(val items: List<String>) :
  2. RecyclerView.Adapter<ForecastListAdapter.ViewHolder>() {
  3. override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
  4. return ViewHolder(TextView(parent.context))
  5. }
  6. override fun onBindViewHolder(holder: ViewHolder, position: Int) {
  7. holder.textView.text = items.[position]
  8. }
  9. override fun getItemCount(): Int = items.size
  10. class ViewHolder(val textView: TextView) : RecyclerView.ViewHolder(textView)
  11. }

又是如此,我们可以像访问属性一样访问context和text。你可以保持以往那样操作(使用getters和setters),但是你会得到一个编译器的警告。如果你还是倾向于Java中的使用方式,这个检查可以被关闭。但是一旦你使用上了这种属性调用的方式你就会爱上它,而且它也节省了额外的字符总量。

回到MainActivity,现在简单地创建一系列的String放入List中,然后使用创建分配Adapter实例。

  1. private val items = listOf(
  2. "Mon 6/23 - Sunny - 31/17",
  3. "Tue 6/24 - Foggy - 21/8",
  4. "Wed 6/25 - Cloudy - 22/17",
  5. "Thurs 6/26 - Rainy - 18/11",
  6. "Fri 6/27 - Foggy - 21/10",
  7. "Sat 6/28 - TRAPPED IN WEATHERSTATION - 23/18",
  8. "Sun 6/29 - Sunny - 20/7"
  9. )
  10. override fun onCreate(savedInstanceState: Bundle?) {
  11. ...
  12. val forecastList = findViewById(R.id.forecast_list) as RecyclerView
  13. forecastList.layoutManager = LinearLayoutManager(this)
  14. forecastList.adapter = ForecastListAdapter(items)
  15. }

List的创建

尽管我会在本书后面来对Collection进行讲解,但是我现在仅仅简单地解释你可以通过使用一个函数listOf创建一个常量的List(很快我们就会讲到的immutable)。它接收一个任何类型的vararg(可变长的参数),它会自动推断出结果的类型。

还有很多其它的函数可以选择,比如setOfarrayListOf或者hashSetOf

为了优化项目的结构,我也移动了一些类到新的包里面。

我们在上面很简短的代码中看到了很多新的东西,所以我会在下一章讲到它们。我们现在必须要学习一些比如基本类型,变量,属性等比较重要的概念才能继续下去。