Glide實(shí)現(xiàn)加載圖片顯示進(jìn)度條效果
先來看看效果圖:

Glide作為最近幾年剛開始流行起來的圖片加載庫,功能非常強(qiáng)大,我相信好多人都開始在項(xiàng)目中使用了,網(wǎng)上關(guān)于Glide的使用教程也非常多,最近在項(xiàng)目中要實(shí)現(xiàn)圖片的進(jìn)度條加載,在網(wǎng)上也沒看到有現(xiàn)成的,就想著自己研究一下。
使用
Glide.with(MainActivity.this).using(new ProgressModelLoader(
new ProgressHandler(MainActivity.this, progressImageView))).
load("http://image2.sina.com.cn/dy/o/2004-11-10/1100077821_2laygS.jpg")
.diskCacheStrategy(DiskCacheStrategy.NONE).into(progressImageView.getImageView());
思路
Glide的圖片下載底層用的是OkHttp,它已經(jīng)實(shí)現(xiàn)好了,所有要實(shí)現(xiàn)進(jìn)度條加載,就必須要知道圖片下載的進(jìn)度,就要自己來寫圖片的下來實(shí)現(xiàn),但是Glide支持不支持呢?網(wǎng)上查了一下發(fā)現(xiàn)它有個(gè)方法
public <T> ImageModelRequest<T> using(final StreamModelLoader<T> modelLoader) {
return new ImageModelRequest<T>(modelLoader);
}
這個(gè)方法可以指定圖片請(qǐng)求loader,我們創(chuàng)建一個(gè)ProgressModelLoader類,實(shí)現(xiàn)StreamModelLoader接口
public class ProgressModelLoader implements StreamModelLoader<String> {
private Handler handler;
public ProgressModelLoader(Handler handler) {
this.handler = handler;
}
@Override
public DataFetcher<InputStream> getResourceFetcher(String model, int width, int height) {
return new ProgressDataFetcher(model, handler);
}
}
重寫getResourceFetcher方法,這個(gè)方法返回一個(gè)DataFetcher類,這個(gè)類是個(gè)數(shù)據(jù)提取類,是個(gè)接口,重寫它的loadData方法來下載圖片,我們來看下我創(chuàng)建的ProgressDataFetcher對(duì)loadData方法的重寫
@Override
public InputStream loadData(Priority priority) throws Exception {
Request request = new Request.Builder().url(url).build();
OkHttpClient client = new OkHttpClient();
client.interceptors().add(new ProgressInterceptor(getProgressListener()));
try {
progressCall = client.newCall(request);
Response response = progressCall.execute();
if (isCancelled) {
return null;
}
if (!response.isSuccessful()) throw new IOException("Unexpected code " + response);
stream = response.body().byteStream();
} catch (IOException e) {
e.printStackTrace();
return null;
}
return stream;
}
使用okhttp下載圖片,添加一個(gè)攔截器
public class ProgressInterceptor implements Interceptor {
private ProgressListener progressListener;
public ProgressInterceptor(ProgressListener progressListener) {
this.progressListener = progressListener;
}
@Override
public Response intercept(Chain chain) throws IOException {
Response originalResponse = chain.proceed(chain.request());
return originalResponse.newBuilder().body(new ProgressResponseBody(originalResponse.body(), progressListener)).build();
}
}
重寫intercept方法,創(chuàng)建一個(gè)ProgressResponseBody得到圖片下載的進(jìn)度,來看一下讀流的方法
private Source source(Source source) {
return new ForwardingSource(source) {
long totalBytesRead = 0;
@Override
public long read(Buffer sink, long byteCount) throws IOException {
long bytesRead = super.read(sink, byteCount);
totalBytesRead += bytesRead != -1 ? bytesRead : 0;
if(progressListener != null)
progressListener.progress(totalBytesRead, responseBody.contentLength(), bytesRead == -1);
return bytesRead;
}
};
}
把讀到的bytesRead和responseBody.contentLength()傳給回調(diào)方法progressListener.progress來計(jì)算進(jìn)度。
大體實(shí)現(xiàn)邏輯到此就結(jié)束了,想看完整代碼的移步至https://github.com/chenpengfei88/GlideLoadImageProgress或者可以通過本地下載:http://xiazai.jb51.net/201705/yuanma/GlideLoadImageProgress(jb51.net).rar
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
Android使用SqLite實(shí)現(xiàn)登錄注冊(cè)功能流程詳解
這篇文章主要介紹了使用Android Studio自帶的sqlite數(shù)據(jù)庫實(shí)現(xiàn)一個(gè)簡(jiǎn)單的登錄注冊(cè)功能,SQLite是一個(gè)軟件庫,實(shí)現(xiàn)了自給自足的、無服務(wù)器的、零配置的、事務(wù)性的SQL數(shù)據(jù)庫引擎,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12
Android仿活動(dòng)時(shí)分秒倒計(jì)時(shí)效果
這篇文章主要為大家詳細(xì)介紹了Android仿活動(dòng)時(shí)分秒倒計(jì)時(shí)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-02-02
Android支持國際化多語言那點(diǎn)事(支持8.0+)
我們?cè)陂_發(fā)app可能會(huì)拓展國外市場(chǎng),那么對(duì)包含英語在內(nèi)的其它語言支持就很有必要了。這篇文章主要介紹了Android支持國際化多語言那點(diǎn)事(支持8.0+),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-06-06
Android開發(fā)中synchronized的三種使用方式詳解
這篇文章主要介紹了Android開發(fā)中synchronized的三種使用方式,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2023-04-04
Android ListView與ScrollView沖突的解決方法總結(jié)
這篇文章主要介紹了Android ListView與ScrollView沖突的解決方法總結(jié)的相關(guān)資料,需要的朋友可以參考下2017-04-04
Android 自動(dòng)化測(cè)試經(jīng)驗(yàn)分享 UiObejct.getFromParent()的使用方法
本篇文章對(duì)Android中UiObejct.getFromParent()的使用進(jìn)行了詳細(xì)的分析介紹。需要的朋友參考下2013-05-05
Android自定義實(shí)現(xiàn)側(cè)滑菜單效果
這篇文章主要為大家詳細(xì)介紹了Android自定義實(shí)現(xiàn)側(cè)滑菜單效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01

