万物RxJava(1):封装高德地图API

本文介绍了如何使用RxJava对高德地图API进行封装,通过创建Observable和使用Emitter接口,实现对高德定位的RxJava式调用。详细步骤包括定义Observable、设置监听、在AMapLocationListener中调用observer方法,以及创建外观类AMapRxHelper,简化调用过程。示例代码展示了在Activity中如何使用封装后的API,让代码更简洁、函数式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

自从去年开始接触RxJava,深深的被rxjava的设计吸引,粗略的阅读了RxJava1的源码之后,感触颇深,今年年初项目更是转用了RxJava2,对RxJava这种函数式编程更加感兴趣,不过本文的重点不在于源码解析,如果想看源码解析,可以出门到这里–>:zxt0601
如果你上文已经看完了,那么我们不难发现,其实RxJava本身是观察者模式,通过Observable订阅者subscribe方法订阅observer观察者,我们首先看一下Observable中的create方法:

     public static <T> Observable<T> create(ObservableOnSubscribe<T> source) {
            ObjectHelper.requireNonNull(source, "source is null");
            return RxJavaPlugins.onAssembly(new ObservableCreate<T>(source));
        }

首先我们先看ObservableOnSubscribe参数,这是一个接口,内部实现也很简单:

    public interface ObservableOnSubscribe<T> {

        /**
         * Called for each Observer that subscribes.
         * @param e the safe emitter instance, never null
         * @throws Exception on error
         */
        void subscribe(@NonNull ObservableEmitter<T> e) throws Exception;
    }

而ObservableEmitter也是一个接口类,而他的作用就比较明显了,我们这里主要看一个ObservableEmitter的父类Emitter:

    public interface Emitter<T> {
        /**
         * Signal a normal value.
         * @param value the value to signal, not null
         */
        void onNext(@NonNull T value);

        /**
         * Signal a Throwable exception.
         * @param error the Throwable to signal, not null
         */
        void onError(@NonNull Throwable error);

        /**
         * Signal a completion.
         */
        void onComplete();
    }

到这里可能很多人会一头雾水,摸不着头脑,接下来我们找到ObservableCreate这个类中,就能很直观的看到其调用关系:

    public final class ObservableCreate<T> extends Observable<T> {
   
   
        final ObservableOnSubscribe<T> source;

        public ObservableCreate(ObservableOnSubscribe<T> source) {
            this.source = source;
        }

        @Override
        protected void subscribeActual(Observer<? super T> observer) {
            CreateEmitter<T> parent = new CreateEmitter<T>(observer);
            observer.onSubscribe(parent);

            try {
                source.subscribe(parent);
            } c
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值