Android自定義短信倒計(jì)時(shí)view流程分析
倒計(jì)時(shí)實(shí)現(xiàn)有三種方式 而這個(gè)自定義view是通過(guò)handler實(shí)現(xiàn)的。為了保證activity銷毀的同時(shí)倒計(jì)時(shí)線程依然進(jìn)行同時(shí)重新創(chuàng)建銷毀又不會(huì)導(dǎo)致內(nèi)存泄漏,我使用了handler
的弱引用將handler
和runnable
設(shè)置成靜態(tài),同時(shí)通過(guò)一系列變量來(lái)銷毀關(guān)閉線程保存狀態(tài),話不多說(shuō)先看效果圖:
下面看源碼:
import android.content.Context; import android.os.Handler; import android.os.Message; import android.util.AttributeSet; import androidx.annotation.NonNull; import com.juexing.payassistant.activity.login.RegisterActivity; import java.lang.ref.WeakReference; //待優(yōu)化為了保存倒計(jì)時(shí)狀態(tài)線程延遲一秒關(guān)閉所有的子線程 //qq也是如此 public class CountDownTimeView extends androidx.appcompat.widget.AppCompatButton { private static volatile int i=60; //用來(lái)保存倒計(jì)時(shí)時(shí)間的中轉(zhuǎn)變量 private static volatile int j=0; private static TimeHandler handler; //每次啟動(dòng)活動(dòng)判斷i是否為0來(lái)讀取倒計(jì)時(shí)時(shí)間 public static int getI() { return i; } //RegisterActivity是調(diào)用該控件的活動(dòng)需要在oncreate中將對(duì)象傳入 public void setActivity(RegisterActivity activity){ handler=new TimeHandler(activity); } public static void setI(int i) { CountDownTimeView.i = i; } //防止多次重復(fù)點(diǎn)擊發(fā)送設(shè)置的變量 private static volatile boolean send=true; private class TimeHandler extends Handler { WeakReference<RegisterActivity> timeActivityWeakReference; public TimeHandler(RegisterActivity registerActivity){ this.timeActivityWeakReference = new WeakReference<>(registerActivity); } @Override public void handleMessage(@NonNull Message msg) { super.handleMessage(msg); RegisterActivity activity=timeActivityWeakReference.get();//獲取活動(dòng) switch (msg.what){ case 1: if(i>0){ activity.getmessage. setText(i+"s"); }else { } break; case 2: activity.getmessage. setText("重新獲取"); break; case 3: i=j-1; j=0; send=false; handler.postDelayed(runnable,1000); } } }; public CountDownTimeView(Context context) { super(context); } public CountDownTimeView(Context context, AttributeSet attrs) { super(context, attrs); } //網(wǎng)絡(luò)請(qǐng)求短信成功后調(diào)用 public void onStart(CountDownTimeView view){ if(send){ if(i==0){ i=60; } handler.postDelayed(runnable,1000); view.setText(i+"s"); send=false; }else { //為了顯示不突兀自動(dòng)減去一秒 view.setText(i-1+"s"); j=i; //將i設(shè)置為0是將所有線程運(yùn)行完畢關(guān)閉釋放內(nèi)存 i=0; handler.removeCallbacksAndMessages(null); //因?yàn)榫€程調(diào)度隨機(jī)性所以要延遲一秒發(fā)送保證子線程關(guān)閉 Message message=Message.obtain(); message.what=3; handler.sendMessageDelayed(message,1000); // i=j; } } //設(shè)置成靜態(tài)保證唯一性 public static Runnable runnable=new Runnable() { @Override public void run() { if(i>0){ i--; Message message=new Message(); message.what=1; handler.handleMessage(message); handler.postDelayed(runnable,1000); }else { if(j!=0){ }else { send=true; Message message=new Message(); message.what=2; handler.handleMessage(message); } } } }; }
在activity的oncreate中需要將activity實(shí)例對(duì)象傳入,并進(jìn)行判斷:
getmessage.setActivity(this); if(getmessage.getI()<60){ if(getmessage.getI()>0){ getmessage.onStart(getmessage); }else { getmessage.setText("重新獲取"); } } }
```getmessage是自定義view的實(shí)例對(duì)象。
如要源碼可以到我的git上獲?。?/p>
[https://github.com/heybixby/CountDownTimerView```](https://github.com/heybixby/CountDownTimerView)
總結(jié)
到此這篇關(guān)于Android自定義短信倒計(jì)時(shí)view流程分析的文章就介紹到這了,更多相關(guān)android 短信倒計(jì)時(shí)view內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- OpenHarmony實(shí)現(xiàn)類Android短信驗(yàn)證碼及倒計(jì)時(shí)流程詳解
- Android使用CountDownTimer模擬短信驗(yàn)證倒計(jì)時(shí)
- Android使用Kotlin和RxJava 2.×實(shí)現(xiàn)短信驗(yàn)證碼倒計(jì)時(shí)效果
- Android 用RxBinding與RxJava2實(shí)現(xiàn)短信驗(yàn)證碼倒計(jì)時(shí)功能
- Android實(shí)現(xiàn)發(fā)送短信驗(yàn)證碼倒計(jì)時(shí)功能示例
- Android短信驗(yàn)證碼倒計(jì)時(shí)驗(yàn)證的2種常用方式
- Android自定義Chronometer實(shí)現(xiàn)短信驗(yàn)證碼秒表倒計(jì)時(shí)功能
- Android開(kāi)發(fā)之獲取短信驗(yàn)證碼后按鈕背景變化并且出現(xiàn)倒計(jì)時(shí)
- Android封裝實(shí)現(xiàn)短信驗(yàn)證碼的獲取倒計(jì)時(shí)
相關(guān)文章
Android事件分發(fā)機(jī)制?ViewGroup分析
這篇文章主要介紹了Android事件分發(fā)機(jī)制?ViewGroup分析,事件分發(fā)從手指觸摸屏幕開(kāi)始,即產(chǎn)生了觸摸信息,被底層系統(tǒng)捕獲后會(huì)傳遞給Android的輸入系統(tǒng)服務(wù)IMS,更多相關(guān)介紹,需要的朋友可以參考一下2022-09-09Flutter Widget移動(dòng)UI框架使用Material和密匙Key實(shí)戰(zhàn)
這篇文章主要為大家介紹了Flutter Widget移動(dòng)UI框架使用Material和密匙Key實(shí)戰(zhàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12使用Jetpack Compose實(shí)現(xiàn)翻轉(zhuǎn)卡片效果流程詳解
Jetpack Compose 是一款基于 Kotlin 的聲明式 UI 工具包,可以方便地創(chuàng)建漂亮的用戶界面。使用 Compose 的動(dòng)畫(huà) API 和可繪制 API,可以輕松實(shí)現(xiàn)翻轉(zhuǎn)卡片效果。通過(guò)設(shè)置旋轉(zhuǎn)角度和透明度等屬性,可以使卡片沿著 Y 軸翻轉(zhuǎn),并實(shí)現(xiàn)翻頁(yè)效果2023-05-05Android手勢(shì)密碼--設(shè)置和校驗(yàn)功能的實(shí)現(xiàn)代碼
這篇文章主要介紹了Android手勢(shì)密碼--設(shè)置和校驗(yàn)功能的實(shí)現(xiàn)代碼,非常不錯(cuò),具有一定的參考校驗(yàn)價(jià)值,需要的朋友可以參考下2018-05-05Android開(kāi)發(fā)之AlertDialog實(shí)現(xiàn)彈出對(duì)話框
這篇文章主要為大家詳細(xì)介紹了Android開(kāi)發(fā)之AlertDialog實(shí)現(xiàn)彈出對(duì)話框,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-09-09Android自定義View實(shí)現(xiàn)loading動(dòng)畫(huà)加載效果
項(xiàng)目開(kāi)發(fā)中對(duì)Loading的處理是比較常見(jiàn)的,安卓系統(tǒng)提供的不太美觀,引入第三發(fā)又太麻煩,這時(shí)候自己定義View來(lái)實(shí)現(xiàn)這個(gè)效果。這篇文章主要介紹了Android自定義View實(shí)現(xiàn)loading動(dòng)畫(huà)加載效果,需要的朋友可以參考下2017-03-03Android切換至SurfaceView時(shí)閃屏(黑屏閃一下)以及黑屏移動(dòng)問(wèn)題的解決方法
本文主要介紹了Android切換至SurfaceView時(shí)閃屏(黑屏閃一下)以及黑屏移動(dòng)問(wèn)題的解決方法。具有一定的參考作用,下面跟著小編一起來(lái)看下吧2017-01-01Android API開(kāi)發(fā)之SMS短信服務(wù)處理和獲取聯(lián)系人的方法
這篇文章主要介紹了Android API開(kāi)發(fā)之SMS短信服務(wù)處理和獲取聯(lián)系人的方法,結(jié)合實(shí)例形式分析了Android API實(shí)現(xiàn)SMS短信發(fā)送及獲取聯(lián)系人的相關(guān)操作步驟與實(shí)現(xiàn)技巧,需要的朋友可以參考下2016-08-08Android自定義PopupWindow實(shí)現(xiàn)炫酷的IOS對(duì)話框效果
這篇文章主要給大家介紹如何在android中實(shí)現(xiàn)高仿ios對(duì)話框效果,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2018-05-05