ListViewをカスタマイズする [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)+"番目がクリックされました。"); } }); } }); } }
関連
スポンサーリンク
関連記事
前の記事: | バックグラウンド処理(非同期処理) [Android Studio] |
次の記事: | SQLiteによるデータベース操作(SELECT/INSERT/UPDATE/DELETE/トランザクション) [Android Studio] |
公開日:2018年05月21日 最終更新日:2018年05月28日
記事NO:02660