Android防止按鈕重復(fù)點擊示例代碼
本文中我將介紹一下我自己封裝的一個小的工具類庫:按鈕點擊事件類庫。
作用:該類庫可以防止按鈕重復(fù)點擊,可以判斷網(wǎng)絡(luò)狀態(tài),可以判斷用戶登錄狀態(tài),以及自定義驗證條件等等。
說明:其實現(xiàn)的核心原理就是通過自定義實現(xiàn)自身的OnClickListener類,并重寫其中的onClick方法,在onClick方法中執(zhí)行相應(yīng)的判斷邏輯之后回調(diào)我們自定義的抽象方法。
具體效果如下圖所示:

使用方式
屏蔽多次點擊事件
/**
* 測試快速點擊事件
*/
fastButton.setOnClickListener(new OnClickFastListener() {
/**
* 自定義實現(xiàn)的抽象方法,不在重寫onClick方法,該方法用于執(zhí)行點擊后的邏輯
*/
@Override
public void onFastClick(View v) {
Toast.makeText(mContext, "您點擊了測試網(wǎng)絡(luò)按鈕...", Toast.LENGTH_LONG).show();
}
});
這里的fastButton就是一個普通的按鈕組件,然后我們?yōu)樵摻M件設(shè)置了點擊事件,并且傳入的是我們自定義的OnClickListener類(這里需要說明的是,不只是button組件任何View組件的點擊事件都是可以的,這里只是以Button組件為例子),這里默認的屏蔽多次點擊事件的時間間隔為900ms,也就是說當我們?yōu)榻M件設(shè)置了我們自定義的點擊事件監(jiān)聽之后,假如有兩次點擊事件,并且第二次點擊時若距離第一次點擊事件小于0.9s,則第二次點擊不會起作用;
屏蔽網(wǎng)絡(luò)情況
/**
* 測試網(wǎng)絡(luò)狀況
*/
networkButton.setOnClickListener(new OnClickNetworkListener() {
/**
* 自定義實現(xiàn)的抽象方法,主要用于執(zhí)行有網(wǎng)絡(luò)之后的邏輯
*/
@Override
public void onNetworkClick(View v) {
Toast.makeText(mContext, "當前設(shè)備有網(wǎng)絡(luò),執(zhí)行后續(xù)操作...", Toast.LENGTH_LONG).show();
}
/**
* 自定義實現(xiàn)的抽象方法,主要用于執(zhí)行當前設(shè)備沒有網(wǎng)絡(luò)之后的邏輯
*/
@Override
public void onNoNetworkClick(View v) {
Toast.makeText(mContext, "當前設(shè)備沒有網(wǎng)絡(luò)...", Toast.LENGTH_LONG).show();
}
});
同樣的,這里的networkButton也是我們自定義的一個按鈕組件,我們?yōu)槠湓O(shè)置了點擊事件監(jiān)聽,并傳入了我們自定義的OnNetworkClickListener類,可以發(fā)現(xiàn)OnNetworkClickListener類中有兩個回調(diào)方法,其中onNetworkClick方法用于執(zhí)行當前設(shè)備有網(wǎng)的情況,而onNoNetworkClick方法用于處理當前設(shè)備沒有網(wǎng)絡(luò)的后續(xù)操作;
屏蔽是否登錄情況
/**
* 測試是否登陸
*/
loginButton.setOnClickListener(new OnClickLoginedListener(mContext) {
/**
* 自定義實現(xiàn)的抽象方法,用于判斷當前設(shè)備是否登錄
*/
@Override
public boolean isLogined(Activity context, View view) {
return false;
}
/**
* 主要用于執(zhí)行判斷用戶登錄之后執(zhí)行的邏輯
*/
@Override
public void onLoginedClick(View v) {
Toast.makeText(mContext, "設(shè)備已登錄,之后后續(xù)操作...", Toast.LENGTH_LONG).show();
}
/**
* 主要用于執(zhí)行判斷用戶未登錄之后執(zhí)行的邏輯
*/
@Override
public void onNoLoginedClick(View v) {
Toast.makeText(mContext, "設(shè)備未登陸,無法執(zhí)行后續(xù)操作...", Toast.LENGTH_LONG).show();
}
});
這里的loginButton同樣是我們自定義的一個按鈕組件,并為其設(shè)置了我們的OnLoginedClickListener類,然后其中有三個回調(diào)方法,
其中方法isLogined用于判斷當前用戶是否登錄,返回為true則表示用戶已經(jīng)登錄,返回為false則表示用戶未登錄,具體實現(xiàn)邏輯需要在業(yè)務(wù)層實現(xiàn),方法onLoginedClick用于執(zhí)行登錄之后的邏輯,而方法onNoLoginedClick用于執(zhí)行用戶尚未登錄的邏輯。
這就是這個類庫大概的實現(xiàn)功能,說完功能之后我們來看一下其具體實現(xiàn)邏輯:
實現(xiàn)方式
上面我們講解了該類庫的使用方式,那么我們是如何實現(xiàn)的呢?下面我們看一下該類庫的源代碼。
防止按鈕重復(fù)點擊
/**
* 方法按鈕重復(fù)點擊的監(jiān)聽類源碼
*/
public abstract class OnClickFastListener extends BaseClickListener {
// 防止快速點擊默認等待時長為900ms
private long DELAY_TIME = 900;
private static long lastClickTime;
private boolean isFastDoubleClick() {
long time = System.currentTimeMillis();
long timeD = time - lastClickTime;
if (0 < timeD && timeD < DELAY_TIME) {
return true;
}
lastClickTime = time;
return false;
}
@Override
public void onClick(View v) {
// 判斷當前點擊事件與前一次點擊事件時間間隔是否小于闕值
if (isFastDoubleClick()) {
return;
}
onFastClick(v);
}
/**
* 設(shè)置默認快速點擊事件時間間隔
* @param delay_time
* @return
*/
public OnClickFastListener setLastClickTime(long delay_time) {
this.DELAY_TIME = delay_time;
return this;
}
/**
* 快速點擊事件回調(diào)方法
* @param v
*/
public abstract void onFastClick(View v);
}
以上就是我們防止按鈕重復(fù)點擊的OnFastClickListener的源碼了,可以看到這里我們定義了防止重復(fù)點擊的OnClickListener對象,并重寫了其onClick方法,可以看到我們在onClick方法中調(diào)用了isFastDoubleClick方法,該方法就是具體實現(xiàn)是否重復(fù)點擊邏輯的,當按鈕上一次點擊的時間與本次點擊的時間間隔小于900ms的時候isFastDoubleClick方法就會返回為true,這時候onClick方法直接返回,不在執(zhí)行后續(xù)的onFastClick方法,否則就直接執(zhí)行onFastClick方法。然后我們在為我們的View組件設(shè)置點擊事件的時候只需要重寫onFastClick方法就好了。。。
按鈕點擊監(jiān)聽網(wǎng)絡(luò)狀況
/**
* 判斷當前設(shè)備是否有網(wǎng)絡(luò)的監(jiān)聽類源碼
*/
public abstract class OnClickNetworkListener extends BaseClickListener {
@Override
public void onClick(View v) {
boolean isNetworkOk = isNetworkConnected(v.getContext());
if (isNetworkOk) {
onNetworkClick(v);
} else {
onNoNetworkClick(v);
}
}
// 點擊事件--有網(wǎng)絡(luò)
public abstract void onNetworkClick(View v);
// 點擊事件--沒有網(wǎng)絡(luò)
public abstract void onNoNetworkClick(View v);
/**
* 網(wǎng)絡(luò)連接是否正常
*
* @param context
* @return
*/
public static boolean isNetworkConnected(Context context) {
if (context != null) {
ConnectivityManager mConnectivityManager = (ConnectivityManager) context
.getSystemService(Context.CONNECTIVITY_SERVICE);
NetworkInfo mNetworkInfo = mConnectivityManager.getActiveNetworkInfo();
if (mNetworkInfo != null) {
return mNetworkInfo.isAvailable();
}
}
return false;
}
}
和剛剛的防止按鈕重復(fù)點擊事件類似,這里也是重寫了自己的OnClickListener對象,然后重寫了其onClick方法,并在其中執(zhí)行isNetworkConnected方法,該方法就是判斷是否當前設(shè)備是否有網(wǎng)絡(luò),若有網(wǎng)絡(luò)則執(zhí)行onNetworkClick方法,若無網(wǎng)絡(luò)則執(zhí)行onNoNetworkClick方法,這樣當我們?yōu)樽约旱腣iew組件設(shè)置點擊事件的時候只需要為View組件設(shè)置onClickListener為我們自定義的OnClickListener對象,然后重寫其中的onNetworkClick和onNoNetworkClick方法,其中onNetworkClick方法為有網(wǎng)絡(luò)的回調(diào)方法,而onNoNetworkClick方法為無網(wǎng)絡(luò)的回調(diào)方法。
按鈕點擊監(jiān)聽是否登錄
/**
* 判斷當前App用戶是否登錄的監(jiān)聽源碼
*/
public abstract class OnClickLoginedListener extends BaseClickListener {
private Activity context = null;
public OnClickLoginedListener(Activity context) {
this.context = context;
}
@Override
public void onClick(View view) {
super.onClick(view);
if (isLogined(context, view)) {
onLoginedClick(view);
} else {
onNoLoginedClick(view);
}
}
/**
* 判斷當前用戶是否登錄
* @param context
* @param view
* @return
*/
public abstract boolean isLogined(Activity context, View view);
/**
* 用戶登錄之后執(zhí)行的邏輯
* @param v
*/
public abstract void onLoginedClick(View v);
/**
* 用戶未登錄執(zhí)行點擊事件
*/
public abstract void onNoLoginedClick(View v);
}
這里也是通過定義自身的OnClickListener類,然后重寫其中的onClick方法,并在其中執(zhí)行isLogined方法,該方法用于返回用戶是否登錄的邏輯判斷,并且也是一個抽象的方法,所以也需要我們在業(yè)務(wù)層實現(xiàn)其具體的邏輯,然后我們重寫了其中的onLoginedClick方法和onNoLoginedClick方法,其中onLoginedClick方法為用戶登錄之后的回調(diào)方法,而onNoLoginedClick方法為用戶未登錄之后執(zhí)行的回調(diào)方法。
定制化執(zhí)行相應(yīng)的業(yè)務(wù)邏輯
/**
* 執(zhí)行定制化判斷邏輯的監(jiān)聽類源碼
*/
public abstract class OnClickCostomListener extends BaseClickListener {
@Override
public void onClick(View view) {
super.onClick(view);
if (isCorrect()) {
onCorrentClick(view);
} else {
onNoCorrentClick(view);
}
}
/**
* 判斷是否邏輯通過
* @return
*/
public abstract boolean isCorrect();
/**
* 判斷正確之后執(zhí)行的邏輯請求
* @param v
*/
public abstract void onCorrentClick(View v);
/**
* 判斷失敗之后執(zhí)行的邏輯請求
* @param v
*/
public abstract void onNoCorrentClick(View v);
}
可以看到這里重新定義了一個OnClickListener類,然后重寫其中的onClick方法,首先執(zhí)行判斷方法isCorrect,然后若判斷通過則執(zhí)行onCorrentClick方法,若判斷未通過則執(zhí)行onNoCorrentClick方法。
這樣我們就大概的分析了防止按鈕重復(fù)點擊類庫的主要實現(xiàn)邏輯與功能,源碼很簡單,以后我會不斷的開源與更新一些好用的類庫的,希望大家多多支持。
總結(jié):
該類庫主要是通過自定義OnClickListener類,并重寫其中的onClick方法實現(xiàn)的;
通過設(shè)置回調(diào)方法為抽象方法保證了我們必須要重寫相應(yīng)的回調(diào)方法;
項目保存地址:Android-repeatclick,歡迎star和follow
相關(guān)文章
UiOS開發(fā)中ITextView回收或關(guān)閉鍵盤使用方法總結(jié)
iOS開發(fā)中,發(fā)現(xiàn)UITextView沒有像UITextField中textFieldShouldReturn:這樣的方法,那么要實現(xiàn)UITextView關(guān)閉鍵盤,必須使用其他的方法,下面是可以使用的幾種方法,需要的朋友參考下吧2016-11-11
基于DownloadManager的簡單下載器編寫小結(jié)
Android自帶的DownloadManager是一個很好的下載文件的工具。該類在API level 9之后出現(xiàn),它已經(jīng)幫我們處理了下載失敗、重新下載等功能,整個下載過程全部交給系統(tǒng)負責(zé),不需要我們過多的處理,非常的nice。關(guān)鍵的是用起來也很簡單,稍微封裝一下就可以幾句話搞定下載2017-12-12
android FragmentTabhost實現(xiàn)導(dǎo)航分頁
這篇文章主要為大家詳細介紹了android FragmentTabhost實現(xiàn)導(dǎo)航分頁,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-08-08
實例詳解android studio如何導(dǎo)入.so文件的方法
通過實例給大家詳細講解了如何在android studio如何導(dǎo)入.so文件以及中間遇到的問題解決辦法,需要的讀者們可以仔細學(xué)習(xí)一下。2017-12-12
Android6.0 storage目錄sd卡存儲的路徑創(chuàng)建詳解
這篇文章主要介紹了Android6.0 storage目錄sd卡存儲的路徑創(chuàng)建的相關(guān)資料,需要的朋友可以參考下2017-01-01

