首先简单的介绍一下Gilde作用范围。Gilde功能十分强大,它可以实现图片处理、图片本地加载、图片网络加载、位图加载、图片内存缓存、图片磁盘缓存、Gif图片加载。使用简单轻松,轻松的后是它强大的心,它帮你解决了http、输入输出流、图片缓存管理、批量加载线程管理、图片处理。

另外,因为Gilde更新了很多年了,所以部分之前的使用方式已经被作者修改,所以本人重新整理了一些基本使用:

github :https://github.com/wasabeef/glide-transformations

1.基本使用

基本形式 :先with():添加上下文或者activity

再load():要加载的图片资源

最后into() :要添加图片的View

2.加载网络图片

   /**
* 加载网络图片
* 基本形式 先with(),再load(),最后into()
*/
mImage = (ImageView)findViewById(R.id.image);
Glide.with(this)
.load("https://s0.52poke.wiki/wiki/thumb/4/4f/120Staryu.png/300px-120Staryu.png")
.into(mImage);

3.加载本地图片

    /**
* 从本地加载图片
*/
Glide.with(this)
.load(getDrawable(R.mipmap.ic_image_one))
.into(mImage);

4.设置占位图、设置异常图片、缓存方式

  1. DiskCacheStrategy.SOURCE 只缓存图像原图
  2. DiskCacheStrategy.NONE 不做磁盘缓存
  3. DiskCacheStrategy.RESULT 只缓存加载后的图像,即处理后最终显示时的图像
  4. DiskCacheStrategy.ALL 缓存所有版本的图像(默认行为)
                /**
* 设置占位图、设置异常图片、缓存方式
*
* 占位图=图片如果还没加载出来,先显示占位图
* 异常图=图片如果加载失败,显示异常图
*/
RequestOptions options = new RequestOptions();
options.placeholder(R.drawable.ic_no_image)//占位图
.error(R.drawable.ic_no_image)//异常图
.diskCacheStrategy(DiskCacheStrategy.NONE);//为了让占位图显示,我们设置不缓存图片
Glide.with(this)
.load("https://s0.52poke.wiki/wiki/thumb/f/f" +
"b/143Snorlax.png/300px-143Snorlax.png")
.apply(options)
.into(mImage);

5.加载gif格式的图片

    /**
* Glide支持加载gif格式的图片
*/
Glide.with(this)
.load("https://gss3.bdstatic.com/-Po3dSag_xI4khGkpoWK1HF6hhy/baike/" +
"w%3D268/sign=fdccc8cb23381f309e198aaf91034c" +
"67/21a4462309f79052fbc1bdcd07f3d7ca7acbd563.jpg")
.into(mImage);

6.只加载静态图片

	/**
* 设置静态图片(将图片只加载成静态图,如果加载的是gif图片,那么只取gif的第一帧)
*/
Glide.with(this)
.asBitmap()//设置静态图片
.load("https://gss3.bdstatic.com/-Po3dSag_xI4khGkpoWK1HF6hhy/baike/" +
"w%3D268/sign=fdccc8cb23381f309e198aaf" +
"91034c67/21a4462309f79052fbc1bdcd07f3d7ca7acbd563.jpg")
.into(mImage);

7.修改图片尺寸大小

	/**
* 指定图片的大小
*/
RequestOptions options1 = new RequestOptions();
options1.override(200,200);
Glide.with(this)
.load("https://s0.52poke.wiki/wiki/thumb/d/" +
"da/041Zubat.png/300px-041Zubat.png")
.apply(options1)
.into(mImage);

8.取消图片自动修改

	/**
* Glide 是会自动处理图片,将网络加载来的图片(就算是小图片),自动放大填满整个ImageView
* 我们试试取消这个自动处理,有2种方法:
* 第一种:options2.dontTransform();//不要图片处理
* 第二种:options2.override(Target.SIZE_ORIGINAL, Target.SIZE_ORIGINAL)//将尺寸设置为图片原始状态
* 注意!第一种方法会导致所有的图片处理都失效.
*/
RequestOptions options2 = new RequestOptions();
options2.dontTransform();//不要图片处理
Glide.with(this)
.load("https://s0.52poke.wiki/wiki/thumb/0/" +
"0c/042Golbat.png/300px-042Golbat.png")
.into(mImage);

9.以图片中心点裁剪图片

	/**
* CenterCrop 自动裁剪大图片的图片中心
*
* 这里我们引入一个Glide作者 最新提供的设置图片方法MultiTransformation多重设置.
* 功能部分与RequestOptions一致
*/
//RequestOptions options3 = new RequestOptions();//依然可以使用RequestOptions方法
//options3.centerCrop(); MultiTransformation mation1 = new MultiTransformation(new CenterCrop());
Glide.with(this)
.load("http://image13.m1905.cn/uploadfile" +
"/2017/0303/20170303104652678276.jpg")
.apply(RequestOptions.bitmapTransform(mation1))
//.apply(options3)
.into(mImage);

10.以图片中心缩小图片

	/**
* FitCenter 以图片中心缩小图片,使它可以放入自定大小的ImageView
*/
MultiTransformation mation2 = new MultiTransformation(new FitCenter());
Glide.with(this)
.load("http://image13.m1905.cn/uploadfile/2017/0303/20170303104652678276.jpg")
.apply(RequestOptions.bitmapTransform(mation2))
.into(mImage);

11.将图片裁剪成圆形

	/**
* CircleCrop() 图片裁剪成圆形
*/
MultiTransformation mation3 = new MultiTransformation(new CircleCrop()); Glide.with(this)
.load("https://timgsa.baidu.com/timg?image&quality=80&size=" +
"b9999_10000&sec=1535109039215&di=1be2c385a8b5b3edfa526cba" +
"ab4da880&imgtype=0&src=http%3A%2F%2Fi1.hdslb.com%2Fbfs%2Far" +
"chive%2Fc6de860ae8a75efbd3153b04ca2f4f08d093e596.jpg")
.apply(RequestOptions.bitmapTransform(mation3))
.into(mImage);

12.模糊图片

	/**
* new BlurTransformation() 模糊图片,参数为模糊度
*
* 注意: RequestOptions options5 = new RequestOptions();
* options5.bitmapTransform(new BlurTransformation()); 设置无效,可能作废
*/ MultiTransformation mation4 = new MultiTransformation(new BlurTransformation(90)); Glide.with(this)
.load("https://timgsa.baidu.com/timg?image&quality=80&size=" +
"b9999_10000&sec=1535109039215&di=1be2c385a8b5b3edfa526cba" +
"ab4da880&imgtype=0&src=http%3A%2F%2Fi1.hdslb.com%2Fbfs%2Far" +
"chive%2Fc6de860ae8a75efbd3153b04ca2f4f08d093e596.jpg")
.apply(RequestOptions.bitmapTransform(mation4))
.into(mImage);

13.黑白图片

	/**
* new GrayscaleTransformation() 黑白化图片
*/
Glide.with(this)
.load("https://media.52poke.com/wiki/7/79/138Omanyte.png")
.apply(RequestOptions.bitmapTransform(new MultiTransformation<Bitmap>(new GrayscaleTransformation())))
.into(mImage);

14.色彩过滤

	/**
* 色彩过滤
*/
Glide.with(this)
.load("https://media.52poke.com/wiki/8/84/101Electrode.png")
.apply(RequestOptions.bitmapTransform(new MultiTransformation<Bitmap>(new ColorFilterTransformation(R.color.color))))
.into(mImage);

15.将图片裁剪成圆角矩形

	/**
* 圆角图片 new RoundedCornersTransformation 参数为 :半径 , 外边距 , 圆角方向(ALL,BOTTOM,TOP,RIGHT,LEFT,BOTTOM_LEFT等等)
*/
MultiTransformation mation5 = new MultiTransformation(
new RoundedCornersTransformation(200,0,RoundedCornersTransformation.CornerType.ALL)); Glide.with(this)
.load("https://timgsa.baidu.com/timg?image&quality=80&size" +
"=b9999_10000&sec=1535108931327&di=d17318883b94e33c2be0e2" +
"f440b869ed&imgtype=0&src=http%3A%2F%2Fimg.zcool.cn%2Fcom" +
"munity%2F012aa7586f9812a8012060c84ede5b.jpg%40900w_1l_2o_100sh.jpg")
.apply(RequestOptions.bitmapTransform(mation5))
.into(mImage);

16.关于RequestOptions 与 MultiTransformation 的组合使用

	/**
* 关于RequestOptions 与 MultiTransformation 的组合使用
*/ MultiTransformation mation6 = new MultiTransformation(new GrayscaleTransformation(),
new RoundedCornersTransformation(200,0,RoundedCornersTransformation.CornerType.ALL));
RequestOptions options3 = new RequestOptions();
options3.transform(mation6)
.placeholder(R.drawable.ic_no_image)
.fallback(R.drawable.ic_no_image)
.error(R.drawable.ic_no_image); Glide.with(this)
.load("https://media.52poke.com/wiki/a/a7/098Krabby.png")
.apply(options3)
.into(mImage);

17.清除内存

	/**
* 清除内存
*/
Glide.get(this).clearMemory();//清除内存

AppGlideModule 用法

在glide4中引入 glideApp,通过annotation将option封装自动生成代码。

第一步必须自定义一个module 继承于AppGlideModule。

@GlideModule
public final class MyGlideModule extends AppGlideModule { }

注意: AppGlideModule实现必须始终与@GlideModule注释一起出现.如果注释不存在,则该模块将不会被发现。重新编译,会自动生成代码,后面可用GlideApp.with() 代替Glide.with()

1、设置手机默认推荐缓存大小。MemorySizeCalculator类通过考虑设备给定的可用内存和屏幕大小想出合理的默认大小.

/**
* MemorySizeCalculator类通过考虑设备给定的可用内存和屏幕大小想出合理的默认大小.
* 通过LruResourceCache进行缓存。
* @param context
* @param builder
*/
@Override
public void applyOptions(Context context, GlideBuilder builder) {
MemorySizeCalculator calculator = new MemorySizeCalculator.Builder(context)
.setMemoryCacheScreens(2)
.build();
builder.setMemoryCache(new LruResourceCache(calculator.getMemoryCacheSize()));
}

2、自定义内存缓存大小


/**
* 自定义缓存大小.
* @param context
* @param builder
*/
@Override
public void applyOptions(Context context, GlideBuilder builder) {
int memoryCacheSizeBytes = 1024 * 1024 * 20; // 20mb
builder.setMemoryCache(new LruResourceCache(memoryCacheSizeBytes));
}

3、Disk Cache.自定义内置磁盘缓存大小

/**
* Disk Cache.自定义内置磁盘缓存大小.
* @param context
* @param builder
*/
@Override
public void applyOptions(Context context, GlideBuilder builder) {
int diskCacheSizeBytes = 1024 * 1024 * 100; // 100 MB
builder.setDiskCache(new InternalCacheDiskCacheFactory(context, diskCacheSizeBytes));
}

4、Disk Cache.自定义内置磁盘缓存大小并指定路径.

/**
* Disk Cache.自定义内置磁盘缓存大小并指定路径.
* @param context
* @param builder
*/
@Override
public void applyOptions(Context context, GlideBuilder builder) {
int diskCacheSizeBytes = 1024 * 1024 * 100; // 100 MB
builder.setDiskCache(
new InternalCacheDiskCacheFactory(context, "cacheFolderName", diskCacheSizeBytes));
}

5、Disk Cache.自定义外置磁盘缓存大小并指定路径.

/**
* Disk Cache.自定义外置磁盘缓存大小并指定路径.
* @param context
* @param builder
*/
@Override
public void applyOptions(Context context, GlideBuilder builder) {
int diskCacheSizeBytes = 1024 * 1024 * 100; // 100 MB
builder.setDiskCache(
new ExternalCacheDiskCacheFactory(context, "cacheFolderName", diskCacheSizeBytes));
}

isManifestParsingEnabled 设置清单解析,设置为false,避免添加相同的modules两次

@Override
public boolean isManifestParsingEnabled() {
return false;
}

清除缓存

/**
* 清除内存缓存.
*/
private void clearMemoryCache(){
// This method must be called on the main thread.
Glide.get(this).clearMemory();
} /**
* 清除磁盘缓存.
*/
private void clearDiskCache(){ new AsyncTask<Void,Void,Void>(){ @Override
protected Void doInBackground(Void... params) {
// This method must be called on a background thread.
Glide.get(getApplicationContext()).clearDiskCache();
return null;
}
};
}

Android 开发 框架系列 glide-transformations 图片处理基本使用的更多相关文章

  1. Android 开发 框架系列 OkHttp拦截器

    前言 此篇博客只讲解okhttp的拦截器功能的详细使用,如果你还不太了解okhttp可以参考我另外一篇博客 Android 开发 框架系列 OkHttp使用详解 添加Interceptor的简单例子 ...

  2. Android 开发 框架系列 Google的ORM框架 Room

    目录 简介 导入工程 使用流程概况 一个简单的小Demo 深入学习 @Entity使用 自定义表名 tableName  自定义字段名@ColumnInfo 主键 @PrimaryKey 索引 @In ...

  3. Android 开发 框架系列 Android-Universal-Image-Loader 图片加载使用demo

    Android-Universal-Image-Loader github地址:https://github.com/nostra13/Android-Universal-Image-Loader 加 ...

  4. Android 开发 框架系列 OkHttp使用详解

    简介 okhttp是一个第三方类库,用于android中请求网络.这是一个开源项目,是安卓端最火热的轻量级框架,由移动支付Square公司贡献(该公司还贡献了Picasso和LeakCanary) . ...

  5. Android 开发 框架系列 百度语音合成

    官方文档:http://ai.baidu.com/docs#/TTS-Android-SDK/6d5d6899 官方百度语音合成控制台:https://cloud.baidu.com/product/ ...

  6. Android 开发 框架系列 EventBus 事件总线

    介绍 GitHub:https://github.com/greenrobot/EventBus 先聊聊EventBus 线程总线是干什么的,使用环境,优点.缺点. 干什么的? 一句话,简单统一数据传 ...

  7. android 开发 框架系列 使用 FileDownloader 实现检查更新的功能class

    首先介绍一下FileDownloader GH :https://github.com/lingochamp/FileDownloader/blob/master/README-zh.md FileD ...

  8. Android 开发 框架系列 OkHttp文件上传功能实现(含断点续传)

    前言 此篇博客只是上传功能的记录demo,如果你还不太了解okhttp可以参考我的另一篇博客https://www.cnblogs.com/guanxinjing/p/9708575.html 代码部 ...

  9. Android 开发 框架系列 OkHttp文件下载功能实现(含断点续传)

    前言 此篇博客只是下载功能的记录demo,如果你还不太了解okhttp可以参考我的另一篇博客https://www.cnblogs.com/guanxinjing/p/9708575.html 代码部 ...

随机推荐

  1. nginx请求数据超长的问题解决

    参考文章 https://www.cnblogs.com/onmyway20xx/p/4469202.html http://blog.51cto.com/iyull/2129220

  2. .net Monitor产生SynchronizationLockException异常的原因

    有时在使用Monitor进行并发同步编程时,会产生SynchronizationLockException异常,抛出的异常内容是"Object synchronization method ...

  3. OpenCV学习(一)基础篇

    OpenCV 2 计算机视觉编程手册读书笔记1 矩阵创建 Mat类是OpenCV中非常有用类,用来创建和操作多维矩阵.可以有很多方法构造它. // 构造函数 //! constructs 2D mat ...

  4. 剑指Offer 36. 两个链表的第一个公共结点 (链表)

    题目描述 输入两个链表,找出它们的第一个公共结点. 题目地址 https://www.nowcoder.com/practice/6ab1d9a29e88450685099d45c9e31e46?tp ...

  5. canvas画圆类似于锯齿指针 angular5

    拿到图的时候大致是这样的,里面的圆是有动态效果的,考虑到gif图耗资源,于是想要用canvas画出来: 仔细看图不难发现,这个锯齿圆类似于表盘,计算好弧度,不难实现: 因为项目现在用的框架是angul ...

  6. linux vi命令详解

    刚开始学着用linux,对vi命令不是很熟,在网上转接了一篇. vi编辑器是所有Unix及Linux系统下标准的编辑器,它的强大不逊色于任何最新的文本编辑器,这里只是简单地介绍一下它的用法和一小部分指 ...

  7. window.location.href webkit不兼容

    window.event.returnValue=false; 在location.href后加上后修复 来自为知笔记(Wiz)

  8. 导入maven项目导入依赖不会报错,但使用的jar会标红

    方法1: 1.通过编译找到报错的jar; 2.在 repository找到此jar,一般未下载完大小为1k我的是这样(); 3.删除未下载完全的jar,在项目上执行maven reimport会重新下 ...

  9. Linux下修改Jenkins默认端口

    我是自动安装的Jenkins,默认目录为 jenkins安装目录:/var/lib/jenkins jenkins日志目录:/var/log/jenkins/jenkins.logjenkins默认配 ...

  10. c# .net 面试总结

    一. sql优化 . 写明查询具体某几列,减少*的使用,表名过长时,尽量使用表的别名 *和列名一样 ,在业务密集的SQL当中尽量不采用IN操作符,用EXISTS 方案代替. in 和 exists的区 ...