OkHttpClient加载图片给DisposableObserver,CompositeDisposable调度控制后台任务队列简单代码

简介: OkHttpClient加载图片给DisposableObserver,CompositeDisposable调度控制后台任务队列简单代码实现一个简单的功能,点击按钮,触发OkHttpClient加载图片给DisposableObserver,然后刷新ListView。
OkHttpClient加载图片给DisposableObserver,CompositeDisposable调度控制后台任务队列简单代码


实现一个简单的功能,点击按钮,触发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>
AI 代码解读




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);
            }
        });
    }
}
AI 代码解读


目录
打赏
0
0
0
0
15
分享
相关文章
池式组件-异步请求池的原理与实现
池式组件-异步请求池的原理与实现
50 0
浏览器渲染过程中如何处理异步任务
在浏览器渲染过程中,异步任务通过事件循环机制处理。JS执行时,同步任务在主线程上执行,形成一个执行栈。异步任务则被推入任务队列中,待主线程空闲时按顺序调用,确保页面流畅渲染与响应。
【专栏】小程序图片合成就绪渲染的转变,从异步并发渲染到同步阻塞渲染
【4月更文挑战第29天】本文探讨了小程序图片合成就绪渲染的转变,从异步并发渲染(提高效率,并发处理但可能导致资源竞争和顺序难控)到同步阻塞渲染(顺序可控,资源管理更精细,可能引起界面卡顿)。同步阻塞通过任务队列和阻塞机制确保顺序,解决并发问题。注意避免长时间阻塞,及时释放资源,优化任务效率,并结合异步处理。选择合适方案取决于实际需求,以平衡效率与一致性。
119 1
Flowable 设置任务处理人的四种方式
Flowable 设置任务处理人的四种方式
1114 1
深入解析 EventLoop 和浏览器渲染、帧动画、空闲回调的关系
关于 Event Loop 的文章很多,但是有很多只是在讲「宏任务」、「微任务」
一文讲解浏览器运行渲染机制、JS任务队列及事件循环
你是不是有过以下困难: • 多个方法互相嵌套,但是最终还是蒙对了 • 不是很明白为什么浏览器有时候会卡死 • 事件循环好像知道那么点,但是就是讲不出来为啥 • …… 本篇文章就把你的问题给一一解答,当然这些东西想完弄清楚,肯定离不开进程,线程,浏览器内核,渲染,事件循环,任务队列等,我们就一个一个的来看,它们到底是怎么工作的。
550 0
一文讲解浏览器运行渲染机制、JS任务队列及事件循环
关于线程的小应用(动态播放图片)以及通过小应用得出线程的一个好处
关于线程的小应用(动态播放图片)以及通过小应用得出线程的一个好处
126 0
关于线程的小应用(动态播放图片)以及通过小应用得出线程的一个好处
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等