由於案子需求,要製作一個展開式多選選單,怕自己忘記,就順便記一下。
參考網站: 網站1 網站2
完成圖片:
1.由於網站1,整理得比較易懂,所以取用網站1的寫法再做修改,非常感謝作者 m(- . -)m
2.開始
3.activity_main.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="${relativePackage}.${activityClass}" >
<ExpandableListView
android:id="@+id/expandableListView"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="10dp"
android:layout_marginRight="10dp"
android:dividerHeight="0dp"
android:groupIndicator="@null" />
</RelativeLayout>
4.group_layout.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/LinearLayout1"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
>
<RelativeLayout
android:layout_width="fill_parent"
android:layout_height="60dp"
android:layout_marginTop="30dp">
<ImageView
android:id="@+id/expandable_group_bg"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_centerVertical="true"
android:scaleType="fitXY"
android:src="@drawable/doroto_expandable_closebg" />
<TextView
android:id="@+id/group_tv"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_marginLeft="10dp"
android:text="123"
android:textColor="#000000"
android:textSize="20sp" />
<ImageView
android:id="@+id/expandable_group_arrow"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignBottom="@+id/group_tv"
android:layout_alignParentRight="true"
android:layout_marginRight="19dp"
android:src="@drawable/doroto_expandable_up" />
</RelativeLayout>
</LinearLayout>
4.child_layout.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal" >
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="50dp" >
<ImageView
android:id="@+id/expandable_child_bg"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scaleType="fitXY"
android:src="@drawable/doroto_expandable_childbg" />
<TextView
android:id="@+id/expandable_child_title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_centerVertical="true"
android:layout_marginLeft="30dp"
android:text="child-child-child"
android:textSize="20sp" />
<RadioButton
android:id="@+id/expandable_child_check"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_centerVertical="true"
android:layout_marginRight="19dp" />
</RelativeLayout>
</LinearLayout>
5.MainActivity.java
package com.zyo.testsprinner;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import android.app.ActionBar.LayoutParams;
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseExpandableListAdapter;
import android.widget.ExpandableListView;
import android.widget.ExpandableListView.OnGroupExpandListener;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;
public class MainActivity extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
final ExpandableListView elv = (ExpandableListView) findViewById(R.id.expandableListView);
/*限制只展開一組*/
elv.setOnGroupExpandListener(new OnGroupExpandListener() {
@Override
public void onGroupExpand(int groupPosition) {
for (int i = 0; i < elv.getCount(); i++) {
if (groupPosition != i) {
elv.collapseGroup(i);
}
}
}
});
// 準備一級清單中顯示的資料:2個一級清單,分別顯示"group1"和"group2"
List<Map<String, String>> groups = new ArrayList<Map<String, String>>();
Map<String, String> group1 = new HashMap<String, String>();
group1.put("group", "群组一");
Map<String, String> group2 = new HashMap<String, String>();
group2.put("group", "群组二");
groups.add(group1);
groups.add(group2);
// 準備第一個一級清單中的二級清單資料:兩個二級清單,分別顯示"childData1"和"childData2"
List<Map<String, String>> child1 = new ArrayList<Map<String, String>>();
Map<String, String> child1Data1 = new HashMap<String, String>();
child1Data1.put("child", "群组一:內容1");
Map<String, String> child1Data2 = new HashMap<String, String>();
child1Data2.put("child", "群组一:內容2");
child1.add(child1Data1);
child1.add(child1Data2);
child1.add(child1Data2);
// 準備第二個一級清單中的二級清單資料:一個二級清單,顯示"child2Data1"
List<Map<String, String>> child2 = new ArrayList<Map<String, String>>();
Map<String, String> child2Data1 = new HashMap<String, String>();
child2Data1.put("child", "群组二:內容1");
child2.add(child2Data1);
child2.add(child2Data1);
child2.add(child2Data1);
child2.add(child2Data1);
child2.add(child2Data1);
child2.add(child2Data1);
child2.add(child2Data1);
child2.add(child2Data1);
child2.add(child2Data1);
child2.add(child2Data1);
child2.add(child2Data1);
child2.add(child2Data1);
child2.add(child2Data1);
child2.add(child2Data1);
child2.add(child2Data1);
// 用一個list物件保存所有的二級清單資料
List<List<Map<String, String>>> childs = new ArrayList<List<Map<String, String>>>();
childs.add(child1);
childs.add(child2);
ExpandableAdapter viewAdapter = new ExpandableAdapter(this, groups,
childs);
elv.setAdapter(viewAdapter);
}
// 自訂的ExpandListAdapter
class ExpandableAdapter extends BaseExpandableListAdapter {
private Context context;
List<Map<String, String>> groups;
List<List<Map<String, String>>> childs;
/*
* 構造函數: 參數1:context物件 參數2:一級清單資料來源 參數3:二級清單資料來源
*/
public ExpandableAdapter(Context context,
List<Map<String, String>> groups,
List<List<Map<String, String>>> childs) {
this.groups = groups;
this.childs = childs;
this.context = context;
}
public Object getChild(int groupPosition, int childPosition) {
return childs.get(groupPosition).get(childPosition);
}
public long getChildId(int groupPosition, int childPosition) {
return childPosition;
}
// 獲取二級清單的View物件
public View getChildView(int groupPosition, int childPosition,
boolean isLastChild, View convertView, ViewGroup parent) {
@SuppressWarnings("unchecked")
String text = ((Map<String, String>) getChild(groupPosition,
childPosition)).get("child");
LayoutInflater layoutInflater = (LayoutInflater) context
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
// 獲取二級清單對應的佈局檔, 並將其各元素設置相應的屬性
LinearLayout linearLayout = (LinearLayout) layoutInflater.inflate(
R.layout.child_layout, null);
TextView tv = (TextView) linearLayout.findViewById(R.id.expandable_child_title);
tv.setText(text);
/*自定義背景切換-最後一個子項目*/
ImageView groupBg=(ImageView)linearLayout.findViewById(R.id.expandable_child_bg);
if (childPosition ==getChildrenCount(groupPosition)-1 )
groupBg.setImageResource(R.drawable.doroto_expandable_endbg);
return linearLayout;
}
public int getChildrenCount(int groupPosition) {
return childs.get(groupPosition).size();
}
public Object getGroup(int groupPosition) {
return groups.get(groupPosition);
}
public int getGroupCount() {
return groups.size();
}
public long getGroupId(int groupPosition) {
return groupPosition;
}
// 獲取一級清單View物件
public View getGroupView(int groupPosition, boolean isExpanded,
View convertView, ViewGroup parent) {
String text = groups.get(groupPosition).get("group");
LayoutInflater layoutInflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
// 獲取一級清單佈局檔,設置相應元素屬性
LinearLayout linearLayout = (LinearLayout) layoutInflater.inflate(
R.layout.group_layout, null);
TextView textView = (TextView) linearLayout
.findViewById(R.id.group_tv);
textView.setText(text);
/*自定義箭頭切換*/
ImageView groupArrow=(ImageView)linearLayout.findViewById(R.id.expandable_group_arrow);
/*自定義背景切換*/
ImageView groupBg=(ImageView)linearLayout.findViewById(R.id.expandable_group_bg);
if(!isExpanded){
groupArrow.setImageResource(R.drawable.doroto_expandable_up);
groupBg.setImageResource(R.drawable.doroto_expandable_closebg);
}else{
groupArrow.setImageResource(R.drawable.doroto_expandable_down);
groupBg.setImageResource(R.drawable.doroto_expandable_openbg);
}
return linearLayout;
}
public boolean hasStableIds() {
return false;
}
public boolean isChildSelectable(int groupPosition, int childPosition) {
return false;
}
}
}
6.使用的圖片![]() |
| doroto_expandable_down |
![]() |
| doroto_expandable_up |
| doroto_expandable_openbg |
| doroto_expandable_closebg |
| doroto_expandable_childbg |
| doroto_expandable_down |




沒有留言:
張貼留言