Android触摸事件传递机制

点击事件分发

  • ACTION_DOWN事件触发时,会从Activity -> PhoneWindow -> DecorView -> ViewGroup -> View顺序,逐层调用对应的dispatchTouchEvent方法分发。
  • 在View的dispatchTouchEvent中,常理会调用onTouchEvent,在onTouchEvent方法中,ACTION_DOWN时,会检查是否是长按,时长超过500毫秒则是长按;在ACTION_UP时,会调用performOnClickInteral,依次调用onClick(),响应点击事件。如果重写onTouch()方法,返回true,则View的dispatchTouchEvent中,有一个if判断条件成立,会将boolean局部变量result置true,那么接下来一个if判断中,该result为true,就不会调用onTouchEvent方法,因此该次触摸事件则消费结束,不会再响应onLongClick和onClick。如果重写onLongClick()方法,返回true,则在onTouchEvent方法中,ACTION_DOWN时,检查是长按后,会调用onLongClick(),响应长按事件,该方法返回true后,会将mHasPerformedLongPress代表是否执行了长按事件的boolean值置true;在ACTION_UP时,调用performOnClickInteral前,会先判断mHasPerformedLongPress,为true,则不调,为false,才调用。因此,重写onLongClick()方法,返回true时,不会再响应onClick。

点击事件传递过程:

  1. ACTION_DOWN事件,Viewgroup的dispatchTouchEvent分发事件,onInterceptTouchEvent拦截事件,默认不拦截,继续向下分发给子View,子View的dispatchTouchEvent分发事件,传给子View的onTouchEvent,若返回true消费,则后面的ACTION_MOVE和ACTION_UP事件按顺序继续分发传递。
  2. 事件传给子View的onTouchEvent时,子View返回false,不消费事件,则事件回传给ViewGroup的onTouchEvent来消费,以后的时间会按照ViewGoup的dispatchTouchEvent到onTouchEvent来传递消费。
  3. 当ViewGroup的onInterceptTouchEvent拦截事件后,则会传递给ViewGroup的onTouchEvent消费,以后的其他事件也会按照ViewGoup的dispatchTouchEvent到onTouchEvent来传递消费,不会再传给子View。

解决触摸事件冲突:

  • 外部拦截。ViewGroup重写onInterceptTouchEvent方法,默认不拦截,事件往下分发给子View,若返回true,则拦截此次事件,将事件传给ViewGroup的onTouchEvent处理。
  • 内部拦截。重写子View的dispatchTouchEvent方法,方法中调用getParent().requestDisallowInterceptTouchEvent(true)方法,传true则代表不希望ViewGroup拦截事件,传false则代表希望ViewGroup拦截事件。
  • 内部拦截。子View重写onTouchEvent方法,返回true,则子View消费该次事件,返回false,该次事件返回给ViewGroup的onTouchEvent处理。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQLAlchemy 是一个 SQL 工具包和对象关系映射(ORM)库,用于 Python 编程语言。它提供了一个高级的 SQL 工具和对象关系映射工具,允许开发者以 Python 类和对象的形式操作数据库,而无需编写大量的 SQL 语句。SQLAlchemy 建立在 DBAPI 之上,支持多种数据库后端,如 SQLite, MySQL, PostgreSQL 等。 SQLAlchemy 的核心功能: 对象关系映射(ORM): SQLAlchemy 允许开发者使用 Python 类来表示数据库表,使用类的实例表示表中的行。 开发者可以定义类之间的关系(如一对多、多对多),SQLAlchemy 会自动处理这些关系在数据库中的映射。 通过 ORM,开发者可以像操作 Python 对象一样操作数据库,这大大简化了数据库操作的复杂性。 表达式语言: SQLAlchemy 提供了一个丰富的 SQL 表达式语言,允许开发者以 Python 表达式的方式编写复杂的 SQL 查询。 表达式语言提供了对 SQL 语句的灵活控制,同时保持了代码的可读性和可维护性。 数据库引擎和连接池: SQLAlchemy 支持多种数据库后端,并且为每种后端提供了对应的数据库引擎。 它还提供了连接池管理功能,以优化数据库连接的创建、使用和释放。 会话管理: SQLAlchemy 使用会话(Session)来管理对象的持久化状态。 会话提供了一个工作单元(unit of work)和身份映射(identity map)的概念,使得对象的状态管理和查询更加高效。 事件系统: SQLAlchemy 提供了一个事件系统,允许开发者在 ORM 的各个生命周期阶段插入自定义的钩子函数。 这使得开发者可以在对象加载、修改、删除等操作时执行额外的逻辑。
SQLAlchemy 是一个 SQL 工具包和对象关系映射(ORM)库,用于 Python 编程语言。它提供了一个高级的 SQL 工具和对象关系映射工具,允许开发者以 Python 类和对象的形式操作数据库,而无需编写大量的 SQL 语句。SQLAlchemy 建立在 DBAPI 之上,支持多种数据库后端,如 SQLite, MySQL, PostgreSQL 等。 SQLAlchemy 的核心功能: 对象关系映射(ORM): SQLAlchemy 允许开发者使用 Python 类来表示数据库表,使用类的实例表示表中的行。 开发者可以定义类之间的关系(如一对多、多对多),SQLAlchemy 会自动处理这些关系在数据库中的映射。 通过 ORM,开发者可以像操作 Python 对象一样操作数据库,这大大简化了数据库操作的复杂性。 表达式语言: SQLAlchemy 提供了一个丰富的 SQL 表达式语言,允许开发者以 Python 表达式的方式编写复杂的 SQL 查询。 表达式语言提供了对 SQL 语句的灵活控制,同时保持了代码的可读性和可维护性。 数据库引擎和连接池: SQLAlchemy 支持多种数据库后端,并且为每种后端提供了对应的数据库引擎。 它还提供了连接池管理功能,以优化数据库连接的创建、使用和释放。 会话管理: SQLAlchemy 使用会话(Session)来管理对象的持久化状态。 会话提供了一个工作单元(unit of work)和身份映射(identity map)的概念,使得对象的状态管理和查询更加高效。 事件系统: SQLAlchemy 提供了一个事件系统,允许开发者在 ORM 的各个生命周期阶段插入自定义的钩子函数。 这使得开发者可以在对象加载、修改、删除等操作时执行额外的逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值