標籤:android http io ar color sp java for on
還是以自訂的TestButton為例。
我們可以通過重寫onTouchEvent方法來處理諸如down move up的訊息:
?
| 123456789101112131415161718 |
public class TestButton extends Button { public TestButton(Context context) { super(context); // TODO Auto-generated constructor stub } public TestButton(Context context, AttributeSet attributeSet) { super(context, attributeSet); // TODO Auto-generated constructor stub } @Override public boolean onTouchEvent(MotionEvent event) { boolean value = super.onTouchEvent(event); System.out.println("super.onTouchEvent: " + value+ " event: " + event.getAction()); return value; } |
也可以通過實現OnTouchListener的介面,然後設定TestButton的onTouchListener可以達到同樣的目的
?
| 1234567 |
class OnTouchListenerTest implements View.OnTouchListener{ @Override public boolean onTouch(View v, MotionEvent event) { return false; } } |
?
| 123 |
TestButton b = (TestButton)findViewById(R.id.button);OnTouchListenerTest listener = new OnTouchListenerTest();b.setOnTouchListener(listener); |
但上述兩種監聽有什麼區別呢?
先看一下Android源碼中對於View中dispatchTouchEvent的實現:
?
| 123456789101112131415 |
public boolean dispatchTouchEvent(MotionEvent event){ ... ... if(onFilterTouchEventForSecurity(event)){ ListenerInfo li = mListenerInfo; if(li != null && li.mOnTouchListener != null && (mViewFlags & ENABLED_MASK) == ENABLED && li.mOnTouchListener.onTouch(this, event)) { return true; } if(onTouchEvent(event)){ return true; } } ... ... return false;} |
可以看到onTouchListener的介面的優先順序是要高於onTouchEvent的,假若onTouchListener中的onTouch方法返回true,
表示此次事件已經被消費了,那onTouchEvent是接收不到訊息的。
因為Button的performClick是利用onTouchEvent實現,假若onTouchEvent沒有被調用到,那麼Button的Click事件也無法響應。
綜合來講:
onTouchListener的onTouch方法優先順序比onTouchEvent高,會先觸發。
假如onTouch方法返回false會接著觸發onTouchEvent,反之onTouchEvent方法不會被調用。
內建諸如click事件的實現等等都基於onTouchEvent,假如onTouch返回true,這些事件將不會被觸發。
Android View的onTouchEvent和OnTouch區別