All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.bumptech.glide.load.data.AssetPathFetcher Maven / Gradle / Ivy

Go to download

A fast and efficient image loading library for Android focused on smooth scrolling.

There is a newer version: 5.0.0-rc01
Show newest version
package com.bumptech.glide.load.data;

import android.content.res.AssetManager;
import android.support.annotation.NonNull;
import android.util.Log;
import com.bumptech.glide.Priority;
import com.bumptech.glide.load.DataSource;
import java.io.IOException;

/**
 * An abstract class for obtaining data for an asset path using an {@link
 * android.content.res.AssetManager}.
 *
 * @param  The type of data obtained from the asset path (InputStream, FileDescriptor etc).
 */
public abstract class AssetPathFetcher implements DataFetcher {
  private static final String TAG = "AssetPathFetcher";
  private final String assetPath;
  private final AssetManager assetManager;
  private T data;

  // Public API.
  @SuppressWarnings("WeakerAccess")
  public AssetPathFetcher(AssetManager assetManager, String assetPath) {
    this.assetManager = assetManager;
    this.assetPath = assetPath;
  }

  @Override
  public void loadData(Priority priority, DataCallback callback) {
    try {
      data = loadResource(assetManager, assetPath);
    } catch (IOException e) {
      if (Log.isLoggable(TAG, Log.DEBUG)) {
        Log.d(TAG, "Failed to load data from asset manager", e);
      }
      callback.onLoadFailed(e);
      return;
    }
    callback.onDataReady(data);
  }

  @Override
  public void cleanup() {
    if (data == null) {
      return;
    }
    try {
      close(data);
    } catch (IOException e) {
      // Ignored.
    }
  }

  @Override
  public void cancel() {
    // Do nothing.
  }

  @NonNull
  @Override
  public DataSource getDataSource() {
    return DataSource.LOCAL;
  }

  /**
   * Opens the given asset path with the given {@link android.content.res.AssetManager} and returns
   * the concrete data type returned by the AssetManager.
   *
   * @param assetManager An AssetManager to use to open the given path.
   * @param path         A string path pointing to a resource in assets to open.
   */
  protected abstract T loadResource(AssetManager assetManager, String path) throws IOException;

  /**
   * Closes the concrete data type if necessary.
   *
   * @param data The data to close.
   */
  protected abstract void close(T data) throws IOException;
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy