前回のmapという「複数のデータを格納する仕組み」を使って
今回は、「simple_list_item_2」で、2行ごとにListViewを表示してみたいと思います。

主な学習のテーマは

■simple_list_item_2
■SimpleAdapter

動画

動画で紹介のSimpleAdapterのAndroidデベロッパーはこちら

コード

▼activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.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:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">


    <ListView
        android:id="@+id/lv"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        tools:layout_editor_absoluteX="1dp"
        tools:layout_editor_absoluteY="1dp" />
</androidx.constraintlayout.widget.ConstraintLayout>

▼MainActivity.kt

package com.example.simplelist2

import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.widget.ListView
import android.widget.SimpleAdapter

class MainActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        val lv:ListView =findViewById(R.id.lv)

        //1)データを用意(mapで)
        val data = mutableListOf(
            mapOf("main" to "メイン1" ,"sub" to "サブ1"),
            mapOf("main" to "メイン2" ,"sub" to "サブ2"),
            mapOf("main" to "メイン3" ,"sub" to "サブ3"),
            mapOf("main" to "メイン4" ,"sub" to "サブ4"),
            mapOf("main" to "メイン5" ,"sub" to "サブ5")
        )

        //2)アダプターにセット
        val adapter =SimpleAdapter(
            this,
            data,
            android.R.layout.simple_list_item_2,
            arrayOf("main","sub"),//第2引数のmapのキー(配列)
            intArrayOf(android.R.id.text1,android.R.id.text2)//第3引数のレイアウトのビューのid(int配列)
        )

        //3)リストにセットして表示
        lv.adapter =adapter

    }
}

テキスト

で、コードを書いていく前に
大まかな概念を軽く説明しておきます。
これが前回の1行だけのリスト表示の図です。前々回か。

XMLでListView、
レイアウトは、android先生で用意された1行だけのテンプレート。
list item 1ってやつですね。

で、データを1行ごとに用意して
それをアダプターにまとめると表示される、というものでした。

で、これを踏まえた上で、
今回、同じところと、変更点を整理していきます。

まず1つめの、リストビューは同じなのでそのままでOK.
xmlにListViewって追加するだけです。

②のレイアウトは、前回の1行だけ表示されるlist item1ではなくって
androidStudio先生が用意してくれているlist item 2っていうのを使っていきます。
2を使うと、こういう上下二行のレイアウトを使えます。

で、③ですよ。今回のいわば本丸。
このように1つずつの要素を格納ではなくって、ここで前回のmapを使います。
具体的にはこのように書きます。
(表示)

ちょっと字が小さいんですが、
mapOfでメインのペアと、サブのペアを1セット。
キーto値、キーto値。
これが1セット。

それをどんどん増やしていきますと。
中をもう少しみていくと、
キーの名前は、全部統一。
値を変えていきます。

今回でいうと、
1つめのキーは全てmain、2つめのキーは全てsubで統一します。
キーto値、キーto値。

で、値が1、2、3と変わっていく。
ということです。まあ値は何でもいいんですが、わかりやすくするために数字だけ変更してます。

で、上の行で表示されるのがメインキーの方で、
下の行をサブキーで指定してあげることで
それに関連付けされている値が表示される、という仕組みになっています。

で、これら3つがそろったら
最後の仕上げでアダプターにまとめるわけですが
ここも少し変更があります。

前回、1行だけの時はArrayAdapterというのを使いました

レイアウトやデータが違うと、アダプターもそれに応じて変更してあげる必要があるんですが
今回はSimpleAdapterというアダプターを使います。

前回のArrayAdapterは簡単なTextView のリストを表示するのに適しているんですけれども
SimpleAdapterはmapが使えるので、今回の2行のようなレイアウトを作ることができます。
ちなみにもっとオリジナルにレイアウトを作りたい場合は
ここのアダプターも、独自のカスタムアダプターを作る必要があったりするんですが
まあ今はとりあえず、1行のレイアウトの時にはarrayAdapter。
2行の時にはSimpleAdapter、何故ならmapが使えるから、という理解でOKです。

 

XML

ListViewを追加。詳細は割愛

 

1.mapでデータを用意

データを用意して、アダプターにセットしていきいきましょう。
main ktを開いてください。

書いていくのは、この宣言の続きに書いていきます。

//1)データを用意(mapで)
//2)アダプターにセット

まずはデータの方ですね。
名前をdataとかにしてあげて、
先ほど説明のとおり
mutableListOf()
でリストを用意します。

val data = mutableListOf()

この中にmapで要素を格納していきます。
mapOf()

ここにキーto値、の1ペア、
そしてもう1つ、キーto値、のサブの1ペアを追加していきます。

話を単純にしたいのでこのように書いていきます。
mapOf("main" to "メイン1" , "sub" to "サブ1"),

mainというキーに対して、値を「メイン1」
もう1つ、subというキーに対して、値を「サブ1」。

あとは、キーは一定で、値だけ変更していきます。

mapOf("main" to "メイン1" , "sub" to "サブ1"),
mapOf("main" to "メイン2" , "sub" to "サブ2"),
mapOf("main" to "メイン3" , "sub" to "サブ3"),
mapOf("main" to "メイン4" , "sub" to "サブ4"),
mapOf("main" to "メイン5" , "sub" to "サブ5"),

これでデータが用意できました。

あとは、最後の仕上げ。
アダプターにセットしていきましょう。
今回はSimpleAdapterを使います。

 

2.アダプターにセット

それではアダプターにセットしていきましょう。

まずはvalでadapterという名前を用意してあげて、
SimpleAdapter()
この中にセットしていきます。

で先ほど、デベロッパーのところでチラっと言いましたけど、
今回、引数が5つあります。

これももう、理屈というより、そういう決まりなので
1つ1つ覚えるというより、使いたい時に検索して
同じようなテンプレートがいくつか出てきますので、それを参考に書き換えればOKだと思います。

丸暗記は挫折のもとなんでね。
覚えるんだったら、
「SimpleAdapterはたしか5つくらいあったなー」くらいでOKです。

しかも前半3つはArrayAdapterと一緒です。

  • 第1引数は、この画面、というか、自分自身という意味でthis
  • 第2引数は、Listの入ったデータ名 この場合はdata
  • 第3引数は、レイアウトなので、今回はandroid.R.layout.simple_list_item_2,
  • 第4引数は、第2引数のmapのキーの配列。今回でいうとmainとsubなので
    arrayOf()とかいてあげて、この中に"main" と "sub"
  • 第5引数は、第3引数のレイアウトのビューのidをint配列で用意します。
    //第3引数のレイアウトのビューのid(int配列)
    intArrayOf(android.R.id.text1,android.R.id.text2)

このtext1とかtext2つーのはどっから出てきたんやっつーのを
余談までに紹介しておくと
ctrlを押しながらlist_item_2をクリックするとxmlファイルが確認できます。

でcodeを見てみると、ここにレイアウトが作られていると。
でTextViewが2段用意されてあって、これがレイアウトなんですね。

で、よくよく見ると、idがtext1とtext2で設定されとると。
なのでここには

android.R.id.text1,と
android.R.id.text2を

指定してあげた、という訳になります。

 

あとはListViewにセットして、
ちゃんと2行のレイアウトが表示されるか確認してみましょう。

//3)リストにセットして表示
lv.adapter = adapter

エミュレータを起動します。

 

 

 

    コメントを残す