glide:请求优先级

图片请求优先级

你经常会遇到这些情况,你的app需要同时加载多个图片。假设你正在创建一个信息展示界面,包含顶部的一个主要照片,还有底部的2个并不重要的小图。对于用户体验,我们最好先加载主角照片,然后再加载底部不紧急的图片。Glide里的.priority()方法和Priority的枚举变量支持你的想法。

在看例子之前,我们先看一下作为.priority()方法参数的Priority的枚举变量。

学习Priority枚举变量

一共有四个不同的枚举变量。下面以递增方式列出:

  • Priority.LOW

  • Priority.NORMAL

  • Priority.HIGH

  • Priority.IMMEDIATE

在跳到例子前,你应当明白优先级并不是非常严格的。Glide会将它们作为一个指导来最优化处理请求。但并不意味着所有的图片都能够按请求的顺序加载。

然而。如果你已经有需要某些重要的图片的使用场景,好好利用优先级!

使用例子: 带有子图的主要元素

让我们回顾一下我们最开始的例子。你正在实现一个信息细节界面,其中包含1个顶部的主要图片,还有底部的2个小图。对于最佳的用户体验,主要图片需要优先被加载。这样,我们分配Priority.HIGH给它。理论上,那就够了。但为了这个例子更有趣,我们通过调用.priority(Priority.LOW)分配给底部的图片低优先级权限:

private void loadImageWithHighPriority() {  
    Glide
        .with( context )
        .load( UsageExampleListViewAdapter.eatFoodyImages[0] )
        .priority( Priority.HIGH )
        .into( imageViewHero );
}

private void loadImagesWithLowPriority() {  
    Glide
        .with( context )
        .load( UsageExampleListViewAdapter.eatFoodyImages[1] )
        .priority( Priority.LOW )
        .into( imageViewLowPrioLeft );

    Glide
        .with( context )
        .load( UsageExampleListViewAdapter.eatFoodyImages[2] )
        .priority( Priority.LOW )
        .into( imageViewLowPrioRight );
}

如果你运行了这个例子,你会发现,不管是多大的图片,几乎所有情况下主要的图片都会被优先显示。(图片越大,需要更多的处理时间)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值