ExpandableListView - 隐藏没有子项的组的指示符

问题描述 投票:101回答:13

ExpandableListView中,有没有办法隐藏没有孩子的团体的群组指标?

android android-listview expandablelistview
13个回答
104
投票

试试这个>>>

对于所有项目

 getExpandableListView().setGroupIndicator(null);

在xml中

android:groupIndicator="@null"

0
投票

简单地说,为隐藏的组头创建一个高度为0的新xml布局。例如,它是'group_list_item_empty.xml'

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"              
              android:layout_width="match_parent"
              android:layout_height="0dp">
</RelativeLayout>

那么您的正常组头布局是'your_group_list_item_file.xml'

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              android:layout_width="match_parent"
              android:layout_height="48dp"
              android:orientation="horizontal">
    ...your xml layout define...
</LinearLayout>

最后,您只需更新Adapter Class中的getGroupView方法:

public class MyExpandableListAdapter extends BaseExpandableListAdapter{   

    //Your code here ...

    @Override
    public View getGroupView(int groupPosition, boolean isExpanded, View convertView, ViewGroup viewGroup) {
        if (Your condition to hide the group header){
            if (convertView == null || convertView instanceof LinearLayout) {
                LayoutInflater mInflater = (LayoutInflater) context.getSystemService(Activity.LAYOUT_INFLATER_SERVICE);
                convertView = mInflater.inflate(R.layout.group_list_item_empty, null);
            }           
            return convertView;
        }else{      
            if (convertView == null || convertView instanceof RelativeLayout) {
                LayoutInflater mInflater = (LayoutInflater) context.getSystemService(Activity.LAYOUT_INFLATER_SERVICE);
                convertView = mInflater.inflate(R.layout.your_group_list_item_file, null);              
            }   
            //Your code here ...
            return convertView;
        }
    }
}

重要说明:布局文件的根标签(隐藏和正常)必须不同(如上例所示,LinearLayout和RelativeLayout)


0
投票

你有没有试过改变ExpandableListView的属性android:groupIndicator="@null"


0
投票

只想改进Mihir Trivedi的答案。您可以将它放在MyExpandableListAdapter类中的getGroupView()中

    View ind = convertView.findViewById(R.id.group_indicator);
    View ind2 = convertView.findViewById(R.id.group_indicator2);
    if (ind != null)
    {
        ImageView indicator = (ImageView) ind;
        if (getChildrenCount(groupPosition) == 0)
        {
            indicator.setVisibility(View.INVISIBLE);
        }
        else
        {
            indicator.setVisibility(View.VISIBLE);
            int stateSetIndex = (isExpanded ? 1 : 0);

            /*toggles down button to change upwards when list has expanded*/
            if(stateSetIndex == 1){
                ind.setVisibility(View.INVISIBLE);
                ind2.setVisibility(View.VISIBLE);
                Drawable drawable = indicator.getDrawable();
                drawable.setState(GROUP_STATE_SETS[stateSetIndex]);
            }
            else if(stateSetIndex == 0){
                ind.setVisibility(View.VISIBLE);
                ind2.setVisibility(View.INVISIBLE);
                Drawable drawable = indicator.getDrawable();
                drawable.setState(GROUP_STATE_SETS[stateSetIndex]);
            }
        }
    }

...至于布局视图,这就是我的group_items.xml的样子

<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">

<TextView
    android:id="@+id/group_heading"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:paddingLeft="20dp"
    android:paddingTop="16dp"
    android:paddingBottom="16dp"
    android:textSize="15sp"
    android:textStyle="bold"/>

<ImageView
    android:id="@+id/group_indicator"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:src="@android:drawable/arrow_down_float"
    android:layout_alignParentRight="true"
    android:paddingRight="20dp"
    android:paddingTop="20dp"/>

<ImageView
    android:id="@+id/group_indicator2"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:src="@android:drawable/arrow_up_float"
    android:layout_alignParentRight="true"
    android:visibility="gone"
    android:paddingRight="20dp"
    android:paddingTop="20dp"/>

希望有所帮助......记得留下一个upvote


-2
投票

convertView.setVisibility(View.GONE)应该可以解决问题。

@Override
public View getGroupView(int groupPosition, boolean isExpanded, View convertView, ViewGroup parent) {
    DistanceHolder holder;
    if (convertView == null) {
        convertView = LayoutInflater.from(context).inflate(R.layout.list_search_distance_header, parent, false);
        if (getChildrenCount(groupPosition)==0) {
            convertView.setVisibility(View.GONE);
        }

88
投票

android:groupIndicator属性采用启用状态的drawable。也就是说,您可以为不同的状态设置不同的图像。

当该组没有子节点时,相应的状态为“state_empty”

请参阅以下参考链接:

thisthis

对于state_empty,你可以设置一个不混淆的不同图像,或者,只是使用透明颜色来显示任何内容......

在你的有状态的drawable中添加这个项目和其他人....

<item android:state_empty="true" android:drawable="@android:color/transparent"/>

所以,你的州名单可以是这样的:

<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_empty="true" android:drawable="@android:color/transparent"/>
    <item android:state_expanded="true" android:drawable="@drawable/my_icon_max" />
    <item android:drawable="@drawable/my_icon_min" />
</selector>

如果您使用的是ExpandableListActivity,则可以在onCreate中设置groupindicator,如下所示:

getExpandableListView().setGroupIndicator(getResources().getDrawable(R.drawable.my_group_statelist));

我测试过这个工作。


39
投票

根据StrayPointer的答案和博客中的代码,您可以进一步简化代码:

在您的xml中,将以下内容添加到ExpandableListView:

android:groupIndicator="@android:color/transparent"

然后在适配器中执行以下操作:

@Override
protected void bindGroupView(View view, Context paramContext, Cursor cursor, boolean paramBoolean){
    **...**

    if ( getChildrenCount( groupPosition ) == 0 ) {
       indicator.setVisibility( View.INVISIBLE );
    } else {
       indicator.setVisibility( View.VISIBLE );
       indicator.setImageResource( isExpanded ? R.drawable.list_group_expanded : R.drawable.list_group_closed );
    }
}

通过使用setImageResource方法,您可以使用单行完成所有操作。您的适配器中不需要三个Integer数组。对于展开和折叠状态,您也不需要XML选择器。一切都是通过Java完成的。

此外,默认情况下扩展组时,此方法还会显示正确的指示符,这与博客中的代码无关。


25
投票

正如在不同的答案中所提到的,由于Android将未展开的列表组视为空,即使该组具有子项,也不会绘制图标。

这个链接解决了我的问题:http://mylifewithandroid.blogspot.com/2011/06/hiding-group-indicator-for-empty-groups.html

基本上,您必须将默认drawable设置为透明,将drawable作为ImageView移动到组视图中,并在适配器中切换图像。


11
投票

在您的代码中,只需使用自定义xml作为组列表,然后将ImageView用于GroupIndicator。

并在ExpandableListAdapter中添加以下数组

private static final int[] EMPTY_STATE_SET = {};
private static final int[] GROUP_EXPANDED_STATE_SET = { android.R.attr.state_expanded };
private static final int[][] GROUP_STATE_SETS = { EMPTY_STATE_SET, // 0
GROUP_EXPANDED_STATE_SET // 1
};

同样在ExpandableListAdapter的方法中添加如下相同的内容

public View getGroupView(int groupPosition, boolean isExpanded, View convertView, ViewGroup parent) 
{ 
    if (convertView == null) 
    {
        LayoutInflater infalInflater = (LayoutInflater) this._context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
        convertView = infalInflater.inflate(R.layout.row_group_list, null);
    }

    //Image view which you put in row_group_list.xml
    View ind = convertView.findViewById(R.id.iv_navigation);
    if (ind != null)
    {
        ImageView indicator = (ImageView) ind;
        if (getChildrenCount(groupPosition) == 0) 
        {
            indicator.setVisibility(View.INVISIBLE);
        } 
        else 
        {
            indicator.setVisibility(View.VISIBLE);
            int stateSetIndex = (isExpanded ? 1 : 0);
            Drawable drawable = indicator.getDrawable();
            drawable.setState(GROUP_STATE_SETS[stateSetIndex]);
        }
    }

    return convertView;
}

参考:http://mylifewithandroid.blogspot.in/2011/06/hiding-group-indicator-for-empty-groups.html


7
投票

这可能是另一种来自XML的方法,设置android:groupIndicator="@null"

参考链接:https://stackoverflow.com/a/5853520/2624806


4
投票

在XML中

android:groupIndicator="@null"

ExpandableListAdapter - > getGroupView复制以下代码

if (this.mListDataChild.get(this.mListDataHeader.get(groupPosition)).size() > 0){
      if (isExpanded) {
          arrowicon.setImageResource(R.drawable.group_up);
      } else {
          arrowicon.setImageResource(R.drawable.group_down);
      }
}

3
投票

建议你我的解决方案:

1)清除默认groupIndicator:

<ExpandableListView
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"       
    android:layout_width="wrap_content"
    android:layout_height="240dp"        
    android:layout_gravity="start"
    android:background="#cccc"  
    android:groupIndicator="@android:color/transparent"     
    android:choiceMode="singleChoice"
    android:divider="@android:color/transparent"        
    android:dividerHeight="0dp"  
     />

2)在ExpandableAdapter中:

@Override
public View getGroupView(int groupPosition, boolean isExpanded,
        View convertView, ViewGroup parent) {
    if (convertView == null) {
        convertView = new TextView(context);
    }
    ((TextView) convertView).setText(groupItem.get(groupPosition));     
    ((TextView) convertView).setHeight(groupHeight);
    ((TextView) convertView).setTextSize(groupTextSize);

    //create groupIndicator using TextView drawable
    if (getChildrenCount(groupPosition)>0) {
        Drawable zzz ;
        if (isExpanded) {
            zzz = context.getResources().getDrawable(R.drawable.arrowup);
        } else {
            zzz = context.getResources().getDrawable(R.drawable.arrowdown);
        }                               
        zzz.setBounds(0, 0, groupHeight, groupHeight);
        ((TextView) convertView).setCompoundDrawables(null, null,zzz, null);
    }       
    convertView.setTag(groupItem.get(groupPosition));       

    return convertView;
}

0
投票

使用它对我来说非常有用。

<selector xmlns:android="http://schemas.android.com/apk/res/android">

<item android:drawable="@drawable/group_indicator_expanded" android:state_empty="false" android:state_expanded="true"/>
<item android:drawable="@drawable/group_indicator" android:state_empty="true"/>
<item android:drawable="@drawable/group_indicator"/>

</selector>
© www.soinside.com 2019 - 2024. All rights reserved.