美文网首页
Rxjava2+Retrofit+RxBinding+RxBus

Rxjava2+Retrofit+RxBinding+RxBus

作者: RoboyCore | 来源:发表于2016-12-28 21:29 被阅读434次
    • 了解RxJava也蛮久了,原来一直不了解其中的原理,尤其是配合Retrofit组合之后线程切换和类型转换老是晕,刚刚有些理解、 乘热打铁,记录一下。

    1.RxJava基本逻辑

    • 添加依赖

        RXjava
       compile 'io.reactivex:rxjava:1.2.4'
       compile 'io.reactivex:rxandroid:1.2.1'
      
      ---Retrofit配合Rxjava
       compile 'com.squareup.retrofit2:retrofit:2.1.0'//retrofit依赖
       compile 'com.squareup.retrofit2:converter-gson:2.1.0'//gson转换器
       compile 'com.squareup.retrofit2:converter-scalars:2.1.0'//标准类型转换器
       compile 'com.squareup.retrofit2:adapter-rxjava:2.1.0'//rxjava转换器
      
       ---Rxbinding依赖
       compile 'com.jakewharton.rxbinding:rxbinding:1.0.0'
      
    • Lambda配置(可忽略)
      compileOptions {
      sourceCompatibility JavaVersion.VERSION_1_8
      targetCompatibility JavaVersion.VERSION_1_8
      }//添加在Android下面的编译配置

          dependencies {
        classpath 'com.android.tools.build:gradle:2.2.3'
        classpath 'me.tatarka:gradle-retrolambda:3.4.0'//插件下载路径
      
        // NOTE: Do not place your application dependencies here; they belong
          // in the individual module build.gradle files
          }
        
        apply plugin: 'me.tatarka.retrolambda'//运用插件
      

    Rxjava运用观察者模式、通过观察者(Observer)/订户(Subscriber )来订阅被观察者


    为了更好使用链式编程、使用的是被观察者订阅观察者(为了可以使用链式编程使得语义相反)
    observable.subscribe(subscriber/observer);


     Observable.create(new Observable.OnSubscribe<String>() {
            @Override
            public void call(Subscriber<? super String> subscriber) {
                subscriber.onNext("dfjhsklafj");
                subscriber.onNext("a");
            }
        }).subscribeOn(AndroidSchedulers.mainThread()).subscribe(new Subscriber<String>() {
            @Override
            public void onCompleted() {
    
            }
    
            @Override
            public void onError(Throwable e) {
    
            }
    
            @Override
            public void onNext(String o) {
    
            }
        });
    

    Observable.create 传入OnSubsecible接口变量实现onCall方法
    也可以使用from来获取本地数组资源
       Observable.from(getResources().getStringArray(R.array.RX)).subscribe(new Subscriber<String>() {
            @Override
            public void onCompleted() {
        System.out.println("s = " + s);
            }
    
            @Override
            public void onError(Throwable e) {
    
            }
    
            @Override
            public void onNext(String s) {
    
            }
        });
    
    被观察者可以使用just代替create传递1--10个参数
    观察者/订阅者可以使用Action来替代它的三个参数

    /**
    * 简化观察者,用方法Action1代替观察者的接口三个方法,选择要使用的1--3方法
    */
    private void Action1(){
    Observable.just('a').subscribe(new Action1<Character>() {
    @Override
    public void call(Character s) {
    System.out.println("s = " + s);

            }
        }, new Action1<Throwable>() {
            @Override
            public void call(Throwable throwable) {
    
            }
        }, new Action0() {
            @Override
            public void call() {
    
            }
        });
    

    上述可以使用Lambda表达式简化逻辑

    只执行观察者Action1的onNext方法

      Observable.create((f)->f.onNext('a')).subscribe((c)-> System.out.println("c = " + c))
    

    三个方法Action1、Action1、Action0都执行

     Observable.just('a','b').subscribe(
                (num)->Log.e("s","s" +num),
                (ex)-> ex.printStackTrace(),
                ()-> System.out.println(" = " )
        );
    
    线程切换(从上往下找)
     //Schedulers
                //IO()网络线程、无法控制最大线程数量
                // newThread()开启新的线程、
                // immediate()当前线程默认、
                // computation()计算线程会计算当前cpu个数来决定开多少线程,有效控制线  程最大数量
                
                //AndroidSchedulers.mainThread()主线程
    
    subScribeOn()订阅发生所在线程(语义是被观察者订阅观察者),所以是被观察者线程
    observeOn()执行观察者处理数据所在线程
    doOnScrible

    *subscribeOn()
    : 指定subscribe()
    所发生的线程,即Observable.OnSubscribe
    被激活时所处的线程。或者叫做事件产生的线程。 *observeOn()
    : 指定Subscriber
    所运行在的线程。或者叫做事件消费的线程。
    添加进度框

    • map:将被观察者数据类型转换为其他类型Fun1

      Observable.just(path)
                       .map(new Func1<String, CharSequence>() {
                           @Override
                           public CharSequence call(String s) {
                               return getData(s);//将数据路径读取成字符串
                           }
                       })
                       .subscribeOn(Schedulers.io())
                       .observeOn(AndroidSchedulers.mainThread())
                       .subscribe((next) -> tv.setText(next));
      
    • flatMap:被观察者二次变幻转成新的观察者->桥接模式


    区别:map第二个参数为目标类型
    flatMap : 第二个参数是另一个被观察者对象的类型


    lift:观察者类型转换,类似于map,但是处理转换的是观察者
    compose:转换的是被观察的对象,接口名是Transformer

    1

    数据配合Rxjava进行Retrofit网络请求

    • retrofit请求后返回call对象通过rxjavaAdapter转换成被观察者对象,然后在给处理后给观察者对象
      1.网络请求接口使用被观察者对象
      {path}放入url路径相对名字
      @Query(s) String q //查询的键值对xx?s=q
      @URL String url //表示url路径如果写了base url 会根据http是否开头只能判断是否加载全部url

      @GET("/dianying/v2/search/movies.json")
        Observable<News> getNews(@Query("client") String client);
      

    2.转换加载数据

        new Retrofit.Builder()
                .baseUrl(BASE_URL)
                .addConverterFactory(ScalarsConverterFactory.create())//字符串转换器
                .addConverterFactory(GsonConverterFactory.create())//json转换器
                .addCallAdapterFactory(RxJavaCallAdapterFactory.create())//Call->rxJava适配器!!!执行完call后返回被观察者实体类对象
                .build().create(NewsServiceNet.class)//接口类
                .getNews(str)//获取数据
                .subscribeOn(Schedulers.io())//被观察者订阅在io线程
                .observeOn(AndroidSchedulers.mainThread())//观察者在主线程执行
                .subscribe(
                        (news)->{
                            if (news == null) {
                                Toast.makeText(this, "无", Toast.LENGTH_SHORT).show();
                            }
                            List<News.Data> data = news.getData();
                            System.out.println("data = " + data);
                            tv.setText(data.toString());
                        },
                        Throwable::printStackTrace
                );//订阅者处理事件
    

    RxBinding

         RxView.clicks(iv).throttleWithTimeout(1000, TimeUnit.MILLISECONDS).subscribe(
                (v)->loadData()
        );//防抖时间,观察者执行点击事件
    

    RXBus

    • 类型EventBus出现,使用Rx链式思想

      未完待续

    相关文章

      网友评论

          本文标题:Rxjava2+Retrofit+RxBinding+RxBus

          本文链接:https://www.haomeiwen.com/subject/plbsvttx.html