我有ListView
的自定义适配器我想将项目名称添加为工作请求的标题。添加单个标头工作正常,但我不确定如何使用addHeaderView
添加多个标头。我不明白到底放置setAdapter
的确切位置,还是应该放置多次?
这是我的单个标头的java代码:
mListView = (ListView)findViewById(R.id.dashboardList);
View header1 = getLayoutInflater().inflate(R.layout.listview_header, null, false);
tv = (TextView) header1.findViewById(R.id.listHeader);
adapter = new MyCustomAdapter(MyDashboardActivity.this, R.layout.mydashboard_row, dashboardBean);
tv.setText("Project 1");
mListView.addHeaderView(header1, null, false);
for (int i=0; i < 7; i++) {
dashboardBean.add(new DashboardBean(workRequests[i],status[i],actualHours[i]));
}
mListView.setAdapter(adapter);
现在,我尝试了两个标题:
mListView = (ListView)findViewById(R.id.dashboardList);
View header1 = getLayoutInflater().inflate(R.layout.listview_header, null, false);
tv = (TextView) header1.findViewById(R.id.listHeader);
adapter = new MyCustomAdapter(MyDashboardActivity.this, R.layout.mydashboard_row, dashboardBean);
tv.setText("RxOffice");
mListView.addHeaderView(header1, null, false);
for (int i=0; i < 4; i++) {
dashboardBean.add(new DashboardBean(workRequests[i],status[i],actualHours[i]));
}
tv.setText(Project 2");
mListView.addHeaderView(header1, null, false);
for (int i=4; i < workRequests.length; i++) {
dashboardBean.add(new DashboardBean(workRequests[i],status[i],actualHours[i]));
}
mListView.setAdapter(adapter);
但这不起作用!它只给我Project 2标题和它下面的所有7个条目。谁能告诉我有什么问题?我猜这与setAdapter
有关。谢谢!
答案 0 :(得分:11)
我不认为你想做的事情可能就像你想要做的那样。当您使用addHeaderView
时,它会将ListAdapter
包裹在HeaderViewListAdapter
中。我查看了它的文档here,这似乎意味着你可以有多个标题,但它们都会位于顶部(duh,标题)。
听起来你真正想要的是分隔符......
您可以使用CommonWare's MergeAdapter。它将允许您插入适配器和视图(以您希望的任何顺序),并将它们作为单个适配器呈现给列表视图。您只需为每个内容部分提供标题和适配器,然后将其设置为列表。
伪代码示例:
myMergeAdapter = new MergeAdapter();
myMergeAdapter.addView(HeaderView1);
myMergeAdapter.addAdapter(listAdapter1);
myMergeAdapter.addView(HeaderView2);
myMergeAdapter.addAdapter(listAdapter2);
setListAdapter(myMergeAdapter);
答案 1 :(得分:2)
我使用最初由CommonsWare编码的自定义Section Adapter
实现了多个标题方案,您可以在listivew中创建部分,例如Books,Games等。请查看以下代码。
部分适配器:
package com.medplan.db;
import java.util.ArrayList;
import java.util.List;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Adapter;
import android.widget.BaseAdapter;
abstract public class SectionedAdapter extends BaseAdapter {
String TAG = "========SectionedAdapter============";
abstract protected View getHeaderView(String caption,
int index,
View convertView,
ViewGroup parent);
private List<Section> sections=new ArrayList<Section>();
private static int TYPE_SECTION_HEADER=0;
public SectionedAdapter() {
super();
sections.clear();
}
public void addSection(String caption, Adapter adapter) {
sections.add(new Section(caption, adapter));
}
public void clear() {
sections.clear();
notifyDataSetChanged();
}
public Object getItem(int position) {
for (Section section : this.sections) {
if (position==0) {
return(section);
}
int size=section.adapter.getCount()+1;
if (position<size) {
return(section.adapter.getItem(position-1));
}
position-=size;
}
return(null);
}
public int getCount() {
int total=0;
for (Section section : this.sections) {
total+=section.adapter.getCount()+1; // add one for header
}
return(total);
}
public int getViewTypeCount() {
int total=1; // one for the header, plus those from sections
for (Section section : this.sections) {
total+=section.adapter.getViewTypeCount();
}
return(total);
}
public int getItemViewType(int position) {
int typeOffset=TYPE_SECTION_HEADER+1; // start counting from here
for (Section section : this.sections) {
if (position==0) {
return(TYPE_SECTION_HEADER);
}
int size=section.adapter.getCount()+1;
if (position<size) {
return(typeOffset+section.adapter.getItemViewType(position-1));
}
position-=size;
typeOffset+=section.adapter.getViewTypeCount();
}
return(-1);
}
public boolean areAllItemsSelectable() {
return(false);
}
public boolean isEnabled(int position) {
return(getItemViewType(position)!=TYPE_SECTION_HEADER);
}
public View getView(int position, View convertView,
ViewGroup parent) {
int sectionIndex=0;
for (Section section : this.sections) {
if (position==0) {
return(getHeaderView(section.caption, sectionIndex,
convertView, parent));
}
int size=section.adapter.getCount()+1;
if (position<size) {
return(section.adapter.getView(position-1,convertView,parent));
}
position-=size;
sectionIndex++;
}
return(null);
}
public long getItemId(int position) {
return(position);
}
class Section {
String caption = null;
Adapter adapter = null;
Section(String caption, Adapter adapter) {
this.caption=caption;
this.adapter=adapter;
}
}
}
在Activity中创建Section适配器对象,请查看以下代码:
final SectionedAdapter adapter =new SectionedAdapter()
{
protected View getHeaderView(String caption, int index, View convertView,ViewGroup parent)
{
result=(TextView)convertView;
if (convertView==null)
{
result=(TextView)getLayoutInflater().inflate(R.layout.section_header,null);
}
result.setText(caption);
// temp=caption;
// ind=index;
return(result);
}
};
<强> section_header.xml 强>
<?xml version="1.0" encoding="utf-8"?>
<TextView
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:background="@color/black"
android:textColor="#FFFFFF"
android:ellipsize="end"
android:textSize="11sp"
style="?android:attr/listSeparatorTextViewStyle" />
<!-- android:background="#515050"-->
在活动内添加部分,如下所示:
注意:userPic&amp; medPic是arraylist的名字。
adapter.addSection("section first", new EfficientAdapter(getApplicationContext(),usersPic));
adapter.addSection("section second", new EfficientAdapter(getApplicationContext(),medPic));
listview.setAdapter(adapter);
答案 2 :(得分:0)
我会用ExpandableListView解决这个问题。它不需要任何额外的库。