使用Glide4如何实现高效加载图片-成都快上网建站

使用Glide4如何实现高效加载图片

本篇文章给大家分享的是有关使用Glide4如何实现高效加载图片,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

十载的昌图网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。营销型网站建设的优势是能够根据用户设备显示端的尺寸不同,自动调整昌图建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。成都创新互联从事“昌图网站设计”,“昌图网站推广”以来,每个客户项目都认真落实执行。

在build.gradle中添加glide依赖

// glide 依赖
compile 'com.github.bumptech.glide:glide:4.6.1'
// glide 相关注解,生成GlideApp代码
annotationProcessor 'com.github.bumptech.glide:compiler:4.6.1'
// Glide网络库配置成okhttp3
compile ('com.github.bumptech.glide:okhttp3-integration:4.6.1') {
  transitive = false
}

Glide全局配置类

package com.leo.demo;

import android.content.Context;
import android.support.annotation.NonNull;

import com.bumptech.glide.Glide;
import com.bumptech.glide.GlideBuilder;
import com.bumptech.glide.Registry;
import com.bumptech.glide.annotation.GlideModule;
import com.bumptech.glide.load.engine.DiskCacheStrategy;
import com.bumptech.glide.load.engine.cache.ExternalCacheDiskCacheFactory;
import com.bumptech.glide.module.AppGlideModule;
import com.bumptech.glide.request.RequestOptions;

/**
 * Created by kangyi on 2018/3/20.
 *
 * Glide全局配置,使用GlideModule注解执行自动代码生成,生成GlideApp,后续的Glide
 * 调用都需要替换为GlideApp.with(context).load(url).into(imageView) 的方式
 *
 */
@GlideModule
public class GlobalGlideConfig extends AppGlideModule {

  @Override
  public void registerComponents(@NonNull Context context, @NonNull Glide glide, @NonNull Registry registry) {
    super.registerComponents(context, glide, registry);
  }

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

  @Override
  public void applyOptions(@NonNull Context context, @NonNull GlideBuilder builder) {
    super.applyOptions(context, builder);

    /**
     * DiskCacheStrategy.NONE: 表示不缓存任何内容。
     * DiskCacheStrategy.DATA: 表示只缓存原始图片。
     * DiskCacheStrategy.RESOURCE: 表示只缓存转换过后的图片。
     * DiskCacheStrategy.ALL : 表示既缓存原始图片,也缓存转换过后的图片。
     * DiskCacheStrategy.AUTOMATIC: 表示让Glide根据图片资源智能地选择使用哪一种缓存策略(默认选项)。
     */
    builder.setDefaultRequestOptions(new RequestOptions().diskCacheStrategy(DiskCacheStrategy.RESOURCE));

    /**
     * 优先外部存储作为磁盘缓存目录,防止内部存储文件过大
     * 外部存储目录默认地址为:/sdcard/Android/data/com.sina.weibolite/cache/image_manager_disk_cache
     */
    builder.setDiskCache(new ExternalCacheDiskCacheFactory(context));
  }
}

代码解析

磁盘缓存策略

缓存常量说明
DiskCacheStrategy.NONE表示不缓存任何内容。
DiskCacheStrategy.DAT表示只缓存原始图片。
DiskCacheStrategy.RESOURCE表示只缓存转换过后的图片。
DiskCacheStrategy.ALL表示既缓存原始图片,也缓存转换过后的图片。
DiskCacheStrategy.AUTOMATIC表示让Glide根据图片资源智能地选择使用哪一种缓存策略(默认选项)。

以上就是使用Glide4如何实现高效加载图片,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注创新互联行业资讯频道。


新闻名称:使用Glide4如何实现高效加载图片
URL标题:http://kswjz.com/article/iehdoc.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流