Class DirectResourceLoader<DataT>

java.lang.Object
com.bumptech.glide.load.model.DirectResourceLoader<DataT>
Type Parameters:
DataT - The type of data this ModelLoader will produce (e.g. InputStream, AssetFileDescriptor etc).
All Implemented Interfaces:
ModelLoader<Integer,DataT>

public final class DirectResourceLoader<DataT> extends Object implements ModelLoader<Integer,DataT>
Loads themed resource ids using Resources.openRawResource(int) or Resources.openRawResourceFd(int) using the theme from ResourceDrawableDecoder.THEME when it's available.

Resource ids from other packages are handled by ResourceLoader via ResourceDrawableDecoder and ResourceBitmapDecoder.

  • Method Details

    • inputStreamFactory

      public static ModelLoaderFactory<Integer,InputStream> inputStreamFactory(Context context)
    • assetFileDescriptorFactory

      public static ModelLoaderFactory<Integer,AssetFileDescriptor> assetFileDescriptorFactory(Context context)
    • drawableFactory

      public static ModelLoaderFactory<Integer,Drawable> drawableFactory(Context context)
    • buildLoadData

      public ModelLoader.LoadData<DataT> buildLoadData(@NonNull Integer resourceId, int width, int height, @NonNull Options options)
      Description copied from interface: ModelLoader
      Returns a ModelLoader.LoadData containing a DataFetcher required to decode the resource represented by this model, as well as a set of Keys that identify the data loaded by the DataFetcher as well as an optional list of alternate keys from which equivalent data can be loaded. The DataFetcher will not be used if the resource is already cached.

      Note - If no valid data fetcher can be returned (for example if a model has a null URL), then it is acceptable to return a null data fetcher from this method.

      Specified by:
      buildLoadData in interface ModelLoader<Integer,DataT>
      Parameters:
      resourceId - The model representing the resource.
      width - The width in pixels of the view or target the resource will be loaded into, or Target.SIZE_ORIGINAL to indicate that the resource should be loaded at its original width.
      height - The height in pixels of the view or target the resource will be loaded into, or Target.SIZE_ORIGINAL to indicate that the resource should be loaded at its original height.
    • handles

      public boolean handles(@NonNull Integer integer)
      Description copied from interface: ModelLoader
      Returns true if the given model is a of a recognized type that this loader can probably load.

      For example, you may want multiple Uri to InputStream loaders. One might handle media store Uris, another might handle asset Uris, and a third might handle file Uris etc.

      This method is generally expected to do no I/O and complete quickly, so best effort results are acceptable. ModelLoaders that return true from this method may return null from ModelLoader.buildLoadData(Object, int, int, Options)

      Specified by:
      handles in interface ModelLoader<Integer,DataT>