關於expandListview去掉標題,圖示的在右邊顯示,,預設展開
阿新 • • 發佈:2019-02-13
1. 設定ExpandableListView 預設是展開的:
先例項化exListView 然後
2. 去掉ExpandableListView 預設的箭頭
用到ExpandableListView時有個箭頭圖示系統自帶的在你自定義佈局也不能去掉只要設定一個屬性即可,如下:
settingLists.setGroupIndicator(null); ~~~~~~~~~~~~~~~~~此處就是設定自定義的箭頭圖示的。置空則沒有了。
也可以自定義(但是位置還是在那個地方不推薦)如下:
首先,自定義一個expandablelistviewselector.xml檔案,具體內容如下: Java程式碼
1首先ExpandableListViewelistview;
expandablelistview響應onGroupClick監聽:設定expandablelistview.setOnGroupClickListener()
摺疊和展開事件,可以設定setOnGroupCollapseListener和setOnGroupExpandListener
ExpandableListView中包含多個group,想要展開一個group時,其他group都關閉:
先例項化exListView 然後
- exListView.setAdapter(exlvAdapter);
- //遍歷所有group,將所有項設定成預設展開
- intgroupCount = exListView.getCount();
- for (inti=0; i<groupCount; i++)
- {
- exListView.expandGroup(i);
- };
2. 去掉ExpandableListView 預設的箭頭
用到ExpandableListView時有個箭頭圖示系統自帶的在你自定義佈局也不能去掉只要設定一個屬性即可,如下:
settingLists.setGroupIndicator(null); ~~~~~~~~~~~~~~~~~此處就是設定自定義的箭頭圖示的。置空則沒有了。
也可以自定義(但是位置還是在那個地方不推薦)如下:
首先,自定義一個expandablelistviewselector.xml檔案,具體內容如下: Java程式碼
- <?xmlversion="1.0"encoding="utf-8"?>
- <selectorxmlns:android="http://schemas.android.com/apk/res/android">
-
<itemandroid:state_expanded
- <itemandroid:drawable="@drawable/expandablelistviewindicator"/>
- </selector>
加一句程式碼如下:
- settingLists.setGroupIndicator(this.getResources().getDrawable(R.layout.expandablelistviewselector));
- 或xml設定:
-
android:groupIndicator="@drawable/groupIndicator_selector"
大功告成
3. 將預設的箭頭修改到右邊顯示:1首先ExpandableListViewelistview;
elistview.setGroupIndicator(null);//將控制元件預設的左邊箭頭去掉,
2在自定義的繼承自BaseExpandableListAdapter的adapter中有一個方法
- /** * 父類view */@Override
- ublic View getGroupView(intgroupPosition, booleanisExpanded, View convertView, ViewGroup parent)
- { Log.i("zhaoxiong","parent view");
- LinearLayoutparentLayout=(LinearLayout) View.inflate(context, R.layout.wowocoupons_parent_item, null);
- TextViewparentTextView=(TextView)parentLayout.findViewById(R.id.parentitem);
- parentTextView.setText(parentlist.get(groupPosition));
- ImageViewparentImageViw=(ImageView) parentLayout.findViewById(R.id.arrow);
- //判斷isExpanded就可以控制是按下還是關閉,同時更換圖片
- if(isExpanded){
- parentImageViw.setBackgroundResource(R.drawable.arrow_down);
- }else{
- parentImageViw.setBackgroundResource(R.drawable.arrow_up); }
- return parentLayout;
- }
expandablelistview響應onGroupClick監聽:設定expandablelistview.setOnGroupClickListener()
摺疊和展開事件,可以設定setOnGroupCollapseListener和setOnGroupExpandListener
ExpandableListView中包含多個group,想要展開一個group時,其他group都關閉:
- exList.setOnGroupExpandListener(new OnGroupExpandListener() {
- @Override
- publicvoid onGroupExpand(int groupPosition) {
- for (int i = 0; i < getData().size(); i++) {
- if (groupPosition != i) {
- exList.collapseGroup(i);
- }
- }
- }
- });
- tt_list.setOnGroupClickListener(new OnGroupClickListener() {
- @Override
- publicboolean onGroupClick(ExpandableListView parent, View v,
- int groupPosition, long id) {
- IsFlag=true;
- if(adapter.getGroupData().get(groupPosition).getList().size()==1){
- Bundle b=new Bundle();
- b.putInt("saveIndex", 0);
- // b.putString("mac", mac);
- // b.putString("deviceId", mDeviceId);
- b.putSerializable("datalist", adapter.getGroupData().get(groupPosition).getList());
- Intent i=new Intent(WappushBindingActivity.this,VideoPlayerActivity.class);
- i.putExtras(b);
- startActivity(i);
- }
- // int groupCount = tt_list.getCount();
- // for (int i=0; i<groupCount; i++){
- // if(i!=GroupPosition)
- // tt_list.collapseGroup(i);
- // };
- // Log.v("xulongheng*WappushBind*tt_list", "onGroupClick:"+previousX+"/"+previousY);
- returntrue; //預設為false,設為true時,點選事件不會展開Group
- }
- });