ホーム > カテゴリ > Java・Android >

ListViewをカスタマイズする [Android Studio]

Android Studioの使い方(目次)

目次

1. 作るもの
2. 画面設計
  2-1. メイン
  2-2. カスタムリストビュー
3. コーディング

1. 作るもの

画像やテキストを追加したカスタムリストビューを作成します。

2. 画面設計

2-1. メイン

ListView(ID:listView)とButton(ID:button)を配置します。

2-2. カスタムリストビュー

ListViewをカスタマイズするにはリストビューのレイアウトファイルを作成します。res\layoutの上で右クリックをして[新規][Layoutリソースファイル]を選択します。

次にファイル名は「list.xml」でルート要素には「LinearLayout」を入力してOKを押します。

次のコードをコピペして下さい。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="match_parent">

    <TextView
        android:id="@+id/textView"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="TextView" />

    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="horizontal">

        <ImageView
            android:id="@+id/imageView"
            android:layout_width="60dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            app:srcCompat="@android:drawable/btn_star_big_on" />

        <TextView
            android:id="@+id/textView2"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginTop="6dp"
            android:layout_weight="1"
            android:text="TextView" />
    </LinearLayout>
</LinearLayout>

このようになります。

後はコーディングです。

3. コーディング

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class MainActivity extends AppCompatActivity {

   @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        // Mapのキー
        final String[] FROM = {"title","name","image"};
        // リソースのコントロールID
        final int[] TO = {R.id.textView, R.id.textView2,R.id.imageView};

        findViewById(R.id.button).setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                ListView lv = findViewById(R.id.listView);

                // リストデータの生成
                List<Map<String,Object>> list = new ArrayList<>();
                Map<String,Object> map = new HashMap<>();

                map.put("title","NO.00001");
                map.put("name","あいうえお");
                map.put("image",android.R.drawable.btn_star_big_on);
                list.add(map);

                map =  new HashMap<>();
                map.put("title","NO.00002");
                map.put("name","かきくけこ");
                map.put("image",android.R.drawable.ic_menu_myplaces);
                list.add(map);

                map =  new HashMap<>();
                map.put("title","NO.00003");
                map.put("name","さしすせそ");
                map.put("image",android.R.drawable.btn_dialog);
                list.add(map);

                // アダプターの設定
                SimpleAdapter adapter = new SimpleAdapter(MainActivity.this,
                                                            list,R.layout.list,FROM,TO);
                lv.setAdapter(adapter);

                // イベント
                lv.setOnItemClickListener(new AdapterView.OnItemClickListener() {
                    @Override
                    public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                        MainActivity.this.setTitle(String.valueOf(position)+"番目がクリックされました。");
                    }
                });
            }
        });
    }
}

関連

ListViewにCheckBoxを追加する





関連記事



公開日:2018年05月21日 最終更新日:2018年05月28日
記事NO:02660