Android4.1中会被系统拦截的InputEent

2024-01-02 08:08

本文主要是介绍Android4.1中会被系统拦截的InputEent,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


1. InputDispatcher::notifyKey

     如果系统发现一个Event是KeyEvent, 会调用nofityKey去通知收到一个KeyEvent. 在notifyKey中会查看policy的策略。 

     mPolicy->interceptKeyBeforeQueueing(&event, /*byref*/ policyFlags);  //mPolicy实际上就是 NativeInputManager。  当这个函数执行后会把对应的policy也设置到poicyFlags里面。

    

2. NativeInputManager::interceptKeyBeforeQueueing(const KeyEvent* keyEvent, uint32_t& policyFlags) 

     NativeInputManager是一个JNI类,自己不做什么工作,只是通过env->CallIntMethod(mServiceObj, gServiceClassInfo.interceptKeyBeforeQueueing, keyEventObj, policyFlags, isScreenOn); 去调用Java的interceptKeyBeforeQueueing方法。 实际上就是调用 InputManagerService.interceptKeyBeforeQueueing()


3. InputManagerService.interceptKeyBeforeQueueing()

    // Native callback.private int interceptKeyBeforeQueueing(KeyEvent event, int policyFlags, boolean isScreenOn) {return mCallbacks.interceptKeyBeforeQueueing(event, policyFlags, isScreenOn);}
   可以看到里面只是调用了回到函数而已,而mCallbacks就是InputMoniter.java

4. InputMoniter.interceptKeyBeforeQueueing()

    /* Provides an opportunity for the window manager policy to intercept early key* processing as soon as the key has been read from the device. */public int interceptKeyBeforeQueueing(KeyEvent event, int policyFlags, boolean isScreenOn) {Slog.d("InputMonitor.java", "interceptKeyBeforeQueueing !!!!!!");return mService.mPolicy.interceptKeyBeforeQueueing(event, policyFlags, isScreenOn);}

5. mService.mPolicy.interceptKeyBeforeQueueing(event, policyFlags, isScreenOn);

    // Native callback.private int interceptKeyBeforeQueueing(KeyEvent event, int policyFlags, boolean isScreenOn) {Slog.d("InputManagerService.java", "interceptKeyBeforeQueueing !!!!!!!!!!!!!!");return mCallbacks.interceptKeyBeforeQueueing(event, policyFlags, isScreenOn);}
    InputMoniter.interceptKeyBeforeQueueing()中就是直接调了mService.mPolicy.interceptKeyBeforeQueueing, mService是WindowManagerService, mPolicy是PhoneWindowManager. 简而言之就是会去直走到PhoneWindowManager中。


6. PhoneWindowManager.interceptKeyBeforeQueueing(KeyEvent event, int policyFlags, boolean isScreenOn) 

    

     代码很长,需要慢慢分析。


7.  InputDispatcher::dispatchKeyLocked

     当InputDispatcher::notifyKey 完成之后,InputDispatcher就会调用dispatchKeyLocked去做进一步的分配。

      一个Event过来都是通过InputDispatcher进行分发的,在dispatchKeyLocked中会调用 InputDispatcher::doInterceptKeyBeforeDispatchingLockedInterruptible 去

     

bool InputDispatcher::dispatchKeyLocked(nsecs_t currentTime, KeyEntry* entry,DropReason* dropReason, nsecs_t* nextWakeupTime) {// Preprocessing.// Give the policy a chance to intercept the key.if (entry->interceptKeyResult == KeyEntry::INTERCEPT_KEY_RESULT_UNKNOWN) {if (entry->policyFlags & POLICY_FLAG_PASS_TO_USER) {CommandEntry* commandEntry = postCommandLocked(& InputDispatcher::doInterceptKeyBeforeDispatchingLockedInterruptible);... ...} else {entry->interceptKeyResult = KeyEntry::INTERCEPT_KEY_RESULT_CONTINUE;}} else if (entry->interceptKeyResult == KeyEntry::INTERCEPT_KEY_RESULT_SKIP) {... ...}// Dispatch the key.dispatchEventLocked(currentTime, entry, inputTargets);return true;
}

8. InputDispatcher::doInterceptKeyBeforeDispatchingLockedInterruptible

    在这个函数中哦你依旧还是通过mPolicy(NativeInputManager)去通过JNI调用InputManagerService. 

void InputDispatcher::doInterceptKeyBeforeDispatchingLockedInterruptible(CommandEntry* commandEntry) {... ...nsecs_t delay = mPolicy->interceptKeyBeforeDispatching(commandEntry->inputWindowHandle,&event, entry->policyFlags);mLock.lock();if (delay < 0) {entry->interceptKeyResult = KeyEntry::INTERCEPT_KEY_RESULT_SKIP;} else if (!delay) {entry->interceptKeyResult = KeyEntry::INTERCEPT_KEY_RESULT_CONTINUE;} else {entry->interceptKeyResult = KeyEntry::INTERCEPT_KEY_RESULT_TRY_AGAIN_LATER;entry->interceptKeyWakeupTime = now() + delay;}entry->release();
}

 9. NativeInputManager::interceptKeyBeforeDispatching

nsecs_t NativeInputManager::interceptKeyBeforeDispatching(const sp<InputWindowHandle>& inputWindowHandle,const KeyEvent* keyEvent, uint32_t policyFlags) {// Policy:// - Ignore untrusted events and pass them along.// - Filter normal events and trusted injected events through the window manager policy to//   handle the HOME key and the like.nsecs_t result = 0;if (policyFlags & POLICY_FLAG_TRUSTED) {jobject inputWindowHandleObj = getInputWindowHandleObjLocalRef(env, inputWindowHandle);jobject keyEventObj = android_view_KeyEvent_fromNative(env, keyEvent);if (keyEventObj) {jlong delayMillis = env->CallLongMethod(mServiceObj,gServiceClassInfo.interceptKeyBeforeDispatching,inputWindowHandleObj, keyEventObj, policyFlags);} env->DeleteLocalRef(inputWindowHandleObj);}return result;
}

 10. InputManagerService.intercepKeyBeforeDispatching()
    // Native callback.private long interceptKeyBeforeDispatching(InputWindowHandle focus,KeyEvent event, int policyFlags) {return mCallbacks.interceptKeyBeforeDispatching(focus, event, policyFlags);}

11. InputMonitor.interceptKeyBeforeDispatching()

    /* Provides an opportunity for the window manager policy to process a key before* ordinary dispatch. */public long interceptKeyBeforeDispatching(InputWindowHandle focus, KeyEvent event, int policyFlags) {Log.d("InputMonitor.java","interceptKeyBeforeDispatching !!!!!!");WindowState windowState = focus != null ? (WindowState) focus.windowState : null;return mService.mPolicy.interceptKeyBeforeDispatching(windowState, event, policyFlags);}


12. PhoneWondowManager.interceptKeyBeforeDispatching()
   public long interceptKeyBeforeDispatching(WindowState win, KeyEvent event, int policyFlags) {final boolean keyguardOn = keyguardOn();final int keyCode = event.getKeyCode();final int repeatCount = event.getRepeatCount();final int metaState = event.getMetaState();final int flags = event.getFlags();final boolean down = event.getAction() == KeyEvent.ACTION_DOWN;final boolean canceled = event.isCanceled();if (DEBUG_INPUT) {Log.d(TAG, "interceptKeyTi keyCode=" + keyCode + " down=" + down + " repeatCount="+ repeatCount + " keyguardOn=" + keyguardOn + " mHomePressed=" + mHomePressed+ " canceled=" + canceled);}// If we think we might have a volume down & power key chord on the way// but we're not sure, then tell the dispatcher to wait a little while and// try again later before dispatching.if (mScreenshotChordEnabled && (flags & KeyEvent.FLAG_FALLBACK) == 0) {if (mVolumeDownKeyTriggered && !mPowerKeyTriggered) {final long now = SystemClock.uptimeMillis();final long timeoutTime = mVolumeDownKeyTime + SCREENSHOT_CHORD_DEBOUNCE_DELAY_MILLIS;if (now < timeoutTime) {return timeoutTime - now;}}if (keyCode == KeyEvent.KEYCODE_VOLUME_DOWN&& mVolumeDownKeyConsumedByScreenshotChord) {if (!down) {mVolumeDownKeyConsumedByScreenshotChord = false;}return -1;}}// First we always handle the home key here, so applications// can never break it, although if keyguard is on, we do let// it handle it, because that gives us the correct 5 second// timeout.if (keyCode == KeyEvent.KEYCODE_HOME) {// If we have released the home key, and didn't do anything else// while it was pressed, then it is time to go home!if (!down) {final boolean homeWasLongPressed = mHomeLongPressed;mHomePressed = false;mHomeLongPressed = false;if (!homeWasLongPressed) {try {IStatusBarService statusbar = getStatusBarService();if (statusbar != null) {statusbar.cancelPreloadRecentApps();}} catch (RemoteException e) {Slog.e(TAG, "RemoteException when showing recent apps", e);// re-acquire status bar service next time it is needed.mStatusBarService = null;}mHomePressed = false;if (!canceled) {// If an incoming call is ringing, HOME is totally disabled.// (The user is already on the InCallScreen at this point,// and his ONLY options are to answer or reject the call.)boolean incomingRinging = false;try {ITelephony telephonyService = getTelephonyService();if (telephonyService != null) {incomingRinging = telephonyService.isRinging();}} catch (RemoteException ex) {Log.w(TAG, "RemoteException from getPhoneInterface()", ex);}if (incomingRinging) {Log.i(TAG, "Ignoring HOME; there's a ringing incoming call.");} else {launchHomeFromHotKey();  //launch home}} else {Log.i(TAG, "Ignoring HOME; event canceled.");}return -1;}}// If a system window has focus, then it doesn't make sense// right now to interact with applications.WindowManager.LayoutParams attrs = win != null ? win.getAttrs() : null;if (attrs != null) {final int type = attrs.type;if (type == WindowManager.LayoutParams.TYPE_KEYGUARD|| type == WindowManager.LayoutParams.TYPE_KEYGUARD_DIALOG) {// the "app" is keyguard, so give it the keyreturn 0;}final int typeCount = WINDOW_TYPES_WHERE_HOME_DOESNT_WORK.length;for (int i=0; i<typeCount; i++) {if (type == WINDOW_TYPES_WHERE_HOME_DOESNT_WORK[i]) {// don't do anything, but also don't pass it to the appreturn -1;}}}if (down) {if (!mHomePressed && mLongPressOnHomeBehavior == LONG_PRESS_HOME_RECENT_SYSTEM_UI) {try {IStatusBarService statusbar = getStatusBarService();if (statusbar != null) {statusbar.preloadRecentApps();}} catch (RemoteException e) {Slog.e(TAG, "RemoteException when preloading recent apps", e);// re-acquire status bar service next time it is needed.mStatusBarService = null;}}if (repeatCount == 0) {mHomePressed = true;} else if ((event.getFlags() & KeyEvent.FLAG_LONG_PRESS) != 0) {if (!keyguardOn) {handleLongPressOnHome();}}}return -1;} else if (keyCode == KeyEvent.KEYCODE_MENU) {// Hijack modified menu keys for debugging featuresfinal int chordBug = KeyEvent.META_SHIFT_ON;if (down && repeatCount == 0) {if (mEnableShiftMenuBugReports && (metaState & chordBug) == chordBug) {Intent intent = new Intent(Intent.ACTION_BUG_REPORT);mContext.sendOrderedBroadcast(intent, null);return -1;} else if (SHOW_PROCESSES_ON_ALT_MENU &&(metaState & KeyEvent.META_ALT_ON) == KeyEvent.META_ALT_ON) {Intent service = new Intent();service.setClassName(mContext, "com.android.server.LoadAverageService");ContentResolver res = mContext.getContentResolver();boolean shown = Settings.System.getInt(res, Settings.System.SHOW_PROCESSES, 0) != 0;if (!shown) {mContext.startService(service);} else {mContext.stopService(service);}Settings.System.putInt(res, Settings.System.SHOW_PROCESSES, shown ? 0 : 1);return -1;}}} else if (keyCode == KeyEvent.KEYCODE_SEARCH) {if (down) {if (repeatCount == 0) {mSearchKeyShortcutPending = true;mConsumeSearchKeyUp = false;}} else {mSearchKeyShortcutPending = false;if (mConsumeSearchKeyUp) {mConsumeSearchKeyUp = false;return -1;}}return 0;} else if (keyCode == KeyEvent.KEYCODE_APP_SWITCH) {if (down && repeatCount == 0 && !keyguardOn) {showOrHideRecentAppsDialog(RECENT_APPS_BEHAVIOR_SHOW_OR_DISMISS);}return -1;} else if (keyCode == KeyEvent.KEYCODE_ASSIST) {if (down) {if (repeatCount == 0) {mAssistKeyLongPressed = false;} else if (repeatCount == 1) {mAssistKeyLongPressed = true;if (!keyguardOn) {launchAssistLongPressAction();}}} else {if (mAssistKeyLongPressed) {mAssistKeyLongPressed = false;} else {if (!keyguardOn) {launchAssistAction();}}}return -1;}// Shortcuts are invoked through Search+key, so intercept those here// Any printing key that is chorded with Search should be consumed// even if no shortcut was invoked.  This prevents text from being// inadvertently inserted when using a keyboard that has built-in macro// shortcut keys (that emit Search+x) and some of them are not registered.if (mSearchKeyShortcutPending) {final KeyCharacterMap kcm = event.getKeyCharacterMap();if (kcm.isPrintingKey(keyCode)) {mConsumeSearchKeyUp = true;mSearchKeyShortcutPending = false;if (down && repeatCount == 0 && !keyguardOn) {Intent shortcutIntent = mShortcutManager.getIntent(kcm, keyCode, metaState);if (shortcutIntent != null) {shortcutIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);try {mContext.startActivity(shortcutIntent);} catch (ActivityNotFoundException ex) {Slog.w(TAG, "Dropping shortcut key combination because "+ "the activity to which it is registered was not found: "+ "SEARCH+" + KeyEvent.keyCodeToString(keyCode), ex);}} else {Slog.i(TAG, "Dropping unregistered shortcut key combination: "+ "SEARCH+" + KeyEvent.keyCodeToString(keyCode));}}return -1;}}// Invoke shortcuts using Meta.if (down && repeatCount == 0 && !keyguardOn&& (metaState & KeyEvent.META_META_ON) != 0) {final KeyCharacterMap kcm = event.getKeyCharacterMap();if (kcm.isPrintingKey(keyCode)) {Intent shortcutIntent = mShortcutManager.getIntent(kcm, keyCode,metaState & ~(KeyEvent.META_META_ON| KeyEvent.META_META_LEFT_ON | KeyEvent.META_META_RIGHT_ON));if (shortcutIntent != null) {shortcutIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);try {mContext.startActivity(shortcutIntent);} catch (ActivityNotFoundException ex) {Slog.w(TAG, "Dropping shortcut key combination because "+ "the activity to which it is registered was not found: "+ "META+" + KeyEvent.keyCodeToString(keyCode), ex);}return -1;}}}// Handle application launch keys.if (down && repeatCount == 0 && !keyguardOn) {String category = sApplicationLaunchKeyCategories.get(keyCode);if (category != null) {Intent intent = Intent.makeMainSelectorActivity(Intent.ACTION_MAIN, category);intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);try {mContext.startActivity(intent);} catch (ActivityNotFoundException ex) {Slog.w(TAG, "Dropping application launch key because "+ "the activity to which it is registered was not found: "+ "keyCode=" + keyCode + ", category=" + category, ex);}return -1;}}// Display task switcher for ALT-TAB or Meta-TAB.if (down && repeatCount == 0 && keyCode == KeyEvent.KEYCODE_TAB) {if (mRecentAppsDialogHeldModifiers == 0 && !keyguardOn) {final int shiftlessModifiers = event.getModifiers() & ~KeyEvent.META_SHIFT_MASK;if (KeyEvent.metaStateHasModifiers(shiftlessModifiers, KeyEvent.META_ALT_ON)|| KeyEvent.metaStateHasModifiers(shiftlessModifiers, KeyEvent.META_META_ON)) {mRecentAppsDialogHeldModifiers = shiftlessModifiers;showOrHideRecentAppsDialog(RECENT_APPS_BEHAVIOR_EXIT_TOUCH_MODE_AND_SHOW);return -1;}}} else if (!down && mRecentAppsDialogHeldModifiers != 0&& (metaState & mRecentAppsDialogHeldModifiers) == 0) {mRecentAppsDialogHeldModifiers = 0;showOrHideRecentAppsDialog(keyguardOn ? RECENT_APPS_BEHAVIOR_DISMISS :RECENT_APPS_BEHAVIOR_DISMISS_AND_SWITCH);}// Handle keyboard language switching.if (down && repeatCount == 0&& (keyCode == KeyEvent.KEYCODE_LANGUAGE_SWITCH|| (keyCode == KeyEvent.KEYCODE_SPACE&& (metaState & KeyEvent.META_CTRL_MASK) != 0))) {int direction = (metaState & KeyEvent.META_SHIFT_MASK) != 0 ? -1 : 1;mWindowManagerFuncs.switchKeyboardLayout(event.getDeviceId(), direction);return -1;}if (mLanguageSwitchKeyPressed && !down&& (keyCode == KeyEvent.KEYCODE_LANGUAGE_SWITCH|| keyCode == KeyEvent.KEYCODE_SPACE)) {mLanguageSwitchKeyPressed = false;return -1;}// Let the application handle the key.return 0;}



这篇关于Android4.1中会被系统拦截的InputEent的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/561846

相关文章

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、

软考系统规划与管理师考试证书含金量高吗?

2024年软考系统规划与管理师考试报名时间节点: 报名时间:2024年上半年软考将于3月中旬陆续开始报名 考试时间:上半年5月25日到28日,下半年11月9日到12日 分数线:所有科目成绩均须达到45分以上(包括45分)方可通过考试 成绩查询:可在“中国计算机技术职业资格网”上查询软考成绩 出成绩时间:预计在11月左右 证书领取时间:一般在考试成绩公布后3~4个月,各地领取时间有所不同

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

基于 YOLOv5 的积水检测系统:打造高效智能的智慧城市应用

在城市发展中,积水问题日益严重,特别是在大雨过后,积水往往会影响交通甚至威胁人们的安全。通过现代计算机视觉技术,我们能够智能化地检测和识别积水区域,减少潜在危险。本文将介绍如何使用 YOLOv5 和 PyQt5 搭建一个积水检测系统,结合深度学习和直观的图形界面,为用户提供高效的解决方案。 源码地址: PyQt5+YoloV5 实现积水检测系统 预览: 项目背景