Android RecyclerView加载网络图片失败及解决方案
在使用RecyclerView显示从服务器获取的图片列表时,图片加载失败是常见问题。本文分析一个典型案例,并提供多种解决方案。
案例:RecyclerView的item布局中仅包含一个ImageView,layout_height属性设置为wrap_content,使用Glide加载图片。运行程序后图片无法显示,但设置ImageView固定高度后图片则正常显示。
问题根源:layout_height="wrap_content"导致问题。RecyclerView布局时,ImageView需要测量自身高度,但图片未加载完成,ImageView无法得知图片高度,导致无法正确测量自身高度,最终图片无法显示。
解决方案:
方法一:设置固定高度
最简单直接的方法,为ImageView设置固定高度,例如android:layout_height="200dp"。但这会使所有图片高度一致,影响用户体验。
方法二:使用占位符
Glide提供占位符功能,在图片加载前显示占位图,提升用户体验。在Glide加载图片代码中添加placeholder()方法:
Glide.with(this.activity.getBaseContext())
.load(src)
.placeholder(R.drawable.placeholder) // 设置占位图
.into(imageView);
方法三:动态设置ImageView高度
为了按图片比例显示,利用Glide的RequestListener动态获取图片宽高比,根据ImageView宽度计算高度,再设置给ImageView。这能保证图片按原始比例显示,避免固定高度带来的问题:
Glide.with(this.activity.getBaseContext())
.load(src)
.addListener(new RequestListener<Drawable>() {
@Override
public boolean onLoadFailed(@Nullable GlideException e, Object model, Target<Drawable> target, boolean isFirstResource) {
return false;
}
@Override
public boolean onResourceReady(Drawable resource, Object model, Target<Drawable> target, DataSource dataSource, boolean isFirstResource) {
int width = imageView.getWidth();
float aspectRatio = (float) resource.getIntrinsicWidth() / (float) resource.getIntrinsicHeight();
int height = Math.round(width / aspectRatio);
imageView.setLayoutParams(new ViewGroup.LayoutParams(width, height));
return false;
}
})
.into(imageView);
选择合适的方案取决于实际需求,以上方法能有效解决RecyclerView加载网络图片显示问题。
以上就是Android RecyclerView加载网络图片显示失败的原因是什么以及如何解决?的详细内容,更多请关注知识资源分享宝库其它相关文章!
版权声明
本站内容来源于互联网搬运,
仅限用于小范围内传播学习,请在下载后24小时内删除,
如果有侵权内容、不妥之处,请第一时间联系我们删除。敬请谅解!
E-mail:dpw1001@163.com
发表评论