Glide 圖片加載庫(kù)詳細(xì)用法

Gilde 定義

Gilde 是google開源的圖片加載庫(kù)。

glide依賴

//glide

compile 'com.github.bumptech.glide:glide:4.0.0'

annotationProcessor 'com.github.bumptech.glide:compiler:4.0.0'

glide 基礎(chǔ)用法

glide 用法傳承目前流行的鏈?zhǔn)秸{(diào)用。

/**

* 基礎(chǔ)用法.

*/

private void baseUsed(){

Glide.with(this)

.load(URL)

.into(mImageView);

}

glide 可以用RequestOptions配置各種參數(shù):

private void gildeOptions(){

RequestOptions options = new RequestOptions();

options.centerCrop()

.placeholder(R.drawable.default_avatar)

.error(R.drawable.image_error)

.fallback(R.drawable.fallback_nodata);

Glide.with(this)

.load(URL)

.apply(options)

.into(mImageView);

}

其中Built in types:

CenterCrop:類似 ScaleType.CENTER_CROP

FitCenter: 類似 ScaleType.FIT_CENTER

CircleCrop: 圓形裁剪

placeholder: 占位即加載中的圖片。

error: 錯(cuò)誤圖片.

fallback: 當(dāng)url為null的時(shí)候,判斷是否設(shè)置了fallback,是的話則顯示fallback圖片,否的話顯示error圖片,如果error還是沒有設(shè)置則顯示placeholder圖片.

這幾個(gè)圖片顯示規(guī)則:

glide.png

glide RequestBuilders還可以重用開始多個(gè)加載

private void multipleLoad(){

RequestOptions options = new RequestOptions();

options.centerCrop()

.placeholder(R.drawable.default_avatar)

.error(R.drawable.image_error)

.fallback(R.drawable.fallback_nodata);

RequestBuilder requestBuilder =

Glide.with(this)

.asDrawable().apply(options);

for(int i=0;i

ImageView view = (ImageView) mImageGroup.getChildAt(i);

requestBuilder.clone()

.load(urls[i])

.into(view);

}

}

AppGlideModule 用法

在glide4中引入 glideApp,通過annotation將option封裝自動(dòng)生成代碼。

第一步必須自定義一個(gè)module 繼承于AppGlideModule。

@GlideModule

public final class MyGlideModule extends AppGlideModule {

}

注意:AppGlideModule實(shí)現(xiàn)必須始終與@GlideModule注釋一起出現(xiàn).如果注釋不存在,則該模塊將不會(huì)被發(fā)現(xiàn)。重新編譯,會(huì)自動(dòng)生成代碼,后面可用GlideApp.with() 代替Glide.with()

1、設(shè)置手機(jī)默認(rèn)推薦緩存大小。MemorySizeCalculator類通過考慮設(shè)備給定的可用內(nèi)存和屏幕大小想出合理的默認(rèn)大小.

/**

* MemorySizeCalculator類通過考慮設(shè)備給定的可用內(nèi)存和屏幕大小想出合理的默認(rèn)大小.

* 通過LruResourceCache進(jìn)行緩存。

* @param context

* @param builder

*/

@Override

public void applyOptions(Context context, GlideBuilder builder) {

MemorySizeCalculator calculator = new MemorySizeCalculator.Builder(context)

.setMemoryCacheScreens(2)

.build();

builder.setMemoryCache(new LruResourceCache(calculator.getMemoryCacheSize()));

}

2、自定義內(nèi)存緩存大小

/**

* 自定義緩存大小.

* @param context

* @param builder

*/

@Override

public void applyOptions(Context context, GlideBuilder builder) {

int memoryCacheSizeBytes = 1024 * 1024 * 20; // 20mb

builder.setMemoryCache(new LruResourceCache(memoryCacheSizeBytes));

}

3、Disk Cache.自定義內(nèi)置磁盤緩存大小

/**

* Disk Cache.自定義內(nèi)置磁盤緩存大小.

* @param context

* @param builder

*/

@Override

public void applyOptions(Context context, GlideBuilder builder) {

int diskCacheSizeBytes = 1024 * 1024 * 100; // 100 MB

builder.setDiskCache(new InternalCacheDiskCacheFactory(context, diskCacheSizeBytes));

}

4、Disk Cache.自定義內(nèi)置磁盤緩存大小并指定路徑.

/**

* Disk Cache.自定義內(nèi)置磁盤緩存大小并指定路徑.

* @param context

* @param builder

*/

@Override

public void applyOptions(Context context, GlideBuilder builder) {

int diskCacheSizeBytes = 1024 * 1024 * 100; // 100 MB

builder.setDiskCache(

new InternalCacheDiskCacheFactory(context, "cacheFolderName", diskCacheSizeBytes));

}

5、Disk Cache.自定義外置磁盤緩存大小并指定路徑.

/**

* Disk Cache.自定義外置磁盤緩存大小并指定路徑.

* @param context

* @param builder

*/

@Override

public void applyOptions(Context context, GlideBuilder builder) {

int diskCacheSizeBytes = 1024 * 1024 * 100; // 100 MB

builder.setDiskCache(

new ExternalCacheDiskCacheFactory(context, "cacheFolderName", diskCacheSizeBytes));

}

isManifestParsingEnabled 設(shè)置清單解析,設(shè)置為false,避免添加相同的modules兩次

@Override

public boolean isManifestParsingEnabled() {

return false;

}

GlideApp用法

基本用法

private void gildeAppUsed(){

GlideApp.with(this)

.load(URL1)

.placeholder(R.drawable.default_avatar)

.error(R.drawable.image_error)

.fallback(R.drawable.fallback_nodata)

.into(mImageView);

}

設(shè)置完全緩存

/**

* 緩存.

*/

private void diskCacheStrategyAll(){

GlideApp.with(this)

.asBitmap()

.load(URL)

.placeholder(R.drawable.default_avatar)

.error(R.drawable.image_error)

.fallback(R.drawable.fallback_nodata)

.diskCacheStrategy(DiskCacheStrategy.ALL)

.into(mImageView);

}

DiskCacheStrategy.NONE 不做磁盤緩存

DiskCacheStrategy.SOURCE 只緩存圖像原圖

DiskCacheStrategy.RESULT 只緩存加載后的圖像,即處理后最終顯示時(shí)的圖像

DiskCacheStrategy.ALL 緩存所有版本的圖像(默認(rèn)行為)

只從緩存中讀取,如果緩存沒有,則失敗.

private void retrieveFromCache(){

GlideApp.with(this)

.asBitmap()

.load(URL)

.placeholder(R.drawable.default_avatar)

.error(R.drawable.image_error)

.fallback(R.drawable.fallback_nodata)

.onlyRetrieveFromCache(true)

.into(mImageView);

}

跳過緩存. 每次都從服務(wù)端獲取最新.

/**

* 跳過緩存. 每次都從服務(wù)端獲取最新.

* diskCacheStrategy: 磁盤緩存

* skipMemoryCache:內(nèi)存緩存

*/

private void skipCache(){

GlideApp.with(this)

.asBitmap()

.load(URL)

.diskCacheStrategy(DiskCacheStrategy.NONE)

.skipMemoryCache(true)

.into(mImageView);

}

清除緩存

/**

* 清除內(nèi)存緩存.

*/

private void clearMemoryCache(){

// This method must be called on the main thread.

Glide.get(this).clearMemory();

}

/**

* 清除磁盤緩存.

*/

private void clearDiskCache(){

new AsyncTask(){

@Override

protected Void doInBackground(Void... params) {

// This method must be called on a background thread.

Glide.get(getApplicationContext()).clearDiskCache();

return null;

}

};

}

其他

自定義圓角Transform

public class CircleTransform extends BitmapTransformation {

public CircleTransform(Context context){

super(context);

}

@Override

protected Bitmap transform(@NonNull BitmapPool pool, @NonNull Bitmap toTransform, int outWidth, int outHeight) {

return circleCrop(pool,toTransform);

}

@Override

public void updateDiskCacheKey(MessageDigest messageDigest) {

}

private static Bitmap circleCrop(BitmapPool pool, Bitmap source) {

if (source == null) return null;

int size = Math.min(source.getWidth(), source.getHeight());

int x = (source.getWidth() - size) / 2;

int y = (source.getHeight() - size) / 2;

Bitmap squared = Bitmap.createBitmap(source, x, y, size, size);

Bitmap result = pool.get(size, size, Bitmap.Config.ARGB_8888);

if (result == null) {

result = Bitmap.createBitmap(size, size, Bitmap.Config.ARGB_8888);

}

Canvas canvas = new Canvas(result);

Paint paint = new Paint();

//畫布中背景圖片與繪制圖片交集部分

paint.setShader(new BitmapShader(squared, BitmapShader.TileMode.CLAMP, BitmapShader.TileMode.CLAMP));

paint.setAntiAlias(true);

float r = size / 2f;

canvas.drawCircle(r, r, r, paint);

return result;

}

}

調(diào)用:

/**

* 自定義圓形裁剪.

*/

private void customerOptions(){

RequestOptions options = new RequestOptions();

options.centerCrop()

.placeholder(R.drawable.default_avatar)

.error(R.drawable.image_error)

.fallback(R.drawable.fallback_nodata)

.transform(new CircleTransform(this));

Glide.with(this)

.load(URL)

.apply(options)

.into(mImageView);

}

作者:johnnycmj

鏈接:http://www.lxweimin.com/p/34cac7ec531e

來源:簡(jiǎn)書

著作權(quán)歸作者所有。商業(yè)轉(zhuǎn)載請(qǐng)聯(lián)系作者獲得授權(quán),非商業(yè)轉(zhuǎn)載請(qǐng)注明出處。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

推薦閱讀更多精彩內(nèi)容