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

com.bumptech.glide.load.ResourceDecoder 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;

import android.support.annotation.Nullable;
import com.bumptech.glide.load.engine.Resource;
import java.io.IOException;

/**
 * An interface for decoding resources.
 *
 * @param  The type the resource will be decoded from (File, InputStream etc).
 * @param  The type of the decoded resource (Bitmap, Drawable etc).
 */
public interface ResourceDecoder {

  /**
   * Returns {@code true} if this decoder is capable of decoding the given source with the given
   * options, and {@code false} otherwise.
   *
   * 

Decoders should make a best effort attempt to quickly determine if they are likely to be * able to decode data, but should not attempt to completely read the given data. A typical * implementation would check the file headers verify they match content the decoder expects to * handle (i.e. a GIF decoder should verify that the image contains the GIF header block.

* *

Decoders that return {@code true} from {@link #handles(Object, Options)} may still * return {@code null} from {@link #decode(Object, int, int, Options)} if the data is * partial or formatted incorrectly.

* * @throws IOException */ boolean handles(T source, Options options) throws IOException; /** * Returns a decoded resource from the given data or null if no resource could be decoded. * *

The {@code source} is managed by the caller, there's no need to close it. The returned * {@link Resource} will be {@link Resource#recycle() released} when the engine sees fit.

* *

Note - The {@code width} and {@code height} arguments are hints only, there is no * requirement that the decoded resource exactly match the given dimensions. A typical use case * would be to use the target dimensions to determine how much to downsample Bitmaps by to avoid * overly large allocations.

* * @param source The data the resource should be decoded from. * @param width The ideal width in pixels of the decoded resource, or {@link * com.bumptech.glide.request.target.Target#SIZE_ORIGINAL} to indicate the original * resource width. * @param height The ideal height in pixels of the decoded resource, or {@link * com.bumptech.glide.request.target.Target#SIZE_ORIGINAL} to indicate the original * resource height. * @param options A map of string keys to objects that may or may not contain options available to * this particular implementation. Implementations should not assume that any or * all of their option keys are present. However, implementations may assume that * if one of their option keys is present, it's value is non-null and is of the * expected type. * @throws IOException */ @Nullable Resource decode(T source, int width, int height, Options options) throws IOException; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy