Android通过layer-list设置默认加载错误图片的实现方案

 更新时间:2025年04月27日 08:46:32   作者:_小马快跑_  
在需求开发中,经常会遇到需要展示图片列表的情况,然而,由于网络问题、图片链接失效等原因,某些图片可能无法正常加载,为了优化用户体验,通常会为加载失败的图片提供一个默认的占位图,所以本文给大家介绍了Android通过layer-list设置默认加载错误图片的实现方案

背景

在需求开发中,经常会遇到需要展示图片列表的情况。然而,由于网络问题、图片链接失效等原因,某些图片可能无法正常加载。为了优化用户体验,通常会为加载失败的图片提供一个默认的占位图。

在常规的实现方式中,可能会直接使用一张默认图片来作为占位图(如果是个单色 图,可以直接用一个drawable文件)。然而,如果图片列表里每个Item宽高比都是变化的时候,默认图片会因为宽高比不同而导致变形,虽然可以通过 ImageView 的 scaleType 设置 CENTER_CROP 以适应不同的图片比例不变形,但如果默认图片本身包含一个居中的小图标,在不同的宽高比下,小图标的显示效果可能会变形或错位。

问题分析

假设我们的默认错误图片是如下所示的样式(背景色 + 一个居中的错误图标):

如果我们将其合成一张完整的 PNG 图片并使用 CENTER_CROP 适配不同的 ImageView 尺寸,可能会遇到两个问题: 1. 小图标会跟随图片裁剪,可能会放大、变形,导致显示不一致。 2. 不同比例的 ImageView 会截取不同区域,导致小图标的位置和大小不可控。

为了解决这个问题,可以换一种思路,利用 layer-list 来动态组合背景和图标,从而确保小图标始终保持固定大小和居中位置。

解决方案:使用 layer-list

在 drawable 资源中,layer-list 允许我们叠加多个图层,可以将背景和图标分开定义,保证不同尺寸的 ImageView 显示时,背景始终铺满,而小图标始终居中,且不会因裁剪而变形。其中小图片的资源如下:

  • 创建 layer-list 资源文件

在 res/drawable/ 目录下创建 drawable_default_error.xml:

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <!-- 背景矩形 -->
    <item>
        <shape android:shape="rectangle">
            <solid android:color="@color/gray_normal" /> <!-- 设置背景颜色 -->
        </shape>
    </item>

    <!-- 居中的错误图标 -->
    <item
        android:width="60dp"
        android:height="60dp"
        android:gravity="center">
        <bitmap
            android:gravity="center"
            android:src="@drawable/chat_ask_message_error" />
    </item>
</layer-list>
  • 代码中使用 layer-list

在使用 Glide 或其他图片加载框架时,我们可以直接将 drawable_default_error.xml 作为 placeholder 和 error 资源:

Glide.with(activity)
    .load(url)
    .placeholder(R.drawable.drawable_default_error) // 加载中显示的占位图
    .error(R.drawable.drawable_default_error) // 加载失败时显示的默认图
    .into(imageView)

效果展示

当图片加载失败时,ImageView 会显示 drawable_default_error.xml 组合的背景 + 图标,效果如下:

相比直接使用一张完整的 PNG 图片,layer-list 方案的优点:

  • 保证背景始终填充整个 ImageView,不会因为 scaleType 而变形。
  • 小图标始终保持固定大小,居中不变形,适应不同的 ImageView 尺寸。
  • 支持动态调整背景色或小图标,无需重新制作整张图片,维护更方便。

总结

在 Android 开发中,layer-list 是一个非常实用的 Drawable 资源,它可以将多个层叠的图形、颜色、图片等组合在一起,实现复杂的视觉效果。在需要为加载失败的图片提供占位图时,使用 layer-list 可以保证背景填充、图标居中且不会变形。

以上就是Android通过layer-list设置默认加载错误图片的实现方案的详细内容,更多关于Android layer-list默认加载错误图片的资料请关注脚本之家其它相关文章!

相关文章

  • Android实现闪屏效果

    Android实现闪屏效果

    这篇文章主要为大家详细介绍了Android实现闪屏效果,实现“一闪而过”效果进入页面,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-07-07
  • Android仿京东、天猫下拉刷新效果

    Android仿京东、天猫下拉刷新效果

    这篇文章主要为大家详细介绍了Android仿京东、天猫下拉刷新效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-03-03
  • Flutter折叠控件使用方法详解

    Flutter折叠控件使用方法详解

    这篇文章主要为大家详细介绍了Flutter折叠控件的使用方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01
  • Android获取SD卡上图片和视频缩略图的小例子

    Android获取SD卡上图片和视频缩略图的小例子

    如果我们需要快速提取图片和视频缩略图可以直接访问android.provider.MediaStore.Images.Thumbnails 和android.provider.MediaStore.Video.Thumbnails这两个数据库,即可查询出来缩略图 。
    2013-06-06
  • 简单实现Android滚动公告栏

    简单实现Android滚动公告栏

    这篇文章主要为大家详细介绍了如何简单实现Android滚动公告栏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • WebView 实现全屏播放视频的示例代码

    WebView 实现全屏播放视频的示例代码

    这篇文章主要介绍了WebView 实现全屏播放视频的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-09-09
  • Android ListView常用小技巧汇总

    Android ListView常用小技巧汇总

    这篇文章为大家详细介绍了Android ListView常用小技巧,帮助大家更好的开发Android项目,感兴趣的小伙伴们可以参考一下
    2016-03-03
  • Android DataBinding布局的加载深入探究

    Android DataBinding布局的加载深入探究

    看了谷歌官方文章确实写的太简略了,甚至看完之后有很多地方还不知道怎么回事儿或者怎么用,那么接下来我将通过文章全面介绍一下DataBinding布局的加载
    2022-11-11
  • Android通过SharedPreferences实现自动登录记住用户名和密码功能

    Android通过SharedPreferences实现自动登录记住用户名和密码功能

    最近使用SharedPreferences实现了一个android自动登录功能,特此分享到脚本之家平台供大家参考
    2017-07-07
  • Android实现自动轮询的RecycleView

    Android实现自动轮询的RecycleView

    这篇文章主要为大家详细介绍了Android实现自动轮询的RecycleView,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-10-10

最新评论