前言:
基于监听的事件处理机制请看这边文章 Android 基于监听的事件处理机制
1、回调机制与监听机制的区别:
监听机制的事件源与事件监听是分开的。我们需要自己设置一个监听器,
回调机制的事件源与事件监听是绑定在一起的。
2、基于回调事件的传播
我们通过自定义button 在控件内实现一些方法的回调。我们通过给button按钮设置触摸事件,回调用户按下这一瞬间的要处理的事件。
首先创建MyButton类继承自AppCompatButton,在这个类里面设置触摸事件。
public class MyButton extends AppCompatButton { public MyButton(Context context) { super(context); } public MyButton(Context context, AttributeSet attrs) { super(context, attrs); } public MyButton(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); } @Override public boolean onTouchEvent(MotionEvent event) { switch (event.getAction()){ case MotionEvent.ACTION_DOWN: //用户按下的一瞬间 Log.e("MyButton", "---onTouchEvent---" ); break; } return false; //设置为false 表示此事件没有被消费,会继续向下传播 } }
之后我们在Activity中也实现这个相同的事件:
@Override public boolean onTouchEvent(MotionEvent event) { switch (event.getAction()){ case MotionEvent.ACTION_DOWN: Log.e("EventActivity", "---onTouchEvent--- "); break; } return false; }
之后我们按下这个按钮,会触发按下的这个事件,输出以下日志:
这个现象说明,当我们给一个控件内部设置触摸,按压等事件后,用户点击屏幕触发了相应的时间,系统会自动回调相关的方法,而Activity也打印了日志,说明这个事件是从控件本身,向外传播的。
接着我们给这个自定义的按钮设置触摸监听器。
btn_my.setOnTouchListener(new View.OnTouchListener() { @Override public boolean onTouch(View v, MotionEvent event) { Log.e("listener", "--onTouch-- " ); return false; } });
之后再次触摸该按钮,输出日志为:
listener先被打印,说明先执行了触摸事件监听器中的方法。
那么也就说明监听优先于回调先被执行。