中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android中ExpandableListView怎么用

發布時間:2021-08-23 10:05:43 來源:億速云 閱讀:117 作者:小新 欄目:開發技術

小編給大家分享一下Android中ExpandableListView怎么用,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

一、前言

  講解一下ExpandableListView的使用方法,感覺對于二級條目顯示功能都可以實現。

二、實現的功能

1、可實現二級列表條目顯示功能,具體包括可自定義,父布局和子布局。可實現父布局全部展開和只展開一個功能。

Android中ExpandableListView怎么用

三、具體代碼

1、主xml代碼

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:orientation="vertical"
    android:layout_height="match_parent">
    <include layout="@layout/top"/>
    <ExpandableListView
        android:id="@+id/expand_list_id"
        android:layout_width="match_parent"
        android:groupIndicator="@null"
        android:layout_height="match_parent">
    </ExpandableListView>
</LinearLayout>

2、父布局xml代碼

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:background="@color/blue"
    android:layout_height="50dp">
    <TextView
        android:id="@+id/parent_textview_id"
        android:layout_width="wrap_content"
        android:text="測試"
        android:textColor="@color/white"
        android:gravity="center_vertical"
        android:paddingLeft="10dp"
        android:textSize="18sp"
        android:layout_height="match_parent" />
 
    <ImageView
        android:id="@+id/parent_image"
        android:layout_width="wrap_content"
        android:layout_alignParentRight="true"
        android:src="@drawable/img_arrow_right"
        android:layout_centerInParent="true"
        android:paddingRight="10dp"
        android:layout_height="wrap_content" />
 
</RelativeLayout>

3、子布局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="match_parent">
    <TextView
        android:id="@+id/chidren_item"
        android:layout_width="match_parent"
        android:text="子項目"
        android:gravity="center_vertical"
        android:paddingLeft="10dp"
        android:textColor="@color/black"
        android:layout_height="40dp" />
 
</LinearLayout>

4、主activity代碼

**
 * Created by fyf on 2019/3/1.
 * 描述:用于實現ExpandableListView的類,主要功能是實現二級列表條目顯示
 */
public class ExpandableListviewActivity extends BaseActivity {
    private ExpandableListView expand_list_id;
    //Model:定義的數據
    private String[] groups = {"開發部", "人力資源部", "銷售部"};
 
    //注意,字符數組不要寫成{{"A1,A2,A3,A4"}, {"B1,B2,B3,B4,B5"}, {"C1,C2,C3,C4"}}
    private String[][] childs = {{"趙珊珊", "錢丹丹", "孫可可", "李冬冬"}, {"周大福", "吳端口", "鄭非", "王瘋狂"}, {"馮程程", "陳類", "楚哦", "魏王"}};
 
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.expandable_list_view);
        setTitle("ExpandableListView二級下拉",false,"");
        initView();
    }
    private void initView(){
        expand_list_id=findViewById(R.id.expand_list_id);
        ExpandableListviewAdapter adapter=new ExpandableListviewAdapter(this,groups,childs);
        expand_list_id.setAdapter(adapter);
        //默認展開第一個數組
        expand_list_id.expandGroup(0);
        //關閉數組某個數組,可以通過該屬性來實現全部展開和只展開一個列表功能
        //expand_list_id.collapseGroup(0);
        expand_list_id.setOnGroupClickListener(new ExpandableListView.OnGroupClickListener() {
            @Override
            public boolean onGroupClick(ExpandableListView expandableListView, View view, int groupPosition, long l) {
                showToastShort(groups[groupPosition]);
                return false;
            }
        });
        //子視圖的點擊事件
        expand_list_id.setOnChildClickListener(new ExpandableListView.OnChildClickListener() {
            @Override
            public boolean onChildClick(ExpandableListView expandableListView, View view, int groupPosition, int childPosition, long l) {
                showToastShort(childs[groupPosition][childPosition]);
                return true;
            }
        });
        //用于當組項折疊時的通知。
        expand_list_id.setOnGroupCollapseListener(new ExpandableListView.OnGroupCollapseListener() {
            @Override
            public void onGroupCollapse(int groupPosition) {
                showToastShort("折疊了數據___"+groups[groupPosition]);
            }
        });
        //
        //用于當組項折疊時的通知。
        expand_list_id.setOnGroupExpandListener(new ExpandableListView.OnGroupExpandListener() {
            @Override
            public void onGroupExpand(int groupPosition) {
                showToastShort("展開了數據___"+groups[groupPosition]);
            }
        });
    }
}

5、adapter代碼

/**
 * Created by fyf on 2019/3/1.
 * 描述:是二級顯示列表的adapter
 */
public class ExpandableListviewAdapter extends BaseExpandableListAdapter {
    //Model:定義的數據
    private String[] groups;
    //注意,字符數組不要寫成{{"A1,A2,A3,A4"}, {"B1,B2,B3,B4,B5"}, {"C1,C2,C3,C4"}}
    private String[][] childs;
    private Context context;
 
    public ExpandableListviewAdapter(Context context,String[] groups,String[][] childs){
        this.context=context;
        this.groups=groups;
        this.childs=childs;
    }
 
    @Override
    public int getGroupCount() {
        return groups.length;
    }
 
    @Override
    public int getChildrenCount(int i) {
        return childs[i].length;
    }
 
    @Override
    public Object getGroup(int i) {
        return groups[i];
    }
 
    @Override
    public Object getChild(int i, int i1) {
        return childs[i][i1];
    }
 
    @Override
    public long getGroupId(int i) {
        return i;
    }
 
    @Override
    public long getChildId(int i, int i1) {
        return i1;
    }
 
    @Override
    //分組和子選項是否持有穩定的ID, 就是說底層數據的改變會不會影響到它們
    public boolean hasStableIds() {
        return true;
    }
 
    @Override
/**
 *
 * 獲取顯示指定組的視圖對象
 *
 * @param groupPosition 組位置
 * @param isExpanded 該組是展開狀態還是伸縮狀態,true=展開
 * @param convertView 重用已有的視圖對象
 * @param parent 返回的視圖對象始終依附于的視圖組
 */
    public View getGroupView(int groupPosition, boolean isExpanded, View convertView, ViewGroup parent) {
        GroupViewHolder groupViewHolder;
        if (convertView == null){
            convertView = LayoutInflater.from(parent.getContext()).inflate(R.layout.expand_parent_item,parent,false);
            groupViewHolder = new GroupViewHolder();
            groupViewHolder.parent_textview_id = convertView.findViewById(R.id.parent_textview_id);
            groupViewHolder.parent_image = convertView.findViewById(R.id.parent_image);
            convertView.setTag(groupViewHolder);
        }else {
            groupViewHolder = (GroupViewHolder)convertView.getTag();
        }
        groupViewHolder.parent_textview_id.setText(groups[groupPosition]);
        //如果是展開狀態,
        if (isExpanded){
            groupViewHolder.parent_image.setImageDrawable(ContextCompat.getDrawable(context,R.drawable.img_arrow_down));
        }else{
            groupViewHolder.parent_image.setImageDrawable(ContextCompat.getDrawable(context,R.drawable.img_arrow_right));
        }
        return convertView;
    }
 
    @Override
    public View getChildView(int groupPosition, int childPosition, boolean isLastChild, View convertView, ViewGroup parent) {
        ChildViewHolder childViewHolder;
        if (convertView==null){
            convertView = LayoutInflater.from(parent.getContext()).inflate(R.layout.expand_chidren_item,parent,false);
            childViewHolder = new ChildViewHolder();
            childViewHolder.chidren_item = (TextView)convertView.findViewById(R.id.chidren_item);
            convertView.setTag(childViewHolder);
 
        }else {
            childViewHolder = (ChildViewHolder) convertView.getTag();
        }
        childViewHolder.chidren_item.setText(childs[groupPosition][childPosition]);
        return convertView;
    }
 
    //指定位置上的子元素是否可選中
    @Override
    public boolean isChildSelectable(int i, int i1) {
        return true;
    }
    static class GroupViewHolder {
        TextView parent_textview_id;
        ImageView parent_image;
    }
 
    static class ChildViewHolder {
        TextView chidren_item;
 
    }
}

看完了這篇文章,相信你對“Android中ExpandableListView怎么用”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

漯河市| 醴陵市| 怀集县| 乡宁县| 洞头县| 青州市| 姜堰市| 乳源| 济源市| 东乡| 甘南县| 西充县| 泽州县| 增城市| 贵南县| 东至县| 泌阳县| 成武县| 临颍县| 卫辉市| 兴宁市| 榕江县| 江口县| 万宁市| 鄂州市| 商都县| 三江| 重庆市| 迭部县| 德庆县| 临澧县| 杭锦后旗| 塘沽区| 岳阳市| 澜沧| 淅川县| 伽师县| 上蔡县| 拉孜县| 任丘市| 安吉县|