ListViewに比べてRecyclerViewの方が使い勝手がいいので、試しに使ってみました。
その時のメモです。
①レイアウトの作成
まずは表示する1列分のレイアウトを作成します。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="120dp"
android:layout_marginLeft="8dp"
android:layout_marginRight="8dp"
android:orientation="vertical">
<TextView
android:id="@+id/titleView"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="8dp"
android:layout_marginRight="8dp"
android:layout_marginTop="8dp"/>
<TextView
android:id="@+id/dateView"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="8dp"
android:layout_marginRight="8dp"
android:layout_marginTop="8dp"/>
</LinearLayout>
そして、RecyclerViewのレイアウトを作成します。
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:background="?android:attr/selectableItemBackground"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.v7.widget.RecyclerView
android:id="@+id/articlRecyclerView"
android:layout_width="390dp"
android:layout_height="583dp"
android:layout_marginEnd="8dp"
android:layout_marginStart="8dp"
android:layout_marginTop="8dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
</android.support.constraint.ConstraintLayout>
②Adapterの作成
class ArticlesAdapter(private val context: Context,
private val articles: List<Article>,
private val articleClicked: (Article) -> Unit) : RecyclerView.Adapter<ArticlesAdapter.ArticleViewHolder>() {
class ArticleViewHolder(view: View, val articleClicked: (Article) -> Unit): RecyclerView.ViewHolder(view) {
val title = view.findViewById<TextView>(R.id.titleView)
val date = view.findViewById<TextView>(R.id.dateView)
fun setUp(article: Article) {
this.itemView.setOnClickListener { articleClicked(article) }
}
}
override fun getItemCount(): Int = articles.size
//1行表示するたびに呼ばれレイアウトを生成してViewHolderを生成して返す
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ArticleViewHolder {
val rowView = LayoutInflater.from(context).inflate(R.layout.article_content, parent, false)
return ArticleViewHolder(rowView, articleClicked)
}
override fun onBindViewHolder(holder: ArticleViewHolder?, position: Int) {
holder!!.let {
it.title.text = articles[position].title
it.date.text = DateFormat.format("yyyy/MM/dd HH:mm",articles[position].date).toString()
it.url.text = articles[position].link
}
holder.setUp(articles[position])
}
}
コンストラクタでcontextと一覧のデータ、タップ時のコールバックを受け取るようにしています。
getItemCount()メソッドで表示件数を取得しています。
onCreateViewHolder()メソッドでviewを生成しています。①で作成した1列分のレイアウトと紐づけを行い、ViewHolderを返しています。
onBindViewHolder()メソッドではデータをタップしたときの処理を記載しています。
③Activityの作成
最後に一覧として表示されるようにActivityを作成します。
class ListArticlesActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_article_list)
articlRecyclerView.layoutManager = LinearLayoutManager(this)
articlRecyclerView.adapter = ArticlesAdapter(this, data.articles) {
// タップしたときの処理を記載
}
}
}
LinearLayoutManagerのインスタンスを生成し、自作したArticlesAdapterを適用させています。
GridLayoutManagerなどの種類があるので、使いたいものをでインスタンス化します。
②のコンストラクタにタップしたときの処理を入れているので、この画面でタップしたときの処理を書きます。
これで最低限の表示はできると思います。
実際使ってみて、ListViewよりは制約がなく、幅広いレイアウトが作れそうな印象です。