android Glide介绍

目录

1.Glide的基本使用

1. 介绍

2. Glide占位符

2.Glide的进阶使用

1. 过渡动画

2. 变化 transform()

3. Generated API

4. GlideExtension与GlideOption


1.Glide的基本使用

1. 介绍

Glide是一个快速高效的Android图片加载库,可以自动加载网络、本地文件,app资源中的图片,注重于平滑的滚动。

开源地址:GitHub - bumptech/glide: An image loading and caching library for Android focused on smooth scrolling 中文文档:Glide v4 : 快速高效的Android图片加载库

引入Glide:

implementation 'com.github.bumptech.glide:glide:4.11.0'
annotationProcessor 'com.github.bumptech.glide:compiler:4.11.0'

基本使用: Glide.with([fragment/Context/View]) .load(url) .into(imageView)

2. Glide占位符

Glide4中占位图的使用方法,包括(placeholder, error,fallback)三种占位图

  1. placeholder 正在请求图片的时候展示的图片

  2. error 如果请求失败的时候展示的图片 (如果没有设置,还是展示placeholder的占位符)

  3. fallback 如果请求的url/model为 null 的时候展示的图片 (如果没有设置,还是展示placeholder的占位符)

示例

RequestOptions requestOptions = new RequestOptions()
        .placeholder(R.drawable.hold)
        .error(R.drawable.error)
        .fallback(R.drawable.empty)
        .override(100,100);
Glide.with(this)
        .load("https://i.328888.xyz/2023/02/20/X1nsd.jpeg1")
        .apply(requestOptions)
        .into(imageView);

2.Glide的进阶使用

1. 过渡动画

定义 Glide 如何从占位符到新加载的图片,或从缩略图到全尺寸图像过渡。

Glide默认是Drawable 此时用DrawableTransitionOptions

如果使用了.asBitmap()方法 此时需要对应使用BitmapTransitionOptions

withCrossFade() 传int就是过渡动画显示的ms数
传DrawableCrossFadeFactory就是自定义工厂  可用于避免占位图显示

 

交叉淡入(避免占位图还能显示)

示例

//自定义工厂使用
DrawableCrossFadeFactory factory =
        new DrawableCrossFadeFactory.Builder().setCrossFadeEnabled(true).build();
Glide.with(this)
        .load("https://i.328888.xyz/2023/02/20/X1nsd.jpeg")
        .apply(requestOptions)
        .transition(DrawableTransitionOptions.withCrossFade(factory))
        .into(imageView);

注意:

为了提升性能,请在使用 Glide 向 ListView , GridView, 或 RecyclerView 加载图片时考虑避免使用动画。

2. 变化 transform()

获取资源并修改它,然后返回被修改后的资源。通常变换操作是用来完成剪裁或对位图应用过滤器。比如对图片 进行圆角配置。

Glide.with(this)
        .load(URL)
        .transform(...)
        .into(iv);
  1. CircleCrop:圆角

  2. RoundedCorners: 四个角度统一指定

  3. GranularRoundedCorners:四个角度单独指定

  4. Rotate:旋转

3. Generated API

1、添加 Glide注解处理器的依赖:

annotationProcessor 'com.github.bumptech.glide:compiler:4.11.0'

2、在 Application 模块中包含一个 AppGlideModule 的实现

@GlideModule
public class MyAppModule extends AppGlideModule {
}

此时我们能够更简单的完成占位符等配置:

GlideApp.with(this).load("")
        .placeholder(R.drawable.hold)
        .into(imageView);

4. GlideExtension与GlideOption

定义一个在频繁使用的选项集合。

@GlideExtension
public class MyAppExtension {
    private MyAppExtension() {
    } // utility class
​
    @GlideOption
    public static BaseRequestOptions<?> defaultImg(BaseRequestOptions<?> options) {
        return options.placeholder(R.drawable.hold)
                .error(R.drawable.error)
                .fallback(R.drawable.error);
    }
}

使用(加一个defaultImg()方法即可)

GlideApp.with(this).load("")
        .placeholder(R.drawable.hold)
        .defaultImg()
        .into(imageView);
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android图片框架Glide-3.7.0(最新,很强大),超好用的图片框架(包含jar和源码) Glide 是一个高效、开源、 Android设备上的媒体管理框架,它遵循BSD、MIT以及Apache 2.0协议发布。Glide具有获取、解码和展示视频剧照、图片、动画等功能,它还有灵活的API,这些API使开发者能够将Glide应用在几乎任何网络协议栈里。创建Glide的主要目的有两个,一个是实现平滑的图片列表滚动效果,另一个是支持远程图片的获取、大小调整和展示。近日,Glide 3.0发布,现已提供 jar包下载 ,同时还支持使用Gradle以及Maven进行构建。该版本包括很多值得关注的新功能,如支持Gif 动画和视频剧照解码、智能的暂停和重新开始请求、支持缩略图等,具体新增功能如下如下: GIF 动画的解码 :通过调用Glide.with(context).load(“图片路径“)方法,GIF动画图片可以自动显示为动画效果。如果想有更多的控制,还可以使用Glide.with(context).load(“图片路径“).asBitmap()方法加载静态图片,使用Glide.with(context).load(“图片路径“).asGif()方法加载动画图片 本地视频剧照的解码: 通过调用Glide.with(context).load(“图片路径“)方法,Glide能够支持Android设备中的所有视频剧照的加载和展示 缩略图的支持: 为了减少在同一个view组件里同时加载多张图片的时间,可以调用Glide.with(context).load(“图片路径“).thumbnail(“缩略比例“).into(“view组件“)方法加载一个缩略图,还可以控制thumbnail()中的参数的大小,以控制显示不同比例大小的缩略图 Activity 生命周期的集成: 当Activity暂停和重启时,Glide能够做到智能的暂停和重新开始请求,并且当Android设备的连接状态变化时,所有失败的请求能够自动重新请求 转码的支持: Glide的toBytes() 和transcode() 两个方法可以用来获取、解码和变换背景图片,并且transcode() 方法还能够改变图片的样式 动画的支持: 新增支持图片的淡入淡出动画效果(调用crossFade()方法)和查看动画的属性的功能 OkHttp 和Volley 的支持: 默认选择HttpUrlConnection作为网络协议栈,还可以选择OkHttp和Volley作为网络协议栈 其他功能: 如在图片加载过程中,使用Drawables对象作为占位符、图片请求的优化、图片的宽度和高度可重新设定、缩略图和原图的缓存等功能
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值