前言:
基于监听的事件处理机制请看这边文章 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先被打印,说明先执行了触摸事件监听器中的方法。
 那么也就说明监听优先于回调先被执行。
                










