RxJava 在Android项目中的使用(二)

RxJava操作符

  • map() 操作符就是用于变换Observable对象的,map操作符返回一个Observable对象,这样就可以实现链式调用,在一个Observable对象上多次使用map操作符,最终将最简洁的数据传递给Subscriber对象
  • from() 接收一个集合作为输入,然后每次输出一个元素给subscriber
  • flatmap() Observable.flatMap()接收一个Observable的输出作为输入,同时输出另外一个Observable
  • filter 过滤,把不符合条件的过滤掉,留下符合条件的
  • take 指定最多输出的数量
  • doOnNext 允许我们在每次输出一个元素之前做一些额外的事情

示例一

  • create() 创建
  • subscribe() 订阅
  • just()
  • from() 尽管与just一样是创建操作符,但是from操作符稍微强大点。因为from操作符的作用是将传入的数组或 Iterable 拆分成具体对象后,依次发送出来。
// TODO: 2016/12/16 创建被观察者 observerable
Observable observable = Observable.create(new Observable.OnSubscribe() {      

    @Override
    public void call(Subscriber subscriber) {            

        subscriber.onNext("111"); 
        subscriber.onNext("222");
        subscriber.onNext("333");
        subscriber.onNext("444");
        subscriber.onCompleted();
    }});
 //// TODO: 2016/12/16 等价于just()   from()
Observable.just("111", "222", "333");
Observable.from(new String[]{"111", "222", "333"});

// TODO: 2016/12/16 示例一 打印字符串数组
Observable.from(new String[]{"1", "2", "3"}).subscribe(new Action1() {    @Override
    public void call(String s) { 
       DebugLog.i(s + "====="); 
   }});


class Course { 
   String name = "";
    public Course(String name) {        this.name = name;    } 
   public String getCourse() {        return " china  " + name;    }
}
class Student {    
String name = ""; 
   Course course[]; 
   public Student(String name) {
        this.name = name;
        course = new Course[]{new Course(getName()), new Course(getName()), new Course(getName()), new Course(getName())};  
  }  
  public String getName() {        return name;    }
}
Student[] students = new Student[]{new Student("zhangsan"), new Student("lisi"), new Student("wangwu"), new Student("maliu")};

// TODO: 2016/12/16  flatmap 变换
Observer observer = new Observer() {
    @Override
    public void onCompleted() { 
   }    
@Override  
  public void onError(Throwable e) { 
   }
    @Override 
   public void onNext(Course course) {   
     DebugLog.i(course.name + "====");
    }
};


Observable.from(students).flatMap(new Func1>() {   
 @Override
  public Observable call(Student student) { 
       return Observable.from(student.course);    }})
.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(observer);

// TODO: 2016/12/16 lift实现 integer对象转换 string

observable.lift(new Observable.Operator() {
    @Override
    public Subscriber call(final Subscriber subscriber) {   
     return new Subscriber() {   
         @Override 
           public void onCompleted() { 
               subscriber.onCompleted();
            }           
         @Override  
          public void onError(Throwable e) {
                subscriber.onError(e); 
           }            
        @Override   
         public void onNext(Integer integer) {
                subscriber.onNext(integer + "============="); 

           }     
   };   
 }
});

示例二

map()特性:

  • 它不必返回Observable对象返回的类型,你可以使用map操作符返回一个发出新的数据类型的observable对象。
  • 可以对一个Observable多次使用map
Observable.just("Hellp Map Operator")
.map(new Func1() {
 @Override
 public Integer call(String s) { 
return 2015;//通过第一个map转成Integer
 }
}).map(new Func1() { 
@Override
 public String call(Integer integer) {
 return String.valueOf(integer);//再通过第二个map转成String
 }
}).subscribe(new Action1() {
 @Override
 public void call(String s) {
 System.out.println(s);
 }
});

示例三

Map是一对一的转换,那么有没有一对多的转换呢?当然有,就是现在要说的 FlatMap
FlatMap操作符使用一个指定的函数对原始Observable发射的每一项数据执行变换操作,这个函数返回一个本身也发射数据的Observable,然后FlatMap合并这些Observables发射的数据,最后将合并后的结果当做它自己的数据序列发射。

private final String url1 = "http://www.iamxiarui.com/wp-content/uploads/2016/06/套路.png";
private final String url2 = "http://www.iamxiarui.com/wp-content/uploads/2016/06/为什么我的流量又没了.png";
private final String url3 = "http://www.iamxiarui.com/wp-content/uploads/2016/05/cropped-iamxiarui.com_2016-05-05_14-42-31.jpg";
private final String url4 = "http://www.iamxiarui.com/wp-content/uploads/2016/05/微信.png";
//一组Url数据private final String[] urls = new String[]{url1, url2, url3, url4};

然后来看flatmap如何处理:

//先传递String类型的UrlObservable.from(urls) .flatMap(new Func1>() {
 @Override 
public Observable call(String s) { 
return Observable.just(s); } })
.map(new Func1() { 
@Override
 public Bitmap call(String s) { 
//通过Map转换成Bitmap类型发送出去
 return GetBitmapForURL.getBitmap(s);
 } }) 
.subscribeOn(Schedulers.io()) // 指定subscribe()发生在IO线程 .observeOn(AndroidSchedulers.mainThread()) // 指定Subscriber的回调发生在UI线程 //可以看到,这里接受的类型是Bitmap,而不是String .subscribe(new Action1() { 
@Override
 public void call(Bitmap bitmap) { mainImageView.setImageBitmap(bitmap); mainProgressBar.setVisibility(View.GONE); 
}
});

你可能感兴趣的:(RxJava 在Android项目中的使用(二))