java无法在ListView中使用自定义项布局正确显示图像
我正在使用ListView显示我的自定义项目布局,其中可能包含一些TextView和ImageView
这是我制作的项目布局(post_item.xml):
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:安卓="http://schemas.安卓.com/apk/res/安卓"
安卓:layout_width="fill_parent"
安卓:layout_height="60dip"
安卓:padding="5dip"
>
<TextView 安卓:id="@+id/listItem_title"
安卓:layout_width="fill_parent"
安卓:layout_height="wrap_content"
安卓:layout_alignParentLeft="true"
安卓:layout_alignParentTop="true"
安卓:layout_weight="1"
/>
<FrameLayout 安卓:id="@+id/listItem_frameContent"
安卓:layout_width="fill_parent"
安卓:layout_height="wrap_content"
安卓:layout_alignParentLeft="true"
安卓:layout_below="@id/userStream_listItem_title"
安卓:layout_weight="1"
>
</FrameLayout>
</RelativeLayout>
最初,我不会将ImageView放在xml布局中,但当我需要以编程方式将其插入FrameLayout时,我会将其插入(需要时,我还会在其中放入另一个视图)。因此,有些项目中有ImageView,而有些项目中没有
我从Internet(通过URL)获取图像以填充ImageView,将其解码为位图,并将其作为位图变量保存在表示自定义项布局的类(类PostItem)中
当活动第一次显示时,它看起来很好,但是当我滚动浏览项目时,出现了一个问题,不应该显示任何图像的项目显示了其他项目的图像,应该显示,尽管它们没有任何ImageView(因为我没有插入它)
我正在使用SDK 1.6和模拟器。我没有在真正的设备上试用过,因为我没有
以下是我的适配器代码:
private class PostItemAdapter extends ArrayAdapter<PostItem> {
private List<PostItem> mPostItems;
public PostItemAdapter(Context context, int textViewResourceId, List<PostItem> postItems) {
super(context, textViewResourceId, postItems);
mPostItems = postItems;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View view = convertView;
if (view == null) {
LayoutInflater layoutInflater = (LayoutInflater) getSystemService(LAYOUT_INFLATER_SERVICE);
view = layoutInflater.inflate(R.layout.post_item, null);
}
PostItem postItem = mPostItems.get(position);
if (postItem != null) {
final FrameLayout contentFrame = (FrameLayout) view.findViewById(R.id.listItem_frameContent);
final TextView titleTextView = (TextView) view.findViewById(R.id.listItem_title);
if (titleTextView != null) {
titleTextView.setText(postItem.getTitle());
}
if (contentFrame != null) {
if (postItem.hasImagePreview()) {
final ImageView previewImageView = new ImageView(getApplicationContext());
previewImageView.setId(LIST_ITEM_IMAGEVIEW_ID);
previewImageView.setAdjustViewBounds(true);
previewImageView.setMaxHeight(75);
previewImageView.setMaxWidth(75);
previewImageView.setImageBitmap(postItem.getImagePreview());
final RelativeLayout.LayoutParams layoutParams =
new RelativeLayout.LayoutParams(RelativeLayout.LayoutParams.WRAP_CONTENT,
RelativeLayout.LayoutParams.WRAP_CONTENT);
layoutParams.addRule(RelativeLayout.ALIGN_PARENT_TOP);
layoutParams.addRule(RelativeLayout.ALIGN_PARENT_LEFT);
contentFrame.addView(previewImageView, layoutParams);
}
if (postItem.hasContent()) {
final TextView contentTextView = new TextView(getApplicationContext());
contentTextView.setText(postItem.getContent());
final RelativeLayout.LayoutParams layoutParams =
new RelativeLayout.LayoutParams(RelativeLayout.LayoutParams.FILL_PARENT,
RelativeLayout.LayoutParams.WRAP_CONTENT);
layoutParams.addRule(RelativeLayout.BELOW, LIST_ITEM_IMAGEVIEW_ID);
layoutParams.addRule(RelativeLayout.ALIGN_LEFT, LIST_ITEM_IMAGEVIEW_ID);
layoutParams.alignWithParent = true;
contentFrame.addView(contentTextView, layoutParams);
}
}
}
return view;
}
}
这是准备项目的代码:
/* inside a method to prepare the items */
mPostItems = new ArrayList<PostItem>();
for (int i=0; i<total); i++) {
/* operation to generate titleToDisplay and contentToDisplay */
/* contentToDisplay might be null */
mPostItems.add(new PostItem(
titleToDisplay,
contentToDisplay,
generateImagePreview()));
}
/* another method */
private Bitmap generateImagePreview(ActivityObject object) {
Bitmap imagePreview = null;
if (/*some condition*/) {
try {
InputStream inStream = (InputStream) (new URL("http://a1.typepad.com/6a010535617444970b0133ecc20b29970b-120si")).getContent();
imagePreview = Drawable.createFromStream(inStream, "linkHref");
}
catch (MalformedURLException ex) {
Log.e("INSIDE generateImagePreview()", ex.getMessage());
}
catch (IOException ex) {
Log.e("INSIDE generateImagePreview()", ex.getMessage());
}
catch (Exception ex) {
Log.e("INSIDE generateImagePreview()", ex.getMessage());
}
}
return imagePreview;
}
这是模拟器中的错误还是我的代码中有错误(可能是位图内存问题)?请帮帮我,我真的被困在这里面了。任何帮助或建议都将不胜感激。提前感谢:)
# 1 楼答案
单元格被列表重用,看起来只有当存在与该项相关联的图像时,才需要更改contentframe图像。这意味着当没有图像并且您正在重用一个单元格时,它将只显示在convert视图中传入的内容。如果没有图像,则应删除contentframe的所有子视图
这就是说,你将来可能会通过更加简洁得到更好的回答。写了一堆代码,花了一段时间来解决这个问题,使得阅读变得更麻烦,因此很少有人会这么做