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
发表评论