OkHttpClient加载图片给DisposableObserver,CompositeDisposable调度控制后台任务队列简单代码
2017-04-18 17:54
513 查看
OkHttpClient加载图片给DisposableObserver,CompositeDisposable调度控制后台任务队列简单代码
实现一个简单的功能,点击按钮,触发OkHttpClient加载图片给DisposableObserver,然后刷新ListView。全程有CompositeDisposable控制任务队列。
布局文件:
Java代码:
package zhangphil.app;
import android.app.Activity;
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.Bundle;
import android.support.annotation.LayoutRes;
import android.support.annotation.NonNull;
import android.support.annotation.Nullable;
import android.util.Log;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.ListView;
import java.util.ArrayList;
import java.util.UUID;
import java.util.concurrent.Callable;
import io.reactivex.Observable;
import io.reactivex.ObservableSource;
import io.reactivex.android.schedulers.AndroidSchedulers;
import io.reactivex.disposables.CompositeDisposable;
import io.reactivex.observers.DisposableObserver;
import io.reactivex.schedulers.Schedulers;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;
public class MainActivity extends Activity {
private final String TAG = String.valueOf(UUID.randomUUID());
private ArrayList mItems = new ArrayList<>();
private ItemAdapter mAdapter;
private OkHttpClient mOkHttpClient;
private CompositeDisposable mCompositeDisposable = new CompositeDisposable();
@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mOkHttpClient = new OkHttpClient();
mAdapter = new ItemAdapter(this, -1);
ListView listView = (ListView) findViewById(R.id.listView);
listView.setAdapter(mAdapter);
findViewById(R.id.button).setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
String url = "http://avatar.csdn.net/9/7/A/1_zhangphil.jpg";
addItems(url);
}
});
}
private void addItems(final String url) {
DisposableObserver disposableObserver = new DisposableObserver<Bitmap>() {
@Override
public void onNext(@NonNull Bitmap bmp) {
Log.d(TAG, "onNext");
mItems.add(bmp);
}
@Override
public void onComplete() {
Log.d(TAG, "onComplete");
mAdapter.notifyDataSetChanged();
}
@Override
public void onError(Throwable e) {
Log.e(TAG, e.toString(), e);
}
};
/**
* 注意此处的写法!
*/
mCompositeDisposable.add(
getBitmapObservable(url)
.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribeWith(disposableObserver)
);
}
/**
* 以下是常规的Android ListView数据添加和更新Adapter
*/
private class ItemAdapter extends ArrayAdapter {
private Context context;
public ItemAdapter(@NonNull Context context, @LayoutRes int resource) {
super(context, resource);
this.context = context;
}
@NonNull
@Override
public View getView(int position, @Nullable View convertView, @NonNull ViewGroup parent) {
ImageView imageView = new ImageView(context);
imageView.setImageBitmap(getItem(position));
return imageView;
}
@Nullable
@Override
public Bitmap getItem(int position) {
Bitmap bmp = (Bitmap) mItems.get(position);
return bmp;
}
@Override
public int getCount() {
return mItems.size();
}
}
@Override
protected void onDestroy() {
super.onDestroy();
//取消所有Okhttp的网络请求
mOkHttpClient.dispatcher().cancelAll();
//如果退出程序,就清除后台任务
mCompositeDisposable.clear();
}
private Observable<Bitmap> getBitmapObservable(@NonNull final String url) {
return Observable.defer(new Callable<ObservableSource<Bitmap>>() {
@Override
public ObservableSource<Bitmap> call() throws Exception {
Thread.sleep(5000);
Bitmap bmp = null;
//同步方法返回观察者需要的数据结果
//在这里处理线程化的操作
Request request = new Request.Builder().url(url).build();
Response response = mOkHttpClient.newCall(request).execute();
try {
if (response.isSuccessful()) {
byte[] bytes = response.body().bytes();
bmp = BitmapFactory.decodeByteArray(bytes, 0, bytes.length);
}
} catch (Exception e) {
e.printStackTrace();
}
Log.d(TAG, "数据正确");
return Observable.just(bmp);
}
});
}
}
实现一个简单的功能,点击按钮,触发OkHttpClient加载图片给DisposableObserver,然后刷新ListView。全程有CompositeDisposable控制任务队列。
布局文件:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/activity_main" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <Button android:id="@+id/button" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="按钮" /> <ListView android:id="@+id/listView" android:layout_width="match_parent" android:layout_height="match_parent" /> </LinearLayout>
Java代码:
package zhangphil.app;
import android.app.Activity;
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.Bundle;
import android.support.annotation.LayoutRes;
import android.support.annotation.NonNull;
import android.support.annotation.Nullable;
import android.util.Log;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.ListView;
import java.util.ArrayList;
import java.util.UUID;
import java.util.concurrent.Callable;
import io.reactivex.Observable;
import io.reactivex.ObservableSource;
import io.reactivex.android.schedulers.AndroidSchedulers;
import io.reactivex.disposables.CompositeDisposable;
import io.reactivex.observers.DisposableObserver;
import io.reactivex.schedulers.Schedulers;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;
public class MainActivity extends Activity {
private final String TAG = String.valueOf(UUID.randomUUID());
private ArrayList mItems = new ArrayList<>();
private ItemAdapter mAdapter;
private OkHttpClient mOkHttpClient;
private CompositeDisposable mCompositeDisposable = new CompositeDisposable();
@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mOkHttpClient = new OkHttpClient();
mAdapter = new ItemAdapter(this, -1);
ListView listView = (ListView) findViewById(R.id.listView);
listView.setAdapter(mAdapter);
findViewById(R.id.button).setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
String url = "http://avatar.csdn.net/9/7/A/1_zhangphil.jpg";
addItems(url);
}
});
}
private void addItems(final String url) {
DisposableObserver disposableObserver = new DisposableObserver<Bitmap>() {
@Override
public void onNext(@NonNull Bitmap bmp) {
Log.d(TAG, "onNext");
mItems.add(bmp);
}
@Override
public void onComplete() {
Log.d(TAG, "onComplete");
mAdapter.notifyDataSetChanged();
}
@Override
public void onError(Throwable e) {
Log.e(TAG, e.toString(), e);
}
};
/**
* 注意此处的写法!
*/
mCompositeDisposable.add(
getBitmapObservable(url)
.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribeWith(disposableObserver)
);
}
/**
* 以下是常规的Android ListView数据添加和更新Adapter
*/
private class ItemAdapter extends ArrayAdapter {
private Context context;
public ItemAdapter(@NonNull Context context, @LayoutRes int resource) {
super(context, resource);
this.context = context;
}
@NonNull
@Override
public View getView(int position, @Nullable View convertView, @NonNull ViewGroup parent) {
ImageView imageView = new ImageView(context);
imageView.setImageBitmap(getItem(position));
return imageView;
}
@Nullable
@Override
public Bitmap getItem(int position) {
Bitmap bmp = (Bitmap) mItems.get(position);
return bmp;
}
@Override
public int getCount() {
return mItems.size();
}
}
@Override
protected void onDestroy() {
super.onDestroy();
//取消所有Okhttp的网络请求
mOkHttpClient.dispatcher().cancelAll();
//如果退出程序,就清除后台任务
mCompositeDisposable.clear();
}
private Observable<Bitmap> getBitmapObservable(@NonNull final String url) {
return Observable.defer(new Callable<ObservableSource<Bitmap>>() {
@Override
public ObservableSource<Bitmap> call() throws Exception {
Thread.sleep(5000);
Bitmap bmp = null;
//同步方法返回观察者需要的数据结果
//在这里处理线程化的操作
Request request = new Request.Builder().url(url).build();
Response response = mOkHttpClient.newCall(request).execute();
try {
if (response.isSuccessful()) {
byte[] bytes = response.body().bytes();
bmp = BitmapFactory.decodeByteArray(bytes, 0, bytes.length);
}
} catch (Exception e) {
e.printStackTrace();
}
Log.d(TAG, "数据正确");
return Observable.just(bmp);
}
});
}
}
相关文章推荐
- OkHttpClient加载图片给DisposableObserver,CompositeDisposable调度控制后台任务队列简单代码
- ImageView简单加载网络图片实例代码
- Android 源码解析: 图片加载库Picasso 4 任务调度 Dispatcher
- 七牛云上传图片 NoClassDedFoundError:com.squareup.okhttp.OkHttpClient异常
- XZ_iOS之使用webView加载后台返回的一串html代码,HTML中的图片不显示
- JQuery悬停控制图片轮播――代码简单
- 323_okhttp加载图片
- OkHttpClient之修改头像如何上传给后台
- 转一个简单的vue.js的图片懒加载的插件代码!
- OKhttpClient 简单使用总结
- AsyncHttpClient 加载图片
- 原生代码加载网络图片和Volley和Picasso的简单介绍和优缺点对比
- 代码: 两列图片瀑布流(一次后台取数据,图片懒加载。下拉后分批显示图片。图片高度未知,当图片onload后才显示容器)
- MVP,购物车啊,图片加载用Fresco,OKhttp+Retrofit实现
- CreateRiaClientFilesTask”任务意外失败。System.Web.HttpException (0x80004005): 未能加载文件或程序集
- 加载网络图片HttpClient
- JQuery悬停控制图片轮播――代码简单
- ImageView+OkHttpUtils实现简单图片显示
- android通过okhttpClient下载网页内容的实例代码
- OkHttpClient简单封装