使用RxJava實(shí)現(xiàn)android里面的倒計(jì)時(shí)效果

image

intervalRange操作符

開(kāi)始前我們先來(lái)了解下intervalRange操作符(了解過(guò)的可以忽哈)。
  intervalRange(long start, long count, long initialDelay, long period, TimeUnit unit)

start:起始數(shù)值
count:發(fā)射數(shù)量
initialDelay:延遲執(zhí)行時(shí)間
period:發(fā)射周期時(shí)間
unit:時(shí)間單位
一句話簡(jiǎn)介就是延遲initialDelay個(gè)unit單位后掷空,以period為周期肋殴,依次發(fā)射count個(gè)以start為初始值并遞增的數(shù)字囤锉。

布局

布局中放一個(gè)Button用來(lái)演示點(diǎn)擊獲取驗(yàn)證碼,并開(kāi)啟倒計(jì)時(shí)重新獲取的功能护锤。

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:padding="15dp"
    tools:context="com.holmeslei.rxjava2demo.ui.CountDownActivity">

    <Button
        android:id="@+id/btn_get_code"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="獲取驗(yàn)證碼" />
</RelativeLayout>

Activity

由于業(yè)務(wù)邏輯簡(jiǎn)單官地,所以就不整什么復(fù)雜的框架了,功能都在Activity中實(shí)現(xiàn)烙懦。

1.使用ButterKnife依賴注入獲取Button的實(shí)例及設(shè)置其點(diǎn)擊監(jiān)聽(tīng)方法驱入。
2.點(diǎn)擊Button后首先將其設(shè)置為不可點(diǎn)擊,然后初始化全局變量Disposable氯析。
3.使用Flowable的intervalRange操作符亏较,從0開(kāi)始每隔1s發(fā)射一個(gè)自增的數(shù)字,持續(xù)11次掩缓,延遲0s執(zhí)行雪情。這樣就設(shè)定好了10秒的倒計(jì)時(shí),可根據(jù)實(shí)際需要修改時(shí)長(zhǎng)你辣。
4.由于需要刷新UI巡通,所以設(shè)定觀察者執(zhí)行在Android的UI線程。
5.在doOnNext的回調(diào)中更新Button的顯示UI舍哄,達(dá)到讀秒的效果宴凉。
6.在doOnComplete的完成回調(diào)中重新將Button設(shè)置為可點(diǎn)擊,然后設(shè)置顯示UI表悬。
7.最后調(diào)用后subscribe()訂閱弥锄,這樣一個(gè)完整的異步事件流就完成了。
8.別忘了在Activity銷毀時(shí)將全局Disposable取消訂閱銷毀掉签孔。使用RxJava將無(wú)用的Disposable及時(shí)銷毀是一個(gè)很好的習(xí)慣叉讥,否則后期就得忙著處理各種OOM異常啦窘行。

public class CountDownActivity extends AppCompatActivity {
    @BindView(R.id.btn_get_code)
    Button btnGetCode;
    private Disposable mdDisposable;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_count_down);
        ButterKnife.bind(this);
    }

    @OnClick(R.id.btn_get_code)
    public void onViewClicked() {
        //點(diǎn)擊后置為不可點(diǎn)擊狀態(tài)
        btnGetCode.setEnabled(false);
        //從0開(kāi)始發(fā)射11個(gè)數(shù)字為:0-10依次輸出饥追,延時(shí)0s執(zhí)行,每1s發(fā)射一次罐盔。
        mdDisposable = Flowable.intervalRange(0, 11, 0, 1, TimeUnit.SECONDS)
                .observeOn(AndroidSchedulers.mainThread())
                .doOnNext(new Consumer<Long>() {
                    @Override
                    public void accept(Long aLong) throws Exception {
                        btnGetCode.setText("重新獲取(" + (10 - aLong) + ")");
                    }
                })
                .doOnComplete(new Action() {
                    @Override
                    public void run() throws Exception {
                        //倒計(jì)時(shí)完畢置為可點(diǎn)擊狀態(tài)
                        btnGetCode.setEnabled(true);
                        btnGetCode.setText("獲取驗(yàn)證碼");
                    }
                })
                .subscribe();
    }

    @Override
    protected void onDestroy() {
        super.onDestroy();
        if (mdDisposable != null) {
            mdDisposable.dispose();
        }
    }
}
/**
     * 使用RxJava1實(shí)現(xiàn)倒計(jì)時(shí)
     */
    private void countDown() {
        final long count = 30;
        Observable.interval(1, TimeUnit.SECONDS)
                .take(31)//計(jì)時(shí)次數(shù)
                .map(new Func1<Long, Long>() {
                    @Override
                    public Long call(Long integer) {
                        return count - integer;
                    }
                })
                .doOnSubscribe(new Action0() {
                    @Override
                    public void call() {
                        cutdown.setEnabled(false);
                        cutdown.setBackgroundColor(Color.DKGRAY);
                    }
                })
                .subscribeOn(Schedulers.io())
                .observeOn(AndroidSchedulers.mainThread())
                .subscribe(new Observer<Long>() {

                    @Override
                    public void onCompleted() {
                        cutdown.setEnabled(true);
                        cutdown.setBackgroundColor(getResources().getColor(R.color.colorPrimary));
                        cutdown.setText("倒計(jì)時(shí)");
                    }

                    @Override
                    public void onError(Throwable e) {

                    }

                    @Override
                    public void onNext(Long aLong) {
                        cutdown.setText("倒計(jì)時(shí)" + aLong);
                    }
                });
    }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末但绕,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子惶看,更是在濱河造成了極大的恐慌捏顺,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,265評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件纬黎,死亡現(xiàn)場(chǎng)離奇詭異幅骄,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)本今,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門(mén)拆座,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)主巍,“玉大人,你說(shuō)我怎么就攤上這事挪凑≡兴鳎” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,852評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵躏碳,是天一觀的道長(zhǎng)搞旭。 經(jīng)常有香客問(wèn)我,道長(zhǎng)菇绵,這世上最難降的妖魔是什么肄渗? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,408評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮咬最,結(jié)果婚禮上恳啥,老公的妹妹穿的比我還像新娘。我一直安慰自己丹诀,他們只是感情好钝的,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,445評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著铆遭,像睡著了一般硝桩。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上枚荣,一...
    開(kāi)封第一講書(shū)人閱讀 49,772評(píng)論 1 290
  • 那天碗脊,我揣著相機(jī)與錄音,去河邊找鬼橄妆。 笑死衙伶,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的害碾。 我是一名探鬼主播矢劲,決...
    沈念sama閱讀 38,921評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼慌随!你這毒婦竟也來(lái)了芬沉?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,688評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤阁猜,失蹤者是張志新(化名)和其女友劉穎丸逸,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體剃袍,經(jīng)...
    沈念sama閱讀 44,130評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡黄刚,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,467評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了民效。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片憔维。...
    茶點(diǎn)故事閱讀 38,617評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡侍芝,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出埋同,到底是詐尸還是另有隱情州叠,我是刑警寧澤,帶...
    沈念sama閱讀 34,276評(píng)論 4 329
  • 正文 年R本政府宣布凶赁,位于F島的核電站咧栗,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏虱肄。R本人自食惡果不足惜致板,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,882評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望咏窿。 院中可真熱鬧斟或,春花似錦、人聲如沸集嵌。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,740評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)根欧。三九已至怜珍,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間凤粗,已是汗流浹背酥泛。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,967評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留嫌拣,地道東北人柔袁。 一個(gè)月前我還...
    沈念sama閱讀 46,315評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像异逐,于是被迫代替她去往敵國(guó)和親捶索。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,486評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容