news 2026/4/23 5:46:46

【Android】Glide的使用

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【Android】Glide的使用

简介

是一个快速高效的Android开源媒体管理和图像加载框架,它将媒体解码、内存和磁盘缓存以及资源池封装到一个简单易用的界面中。

Glide支持拉取,解码和展示视频快照,图片和GIF动画。

**优点:**1.使用简单,并且支持多种图片格式,既可以获取网络资源又可以获取本地资源,不用处理网络请求、缓存、内存管理、图片解码等复杂逻辑;

2.性能优秀:自动管理 Bitmap 内存,防止内存溢出,可以自动根据ImageView调整图片大小,节省内存。

所需权限

网络加载

通过网络连接加载图像,需要添加INTERNETACCESS_NETWORK_STATE权限

<manifest>...<uses-permissionandroid:name="android.permission.INTERNET"/><!--允许Glide监视连接状态--><uses-permissionandroid:name="android.permission.ACCESS_NETWORK_STATE"/>...</manifest>

本地存储

要从DCIM或图片等本地文件夹加载图像,需要添加READ_EXTERNAL_STORAGE权限

<manifest>...<uses-permissionandroid:name="android.permission.READ_EXTERNAL_STORAGE"/>...</manifest>

要将Glide的缓存存储到公共sdcard上,需要使用WRITE_EXTERNAL_STORAGE权限

<manifest>...<uses-permissionandroid:name="android.permission.WRITE_EXTERNAL_STORAGE"/>...</manifest>

基本用法

在build.gradle中添加依赖

implementation'com.github.bumptech.glide:glide:4.12.0'
  • **with(Context context)**可以传递Activity/Fragment,并且它会和所传参数的生命周期进行绑定
  • **load(String imageUrl)**加载图片,传入的是图片的URL地址
  • placeholder占位符是在请求正在进行时,显示的图片
  • error表示请求失败时,会显示设置的图片
  • fallback表示传递的是null值时,会显示设置的图片
  • into(ImageView targetImageView)传入要展示图片的控件
  • transform用来完成剪裁(切圆)或对位图应用过滤器,但它也可以用于转换GIF动画,甚至自定义的资源类型
  • override将图片大小调整为给定的尺寸(以像素为单位),调整大小不考虑纵横比
  • transition控制图片加载完成后的过渡动画效果

简单使用

加载图片

Uriuri=Uri.parse("https://th.bing.com/th/id/R.c0b37497ff48b914ae99c7dcdcf7b95d?rik=HUXUOfyLgw7hHA&pid=ImgRaw&r=0");//加载网络图片Glide.with(this).load(uri).into(imageView);//应用资源Glide.with(this).load(R.drawable.image1).into(imageView);//加载圆形图片Glide.with(this).load(uri).circleCrop().into(imageView);//增加占位符和加载失败显示图片Glide.with(this).load(uri).placeholder(R.drawable.image1).error(R.drawable.image1).fallback(R.drawable.image1).into(imageView);//图片大小调整Glide.with(this).load(uri).override(600,200).into(imageView);

缩放图片

对于任何图像的任何处理,调整图像的大小可能会扭曲长宽比,丑化图片的显示。

Glide提供了变换去处理图片显示

  • centerCrop():会缩放图片,让图片充满整个ImageView的边框,然后裁掉超出的部分,ImageView会被完全填充满,但是图片可能不能完全显示
  • fitCenter():会缩放图片让两边都相等或小于ImageView的所需求的边框,图片会被完整显示但可能不会填满整个ImageView
Glide.with(this).load(uri).override(600,200).centerCrop().into(imageView);Glide.with(this).load(uri).override(600,200).fitCenter().into(imageView);

图片过渡

使用crossfade动画可以使改变图片的效果变得更加平滑

Glide.with(this).load(uri).placeholder(R.drawable.image1).error(R.drawable.image1).transition(DrawableTransitionOptions.withCrossFade())//withCrossFade(int duration)方法可以传入时间,默认时间是300毫秒.into(imageView);

除此之外,Glide还支持xml中自定义的动画文件

Glide.with(this).load(uri).transition(GenericTransitionOptions.with(R.anim.zoom_in)).into(imageView);

加载gif

StringgifUrl="https://i-blog.csdnimg.cn/blog_migrate/c0a5b53d30d8e1c25ea014b113b66fdf.gif";Glide.with(this).load(gifUrl).into(imageView);

还可以使用asGif()强迫生成一个gif

Glide.with(this).asGif().load(gifUrl).error(R.drawable.image1).into(imageView);

如果只想显示gif的第一帧图片,可以调用asBitmap()将其作为常规图片显示

Glide.with(this).asBitmap().load(gifUrl).into(imageView);

显示本地视频缩略图

StringfilePath="/storage/emulated/0/Pictures/targetVideo.mp4";Glide.with(this).asBitmap().load(Uri.fromFile(newFile(filePath))).into(imageView);

取消加载

Glide.with(this).clear(imageView);

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

高斯模糊

使用库

implementation'jp.wasabeef:glide-transformations:4.3.0'

简单使用

publicstaticvoidloadImageViewTransform(Contextmcontext,byte[]path,ImageViewimageView){//前一个参数为圆角,后一个为模糊值,越大越模糊BlurTransformationblurTransformation=newBlurTransformation(10,15);Glide.with(mcontext).load(path).apply(RequestOptions.bitmapTransform(blurTransformation)).into(imageView);}

组合使用

高斯模糊可以和各种效果组合

@GlideOptionpublicstaticBaseRequestOptions<?>applyBlurHead(BaseRequestOptions<?>options,intsize){//高斯模糊BlurTransformationblurTransformation=newBlurTransformation(20,1);//高斯模糊和切圆组合returnoptions.override(size).placeholder(R.drawable.image1).error(R.drawable.ic_launcher_background).transform(newMultiTransformation<>(blurTransformation,newCircleCrop()));}

注意:默认情况下,对每一个后续呼叫transform()或任何特定的transform方法(fitCenter(),centerCrop(),bitmapTransform()等)将取代先前的transform。

要将多个转换应用于单个加载,可使用MultiTransformation

自定义API

可以通过Glide提供的注解,来添加自己定义的API

  • GlideModule注解用于AppGlideModule

  • GlideExtension注解用于表示一个扩展Glide API的类,任何拓展的Glide API的类都必须使用这个注解来标记,被@GlideExtension注解的类以工具类的方式实现

    被@GlideExtension注解的类有两种扩展方式:

    • GlideOption-注解为RequestOptions添加一个选项
    • GlideType-添加新的资源类型的支持(GIF,SVG等)

首先添加Glide注解处理器配置

annotationProcessor "com.github.bumptech.glide:compiler:4.12.0"

项目需要通过GlideModule注解继承子AppGlideModule类的子类,并通过GlideExtension注解到工具类上来扩展自定义GlideAPI。

使用GlideOption和GlideType注解的方法必须为静态方法,经过Rebuild Project之后,最后会被编译到XXXRequest.java类

//Application模块内,GlideModule注解自定义子类继承AppGlideModule,可以不用重写任何方法@GlideModule(glideName="GlideApp")publicclassMyGlideModuleextendsAppGlideModule{publicvoidapplyOptions(Contextcontext,GlideBuilderbuilder){//可以添加一些全局性的optionssuper.applyOptions(context,builder);}}@GlideExtensionpublicclassMyGlideExtensions{privateMyGlideExtensions(){}//GlideOption注解,添加自定义的Option@GlideOptionpublicstaticBaseRequestOptions<?>mMiniThunb(BaseRequestOptions<?>options,intsize){returnoptions.fitCenter().override(size);}privatestaticfinalRequestOptionsDECODE_TYPE_GIF=RequestOptions.decodeTypeOf(GifDrawable.class);//GlideType注解,添加自定义的资源类型@GlideType(GifDrawable.class)publicstaticRequestBuilder<GifDrawable>asMyGif(RequestBuilder<GifDrawable>requestBuilder){returnrequestBuilder.transition(newDrawableTransitionOptions())//设置用于在加载完成时从占位符到正常显示的过渡效果.apply(DECODE_TYPE_GIF);// 将自定义的ResourceClass设置到resourceClass参数}}//使用自定义APIGlideApp.with(this).asMyGif()//使用自定义的资源.load(gifUrl).mMiniThunb(600)//使用自定义的Option.into(imageView);
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 12:14:06

智能决策指南:如何为你的微服务系统挑选合适的事务模式

智能决策指南&#xff1a;如何为你的微服务系统挑选合适的事务模式 【免费下载链接】school-of-sre linkedin/school-of-sre: 这是一个用于培训软件可靠性工程师&#xff08;SRE&#xff09;的在线课程。适合用于需要学习软件可靠性工程和运维技能的场景。特点&#xff1a;内容…

作者头像 李华
网站建设 2026/4/23 11:31:07

网盘直链下载助手:5分钟轻松突破下载限速终极指南

还在为网盘龟速下载而烦恼吗&#xff1f;网盘直链下载助手作为一款免费开源的浏览器脚本工具&#xff0c;能够帮助你快速获取百度网盘、阿里云盘等主流网盘的直链下载地址&#xff0c;让下载速度瞬间提升到满速状态&#xff01;&#x1f680; 【免费下载链接】baiduyun 油猴脚本…

作者头像 李华
网站建设 2026/4/23 11:31:05

【源码解读之 Mybatis】【核心篇】-- 第10篇:动态SQL实现原理详解

第10篇&#xff1a;动态SQL实现原理详解 前言 在前面的章节中&#xff0c;我们学习了 MyBatis 的核心执行流程&#xff0c;特别是第9篇中详细介绍了 MappedStatement 和 SqlSource 的作用。你可能注意到&#xff0c;MyBatis 能够根据不同的条件动态生成 SQL&#xff0c;这正是 …

作者头像 李华
网站建设 2026/4/23 11:38:28

飞书文档批量导出终极指南:25分钟搞定700+文档的完整备份方案

飞书文档批量导出终极指南&#xff1a;25分钟搞定700文档的完整备份方案 【免费下载链接】feishu-doc-export 项目地址: https://gitcode.com/gh_mirrors/fe/feishu-doc-export 作为一名资深团队管理者&#xff0c;我曾经面临过最头疼的文档迁移问题——公司从飞书切换…

作者头像 李华
网站建设 2026/4/23 11:31:26

1小时打造你的DirectX修复工具原型

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 快速开发一个DirectX修复工具原型&#xff0c;核心功能&#xff1a;1.基本组件检测 2.常见dll修复 3.简易GUI界面 4.基础日志功能。使用PythonPyQt实现&#xff0c;要求2小时内可完…

作者头像 李华