Glide框架的使用

简介

Glide是一款谷歌官方推荐使用的强大图片加载框架。它具有使用非常简单、可配置度高、加载的图片格式丰富、加载的图片路径多种、高效的缓存策略和与Activity/Fragment生命周期绑定等特点。

特点

(1)使用简单
(2)可配置度高,自适应程度高
(3)支持常见图片格式 jpg、png、gif、webp
(4)支持多种数据源 网络、本地、资源、Assets 等
(5)高效缓存策略,支持Memory和Disk图片缓存 默认Bitmap格式采用RGB_565内存使用至少减少一半
(6)生命周期集成,根据Activity/Fragment生命周期自动管理请求
(7)高效处理Bitmap 使用Bitmap Pool使Bitmap复用,主动调用recycle回收需要回收的Bitmap,减小系统回收压力

下载地址

https://github.com/bumptech/glide

功能

1)简单使用

Glide.with(this).load("url").into(imageView);

2)Glide.with()使用

(1)with(Context context)
使用Application上下文,Glide请求将不受Activity/Fragment生命周期控制。
(2)with(Activity activity)
使用Activity作为上下文,Glide的请求会受到Activity生命周期控制。
(3)with(FragmentActivity activity)
Glide的请求会受到FragmentActivity生命周期控制。
(4)with(android.app.Fragment fragment)
Glide的请求会受到Fragment 生命周期控制。
(5)with(android.support.v4.app.Fragment fragment)
Glide的请求会受到Fragment生命周期控制。

3)load()使用

Glide基本可以load任何可以拿到的媒体资源

//SD卡资源:
load("file://"+ Environment.getExternalStorageDirectory().getPath()+"/test.jpg")

//assets资源:
load("file:///android_asset/f003.gif")

//raw资源:
load("Android.resource://com.frank.glide/raw/raw_1")
//或
load("android.resource://com.frank.glide/raw/"+R.raw.raw_1)

//drawable资源:
load("android.resource://com.frank.glide/drawable/news")
//或
load("android.resource://com.frank.glide/drawable/"+R.drawable.news) 

//ContentProvider资源:
load("content://media/external/images/media/139469") 

//http资源:
load("http://img.my.csdn.NET/uploads/201508/05/1438760757_3588.jpg") 

//https资源:
load("https://wx4.sinaimg.cn/mw690/7944ffc4ly1fixi692jkqj22g53o7u10.jpg") 

注意:load不限于String类型
还可以是:load(Uri uri),load(File file),load(Integer resourceId),load(URL url),load(byte[] model),load(T model),loadFromMediaStore(Uri uri)。

4)重要功能

(1)禁止内存缓存:
.skipMemoryCache(true)
(2)清除内存缓存:
必须在UI线程中调用Glide.get(context).clearMemory();
(3)禁止磁盘缓存:
.diskCacheStrategy(DiskCacheStrategy.NONE)
(5)获取缓存大小:

new GetDiskCacheSizeTask(textView).execute(new File(getCacheDir(), DiskCache.Factory.DEFAULT_DISK_CACHE_DIR));

(6)指定资源的优先加载顺序:

//优先加载
    Glide
        .with(context)
        .load(heroImageUrl)
        .priority(Priority.HIGH)
        .into(imageViewHero);

    //后加载
    Glide
        .with(context)
        .load(itemImageUrl)
        .priority(Priority.LOW)
        .into(imageViewItem);

(7)先显示缩略图,再显示原图:

//用原图的1/10作为缩略图

    Glide

        .with(this)

        .load("http://inthecheesefactory.com/uploads/source/nestedfragment/fragments.png")

        .thumbnail(0.1f)

        .into(iv_0);

    //用其它图片作为缩略图

    DrawableRequestBuilder<Integer> thumbnailRequest = Glide

        .with(this)

        .load(R.drawable.news);

    Glide.with(this)

        .load("http://inthecheesefactory.com/uploads/source/nestedfragment/fragments.png")

        .thumbnail(thumbnailRequest)

        .into(iv_0);

(8)对图片进行裁剪、模糊、滤镜等处理:

    //圆形裁剪

    Glide.with(this)

        .load("http://inthecheesefactory.com/uploads/source/nestedfragment/fragments.png")

        .bitmapTransform(new CropCircleTransformation(this))

        .into(iv_0);

    //圆角处理

    Glide.with(this)

        .load("http://inthecheesefactory.com/uploads/source/nestedfragment/fragments.png")

        .bitmapTransform(new RoundedCornersTransformation(this,30,0, RoundedCornersTransformation.CornerType.ALL))

        .into(iv_0);

    //灰度处理

    Glide.with(this)

        .load("http://inthecheesefactory.com/uploads/source/nestedfragment/fragments.png")

        .bitmapTransform(new GrayscaleTransformation(this))

        .into(iv_0);

    //其它变换...

(9)对请求状态进行监听:
(10)对资源的下载进度进行监听:

基本使用

//加载网络图片
        tvGlide1.setText("加载网络图片");
        Glide.with(this)
                .load("https://wx4.sinaimg.cn/mw690/7944ffc4ly1fixi692jkqj22g53o7u10.jpg\n")
                .into(ivGlide1);

        //加载资源图片
        tvGlide2.setText("加载资源图片");
        Glide.with(this).load(R.drawable.ic_launcher_background).into(ivGlide2);

        //加载本地图片
        tvGlide3.setText("加载本地图片");
        String path = Environment.getExternalStorageDirectory() + "/bobo.jpg";
        File file = new File(path);
        Uri uri = Uri.fromFile(file);
        Glide.with(this).load(uri).into(ivGlide3);

        //加载网络gif
        tvGlide4.setText("加载网络gif");
        String gif = "http://b.hiphotos.baidu.com/zhidao/pic/item/faedab64034f78f066abccc57b310a55b3191c67.jpg";
        Glide.with(this).load(gif).placeholder(R.drawable.ic_launcher_background).into(ivGlide4);

        //加载资源gif
        tvGlide5.setText("加载资源gif");
        Glide.with(this).load(R.drawable.loading)
                .placeholder(R.drawable.ic_launcher_background)
                .into(ivGlide5);

        //加载本地gif
        tvGlide6.setText("加载本地gif");
        String gifPath = Environment.getExternalStorageDirectory() + "/girl.gif";
        File gifFile = new File(gifPath);
        Glide.with(this).load(gifFile).placeholder(R.drawable.ic_launcher_background).into(ivGlide6);

        //(7)加载本地小视频和快照
        tvGlide7.setText("加载本地小视频和快照");
        String videoPath =Environment.getExternalStorageDirectory()+"/7.mp4";
        File videoFile = new File(videoPath);
        Glide.with(this).load(Uri.fromFile(videoFile)).placeholder(R.mipmap.ic_launcher).into(ivGlide7);

        //(8)设置缩略图比例,然后,先加载缩略图,再加载原图
        tvGlide8.setText("设置缩略图比例,然后,先加载缩略图,再加载原图");
        String urlPath= Environment.getExternalStorageDirectory() + "/bobo.jpg";
        Glide.with(this).load(new File(urlPath)).thumbnail(0.1f)
                .centerCrop().placeholder(R.mipmap.ic_launcher)
                .into(ivGlide8);

        //(9)先建立一个缩略图对象,然后,先加载缩略图,再加载原图
        tvGlide9.setText("先建立一个缩略图对象,然后,先加载缩略图,再加载原图");
        RequestBuilder<Drawable> requestManager =  Glide.with(this).load(new File(urlPath));
        Glide.with(this).load(Uri.fromFile(videoFile))
                .thumbnail(requestManager).centerCrop()
                .placeholder(R.mipmap.ic_launcher).into(ivGlide9);
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,454评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,553评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,921评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,648评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,770评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,950评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,090评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,817评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,275评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,592评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,724评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,409评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,052评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,815评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,043评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,503评论 2 361
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,627评论 2 350

推荐阅读更多精彩内容