這篇文章將為大家詳細講解有關ExpandableListView如何實現手風琴效果,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
成都創新互聯專注為客戶提供全方位的互聯網綜合服務,包含不限于成都網站建設、網站建設、隨縣網絡推廣、小程序制作、隨縣網絡營銷、隨縣企業策劃、隨縣品牌公關、搜索引擎seo、人物專訪、企業宣傳片、企業代運營等,從售前售中售后,我們都將竭誠為您服務,您的肯定,是我們最大的嘉獎;成都創新互聯為所有大學生創業者提供隨縣建站搭建服務,24小時服務熱線:18982081108,官方網址:vcdvsql.cn
具體內容如下
1. 效果示例圖
2. 創建方法
(1)第一種方法與ListView等普通控件一樣,直接在布局文件中添加ExpandableListView控件即可。
(2)第二種方法則是創建一個Activity繼承自ExpandableListActivity,而后通過getExpandableListView()方法可獲得一個ExpandableListView對象。
第二種方法僅適用于一個頁面中只有一個ExpandableListView的情況。繼承的Activity不需要再調用setContentView()方法,在ExpandableListActivity中已經關聯了一個系統定義的布局文件。
3. 部分屬性和點擊事件
android:groupIndicator、android:childIndicator:組條目和子條目前面的圖標,默認值為箭頭,可設置自定義圖片資源。若不顯示該圖標,則設置為@null。
android:divider、android:childDivider:組和子條目的分隔線。
ExpandableListView的點擊事件有兩個,分別對應組和子條目的點擊事件:
設置組的點擊事件:setOnGroupClickListener(OnGroupClickListener listener)
設置子條目的點擊事件:setOnChildClickListener(OnChildClickListener listener)
5. 適配器
根據數據源的不同,可使用的適配器有兩個:BaseExpandableListAdapter和CursorTreeAdapter,其中,CursorTreeAdapter用于數據源為Cursor對象的情況下,其它情況則使用BaseExpandableListAdapter。
(1)BaseExpandableListAdapter需要重寫的方法:
getGroup():從數據源中獲取組的數據內容。
getGroupCount():獲取組的總數。
getGroupId():獲取組的ID。
getGroupView():獲取組的視圖。
getChild():從數據源中獲取子條目的內容。
getChildCount():獲取指定組中的子條目總數,并非全部的子條目。
getChildId():獲取子條目的ID。
getChildView():獲取子條目的視圖
hasStableIds():判斷id對應的條目是否已經繪制,用于優化列表。
isChildSelectable():子條目是否允許點擊,若返回false,則子條目點擊事件無效。
(2)CursorTreeAdapter需要重寫的方法:
CursorTreeAdapter():構造方法傳入組的Cursor對象。
getChildrenCursor():傳入組的Cursor對象,獲取相應的組的子條目的Cursor對象。
newGroupView():創建組的視圖,返回一個新的視圖。
bindGroupView():在這里綁定組視圖的數據內容,第一個參數即newGroupView()方法的返回值。
newChildView():創建子條目的視圖。
bindChildView():綁定子條目視圖的數據內容。
6. 簡單范例
實現效果圖中的例子。
布局:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout 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="com.studying.expandablelistviewdemo.MainActivity"> <ExpandableListView android:id="@+id/elv_local_data" android:layout_width="match_parent" android:layout_height="match_parent" /> </LinearLayout>
Activity:
public class MainActivity extends Activity { private ExpandableListView elv; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); elv = (ExpandableListView) findViewById(R.id.elv_local_data); MyBaseExpandableListAdapter adapter = new MyBaseExpandableListAdapter(this, LoadData.getGroupData(), LoadData.getChildData()); elv.setAdapter(adapter); } }
加載測試數據用的工具類:
public class LoadData { // 組的數據內容 public static List<String> getGroupData() { List<String> groupDataList = new ArrayList<>(); groupDataList.add("計算機基礎"); groupDataList.add("安卓開發"); return groupDataList; } // 子條目的數據內容 public static List<List<String>> getChildData() { List<List<String>> childDataList = new ArrayList<>(); List<String> group1 = new ArrayList<>(); group1.add("數據結構"); group1.add("算法"); group1.add("計算機網絡"); childDataList.add(group1); List<String> group2 = new ArrayList<>(); group2.add("控件使用"); group2.add("網絡操作"); group2.add("數據存儲"); group2.add("四大組件"); childDataList.add(group2); return childDataList; } }
適配器:
public class MyBaseExpandableListAdapter extends BaseExpandableListAdapter { private Context mContext; private List<String> groupName; private List<List<String>> childName; public MyBaseExpandableListAdapter(Context mContext, List<String> groupName, List<List<String>> childName) { this.mContext = mContext; this.groupName = groupName; this.childName = childName; } @Override public int getGroupCount() { return groupName.size(); } @Override public long getGroupId(int groupPosition) { return groupPosition; } @Override public String getGroup(int groupPosition) { return groupName.get(groupPosition); } @Override public View getGroupView(int groupPosition, boolean isExpanded, View convertView, ViewGroup parent) { convertView = View.inflate(mContext, R.layout.item_group_name, null); TextView groupName = (TextView) convertView.findViewById(R.id.group_name); groupName.setText(getGroup(groupPosition)); return convertView; } @Override public int getChildrenCount(int groupPosition) { return childName.get(groupPosition).size(); } @Override public long getChildId(int groupPosition, int childPosition) { return childPosition; } @Override public String getChild(int groupPosition, int childPosition) { return childName.get(groupPosition).get(childPosition); } @Override public View getChildView(int groupPosition, int childPosition, boolean isLastChild, View convertView, ViewGroup parent) { convertView = View.inflate(mContext, R.layout.item_child_name, null); TextView childName = (TextView) convertView.findViewById(R.id.child_name); childName.setText(getChild(groupPosition, childPosition)); return convertView; } @Override public boolean hasStableIds() { return false; } @Override public boolean isChildSelectable(int groupPosition, int childPosition) { return true; } }
關于“ExpandableListView如何實現手風琴效果”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
本文名稱:ExpandableListView如何實現手風琴效果
本文網址:http://vcdvsql.cn/article26/poohcg.html
成都網站建設公司_創新互聯,為您提供關鍵詞優化、企業建站、商城網站、移動網站建設、外貿網站建設、用戶體驗
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯