我是一名iOS开发人员,跳转到Android来移植我正在开发的项目,而且我似乎无法掌握Android自定义BaseAdapter的一些概念。我正在开发一个应用程序,用于解析站点中的XML,并将XML元素中的文本填充到ListView中。我有XML解析部分没有问题。我碰到的问题是在列表视图中的每一行添加一个按钮。我理解设置OnClick Listener的概念,并且需要实现BaseAdapter,但似乎无法将我的数据从我的主要活动获取到包含BaseAdapter的类中。目前,数据不会在应用程序启动时显示。我已经执行了一些调试,并验证了来自menuItems ArrayList的数据正确地发送到BaseAdapter类,我只是没有得到如何让它显示在ListView中。这可能是一个非常小的事情,我认为我只是看了太久而没有看到它。任何帮助将不胜感激。下面列出了代码和布局XML。Android - BaseAdapter - XML,ListView,按钮
public class Podcasts extends ListActivity{
private static final String HASHMAP_ID = "_id";
private CustomAdapter adap;
static final String URL = "http://www.undignified.podbean.com/feed";
//XML Node Keys
static final String KEY_ITEM = "item";
static final String KEY_TITLE = "title";
static final String KEY_DESCRIPTION = "itunes:subtitle";
static final String KEY_PODCASTURL = "enclosure";
public static final ArrayList<HashMap<String, String>> menuItems = new ArrayList<HashMap<String, String>>();
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.podcasts);
//Instance of XML parser
UndigParser uparser = new UndigParser();
String xml = uparser.getXmlFromURL(URL);
Document doc = uparser.getDomElement(xml);
NodeList nl = doc.getElementsByTagName(KEY_ITEM);
for(int i = 0; i < nl.getLength(); i++){
HashMap<String, String> map = new HashMap<String, String>();
Element e = (Element) nl.item(i);
map.put(KEY_TITLE, uparser.getValue(e, KEY_TITLE));
map.put(KEY_DESCRIPTION, uparser.getValue(e, KEY_DESCRIPTION));
map.put(KEY_PODCASTURL, uparser.getValue(e, KEY_PODCASTURL));
menuItems.add(map);
}
adap = new CustomAdapter(this, menuItems, R.layout.list_item, new String[] {KEY_TITLE, KEY_DESCRIPTION, KEY_PODCASTURL}, new int[]{ R.id.title, R.id.description, R.id.podcasturl});
//adap = new CustomAdapter(this, menuItems);
setListAdapter(adap);
public static class CustomAdapter extends BaseAdapter implements Filterable{
private LayoutInflater mInflater;
private Context context;
public CustomAdapter(Context context, ArrayList<HashMap<String, String>> menuItems, int listItem, String[] strings, int[] is){
mInflater = LayoutInflater.from(context);
this.context = context;
}
public View getView(final int position, View convertView, ViewGroup parent){
ViewHolder holder;
if(convertView==null){
convertView = mInflater.inflate(R.layout.list_item, null);
holder = new ViewHolder();
holder.description=(TextView)convertView.findViewById(R.id.description);
holder.podcasturl=(TextView)convertView.findViewById(R.id.podcasturl);
holder.title=(TextView)convertView.findViewById(R.id.title);
holder.downloadBTN=(Button)convertView.findViewById(R.id.btnStartDownload);
convertView.setOnClickListener(new OnClickListener(){
private int pos = position;
@Override
public void onClick(View v){
Toast.makeText(context, "Text-" + String.valueOf(pos), Toast.LENGTH_SHORT).show();
}
});
holder.downloadBTN.setOnClickListener(new OnClickListener(){
private int pos = position;
@Override
public void onClick(View v){
Toast.makeText(context, "Button-"+String.valueOf(pos), Toast.LENGTH_SHORT).show();
}
});
convertView.setTag(holder);
}else{
holder = (ViewHolder)convertView.getTag();
}
return convertView;
}
static class ViewHolder{
TextView description;
TextView title;
TextView podcasturl;
Button downloadBTN;
}
@Override
public int getCount() {
// Currently set to zero. If I set it to menuItems.size() it will crash the app.
return 0;
}
@Override
public Object getItem(int position) {
return null;
}
@Override
public long getItemId(int position) {
return 0;
}
@Override
public Filter getFilter() {
return null;
}
}
XML布局 - list_item.xml:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:padding="5dip">
<LinearLayout
android:id="@+id/LinearLayout01"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
xmlns:android="http://schemas.android.com/apk/res/android">
<Button
android:id="@+id/startPodcastDownload"
android:layout_width="50dip"
android:layout_height="50dip"
android:focusable="false"
android:text="Download Podcast">
</Button>
</LinearLayout>
<TextView
android:id="@+id/title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_toRightOf="@+id/LinearLayout01"
android:textColor="#acacac"
android:paddingBottom="2dip">
</TextView>
<TextView
android:id="@+id/description"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_toRightOf="@+id/LinearLayout01"
android:layout_below="@id/title"
android:textColor="#acacac"
android:paddingBottom="2dip">
</TextView>
<TextView
android:id="@+id/podcasturl"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_toRightOf="@+id/LinearLayout01"
android:layout_below="@+id/description"
android:textColor="#acacac"
android:paddingBottom="2dip">
</TextView>
</RelativeLayout>
感谢您的回复。我做了上面列出的更改,并且它是一个NullPointerException: java.lang.NullPointerException at tv.undignified.android.Podcasts $ CustomAdapter.getView(Podcasts.java:150) at android.widget.AbsListView。 obtainView(AbsListView.java:1315) 在android.widget.ListView.measureHeightOfChildren(ListView.java:1198) 在android.widget.ListView.onMeasure(ListView.java:1109) 在android.view.View.measure( View.java:8171) at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:3132) at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1012) – Fostenator 2012-07-27 04:10:59
已作出更改。仍然收到完全相同的错误。它几乎看起来不能得到menuItems的大小? – Fostenator 2012-07-27 04:25:40
in getCount()尝试通过Log.d(“size”,“”+ menuItems.size())查看menuItems的大小。 – AkashG 2012-07-27 05:25:40