Android事件分发详解(四)——事件传递基础示例

简介: MainActivity如下:package com.cn;import android.app.Activity;import android.
MainActivity如下:
package com.cn;
import android.app.Activity;
import android.os.Bundle;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.View.OnTouchListener;
/**
 * Demo描述:
 * Android事件传递基础
 * 
 * 背景知识:
 * 事件的传递方向为:从最外层(Activity)传递至最内层(某个View)
*  事件的消费方向为:从最内层(某个View)传递至最外层(Activity)
*  
*  
 * 
 * Demo构成:
 * 1 一个普通的Activity中包含一个自定义Button.
 * 2 覆写Activity的dispatchTouchEvent和onTouchEvent
 * 3 自定义Button中覆写dispatchTouchEvent和onTouchEvent
 *   两者的返回值均为默认值(true).
 * 4 在Activity中为自定义Button注册TouchListener,
 *   覆写里面的onTouch(),该方法默认返回false表示事件未消耗.
 * 5 在Activity中为自定义Button注册ClickListener,
 * 
 * 
 * 点击屏幕上的Button进行测试
 * 
 * 
 * Touch事件的处理顺序为:
 * 1 Activity的dispatchTouchEvent()方法
 *   如果它返回false表示不分发事件,则2,3,4不会执行
 * 2 自定义Button的dispatchTouchEvent()方法
 *   如果它返回false表示不分发事件,则3,4不会执行
 * 3 Activity中自定义Button的TouchListener执行
 *   如果它返回true表示事件已经消耗,则4不会执行
 * 4 自定义Button的onTouchEvent()方法
 *   如果它返回false(事件未被消费)即返回给自定义Button的dispatchTouchEvent()方法一个false.
 *   所以自定义Button会中断事件的分发,即每次只分发ACTION_DOWN事件,不分发ACTION_MOVE和ACTION_UP.
 *   所以,每次自定义Button只会响应ACTION_DOWN,不会收到ACTION_MOVE和ACTION_UP.
 *   也正因为这些事件没有被消耗,所以事件会向上传递,于是Activity的onTouchEvent()方法
 *   可以响应到一系列的ACTION_DOWN和ACTION_MOVE以及ACTION_UP.
 *   如果它返回true(事件被消费),那么事件就不会向上传递给Activity了.
 *   Activity自然也收到不到一系列的ACTION_DOWN和ACTION_MOVE以及ACTION_UP.
 *   
 *   小结:
 *   (1) 每一次的ACTION_DOWN和ACTION_MOVE以及ACTION_UP都会引起每一层的dispatchTouchEvent()
 *   (2) 但是每一层的onTouchEvent()就不一定会执行了.比如下层已经消耗掉了事件,那么上层就不会响应onTouchEvent()了.
 *   
 * 5 自定义Button的ClickListener中的onClick()方法
 * 
 * 
 * 小结:
 * 1 因为自定义Button的onTouchEvent默认返回为true.
 *   表示事件已经消耗,不会继续向上层传递,所以Activity中的onTouchEvent方法不会调用
 * 2 再次证明:
 *   View中onTouch()先于onTouchEvent()执行
 *   View中onTouchEvent()先于onClick()执行,或者说在onTouchEvent()中调用了onClick()
 * 3 1和2代表的是:事件的传递方向-->从最外层(Activity)传递至最内层(某个View)
 *
 * 
 * 
 * 
 * 
 * 常量对应:
 * ACTION_DOWN----->0
 * ACTION_UP------->1
 * ACTION_MOVE----->2
 * 
 * 参考资料:
 * 1 http://blog.csdn.net/bigconvience/article/details/26391743
 * 2 http://blog.csdn.net/siobhan/article/details/8257334
 * 3 http://blog.csdn.net/drunkcello/article/details/39892761
 * 4 http://blog.csdn.net/yuanzeyao/article/details/37961997
 * 5 http://blog.csdn.net/lmj623565791/article/details/38960443
 * 6 http://blog.csdn.net/lmj623565791/article/details/39102591
 *   Thank you very much
 * 
 */
public class MainActivity extends Activity {
	private EventButton mEventButton;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		init();
	}
   private void init(){
	   mEventButton=(EventButton) findViewById(R.id.button);
	   mEventButton.setOnTouchListener(new OnTouchListener() {
		@Override
		public boolean onTouch(View v, MotionEvent event) {
			System.out.println("---> 按钮的OnTouchListener  "+event.getAction());
			return false;
		}
	   });
	   mEventButton.setOnClickListener(new OnClickListener() {
		@Override
		public void onClick(View view) {
			System.out.println("---> 按钮的OnClickListener  点击了Button");
		}
	   });
	   
   }

    
    @Override
    public boolean dispatchTouchEvent(MotionEvent ev) {
    	System.out.println("---> Activity dispatchTouchEvent "+ev.getAction()+"  , it defaulst is true");
    	return super.dispatchTouchEvent(ev);
    }
    
    @Override
    public boolean onTouchEvent(MotionEvent event) {
    	System.out.println("---> Activity onTouchEvent "+event.getAction()+"  , it defaulst is false");
    	return super.onTouchEvent(event);
    }
    

}

EventButton如下:
package com.cn;
import android.content.Context;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.widget.Button;

public class EventButton extends Button {
	public EventButton(Context context, AttributeSet attrs) {
		super(context, attrs);
	}
	
	@Override
	public boolean dispatchTouchEvent(MotionEvent event) {
		System.out.println("---> 按钮 dispatchTouchEvent , it defaulst is true");
		return super.dispatchTouchEvent(event);
	}
	
	@Override
	public boolean onTouchEvent(MotionEvent event) {
		System.out.println("---> 按钮 onTouchEvent  , it defaulst is true");
		return super.onTouchEvent(event);
		//return false;
	}
}

main.xml如下:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity" >

    <com.cn.EventButton
        android:id="@+id/button"
        android:layout_width="250dip"
        android:layout_height="250dip"
        android:layout_centerInParent="true"
        android:text="Touch me" 
       />

</RelativeLayout>

相关文章
|
11月前
|
开发框架 前端开发 Android开发
Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势
本文深入探讨了 Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势。这对于实现高效的跨平台移动应用开发具有重要指导意义。
1020 4
|
12月前
|
Android开发
Android面试高频知识点(1) 图解Android事件分发机制
Android面试高频知识点(1) 图解Android事件分发机制
|
12月前
|
存储 前端开发 测试技术
Android kotlin MVVM 架构简单示例入门
Android kotlin MVVM 架构简单示例入门
184 1
|
12月前
|
Android开发
Android面试高频知识点(1) 图解 Android 事件分发机制
Android面试高频知识点(1) 图解 Android 事件分发机制
143 1
|
12月前
|
Android开发
Android 事件分发机制详细解读
Android 事件分发机制详细解读
188 5
|
12月前
|
XML 前端开发 Android开发
Android面试高频知识点(1) 图解Android事件分发机制
Android面试高频知识点(1) 图解Android事件分发机制
Android面试高频知识点(1) 图解Android事件分发机制
|
Android开发
Android面试高频知识点(1) 图解 Android 事件分发机制
在Android开发中,事件分发机制是一块Android比较重要的知识体系,了解并熟悉整套的分发机制有助于更好的分析各种点击滑动失效问题,更好去扩展控件的事件功能和开发自定义控件,同时事件分发机制也是Android面试必问考点之一,如果你能把下面的一些事件分发图当场画出来肯定加分不少。废话不多说,总结一句:事件分发机制很重要。
374 9
|
图形学 Android开发
小功能⭐️Unity调用Android常用事件
小功能⭐️Unity调用Android常用事件
|
开发工具 Android开发
Android项目架构设计问题之组件A通知组件B某个事件的发生如何解决
Android项目架构设计问题之组件A通知组件B某个事件的发生如何解决
97 0
|
Android开发
39. 【Android教程】触摸事件分发
39. 【Android教程】触摸事件分发
100 2

热门文章

最新文章

  • 1
    Android实战经验之Kotlin中快速实现MVI架构
    344
  • 2
    即时通讯安全篇(一):正确地理解和使用Android端加密算法
    212
  • 3
    escrcpy:【技术党必看】Android开发,Escrcpy 让你无线投屏新体验!图形界面掌控 Android,30-120fps 超流畅!🔥
    555
  • 4
    【01】噩梦终结flutter配安卓android鸿蒙harmonyOS 以及next调试环境配鸿蒙和ios真机调试环境-flutter项目安卓环境配置-gradle-agp-ndkVersion模拟器运行真机测试环境-本地环境搭建-如何快速搭建android本地运行环境-优雅草卓伊凡-很多人在这步就被难倒了
    854
  • 5
    Cellebrite UFED 4PC 7.71 (Windows) - Android 和 iOS 移动设备取证软件
    313
  • 6
    【03】仿站技术之python技术,看完学会再也不用去购买收费工具了-修改整体页面做好安卓下载发给客户-并且开始提交网站公安备案-作为APP下载落地页文娱产品一定要备案-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
    232
  • 7
    Android历史版本与APK文件结构
    739
  • 8
    【02】仿站技术之python技术,看完学会再也不用去购买收费工具了-本次找了小影-感觉页面很好看-本次是爬取vue需要用到Puppeteer库用node.js扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
    246
  • 9
    【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
    262
  • 10
    APP-国内主流安卓商店-应用市场-鸿蒙商店上架之必备前提·全国公安安全信息评估报告如何申请-需要安全评估报告的资料是哪些-优雅草卓伊凡全程操作
    491