glide自定义分析

ModelLoader
工厂接口,用于将任意复杂的数据模型转换为具体的数据类型,DataFetcher可以使用该接口来获取由资源代表的资源的数据模型.

public interface ModelLoader<Model, Data> {
   
}

DataFetcher
懒惰地检索可用于加载资源的数据

public interface DataFetcher<T> {
   
}

GlideContext

Glide中所有加载的全局上下文,其中包含并公开了加载资源所需的各种注册表和类.

public class GlideContext extends ContextWrapper {
   
}

RequestManagerRetriever
用于创建新的RequestManager的静态方法的集合,或者从Acivity和Fragment中检索现有的

public class RequestManagerRetriever implements Handler.Callback {
   
}

RequestManager
一类用于管理和启动Glide的请求。 可以使用Activity,fragment和连接生命周期事件来智能地停止,启动和重新启动请求.通过实例化新对象或利用Activity和Fragment生命周期处理.

public class RequestManager
    implements ComponentCallbacks2, LifecycleListener, ModelTypes<RequestBuilder<Drawable>> {
   
  protected final Glide glide;

  @NonNull
  @CheckResult
  public RequestBuilder<Drawable> asDrawable() {
   
    return as(Drawable.class);
  }
  
  @NonNull
  @CheckResult
  public <ResourceType> RequestBuilder<ResourceType> as(
      @NonNull Class<ResourceType> resourceClass) {
   
    return new RequestBuilder<>(glide, this, resourceClass, context);
  }
  
  synchronized void track(@NonNull Target<?> target, @NonNull Request request) {
   
    targetTracker.track(target);
    requestTracker.runRequest(request);
  }
}

RequestBuilder
通用类,可以处理通用资源类型的设置选项和启动负载.

public class RequestBuilder<TranscodeType> extends BaseRequestOptions<RequestBuilder<TranscodeType>>
    implements Cloneable, ModelTypes<RequestBuilder<TranscodeType>> {
   
    
  private final Context context;
    
  private final RequestManager requestManager;
    
    
  private final Class<TranscodeType> transcodeClass;
    
    
  private final Glide glide;//单例类
    
    
  private final GlideContext glideContext;

  @NonNull
  @Override
  @CheckResult
  public RequestBuilder<TranscodeType> load(@Nullable String string) {
   
    return loadGeneric(string);
  }
  
  @NonNull
  private RequestBu
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值