Android图片加载框架之(Glide和Picasso的区别,Glide的简单使用)

Glide,一个被google所推荐的图片加载库,常见的还有Picasso,Fresco等,每一个都非常稳定,功能也都十分强大。但是它们的使用场景基本都是重合的,也就是说我们基本只需要选择其中一个来进行学习和使用就足够了,每一个框架都尝试去掌握的话则有些浪费时间。最常用的是Glide和Picasso,今天就针对于Glide和Picasso的区别,以及Glide的简单使用来进行具体介绍

Picasso的基本用法

Picasso.with(this) .load(“http://nuuneoi.com/uploads/source/playstore/cover.jpg“) .into(ivImgPicasso);

Picasso.with(this) .load(“http://nuuneoi.com/uploads/source/playstore/cover.jpg“) .resize(768, 432) .into(ivImgPicasso);

Picasso.with(this) .load(“http://nuuneoi.com/uploads/source/playstore/cover.jpg“) .fit() .centerCrop() .into(ivImgPicasso);

这三种方法都可以加载图片显示到页面上,

第一种:加载了全尺寸的图片到内存,然后让GPU来实时重绘大小

第二种:你需要主动计算ImageView的大小,或者说你的ImageView大小是具体的值(而不是wrap_content),

第三种:按统一比例缩放图片(保存图片的尺寸比例)便于图片的二维(宽度和高度)等于或者大于相应的视图的维度,这种方法和Glide加载图片占用的内存几乎是相同的,虽然内存开销差距不大,但是在这个问题上Glide完胜Picasso。因为Glide可以自动计算出任意情况下的ImageView的大小。


Glide的基本用法:

Glide.with(this) .load("图片的URL".into(ivImgGlide);

load方法中不仅可以传入图片地址,还可以传入图片文件File,resource,图片的byte数组等

Glide与Picasso的区别:

1、内存:

            加载同一张图片Picasso,Picasso的内存开销仍然远大于Glide。

2、Image质量的细节:

            Glide默认的是Bitmap格式是RGB-565

            Picasso默认ARGB_8888格式

           Glide加载的图片没有Picasso那么平滑,但是很难察觉

3、磁盘缓存:      

        (1)Picasso缓存的是全尺寸的。而Glide缓存的跟ImageView尺寸相同

      (2)将ImageView调整成不同大小不管大小如何设置。Picasso只缓存一个全尺寸的。Glide则不同,它会为每种大小的ImageView缓存一次

            让Glide既缓存全尺寸又缓存其他尺寸的方法:

Glide.with(this) .load(“http://nuuneoi.com/uploads/source/playstore/cover.jpg“) .diskCacheStrategy(DiskCacheStrategy.ALL) .into(ivImgGlide);

Glide的这种方式优点是加载显示非常快。而Picasso的方式则因为需要在显示之前重新调整大小而导致一些延迟,Glide比Picasso快,虽然需要更大的空间来缓存。

4、Gif动图

            Glide可以加载Gif动图,Picasso不可以加载动图

            Glide动画会消耗太多的内存,因此使用时谨慎使用

总结一下他们之间的区别:

(1)Glide比Picasso加载速度快,但Glide比Picasso需要更大的空间来缓存;

(2)Glide加载图像及磁盘缓存的方式都优于Picasso,且Glide更有利于减少OutOfMemoryError的发生;

(3)Glide可以加载Gif动图,Picasso不可以加载动图

(4)Picasso加载的图片比Glide加载的图片平滑(可忽略不计)

Glide的具体使用方法:

1、基本使用:
添加依赖,现在Glide最新的依赖有4.x.x的
dependencies {
    compile 'com.github.bumptech.glide:glide:3.7.0'
}

基本使用是:

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

2、with()

this可以是:

Context
Activity
Fragment
FragmentActivity
ApplicationContext
Context、Activity、Fragment、FragmentActivity,都是glide经过方法都是向activity中添加一个fragment,因为glide无法直接获取到activity,添加一个与activity绑定的fragment,可以保证glide随着activity的生命周期变化而停止暂时取消加载请求。

3、load()

load是核心的请求方法, 在源码中我们可以看到是在这里进行网络请求,

// 加载本地图片
File file = new File(getExternalCacheDir() + "/image.jpg");
Glide.with(this).load(file).into(imageView);

// 加载应用资源
int resource = R.drawable.image;
Glide.with(this).load(resource).into(imageView);

// 加载二进制流
byte[] image = getImageBytes();
Glide.with(this).load(image).into(imageView);

// 加载Uri对象
Uri imageUri = getImageUri();
Glide.with(this).load(imageUri).into(imageView);

4、占位图

我们在实际加载图片的时候,由于各种原因比如网慢,一时无法请求回数据时,考虑到用户体验,一个占位图也是非常重要的

Glide.with(this)
     .load(url)
     .placeholder(R.drawable.loading)
     .error(R.drawable.error)
     .into(imageView);

5、动图

asBitmap()去加载gif图片,那么只会显示静态图片,并且只显示动图的第一帧 
.asGif()去加载静态图片会显示错误图片,报错。

Glide.with(this)
     .load(url)
     .asBitmap()
     .placeholder(R.drawable.loading)
     .error(R.drawable.error)
     .diskCacheStrategy(DiskCacheStrategy.NONE)
     .into(imageView);

6、Glide 使用加载动画和禁止动画

glide默认有淡入淡出动画.crossFade()也可以不加,也有重载.crossFade(int duration),主要设置动画进行快慢,默认是300毫秒。

Glide
    .with(context)
    .load(UsageExampleListViewAdapter.eatFoodyImages[0])
    .placeholder(R.mipmap.ic_launcher) 
    .error(R.mipmap.future_studio_launcher)
    .crossFade()
    .into(imageViewFade);

7、设置图片大小;

.override(300, 200);   //设置加载图片尺寸大小

8、图片请求的优先级

Glide可以通过Priority枚举来设置加载图片的优先级,具体使用场景就是,我们点击一个页面时,先加载页面中重要的图片,再加载那些子图像

Priority (优先级)枚举给了四个不同的选项,下面是按照递增priority(优先级)的

Priority.LOW 最低
Priority.NORMAL 正常
Priority.HIGH 最高
Priority.IMMEDIATE 立即

注意:优先级并不是完全严格遵守的。Glide 将会用他们作为一个准则,并尽可能的处理这些请求,但是它不能保证所有的图片都会按照所要求的顺序加载。

.priority(Priority.HIGH); 

9、缩略图

缩略图不同于前面提到的占位图。占位图应当是跟app绑定在一起的资源。缩略图是一个动态的占位图,可以从网络加载。缩略图也会被先加载,直到实际图片请求加载完毕。如果因为某些原因,缩略图获得的时间晚于原始图片,它并不会替代原始图片,而是简单地被忽略掉。具体的应用场景有很多,可以提供几张图片便于大家理解

Android图片加载框架之(Glide和Picasso的区别,Glide的简单使用)_第1张图片Android图片加载框架之(Glide和Picasso的区别,Glide的简单使用)_第2张图片

图中的1,2,3,4,5,6就是缩略图,7,就是原图;这样大家应该会理解一点了,我觉得吧(这里只是说一下自己的观点)缩略图一是用户体验较好,从用户的角度,我们已经看见了一个小版本的图片。点击才会加载同样的图片(高分辨率),二是省流量,一张原图或许需要几M但是一张缩略图或许只需要几K,

那怎么加载缩略图呢?Glide提供了2个不同的方法产生缩略图。

第一种,是通过在加载的时候指定一个小的分辨率,产生一个缩略图。

.thumbnail( 0.1f )里面的参数是一个浮点乘法运算
这个方法是啥意思呢?

例如,传递一个0.1f作为参数,Glide会加载原始图片大小的10%的图片。

原始图片---->1000x1000像素,

则缩略图---->100x100像素。

由于图片将会比ImageView小,你需要确保缩放类型是否正确。

注意:你所有的请求设置都会影响到你的缩略图。例如,如果你使用了一个变换让你的图片变为灰度图,缩略图也同样将会是灰度图。

第二个方法是传递一个新的Glide请求作为参数,我们看看例子

这种方法的应用场景:虽然用.thunmbnail()这种方法简单有效,但也不是总有意义的。为啥这么说呢, 如果缩略图需要从网络加载同样全分辨率图片,可能不是不快。所以提供了第二种方法

DrawableRequestBuilder thumbnailRequest = Glide
        .with( context )
        .load( eatFoodyImages[2] );
 
    Glide
        .with( context )
        .load( UsageExampleGifAndVideos.gifUrl )
        .thumbnail( thumbnailRequest )
        .into( imageView3 );

第一个缩略图请求跟第二个是完全没有关系的,可以是不同的Url,对其进行不同的转换

如果你觉得不够刺激,你还可以用递归用一个额外的缩略图去请求一个缩略图

10、缓存

 我们都知道Glide是自带缓存的,所有的图片请求都会被缓存在内存和磁盘上。大多数情况下,缓存是一个非常有用的东西,但在一些特殊的情况下并不是很明智。比如,如果你有一张不段变化的图片,但是都是用的同一个URL,这时候就需要我们避免缓存,Glide提供了一些方法避免内存存储和磁盘存储;

禁止内存存储

.skipMemoryCache( true )

去特意告诉Glide跳过内存缓存,这个只影响内存缓存!Glide为了避免以后的网络请求,仍然会缓存到磁盘

禁止磁盘存储:

如果你想要禁止请求的磁盘缓存,使用枚举型变量DiskCacheStrategy.NONE作为参数。

.diskCacheStrategy( DiskCacheStrategy.NONE )

.diskCacheStrategy()中枚举参数以及意义:

DiskCacheStrategy.NONE 啥也不缓存

DiskCacheStrategy.SOURCE 只缓存全尺寸图.

DiskCacheStrategy.RESULT 只缓存最终降低分辨后用到的图片

DiskCacheStrategy.ALL 缓存所有类型的图片 (默认)

结合两个方法就可以同时禁止内存存储和磁盘缓存了

上面是我对Glide的简单理解,希望可以帮助到大家!之后会对Glide源码进行分析,有问题可以在评论区留言。

May everyone be happy every day and everything go well!







你可能感兴趣的:(Glide)