我想在我的应用程序中显示列表视图。每行应包含文本和图像。我已经使用ArrayAdapter来显示它,但是如何在文本后插入图像。 这是代码:
String lvr[]={"Android","iPhone","BlackBerry","AndroidPeople"};
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
list1 = (ListView) findViewById(R.id.cg_listview1);
list1.setAdapter(new ArrayAdapter<String>(this,R.layout.alerts , lvr));
此处警报是我的布局,其中仅包含textView。
答案 0 :(得分:1)
您需要创建自定义适配器才能实现此目的。
public class ResultAdapter extends BaseAdapter {
private final Context context;
private final List<Result> results;
public ResultAdapter(Context context, List<Result> results) {
this.context = context;
this.results = results;
}
@Override
public int getCount() {
return this.results.size();
}
@Override
public Object getItem(int position) {
return this.results.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
}
}
创建用于存储文本和图像的Result类。在getView方法中,以编程方式创建View,或者使用LayoutInflater从XML布局加载它。
答案 1 :(得分:1)
如果您希望控制项目布局在列表视图中的显示方式,则应自行制作ArrayAdapter
的自定义实现:
管理ListView的ListAdapter 由任意数组支持 对象。 (...)使用其他东西 比数组显示的TextViews, 例如,ImageViews,或者有 除了toString()之外的一些数据 结果填充视图,覆盖 getView(int,View,ViewGroup)来 返回你想要的视图类型。
如果您只是谷歌搜索custom arrayadapter example,您应该找到足够的示例来向您展示如何实施此功能。两个这样的例子是:
祝你好运:)答案 2 :(得分:1)
代码完成,文本视图更改。 ArrayList是通用的,但您必须使用ArrayList构造函数来添加,插入和移除才能工作。
public class ListViewLearn extends Activity {
public Button btnAddData;
public ListView listShow;
public listRayAdapter adapter;
public ArrayList<Integer> tmpStrRay;
public Resources mainRes;
public void onCreate(Bundle savedInstanceState) {
setContentView(R.layout.mainlistlayout);
tmpStrRay = new ArrayList<Integer>();
tmpStrRay.add(1);
tmpStrRay.add(2);
tmpStrRay.add(3);
mainRes= getApplicationContext().getResources();
adapter = new listRayAdapter(getApplicationContext(),R.layout.listitem, tmpStrRay);
btnAddData = (Button) findViewById(R.id.btnAddData);
btnAddData.setOnClickListener(clickit);
listShow= (ListView) findViewById(R.id.listShow);
listShow.setAdapter(adapter);
super.onCreate(savedInstanceState);
}
final OnClickListener clickit = new OnClickListener(){
@Override
public void onClick(View v) {
for (int xx=4; xx<=50; xx++){
adapter.add(new Integer(xx));
}
}};
class listRayAdapter extends ArrayAdapter<Integer>
{
private ArrayList<Integer> items;
Bitmap tmpImg;
public listRayAdapter(Context context, int textVwId, ArrayList<Integer> txtRay)
{
super(context,textVwId,txtRay);
this.items = txtRay;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View newv= convertView;
if (newv == null) {
LayoutInflater vi = (LayoutInflater)getSystemService(Context.LAYOUT_INFLATER_SERVICE);
newv = vi.inflate(R.layout.listitem, null);
}
if ((position%2)==0){
tmpImg = BitmapFactory.decodeResource(mainRes, R.drawable.even);
}else{
tmpImg = BitmapFactory.decodeResource(mainRes, R.drawable.odd);
}
ImageView img = (ImageView) newv.findViewById(R.id.img);
img.setImageBitmap(tmpImg);
TextView tt= (TextView) newv.findViewById(R.id.listedItem);
Integer tmpInt = new Integer(items.get(position));
tt.setText(tmpInt.toString());
return newv;
}
}
}