<?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="match_parent"
android:orientation="vertical" >
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
<ExpandableListView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:id="@+id/ecpandable"
/>
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
</LinearLayout>
package cn.csdn.activity;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AbsListView;
import android.widget.BaseExpandableListAdapter;
import android.widget.ExpandableListAdapter;
import android.widget.ExpandableListView;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
data:image/s3,"s3://crabby-images/16507/1650758e64773369e558bf6a35239aa629f2eb9d" alt="" public class ExpandableListViewActivity extends Activity {
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
@Override
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.expandable_layout);
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" /** *//**BaseExpandableListAdapter实现了ExpandableListAdapter*/
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" ExpandableListAdapter adapter = new BaseExpandableListAdapter() {
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" /** *//**----------定义数组-------------------------------------------------------------------*/
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" private int[] images = new int[] {
R.drawable.ic_launcher,
R.drawable.stop,
R.drawable.play
};
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" private String[] armTypes = new String[] {
"神族","虫族","人族"
};
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" private String[][] arms = new String[][] {
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" {"狂战士","龙骑士","黑暗圣堂"},
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" {"小狗","飞龙","自爆妃子"},
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" {"步兵","伞兵","护士mm"}
};
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" /**//*===========组元素表示可折叠的列表项,子元素表示列表项展开后看到的多个子元素项=============*/
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" /** *//**----------得到armTypes和arms中每一个元素的ID-------------------------------------------*/
//获取组在给定的位置编号,即armTypes中元素的ID
@Override
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" public long getGroupId(int groupPosition) {
return groupPosition;
}
//获取在给定的组的儿童的ID,就是arms中元素的ID
@Override
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" public long getChildId(int groupPosition, int childPosition) {
return childPosition;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" /** *//**----------根据上面得到的ID的值,来得到armTypes和arms中元素的个数 ------------------------*/
//获取的群体数量,得到armTypes里元素的个数
@Override
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" public int getGroupCount() {
return armTypes.length;
}
//取得指定组中的儿童人数,就是armTypes中每一个种族它军种的个数
@Override
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" public int getChildrenCount(int groupPosition) {
return arms[groupPosition].length;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" /** *//**----------利用上面getGroupId得到ID,从而根据ID得到armTypes中的数据,并填到TextView中 -----*/
//获取与给定的组相关的数据,得到数组armTypes中元素的数据
@Override
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" public Object getGroup(int groupPosition) {
return armTypes[groupPosition];
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
//获取一个视图显示给定组,存放armTypes
@Override
public View getGroupView(int groupPosition, boolean isExpanded,
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" View convertView, ViewGroup parent) {
TextView textView = getTextView();//调用定义的getTextView()方法
textView.setText(getGroup(groupPosition).toString());//添加数据
return textView;
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" /** *//**----------利用上面getChildId得到ID,从而根据ID得到arms中的数据,并填到TextView中---------*/
//获取与孩子在给定的组相关的数据,得到数组arms中元素的数据
@Override
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" public Object getChild(int groupPosition, int childPosition) {
return arms[groupPosition][childPosition];
}
//获取一个视图显示在给定的组 的儿童的数据,就是存放arms
@Override
public View getChildView(int groupPosition, int childPosition, boolean isLastChild,
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" View convertView, ViewGroup parent) {
LinearLayout ll = new LinearLayout(ExpandableListViewActivity.this);
ll.setOrientation(0);//定义为纵向排列
ImageView logo = new ImageView(ExpandableListViewActivity.this);
logo.setImageResource(images[groupPosition]);//添加图片
ll.addView(logo);
TextView textView = getTextView();//调用定义的getTextView()方法
textView.setText(getChild(groupPosition,childPosition).toString());//添加数据
ll.addView(textView);
return ll;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" /** *//**------------------自定义一个设定TextView属性的方法----------------------------------------------*/
//定义一个TextView
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" private TextView getTextView() {
AbsListView.LayoutParams lp = new AbsListView.LayoutParams(ViewGroup.LayoutParams.FILL_PARENT,40);
TextView textView = new TextView(ExpandableListViewActivity.this);
textView.setLayoutParams(lp);
textView.setPadding(36, 0, 0, 0);
textView.setTextSize(20);
return textView;
}
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" /** *//**-------------------其他设置-------------------------------------------------------------------*/
//孩子在指定的位置是可选的,即:arms中的元素是可点击的
@Override
public boolean isChildSelectable(int groupPosition,
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" int childPosition) {
return true;
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
//表示孩子是否和组ID是跨基础数据的更改稳定
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" public boolean hasStableIds() {
return true;
}
};
data:image/s3,"s3://crabby-images/4989c/4989c5aa5aeee035dc328aff8277d531300533ab" alt="" /** *//**使用适配器*/
ExpandableListView expandListView = (ExpandableListView) this.findViewById(R.id.ecpandable);
expandListView.setAdapter(adapter);
}
data:image/s3,"s3://crabby-images/a0398/a0398c5eaea7654f53f3ad01f4ef86b30b77f7b1" alt=""
}
data:image/s3,"s3://crabby-images/370e0/370e053b28c0d1e5a884270fad646284f2d183b3" alt=""
data:image/s3,"s3://crabby-images/83749/83749b8594e8948a03e6d0f1e08d2656ce80138d" alt=""
|