Android Glide 的简单使用(一),Android面试题及答案

  • 深度的生命周期集成,以确保仅优先处理活跃的Fragment和Activity的请求,并有利于应用在必要时释放资源以避免在后台时被杀掉。

Glide基本用法

=========

  • with 传入的可以是当前上下文的对象。

  • load 加载图片,图片可以是本地图片,应用资源的图片也可以是一张网络图片。

  • placeholder 占位符是在请求正在进行时,显示的图片。

  • error 当请求永久失败时,会显示设置图片。

  • into 传入要展示图片的控件。

  • transform 用来完成剪裁(切圆)或对位图应用过滤器,但它也可以用于转换GIF动画,甚至自定义的资源类型。

简单使用

====

在build.gradle中添加依赖

implementation ‘com.github.bumptech.glide:glide:4.12.0’

加载图片

Uri uri = Uri.parse(“https://profile.csdnimg.cn/C/A/6/1_g984160547”);

//        String uri = “https://profile.csdnimg.cn/C/A/6/1_g984160547”;

//上面两种写法效果相同

Glide.with(this).load(uri).into(agb.ivInitial);

//应用资源

Glide.with(this).load(R.mipmap.sc1).into(agb.ivAppMipmap);

//画圆

Glide.with(this).load(uri).circleCrop().into(agb.ivCirclecrop);

//增加占位符和加载失败显示图片

Glide.with(this).load(uri).

placeholder(R.mipmap.sc1)

.error(R.mipmap.sc2)

.into(agb.ivInitial);

FutureTarget target= Glide.with(this)

.asBitmap()

.load(uri)

.submit();

new Thread(new Runnable() {

@Override

public void run() {

try {

Bitmap bitmap = target.get();//同步请求

//子线程切主线程更新UI

runOnUiThread(new Runnable() {

@Override

public void run() {

agb.ivOptions.setImageBitmap(bitmap);

}

});

} catch (Exception e) {

e.printStackTrace();

}

}

}).start();

取消加载

Glide.with(this).clear(agb.ivCirclecrop);

注意: 尽管及时取消不必要的加载是很好的实践,但这并不是必须的操作。实际上,当 Glide.with() 中传入的 Activity 或 Fragment 实例销毁时,Glide 会自动取消加载并回收资源。

Generated API

=============

Glide v4 使用 注解处理器 (Annotation Processor) 来生成出一个 API,它允许应用扩展 Glide 的 API并包含各种集成库提供的组件。

Generated API 模式的设计出于以下两个目的:

  • 1.集成库可以为 Generated API 扩展自定义选项。

  • 2.在 Application 模块中可将常用的方法组打包成一个选项在 Generated API 中使用

虽然以上所说的工作均可以通过手动创建 RequestOptions 子类的方式来完成,但想将它用好更具有挑战,并且降低了 API 使用的流畅性。

使用Generated API(高级用法)

=====================

1.在build.gradle中添加依赖

annotationProcessor ‘com.github.bumptech.glide:compiler:4.12.0’

2.创建一个添加有 @GlideModule 注解,继承自 AppGlideModule 的类。此类可生成出一个流式 API,内联了多种选项和集成库中自定义的选项:

@GlideModule

public class MyGlideModule extends AppGlideModule

{

}

3.生成的 API 默认名为 GlideApp ,与 AppGlideModule 的子类包名相同。在 Application 模块中将 Glide.with() 替换为 GlideApp.with(),即可使用该 API 去完成加载工作。

GlideApp.with(this).load(uri).circleCrop().into(agb.ivCirclecrop);

Android Studio 在大多数时候都可以正确地处理注解处理器 (annotation processor) 和 generated API。然而,当你第一次添加你的 AppGlideMod

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值