您好,登錄后才能下訂單哦!
這篇文章主要介紹SimpleCommand框架ImageLoader API的示例分析,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
在ImageLoader中有以下幾個(gè)不同的構(gòu)造器:
/** * 注意: 次構(gòu)造器不支持下載進(jìn)度提示功能 * @param context * @param withCache 是否支持緩存 * false--不帶緩存 * true--支持緩存功能,默認(rèn)緩存路徑在外置存儲(chǔ)緩沖目錄中的picasso-big-cache文件夾中 */ public ImageLoader(Context context, boolean withCache) { this(context, null, withCache); } /** * 支持下載進(jìn)度提示,以及設(shè)置緩存路徑 * @param context * @param listener 下載進(jìn)度監(jiān)聽器 * @param cachePath 緩存路徑字符串 */ public ImageLoader(Context context, ProgressListener listener, String cachePath) { // TODO extend to support multiple libraries as Glide // TODO must be initialized and kept as an member instance to avoid losing cache Picasso.Builder builder = setupLoaderClientWithCachePath(context, listener, cachePath); setupListener(builder); picasso = builder.build(); picasso.setIndicatorsEnabled(BuildConfig.DEBUG); picasso.setLoggingEnabled(BuildConfig.DEBUG); } /** * 支持下載進(jìn)度提示,以及設(shè)置緩存路徑為默認(rèn)路徑picasso-big-cache * @param context * @param listener 下載進(jìn)度監(jiān)聽器 * @param withCache 是否支持緩存 */ public ImageLoader(Context context, ProgressListener listener, boolean withCache) { // TODO extend to support multiple libraries as Glide // TODO must be initialized and kept as an member instance to avoid losing cache Picasso.Builder builder = setupLoaderClient(context, listener, withCache); setupListener(builder); picasso = builder.build(); picasso.setIndicatorsEnabled(BuildConfig.DEBUG); picasso.setLoggingEnabled(BuildConfig.DEBUG); }
public void shutdown() { if (picasso == null) return; Logger.d(Logger.TAG, "Image loader has been shutdown"); picasso.shutdown(); callback = null; }
將ImageLoader停止,一般在Activity停止,或者任務(wù)結(jié)束時(shí)調(diào)用此方法將其關(guān)閉
public ImageLoader cancelRequest(ImageView imageView) { picasso.cancelRequest(imageView); return this; }
取消之前顯示到ImageView上的請(qǐng)求
public ImageLoader load(final int resourceId) { cleanResources(); this.imageResourceId = resourceId; return this; } public ImageLoader load(final String imageUri) { cleanResources(); this.imageUri = imageUri; return this; }
分別加載本地drawable文件夾下的圖片,以及網(wǎng)絡(luò)圖片
public ImageLoader withPlaceholder(final int placeholder) { this.placeholder = placeholder; return this; }
設(shè)置ImageLoader下載圖片時(shí)的預(yù)覽圖
public ImageLoader withErrorImage(final int errorImage) { this.errorImage = errorImage; return this; }
下載圖片失敗時(shí)顯示的圖片
public ImageLoader withTag(final String tag) { this.tag = tag; return this; } public void pause(final String tag) { if (picasso == null) return; picasso.pauseTag(tag); } public void resume(final String tag) { if (picasso == null) return; picasso.resumeTag(tag); }
以上三個(gè)方法依次是
1 下載圖片時(shí)添加標(biāo)簽tag
2 暫停tag標(biāo)簽的下載任務(wù)
3 resume tag標(biāo)簽的下載任務(wù)
public ImageLoader withCallback(final Callback callback) { this.callback = callback; return this; }
給ImageLoader設(shè)置下載完成的回調(diào),包含onSuccess和onFailed方法
public ImageLoader fit() { this.fit = true; return this; } public ImageLoader centerCrop() { this.centerCrop = true; return this; } public ImageLoader centerInside() { this.centerInside = true; return this; } public ImageLoader resize(final int widthResId, final int heightResId) { this.widthResId = widthResId; this.heigthResId = heightResId; return this; }
分別設(shè)置Picasso下載圖片時(shí)的相應(yīng)屬性, 可以參考ImageView的scaleType屬性
public void into(final ImageView imageView) { run(imageView); }
into方法調(diào)用內(nèi)部run方法,并啟動(dòng)下載任務(wù)。 此方法需要在以上所有的API之后調(diào)用。
以上是“SimpleCommand框架ImageLoader API的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。