android输入系统C++最上层文件是com_android_serve_input_InputManagerService.cpp

global key:
按下按键,启动某个APP
可以自己指定,修改frameworks\base\core\res\res\xml\Global_keys.xml
假设它是AKEYCODE_TV

system key:
比如音量键 AKEYCODE_VOLUME_DOWN

user key:
其他按键,比如ABCD
AKEYCODE_A

reader线程把驱动上报的scancode根据.kl文件转换成keycode

android_system_code\frameworks\base\core\res\res\xml\Global_keys.xml
  A global key will NOT go to the foreground application and instead only ever be sent via targeted
  broadcast to the specified component. The action of the intent will be
  android.intent.action.GLOBAL_BUTTON and the KeyEvent will be included in the intent as
  android.intent.extra.KEY_EVENT.

三种按键的处理过程:

(1)Globalkey:AKEYCODE_TV

 NotifyKeyArgs args()//在InputReader.cpp中,使用收到的数据构造args

  getListener()->notifyKey(&args)//通知listener,这里的listener是在new InputReader的时候传入的mDispatcher对象,其是一个InputDispatcher类

    mPolicy->interceptKeyBeforeQueueing(&event,policyFlags)//稍加处理,其是调用phoneWindowManager.java中的同名函数,对于Globalkey,返回PASS_TO_USER,根据返回值设置policeFlags(表示是否把事件传给用户)

    needWake = enqueueInboundEventLocked(newEntry)//放入mInboundQueue队列,newEntry根据policyFlags被构造

    if(needWake){

      mLooper->wake()//唤醒Dispatcher线程

    }

(2)system key:AKEYCODE_VOLUME_DOWN

 NotifyKeyArgs args()//在InputReader.cpp中,使用收到的数据构造args

  getListener()->notifyKey(&args)//通知listener,这里的listener是在new InputReader的时候传入的mDispatcher对象,其是一个InputDispatcher类

    mPolicy->interceptKeyBeforeQueueing(&event,policyFlags)//稍加处理,其是调用phoneWindowManager.java中的同名函数,对于systemkey,分类处理,如果可以直接处理的话,处理它,设置返回!PASS_TO_USER;如果可以直接处理设置为PASS_TO_USER,,根据返回值设置policeFlags(表示是否把事件传给用户)

    needWake = enqueueInboundEventLocked(newEntry)//放入mInboundQueue队列,newEntry根据policyFlags被构造

    if(needWake){

      mLooper->wake()//唤醒Dispatcher线程

    }

(3)user key:AKEYCODE_A

 NotifyKeyArgs args()//在InputReader.cpp中,使用收到的数据构造args

  getListener()->notifyKey(&args)//通知listener,这里的listener是在new InputReader的时候传入的mDispatcher对象,其是一个InputDispatcher类

    mPolicy->interceptKeyBeforeQueueing(&event,policyFlags)//稍加处理,其是调用phoneWindowManager.java中的同名函数,对于普通按键,返回PASS_TO_USER,根据返回值设置policeFlags(表示是否把事件传给用户)

    needWake = enqueueInboundEventLocked(newEntry)//放入mInboundQueue队列,newEntry根据policyFlags被构造

    if(needWake){

      mLooper->wake()//唤醒Dispatcher线程

    }

10. Dispatcher线程情景分析_dispatch前处理

(1)、命令队列为空时//if(!havaCommandsLocked){dispatchOnceInndrLocked(&nextWakeupTime)}

a、从mInboundQueue取出事件

b、用它来生成命令放入命令队列或者丢弃(对于!PASS_TO_USER的事件)

d、执行完命令后,对于经过处理的事件:Globalkey丢弃、Systemkey丢弃、userkey找到target后Dispatcher分发

(2)命令队列友数据时//if(runCommandsLockedInterruptible()){nextWakeupTime = LONG_LONG_MIN}

c、执行命令:Globalkey发广播、Systemkey直接处理、userkey不处理

情景分析:

(1)policyFlags = !PASS_TO_USER(不传给APP)

dispatchOnceInndrLocked()//从mInboundQueue取出事件

  DropReason dropReason = DROP_REASON_NOT_DROPPED//初始化为不丢弃

  if(!(mPendingEvent->policyFlags & POLLCY_FLAG_PASS_TO_USER))//数据的flag为!PASS_TO_USER

    dropReason = DROP_REASON_POLLCY //设置丢弃标准

  dispatchKeyLocked()//如果是按键类事件,执行该函数

    if(*dropReason  !=DROP_REASON_NOT_DROPPED){

      setInjectionResultLocked();

      return true;//dropReason表示放弃该数据的时候直接发回true

    }

(2)policyFlags == PASS_TO_USER

如果flags是PASS_TO_USER,构造命令把其放入命令队列

nextWakeupTime =LONG_LONG_MIN 表示Dispatch线程不会休眠,会再次执行dispatchOnce函数

processKey//Reader线程

  getListener()->notifyKey(&args)

    polictFlags |= POLICY_FLAG_TRUSTED

    event.initialize()

    mPolicy->interceptKeyBeforeQueueing(&event,policyFlags)//放入队列前先稍加处理:分类(Global输入/System输入/User输入)、处理紧急事件(比如来电、按音量、静音)

      policyFlags |= POLICY_FLAG_INTERACTIVE

      jobject keyEventObjg = android_view_keyEvent_fromNative(env,keyEvent)

      wmActions = env->CalllntMethod(...gServiceClassInfo.interceptKeyBeforeQueueing...)

        mWindowManagerCallBacks.interceptKeyBeforeQueueing(event,policyFlags)

          interceptKeyBeforeQueueing

      handleInterceptActions(...)

        policyFlags |= POLLCY_FLAG_PASS_TO_USER

    KeyEntry* newEntry = new KeyEntry()

    enqueueInboundEventLocked(newEntry)

      mInboundQueue.enqueueAtTail(entry)//InputReader线程把数据放入mInboundQueue

    mLooper->wake()

threadLoop

  dispatchOnce

    dispatchOnceInnerLocked(&nextWakeupTime)//从mInboundQueue取出数据生成命令

      mPendingEvent = mInboundQueue.dequeueAtHead()//从mInboundQueue从取出数据

      KeyEntry* typedEntry = static_case<KeyEntry*>(mPendingEvent)

      dispatchKeyLocked

        postCommandLocked(&InputDispatcher::doInterceptKeyBeforeDispatchingLockedInterruptible)//对于Global/System按键处理:放入mcommandQueue命令队列,依次处理

        findFocusedWindowTargetsLocked

        dispatchEventLocked

          prepareDispatchCycleLocked

            enqueueDispatchEntriesLocked

              enqueueDispatchEntryLocked

                connection->outboundQueue.enqueueAtTail//

对于User按键放入队列,查找目标APP,得到connection,放人APP里面的outboundQueue

              startDispatchCycleLocked//从outboundQueue取出事件,通过connection发给APP

    runCommandsLockedInterruptible()//执行命令,命令就是doInterceptKeyBeforeDispatchingLockedInterruptible函数

    mLooper->pollOnce()

    

10.7 android输入系统_Dispatcher线程情景分析_Reader线程传递事件和dispatch前处理的更多相关文章

  1. Android系统--输入系统(十三)Dispatcher线程情景分析_Reader线程传递事件

    Android系统--输入系统(十三)Dispatcher线程情景分析_Reader线程传递事件 1. 输入按键 我们知道Android系统的按键分为三类:(1)Global Key;(2)Syste ...

  2. 10.6 android输入系统_Dispatcher线程_总体框架

    图解Android - Android GUI 系统 (5) - Android的Event Input System - 漫天尘沙 - 博客园.htm // 关注里面的Dispatcher处理流程h ...

  3. 10.9 android输入系统_APP跟输入系统建立联系和Dispatcher线程_分发dispatch

    12. 输入系统_APP跟输入系统建立联系_InputChannel和Connection核心: socketpair // 第9课第3节_输入系统_必备Linux编程知识_任意进程双向通信(scok ...

  4. 10.5 android输入系统_Reader线程_使用EventHub读取事件和核心类及配置文件_实验_分析

    4. Reader线程_使用EventHub读取事件 使用inotify监测/dev/input下文件的创建和删除 使用epoll监测有无数据上报 细节: a.fd1 = inotify_init(& ...

  5. 10.4 android输入系统_框架、编写一个万能模拟输入驱动程序、reader/dispatcher线程启动过程源码分析

    1. 输入系统框架 android输入系统官方文档 // 需FQhttp://source.android.com/devices/input/index.html <深入理解Android 卷 ...

  6. 10.14 android输入系统_多点触摸驱动测试及Reader线程、InputStage分析

    21. 多点触摸_电容屏驱动程序_实践_tiny4412 tiny4412触摸屏: 分辨率为800 x 480http://wiki.friendlyarm.com/wiki/index.php/LC ...

  7. 10.12 android输入系统_InputStage理论

    android应用程序对输入系统的处理分为多个阶段,我们把这些阶段称为InputStage 理论处理流程: (1)activity发给window,如果window不能处理,再由activity处理; ...

  8. 10.11 android输入系统_补充知识_activity_window_decor_view关系

    android里:1个application, 有1个或多个activity(比如支付宝有:首页.财富.口碑.朋友.我的,这些就是activity)1个activity, 有1个window(每个ac ...

  9. 10.13 android输入系统_多点触摸驱动理论与框架

    1.多点触摸驱动理论 驱动程序仅上报多个触点的位置就可以,是放大还是缩小由应用程序控制 对于多点触摸驱动在linux系统中有个输入子系统,其已经实现了open/read/write等接口 我们只需要实 ...

随机推荐

  1. 43.安装npm及cnpm(Windows)

    转自:https://www.cnblogs.com/yominhi/p/7039795.html [工具官网] Node.js : http://nodejs.cn/ 淘宝NPM: https:// ...

  2. vue -- config index.js 配置文件详解

    此文章介绍vue-cli脚手架config目录下index.js配置文件 此配置文件是用来定义开发环境和生产环境中所需要的参数 关于注释 当涉及到较复杂的解释我将通过标识的方式(如(1))将解释写到单 ...

  3. reactor官方文档译文(2)Reactor-core模块

    You should never do your asynchronous work alone. — Jon Brisbin 完成Reactor 1后写到 You should never do y ...

  4. 闲的无聊写了个很(wu)有(liao)意(dao)思(bao)的程序

    下午机房断网了 闲的无聊,写了个小游戏 忘了sleep在哪个库里了.. 自带变色效果哦 #include<iostream> #include<cstdio> #include ...

  5. 51nod1004 n^n的末位数字

    题目来源: Author Ignatius.L (Hdu 1061) 基准时间限制:1 秒 空间限制:131072 KB 分值: 5 难度:1级算法题  收藏  关注 给出一个整数N,输出N^N(N的 ...

  6. C# 开发 —— 数组类对象接口

    数组类型是从抽象基类 Array 派生的引用类型,通过new运算符创建数组并将数组元素初始化为他们的默认值 一维数组 type[] arrayname; 数组的长度不是声明的一部分,而且数组必须在访问 ...

  7. 【DRF路由】

    在urls.py文件中按照如下步骤写,即可正确使用DRF的内置路由. from .views import BookModel # 1. 导入我们的视图 from rest_framework.rou ...

  8. readonly&&declare&&unset &&export&&env环境变量

    readonly命令用于定义只读shell变量和shell函数.readonly命令的选项-p可以输出显示系统中所有定义的只读变量. 选项 -f:定义只读函数: -a:定义只读数组变量: -p:显示系 ...

  9. usermod---修改用户账户信息

    usermod可用来修改用户帐号的各项设定. 语法 usermod [-LU][-c <备注>][-d <登入目录>][-e <有效期限>][-f <缓冲天数 ...

  10. unity3d编程日志

    2014/4/27 编写脚本的时候,加入了中文凝视,发现console面板有非常多不可思议的bug.查了一下发现是由于monodevelop脚本中文凝视报错,而英文凝视不会受影响. 解决方法:把凝视放 ...