java.lang.Object ↳ android.view.View ↳ android.view.ViewGroup ↳ android.widget.AdapterView<T extends android.widget.Adapter> ↳ android.widget.AbsListView ↳ android.widget.ListView ↳ android.widget.ExpandableListViewを使用します
Group のリストがありそれぞれが Child のリストを保持しています.
Group をクリックすRと Child のリストが開き,もう一度クリックするとリストが閉じられます.
というわけで,ExpandableListView をいじってみた.
サンプルコード
- public class ExpandableListViewSample extends Activity {
- private static final String KEY1 = "GROUP";
- private static final String KEY2 = "CHILD";
- // 表示させる文字列
- private String[] GROUPS = {"Group1", "Group2", "Group3"};
- private String[][][] CHILDREN = {
- {{"Child11", "Text11"}},
- {{"Child21", "Text21"}, {"Child22", "Text22"}},
- {{"Child31", "Text31"}, {"Child32", "Text32"}, {"Child33", "Text33"}},
- };
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.expandablelistview_sample);
- // 設定する文字列のリスト
- List<Map<String, String>> groupData =
- new ArrayList<Map<String, String>>();
- List<List<Map<String, String>>> childData =
- new ArrayList<List<Map<String, String>>>();
- // リストに文字列を設定していく
- for (int i = 0; i < GROUPS.length; i++) {
- // 親要素の追加
- Map<String, String> curGroupMap =
- new HashMap<String, String>();
- groupData.add(curGroupMap);
- curGroupMap.put(KEY1, GROUPS[i]);
- curGroupMap.put(KEY2, "");
- List<Map<String, String>> children =
- new ArrayList<Map<String, String>>();
- if (CHILDREN.length > i) {
- for (int j = 0; j < CHILDREN[i].length; j++) {
- // 子要素の追加
- Map<String, String> curChildMap =
- new HashMap<String, String>();
- children.add(curChildMap);
- curChildMap.put(KEY1, CHILDREN[i][j][0]);
- curChildMap.put(KEY2, CHILDREN[i][j][1]);
- }
- }
- childData.add(children);
- }
- // ExpandbleListAdapter の作成
- ExpandableListAdapter adapter =
- new SimpleExpandableListAdapter(
- this,
- groupData,
- android.R.layout.simple_expandable_list_item_1,
- new String[] { KEY1, KEY2 },
- new int[] { android.R.id.text1, android.R.id.text2 },
- childData,
- android.R.layout.simple_expandable_list_item_2,
- new String[] { KEY1, KEY2 },
- new int[] { android.R.id.text1, android.R.id.text2 }
- );
- ExpandableListView listView =
- (ExpandableListView) findViewById(R.id.ExpandableListView);
- // Adapter を設定
- listView.setAdapter(adapter);
- // グループがクリックされた時に呼び出されるコールバックを登録
- listView.setOnGroupClickListener(new OnGroupClickListener() {
- @Override
- public boolean onGroupClick(ExpandableListView parent,
- View v, int groupPosition, long id) {
- // クリックされた時の処理
- return false;
- }
- });
- // グループ内の項目がクリックされた時に呼び出されるコールバックを登録
- listView.setOnChildClickListener(new OnChildClickListener() {
- @Override
- public boolean onChildClick(ExpandableListView parent, View v,
- int groupPosition, int childPosition, long id) {
- // クリックされた時の処理
- return false;
- }
- });
- }
- }
さらに
setOnGroupCollapseListener でグループが閉じた時,
setOnGroupExpandListener でグループが開いた時
の処理もできる模様!
XMLリソース
- <?xml version="1.0" encoding="utf-8"?>
- <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:orientation="vertical"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent">
- <TextView
- android:layout_width="fill_parent"
- android:layout_height="wrap_content"
- android:text="ExpandableListViewSample" />
- <ExpandableListView
- android:layout_width="fill_parent"
- android:layout_height="0dip"
- android:layout_weight="1"
- android:id="@+id/ExpandableListView">
- </ExpandableListView>
- </LinearLayout>
グループを開いたとき
こんな感じ!
参考サイト http://developer.android.com/intl/ja/reference/android/widget/ExpandableListView.html
0 件のコメント:
コメントを投稿