我正在尝试创建一个listView
,以便列表中的每个项目都由一个TextView
和一个(或多个)组成ImageView
。
到目前为止,我已经设法使用listView
仅TextViews
通过使用 aArrayList<String>
和ArrayAdapter<String>
适配器的项目。
有没有办法实现我想要的?还有其他方法会更容易吗?(就像使用 TableRows,但我不确定它们是否可以配置为具有 onClickListener)
您应该使用自定义列表视图。 http://www.androidpeople.com/android-custom-listview-tutorial-part-1。看看链接。
@Override
public int getItemViewType(int position)
{
int type;
if (ID.get(position)== 0){
type = TYPE_ITEM1; //type 0 for image
}
else if (ID.get(position) == 1){
type = TYPE_ITEM2; //type 1 for text
}else {
type = TYPE_ITEM3; //type 2 for videos
}
return type;
}
@Override
public int getViewTypeCount() {
return 3; //three different layouts to be inflated
}
您可以通过 ListView 的 Arraydapter 提供自定义视图(您可以扩展 ArrayAdapter 以创建自己的)。关于您的另一个问题,是的,可以使 TableRows 可点击(例如,您可以在 XML 布局文件上执行此操作)。
创建一个具有如下布局的`list_items.xml`:
<LinearLayout
android:orientation="horizontal"
[...]
<ImageView
[...]
android:id="@+id/myimage"/>
<TextView
[...]
android:id="@+id/mytext"/>
</LinearLayout>
然后创建一个 BaseAdapter:
class MyAdapter extends BaseAdapter {
private Context context;
private LayoutInflater inflater;
private ViewHolder holder;
private ArrayList<HashMap<String, String>> data;
public MyAdapter(Context context, ArrayList<HashMap<String, String>> data) {
this.context = context;
this.data = data;
inflater = LayoutInflater.from(context);
}
// Below the Magic
public View getView(int position, View convertView, ViewGroup parent) {
inflater = (LayoutInflater) context.getSystemService(Activity.LAYOUT_INFLATER_SERVICE);
if(convertView == null || convertView.getTag() == null) {
// Here you load the list_items.xml an inflate your Layout with it
convertView = inflater.inflate(R.layout.list_items, null);
holder = new ViewHolder();
holder.text = (TextView) convertView.findViewById(R.id.mytext);
holder.image = (ImageView) convertView.findViewById(R.id.myimage);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}
// We get the HashMap for our current Position in the ListView
row = data.get(position);
if(row != null) {
holder.text.setText(row.get("test"));
// Below could be setImageBitmap, setImageResource,...
// depends on how you get your image
holder.image.setImageBitmap(getImage(row.get("image"));
}
return convertView;
}
class ViewHolder {
TextView text;
ImageView image;
}
}
public getImage(String image) {
// Get your image from where you want it SD, drawable, internet)
}
一个这样的称呼:
MyAdapter myAdapter = new MyAdapter(this, data);
myListView.setAdapter(myAdapter);
我假设您将数据传递到 ArrayList 中,其中包含每行的 HashMap:
#ListItem1 = data(0) - data.get(0).get("title"), data.get(0).get("image")
#ListItem2 = data(1) - data.get(1).get("title"), data.get(1).get("image")
我已经从我的应用程序上传了所有可能满足您需求的代码。随意下载和使用:
https://github.com/billmcnamara/BarcelonaTravelGuide.Android