在android 編程時,有時候要實現當Button一直按下的時候,執行一些邏輯代碼,當按鈕彈起的時候,終止這些邏輯代碼的執行。
比如在 設置頁面的滑動開關時,如果不監聽ACTION_CANCEL,在滑動到中間時,如果你手指上下移動,就是移動到開關控件之外,就會造成開關的按鈕停頓在中間位置。
在一般情況下,實現這個邏輯需要注冊OnTouchListener監聽,OnTouchListener的OnTouch方法中代碼如下:
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
//按鈕按下邏輯
break;
case MotionEvent.ACTION_UP:
//按鈕彈起邏輯
break;
}
在一般情況下,這樣寫是沒有問題的,
但是當手指快速滑過這個Button時,就會發現只觸發了
ACTION_DOWN時間,沒有觸發ACTION_UP,就會導致,按鈕按下的邏輯代碼一直會執行。當焦點移動到件之外,此時會觸發ACTION_CANCEL,而不是ACTION_UP,造成按下的邏輯一直會執行。
為了解決這個問題,上述代碼可以需要修改為:
switch (event.getAction()) { case MotionEvent.ACTION_DOWN: //按鈕按下邏輯 break; case MotionEvent.ACTION_UP: //按鈕彈起邏輯 break; case MotionEvent.ACTION_CANCEL: //按鈕彈起邏輯 break; }
ACTION_UP處理的是在Button原位置彈起,ACTION_CANCEL處理的是焦點離開Button,兩者都需要處理
,才能解決這個問題。
示例(我這個是在按下的時候,讓按鈕放大,手抬起的時候縮小操作):
login_with_sina.setOnTouchListener(new OnTouchListener() { public boolean onTouch(View v, MotionEvent event) { switch (event.getAction()) { case MotionEvent.ACTION_DOWN: System.out.println("++++++key_down"); AnimUtil.showOnFocusAnimation(login_with_sina); break; case MotionEvent.ACTION_UP: System.out.println("++++++key_down"); AnimUtil.showLooseFocusAinimation(login_with_sina); break; case MotionEvent.ACTION_CANCEL: System.out.println("++++++key_down"); AnimUtil.showLooseFocusAinimation(login_with_sina); break; } return true; } });