Android 如何设置expandablelist底部的页脚?
我使用了expandablelist,我想在屏幕底部设置它的页脚,但它不起作用。我附上了它的代码和截图Android 如何设置expandablelist底部的页脚?,android,expandablelistview,footer,Android,Expandablelistview,Footer,我使用了expandablelist,我想在屏幕底部设置它的页脚,但它不起作用。我附上了它的代码和截图 <ExpandableListView android:layout_alignParentBottom="true" android:id="@+id/list_slidermenu" android:layout_width="260dp" android:layout_height="fill_parent"
<ExpandableListView
android:layout_alignParentBottom="true"
android:id="@+id/list_slidermenu"
android:layout_width="260dp"
android:layout_height="fill_parent"
android:layout_gravity="start"
android:background="@color/colorAccent"
android:choiceMode="singleChoice"
android:divider="@color/colorPrimary"
android:dividerHeight="1dp"
android:groupIndicator="@null"
android:listSelector="@drawable/list_selector" >
</ExpandableListView>
expListView = (ExpandableListView) findViewById(R.id.list_slidermenu);
TextView textView = new TextView(this);
textView.setText("footer");
expListView.addFooterView(textView);
expListView=(ExpandableListView)findViewById(R.id.list\u slidermenu);
TextView TextView=新的TextView(此);
setText(“页脚”);
expListView.addFooterView(文本视图);
编辑的
public class ExpandableListAdapter extends BaseExpandableListAdapter {
private Context _context;
private List<String> _listDataHeader; // header titles
// child data in format of header title, child title
private HashMap<String, List<String>> _listDataChild;
public ExpandableListAdapter(Context context,
List<String> listDataHeader,
HashMap<String, List<String>> listChildData) {
this._context = context;
this._listDataHeader = listDataHeader;
this._listDataChild = listChildData;
}
@Override
public Object getChild(int groupPosition, int childPosititon) {
return this._listDataChild.get(
this._listDataHeader.get(groupPosition))
.get(childPosititon);
}
@Override
public long getChildId(int groupPosition, int childPosition) {
return childPosition;
}
@Override
public View getChildView(int groupPosition, final int childPosition,
boolean isLastChild, View convertView, ViewGroup parent) {
final String childText = (String) getChild(groupPosition,
childPosition);
if (convertView == null) {
LayoutInflater infalInflater = (LayoutInflater) this._context
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
convertView = infalInflater.inflate(R.layout.list_item, null);
}
TextView txtListChild = (TextView) convertView
.findViewById(R.id.lblListItem);
txtListChild.setText(childText);
Drawable drawable = getDrawable(R.drawable.ic_menu_gallery);
txtListChild.setCompoundDrawablesRelativeWithIntrinsicBounds(drawable, null, null, null);
return convertView;
}
@Override
public int getChildrenCount(int groupPosition) {
return this._listDataChild.get(
this._listDataHeader.get(groupPosition)).size();
}
@Override
public Object getGroup(int groupPosition) {
return this._listDataHeader.get(groupPosition);
}
@Override
public int getGroupCount() {
return this._listDataHeader.size();
}
@Override
public long getGroupId(int groupPosition) {
return groupPosition;
}
@Override
public View getGroupView(int groupPosition, boolean isExpanded,
View convertView, ViewGroup parent) {
String headerTitle = (String) getGroup(groupPosition);
if (convertView == null) {
LayoutInflater infalInflater = (LayoutInflater) this._context
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
convertView = infalInflater.inflate(R.layout.list_group, null);
}
// changing the +/- on expanded list view
TextView txt_plusminus = (TextView) convertView
.findViewById(R.id.plus_txt);
if (isExpanded) {
txt_plusminus.setText("-");
Drawable plusDrawable = getDrawable(android.R.drawable.ic_menu_more);
plusDrawable.setBounds(0, 0, 0, 0); txt_plusminus.setCompoundDrawablesWithIntrinsicBounds(android.R.drawable.btn_dropdown, 0, 0, 0);
txt_plusminus.setCompoundDrawablesRelativeWithIntrinsicBounds(null, null, plusDrawable, null);
// txt_plusminus.setCompoundDrawablesRelativeWithIntrinsicBounds(null,null,plusDrawable,null);
} else {
txt_plusminus.setText("+");
}
TextView lblListHeader = (TextView) convertView
.findViewById(R.id.lblListHeader);
// lblListHeader.setTypeface(null, Typeface.BOLD);
lblListHeader.setText(headerTitle);
lblListHeader.setTextColor(getColor(R.color.black));
// nav drawer icons from resources
// navMenuIcons =
// getResources().obtainTypedArray(R.array.nav_drawer_icons);
// imgListGroup.setImageDrawable(navMenuIcons.getDrawable(groupPosition));
// adding icon to expandable list view
ImageView imgListGroup = (ImageView) convertView
.findViewById(R.id.ic_txt);
imgListGroup.setImageResource(SubMenuActivity.icon[groupPosition]);
return convertView;
}
@Override
public boolean hasStableIds() {
return false;
}
@Override
public boolean isChildSelectable(int groupPosition, int childPosition) {
return true;
}
}
enter code here
公共类ExpandableListAdapter扩展了BaseExpandableListAdapter{
私人语境(private Context)(私人语境);;
私有列表_listDataHeader;//头标题
//标题标题、子标题格式的子数据
私有HashMap_listDataChild;
公共ExpandableListAdapter(上下文,
列表listDataHeader,
HashMap listChildData){
这._context=context;
这。_listDataHeader=listDataHeader;
这。_listDataChild=listChildData;
}
@凌驾
公共对象getChild(int-groupPosition、int-ChildPosition){
返回此。\u listDataChild.get(
此._listDataHeader.get(groupPosition))
.get(childpositionon);
}
@凌驾
公共长getChildId(int-groupPosition,int-childPosition){
返回子位置;
}
@凌驾
公共视图getChildView(int groupPosition,final int childPosition,
布尔值isLastChild、视图转换视图、视图组父级){
最终字符串childText=(字符串)getChild(groupPosition,
儿童体位);
if(convertView==null){
LayoutInflater infalInflater=(LayoutInflater)this.\u上下文
.getSystemService(上下文布局\充气机\服务);
convertView=infalInflater.充气(R.layout.list_项,空);
}
TextView txtListChild=(TextView)convertView
.findviewbyd(R.id.lblListItem);
setText(childText);
Drawable Drawable=getDrawable(R.Drawable.ic\u菜单\u画廊);
setCompoundDrawablesRelativeWithIntrinsicBounds(drawable,null,null,null);
返回视图;
}
@凌驾
公共整数getChildrenCount(整数组位置){
返回此。\u listDataChild.get(
这是.u listDataHeader.get(groupPosition)).size();
}
@凌驾
公共对象getGroup(int-groupPosition){
返回此。\u listDataHeader.get(groupPosition);
}
@凌驾
public int getGroupCount(){
返回此值。_listDataHeader.size();
}
@凌驾
公共长getGroupId(int-groupPosition){
返回组位置;
}
@凌驾
公共视图getGroupView(int-groupPosition,布尔值isExpanded,
视图(视图、视图组父级){
字符串头文件=(字符串)getGroup(groupPosition);
if(convertView==null){
LayoutInflater infalInflater=(LayoutInflater)this.\u上下文
.getSystemService(上下文布局\充气机\服务);
convertView=infalInflater.充气(R.layout.list_组,空);
}
//更改展开列表视图上的+/-值
TextView txt_plusminus=(TextView)convertView
.findviewbyd(R.id.plus_txt);
如果(扩展){
txt_plusminus.setText(“-”);
Drawable plusDrawable=getDrawable(android.R.Drawable.ic\u菜单\u更多);
plusDrawable.setBounds(0,0,0,0);txt_plusminus.setCompoundDrawable SwithinInsitCBounds(android.R.drawable.btn_下拉列表,0,0);
txt_plusminus.setCompoundDrawablesRelativeWithIntrinsicBounds(null,null,plusDrawable,null);
//txt_plusminus.setCompoundDrawablesRelativeWithIntrinsicBounds(null,null,plusDrawable,null);
}否则{
txt_plusminus.setText(“+”);
}
TextView lblistheader=(TextView)convertView
.findviewbyd(R.id.lblistheader);
//lblListHeader.setTypeface(null,Typeface.BOLD);
lblListHeader.setText(标题);
lblListHeader.setTextColor(getColor(R.color.black));
//参考资料中的导航抽屉图标
//导航仪=
//getResources().obtainTypedArray(R.array.nav_抽屉图标);
//imgListGroup.setImageDrawable(navMenuics.getDrawable(groupPosition));
//向可展开列表视图添加图标
ImageView imgListGroup=(ImageView)convertView
.findviewbyd(R.id.ic_txt);
imgListGroup.setImageResource(submenuality.icon[groupPosition]);
返回视图;
}
@凌驾
公共布尔表ID(){
返回false;
}
@凌驾
公共布尔值isChildSelectable(int-groupPosition,int-childPosition){
返回true;
}
}
在这里输入代码
您可以使用以下代码在列表中添加页脚:
View v= inflator.inflate(R.layout.your_view, null);
expandableList.addFooterView(v);
您可以使用以下代码在列表中添加页脚:
View v= inflator.inflate(R.layout.your_view, null);
expandableList.addFooterView(v);
查看以下代码:
View v= inflator.inflate(R.layout.your_view, null);
expandableList.addFooterView(v);
公共类MainActivity扩展了AppCompatActivity{
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ExpandableListView list = findViewById(R.id.list_slidermenu);
TextView v = new TextView(this);
v.setText("Footer");
list.addFooterView(v);
list.setAdapter(new ExpanadableListAdapter());
}
class ExpanadableListAdapter extends BaseExpandableListAdapter {
@Override
public int getGroupCount() {
return 0;
}
@Override
public int getChildrenCount(int groupPosition) {
return 0;
}
@Override
public Object getGroup(int groupPosition) {
return null;
}
@Override
public Object getChild(int groupPosition, int childPosition) {
return null;
}
@Override
public long getGroupId(int groupPosition) {
return 0;
}
@Override
public long getChildId(int groupPosition, int childPosition) {
return 0;
}
@Override
public boolean hasStableIds() {
return false;
}
@Override
public View getGroupView(int groupPosition, boolean isExpanded, View convertView, ViewGroup parent) {
return null;
}
@Override
public View getChildView(int groupPosition, int childPosition, boolean isLastChild, View convertView, ViewGroup parent) {
return null;
}
@Override
public boolean isChildSelectable(int groupPosition, int childPosition) {
return false;
}
}
}
查看以下代码:
View v= inflator.inflate(R.layout.your_view, null);
expandableList.addFooterView(v);
公共类MainActivity扩展了AppCompatActivity{
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ExpandableListView list = findViewById(R.id.list_slidermenu);
TextView v = new TextView(this);
v.setText("Footer");
list.addFooterView(v);
list.setAdapter(new ExpanadableListAdapter());
}
class ExpanadableListAdapter extends BaseExpandableListAdapter {
@Override
public int getGroupCount() {
return 0;
}
@Override
public int getChildrenCount(int groupPosition) {
return 0;
}
@Override
public Object getGroup(int groupPosition) {
return null;
}
@Override
public Object getChild(int groupPosition, int childPosition) {
return null;
}
@Override
public long getGroupId(int groupPosition) {
return 0;
}
@Override
public long getChildId(int groupPosition, int childPosition) {
return 0;
}
@Override
public boolean hasStableIds() {
return false;
}
@Override
public View getGroupView(int groupPosition, boolean isExpanded, View convertView, ViewGroup parent) {
return null;
}
@Override
public View getChildView(int groupPosition, int childPosition, boolean isLastChild, View convertView, ViewGroup parent) {
return null;
}
@Override
public boolean isChildSelectable(int groupPosition, int childPosition) {
return false;
}
}
}
Footer
view将在列表的最后一项之后获得add。因此这是addFooterView()的预期输出
。如果您需要视图始终位于底部,您可以使用底部对齐的视图列表视图
。或者使用页脚视图
方法,您可以使用列表视图
填充高度,以便