![](/img/trans.png)
[英]Android RecyclerView freezes when image loading is done using Picasso
[英]Picasso image misplacement issue when using with RecyclerView
在我的應用程序中,我正在展示從Web服務中獲取的文章。 那些文章有標題,圖像和其他領域。 為了顯示圖像,我正在使用畢加索 。
問題 - 在滾動RecyclerView時,我看到圖像放錯了位置。 有些項目有重復的圖像。 我知道它是RecyclerView重用xml項目布局,因此它產生了一個問題。 但我認為必須解決這個問題。 我已經google了這個,並在stackoverflow上發現了一些帖子,但這沒有幫助。 例如-
我嘗試過以下但有同樣的問題 -
public class ArticleAdapter extends RecyclerView.Adapter<ArticleAdapter.ArticleViewHolder> {
protected Activity mActivity;
protected List<Article> mItems = new ArrayList<>();
private static OnEntityClickCallback mCallback;
public ArticleAdapter(Activity pActivity) {
mActivity = pActivity;
}
public void setItemClickCallback(OnEntityClickCallback pCallback) {
this.mCallback = pCallback;
}
@Override
public ArticleViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View articleView = LayoutInflater.from(parent.getContext()).inflate(R.layout.layout_article_item, parent, false);
return new ArticleViewHolder(articleView);
}
public void addItem(List<Article> moreItems) {
mItems.addAll(moreItems);
notifyDataSetChanged();
}
public void removeItems(){
mItems.clear();
notifyDataSetChanged();
}
@Override
public void onBindViewHolder(ArticleViewHolder holder, int position) {
holder.bind(mItems.get(position));
}
@Override
public int getItemCount() {
return mItems.size();
}
static class ArticleViewHolder extends RecyclerView.ViewHolder {
private TextView tvTitle;
TextView tvAuthor;
TextView tvPostdate;
ImageView imgImage;
RatingBar ratingBar;
public ArticleViewHolder(View view) {
super(view);
this.tvTitle = (TextView) view.findViewById(R.id.tv_title);
this.tvAuthor = (TextView) view.findViewById(R.id.tv_author);
this.tvPostdate = (TextView) view.findViewById(R.id.tv_date);
this.imgImage = (ImageView) view.findViewById(R.id.img_image);
this.ratingBar = (RatingBar) view.findViewById(R.id.ratingBar);
}
public void bind(final Article article) {
tvTitle.setText(article.getTitle());
tvPostdate.setText(article.getPostdate());
tvAuthor.setText(article.getAuthor());
// Canceling the older request
Picasso.with(imgImage.getContext()).cancelRequest(imgImage);
// Creating a new request.
if (article.getImage() != null) {
Picasso.with(imgImage.getContext()).load(article.getImageUrl())
.placeholder(R.drawable.noimage)
.error(R.drawable.noimage)
.into(imgImage);
}
this.itemView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (mCallback != null)
mCallback.onEntitySelected(article);
}
});
}
}
}
更新 - 我的布局文件的一部分
<ImageView
android:id="@+id/img_image"
android:layout_width="match_parent"
android:layout_height="@dimen/cardview_image_thumbnail_height"
android:layout_alignParentStart="true"
android:layout_alignParentLeft="true"
android:scaleType="centerCrop"
android:layout_margin="@dimen/cardview_padding_btw_widgets"
android:src="@drawable/noimage"
/>
任何幫助,將不勝感激。 謝謝。
外部設置drawable,因為你正在獲得已經附加了一些drawable的imageview。 Imageview未重新創建,因此ImageView中的上一個圖像將一直顯示,直到您將其刪除。
if (article.getImage() != null) {
Picasso.with(imgImage.getContext()).load(article.getImageUrl())
.placeholder(R.drawable.noimage)
.error(R.drawable.noimage)
.into(imgImage);
}else{
// imgImage.setImageDrawable(null);
imgImage.setImageDrawable(R.drawable.some_drawable);
}
在onBindViewHolder中使用setTag,它將保存數據,您的圖像不會錯位。
@Override
public void onBindViewHolder(ArticleViewHolder holder, int position) {
holder.bind(mItems.get(position));
holder.imgImage.setTag(mItems.get(position));
}
要么
也許試試你的方法也許它有效
@Override
public void onBindViewHolder(ArticleViewHolder holder, int position) {
holder.bind.setTag(mItems.get(position));
}
您的視圖可以重復使用。
調用Picasso.with(imgImage.getContext()).cancelRequest(imgImage);
取消ImageView的任何現有請求。
然后你可以加載你的圖像如果article.getImage() != null
並提供一個后備,如果你的文章圖像是空的像imgImage.setImageDrawable(R.drawable.some_drawable);
此外,它對我有用:
@Override
public long getItemId(int position) {
return position;
}
@Override
public int getItemViewType(int position) {
return position;
}
這些方法是訪問列表數據的更簡潔方法。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.