【Java】ListViewの使い方 ②テキストを2つ表示する
data:image/s3,"s3://crabby-images/574df/574dfe4dce10ffa4a505292bb3e7392dce2e5071" alt=""
この記事では「テキストを2つ表示する ListView の作成方法」を紹介しています。
data:image/s3,"s3://crabby-images/eab78/eab78715a98a858a9e67ed145f79ec791ad85c50" alt=""
テキストを1つだけ表示する場合や画像を表示する方法はこちらをお読みください。
Kotlin のコードはこちら
開発環境
ListViewSample というプロジェクトを作成して、MainActivity.java と activity_main.xml がある状態で進めていきます。
Android Studio | Chipmunk 2021.2.1 |
---|---|
Android Emulator | Nexus 4 (API 32) |
minSdk | 16 |
targetSdk | 32 |
ListView の作成方法
activity_main.xml に ListView を用意して id 属性を指定します。(10行目)
MainActivity.java では、Map 型の要素を持つ ArrayListリストでデータを用意して ListView にセットします。(9~35行目)
29 行目
今回は Map 型で用意したデータを使うので SimpleAdapter を使います。
テキストを1つ表示するだけなど List 配列のデータを使うときは ArrayAdapter を使います。
32 行目
android.R.layout.simple_list_item_2 は標準で用意されているリスト項目のレイアウトで、TextView が2つあるレイアウトです。
data:image/s3,"s3://crabby-images/f92be/f92be11b22bb876628ba18154a54604954276b7e" alt=""
33・34行目
Map のキーとレイアウト(android.R.layout.simple_list_item_2)に用意されている id を紐づけます。
data:image/s3,"s3://crabby-images/45e26/45e26f8b461d4536f6d705a27d3f1abab7ff8846" alt=""
以上で完了です。
data:image/s3,"s3://crabby-images/eab78/eab78715a98a858a9e67ed145f79ec791ad85c50" alt=""
クリックイベントの書き方
項目を選択したときに処理を行うには setOnItemClickListener を使います。
以下のサンプルでは、選択した項目のテキストを取得して Toast を表示しています。
実行結果
data:image/s3,"s3://crabby-images/dd15d/dd15da224c37eb28f0e35a6e28a6945fa9844603" alt=""
項目を追加・削除する方法
マップデータに項目を追加・削除して notifyDataSetChanged メソッドで変更を反映させます。(15~24行目)