Android 事件传递与焦点处理(tv)

1、概述

上节介绍了android tv app 与android mobile app 的一些表现形式的不同。在实际编程中需要很多的焦点处理,而焦点处理有经常是在事件传递函数内处理的。所以本节做个android 事件传递与焦点处理的小结。另既然描述到android事件传递不可避免就涉及到了android手势拦截。这也是对原有知识认识的一个补充,因为之前涉及到安卓事件传递就是为了做手势拦截,以至于当看到代码在手势分发函数里处理tv的焦点,与界面移动填充时。一时有点迷糊,为什么是写在dispathKeyEvent里不是写在onInterceptTouchEvent里。原因就是因为这是在事件传递流程里处理焦点,而不是在事件传递流程里拦截事件。

2、Android简单的事件传递流程

提到android事件传递流程肯定会涉及到几个以下几个函数


函数


说明


备注


dispathTouchEvent (MotionEvent ev)


事件分发(手势分发)


触摸屏-手机


dispatchKeyEvent(KeyEvent event)


事件分发


遥控- tv


onInterceptTouchEvent


事件拦截(手势拦截)

返回true: 事件被拦截,事件传递给自己的

onTouchEvent

返回false:事件继续传递


ViewGroup才有


onTouchEvent


事件处理

返回true:事件被消费终止传递

返回false:继续传递

表1

Android事件传递有两种事件,一种是触摸屏的触摸事件,一种就是按键事件,键盘模式和遥控就用这种,不在熬述。dispathTouchEvent 和 dispatchKeyEvent 走的流程是一样的。

事件传递流程细节与源码的分析,网上有很多详细的描述,有些说的也是云里雾里,结合实际项目中的使用并参考:

PRE_andevcon_mastering-the-android-touch-system

事件传递从Activity的事件分发函数开始dispath… 如果没有事件消费最终在回到activty的ontouchEvent在子view被消费了,那就不会传到这个函数。

简单的Down事件的传递如下图和表1结合看:(事件未被消费)

图1

图2

关于拦截:对于拦截down事件后move/up 事件的传递比较复杂,实际使用中只要知道哪个view 是没有down事件的也就没有move/up 而且在实际项目中自己拦截的是move事件。onInterceptTouchEvent

public booleanonInterceptTouchEvent(MotionEvent ev)

事件拦截函数onInterceptTouchEvent是ViewGroup才有的函数。事件拦截(手势拦截)也是在自定义ViewGroup时才要做的。实际情况遇到的是,对于move事件在一些边界使用条件的时候要决定是让ViewGroup自己处理还是childView来处理。其中通过返回值确定是否拦截,false继续传递,true拦截给自己,流程见图1,图2。

3、dispathKeyEvent 与 dispathTouchEvent

事件分发函数,也是事件流程的调度函数。基类的dispath…函数决定了事件传递的方式,里面有涉及到调用onInterceptTouchEvent,和onTouchEvent函数。

做自定ViewGroup事件拦截是不需要重写dispath…的只要重写onInterceptTouchEvent这个函数就可以。所以之前也比较少见重写dispath…

但是在tv app里好多地方是重写了该函数。开始的时候有点不明白为什么写在这里,后来看到每个dispathKeyEvent 函数都有调用super.dispathKeyEvent就明白了,重写dispathKeyEvent并没有影响事件的分发。只是相当于一个钩子挂在事件传递流程上来处理:点击按键手势时理焦点效果与界面效果,

4、焦点处理

手机app开发时焦点处理比较少,有就是editText有时候需要获取下焦点,或者移除下,其实也比较少处理。Tv里就比较多要处理,这里罗列下几个焦点处理函数


Activity


View currentView = getCurrentFocus();


ViewGroup


View currentView = findFocus();


View


currentView.focusSearch(direction);


找到指定方向最近的一个可获取焦点的view 如果没有返回null


setClickedAble


setFocusAble

时间: 2024-10-13 16:22:35

Android 事件传递与焦点处理(tv)的相关文章

android事件传递机制详解

本篇内容将结合Android源码来分析Android的事件传递机制.众所周知,点按.滑动.触摸构成了Android等智能设备的基本操作,几乎所有的应用都通过对触摸屏的操作来进行应用程序的使用.那么,在Android中,触摸事件是如何响应及传递的呢,通过本篇内容你将有一个初步的了解. 实验环境 OS X 10.9 Eclipse(ADT) Android源码版本:API Level 19(Android 4.4) Android事件构成 在Android中,事件主要包括点按.长按.拖拽.滑动等,点

Android事件传递机制(转)

Android事件构成 在Android中,事件主要包括点按.长按.拖拽.滑动等,点按又包括单击和双击,另外还包括单指操作和多指操作.所有这些都构成了Android中的事件响应.总的来说,所有的事件都由如下三个部分作为基础: 按下(ACTION_DOWN) 移动(ACTION_MOVE) 抬起(ACTION_UP) 所有的操作事件首先必须执行的是按下操作(ACTIONDOWN),之后所有的操作都是以按下操作作为前提,当按下操作完成后,接下来可能是一段移动(ACTIONMOVE)然后抬起(ACTI

Android事件传递机制

实验环境 OS X 10.9 Eclipse(ADT) Android源码版本:API Level 19(Android 4.4) Android事件构成 在Android中,事件主要包括点按.长按.拖拽.滑动等,点按又包括单击和双击,另外还包括单指操作和多指操作.所有这些都构成了Android中的事件响应.总的来说,所有的事件都由如下三个部分作为基础: 按下(ACTION_DOWN) 移动(ACTION_MOVE) 抬起(ACTION_UP) 所有的操作事件首先必须执行的是按下操作(ACTIO

Android事件传递机制详解及最新源码分析——ViewGroup篇

在上一篇<Android事件传递机制详解及最新源码分析--View篇>中,详细讲解了View事件的传递机制,没掌握或者掌握不扎实的小伙伴,强烈建议先阅读上一篇. 好了,废话还是少说,直奔主题,开始本篇的ViewGroup事件传递机制探索之旅. 依然从简单的Demo例子现象开始分析 新建安卓工程,首先自定义一个Button以及一个RelativeLayout,很简单,只是重写了主要与事件传递机制相关的方法,代码如下: 自定义WLButton类: 1 public class WLButton e

细说Android事件传递机制(dispatchTouchEvent、onInterceptTouchEvent、onTouchEvent)

本文背景:前些天用到了之前写的自定义图片文字复合控件,在给他设置监听时遇到了麻烦.虽然最后解决了问题,但发现在不重写LinearLayout的onInterceptTouchEvent时,子ImageView.子TextView.父Linearlayout三者不同的属性配置(android:clickable android:focuseable)会造成自定义控件onClick监听失败.或成功.复写了父Linearlayout 的onInterceptTouchEvent时,监听不受子图片.子文

Android事件传递机制(dispatchTouchEvent、onInterceptTouchEvent、onTouchEvent)

一.View的dispatchTouchEvent和onTouchEvent 探讨Android事件传递机制前,明确android的两大基础控件类型:View和ViewGroup.View即普通的控件,没有子布局的,如Button.TextView. ViewGroup继承自View,表示可以有子控件,如Linearlayout.Listview这些.而事件即MotionEvent,最重要的有3个: (1)MotionEvent.ACTION_DOWN  按下View,是所有事件的开始 (2)M

转:Android事件传递机制

转:这里 本文为InfoQ中文站特供稿件,首发地址为:http://www.infoq.com/cn/articles/android-event-delivery-mechanism.如需转载,请与InfoQ中文站联系. 运用的前提是掌握掌握的本质是理解 本篇内容将结合Android源码来分析Android的事件传递机制.众所周知,点按.滑动.触摸构成了Android等智能设备的基本操作,几乎所有的应用都通过对触摸屏的操作来进行应用程序的使用.那么,在Android中,触摸事件是如何响应及传递

android事件传递机制的浅谈

想必大家有时会遇到需要自定义控件吧,这个时候就会遇到事件的传递和处理了,非常繁琐啊!百度上面一大票关于事件的传递机制,但是都千篇一律,都是dispatchTouchEvent 返回true,则事件被拦截,false则分发给子控件之类的,经过几天的研究发现这个事件传递并没有说的这么简单也没有想象中的难. 一般的点击事件.滑动事件都是用ACTION_UP.ACTION_MOE.ACTION_DOWN组成的,android应用里面默认情况下,触摸事件是从activity开始传递,假设里面的view都不

Android事件传递(二ViewGroup事件的传递)

经过上一篇的实验,我门只是仅仅对View的事件的传递进行了分析,但是还有一个比较厉害的ViewGroup我们肯定是要说一下的,ViewGroup的二叉视图分析 我们能看到,一边是View一边是ViewGroup,而ViewGroup中又可以添加View和ViewGroup,但是我们都知道,ViewGroup是可以有自己的孩子的,也可以对自己的孩子进行拜访等等,而View就没有这些特性,那么我们就能想象一下它的传递机制到底和View有什么样的不同.下面给大家乘上我自己的实验结果在ViewGroup