android外接键盘打汉字,Android在外接物理键盘时,如何强制调用系统软键盘

Android在外接物理键盘时,如何强制调用系统软键盘?

第一次写,写的不好请见谅

参考:

物理键盘映射过程:

手机/system/usr/keylayout/*.kl :内核将keyCode映射成有含义的字符串

KeycodeLabels.h : framework 将字符串映射成keyEvent的keyCode

frameworks/…/res/values/attrs.xml

a379efac76ea

a379efac76ea

a379efac76ea

一、问题描述:

当平板连接上蓝牙扫描枪(外接物理键盘)时候,不能弹出软键盘输入,需要打开系统的输入法选择界面关闭硬件物理键盘后才能调用弹出系统软键盘;

理想效果:

在平板连接上蓝牙扫描枪后仍可以调用系统软键盘输入,将系统的物理键盘默认设置为关闭状态,或不需要开启关闭物理键盘,

1.首先:你要知道AndroidManifest.xml文件。这里这里有的信息对于理解程序又很大的意义。

2.学会使用grep命令。修改系统的源代码时候这个很重要,

3.当想修改一个程序时,先找到这个程序的位置,大部分只要修改framework 和package 两个文件夹下的内容

4.关键字,例如要修改statuBars。先使用hierarchyviewer查看statuBar属于那个部分。

5.根据图标,使用grep在framework中查找对应的位置。

6.然后就是修改程序了。

frameworks/base/services/Java/com/android/server/wm/WindowManagerService.java

关键代码:行6618 computeScreenConfigurationLocked()方法中

[java] view plaincopy在CODE上查看代码片派生到我的代码片

boolean hardKeyboardAvailable = config.keyboard!= Configuration.KEYBOARD_NOKEYS;if (hardKeyboardAvailable != mHardKeyboardAvailable) {                  mHardKeyboardAvailable = hardKeyboardAvailable;mHardKeyboardEnabled = !hardKeyboardAvailable;mH.removeMessages(H.REPORT_HARD_KEYBOARD_STATUS_CHANGE);mH.sendEmptyMessage(H.REPORT_HARD_KEYBOARD_STATUS_CHANGE);}              if (!mHardKeyboardEnabled) {                  config.keyboard= Configuration.KEYBOARD_NOKEYS;}

将mHardKeyboardEnabled直接改成false

这样改软键盘是能用但是物理键盘是用不了的

最后研究代码frameworks\base\services\core\java\com\android\server\wm\WindowManagerService.java

如果把updateShowImeWithHardKeyboard方法中的showImeWithHardKeyboard变量直接置为true,则可以实现软键盘与物理键盘的同时使用,

但此举修改影响范围很大,不推荐。

publicvoidupdateShowImeWithHardKeyboard() {//modified by Janning for enble the HardKeyboard startfinalbooleanshowImeWithHardKeyboard = Settings.Secure.getIntForUser(                mContext.getContentResolver(), Settings.Secure.SHOW_IME_WITH_HARD_KEYBOARD,0,                mCurrentUserId) ==1;//final boolean showImeWithHardKeyboard = true;//modified by Janning for enble the HardKeyboard endsynchronized(mWindowMap) {if(mShowImeWithHardKeyboard != showImeWithHardKeyboard) {                mShowImeWithHardKeyboard = showImeWithHardKeyboard;                mH.sendEmptyMessage(H.SEND_NEW_CONFIGURATION);            }        }    }

后续继续研究代码发现在WindowManagerService.java的computeScreenConfigurationLocked方法中有通过判断当前物理键盘类型来控制是否同时启用软件盘的处理逻辑:

boolean computeScreenConfigurationLocked(Configuration config) {        if (!mDisplayReady) {            return false;}        // TODO(multidisplay): For now, apply Configuration to main screen only.        final DisplayContent displayContent = getDefaultDisplayContentLocked();// Use the effective"visual"dimensions based on current rotation        final boolean rotated = (mRotation == Surface.ROTATION_90                || mRotation == Surface.ROTATION_270);final int realdw = rotated ?                displayContent.mBaseDisplayHeight: displayContent.mBaseDisplayWidth;final int realdh = rotated ?                displayContent.mBaseDisplayWidth: displayContent.mBaseDisplayHeight;int dw = realdw;int dh = realdh;if (mAltOrientation) {            if (realdw > realdh) {                // Turn landscape into portrait.                int maxw = (int)(realdh/1.3f);if (maxw < realdw) {                    dw = maxw;}            } else {                // Turn portrait into landscape.                int maxh = (int)(realdw/1.3f);if (maxh < realdh) {                    dh = maxh;}            }        }        if (config != null) {            config.orientation= (dw <= dh) ? Configuration.ORIENTATION_PORTRAIT :                    Configuration.ORIENTATION_LANDSCAPE;}        // Update application display metrics.        final int appWidth = mPolicy.getNonDecorDisplayWidth(dw, dh, mRotation);final int appHeight = mPolicy.getNonDecorDisplayHeight(dw, dh, mRotation);final DisplayInfo displayInfo = displayContent.getDisplayInfo();synchronized(displayContent.mDisplaySizeLock) {            displayInfo.rotation= mRotation;displayInfo.logicalWidth= dw;displayInfo.logicalHeight= dh;displayInfo.logicalDensityDpi= displayContent.mBaseDisplayDensity;displayInfo.appWidth= appWidth;displayInfo.appHeight= appHeight;displayInfo.getLogicalMetrics(mRealDisplayMetrics,                    CompatibilityInfo.DEFAULT_COMPATIBILITY_INFO, null);displayInfo.getAppMetrics(mDisplayMetrics);mDisplayManagerInternal.setDisplayInfoOverrideFromWindowManager(                    displayContent.getDisplayId(), displayInfo);}        if (false) {            Slog.i(TAG,"Set app display size: "+ appWidth +" x "+ appHeight);}        final DisplayMetrics dm = mDisplayMetrics;mCompatibleScreenScale = CompatibilityInfo.computeCompatibleScaling(dm,                mCompatDisplayMetrics);if (config != null) {            config.screenWidthDp= (int)(mPolicy.getConfigDisplayWidth(dw, dh, mRotation)                    / dm.density);config.screenHeightDp= (int)(mPolicy.getConfigDisplayHeight(dw, dh, mRotation)                    / dm.density);computeSizeRangesAndScreenLayout(displayInfo, rotated, dw, dh, dm.density, config);config.compatScreenWidthDp= (int)(config.screenWidthDp/ mCompatibleScreenScale);config.compatScreenHeightDp= (int)(config.screenHeightDp/ mCompatibleScreenScale);config.compatSmallestScreenWidthDp= computeCompatSmallestWidth(rotated, dm, dw, dh);config.densityDpi= displayContent.mBaseDisplayDensity;// Update the configuration based on available input devices, lid switch,            //andplatform configuration.            config.touchscreen= Configuration.TOUCHSCREEN_NOTOUCH;config.keyboard= Configuration.KEYBOARD_NOKEYS;config.navigation= Configuration.NAVIGATION_NONAV;int keyboardPresence =0;int navigationPresence =0;final InputDevice[] devices = mInputManager.getInputDevices();final int len = devices.length;for (int i =0; i < len; i++) {InputDevice device = devices[i];if (!device.isVirtual()) {                    final int sources = device.getSources();final int presenceFlag = device.isExternal() ?                            WindowManagerPolicy.PRESENCE_EXTERNAL :                                    WindowManagerPolicy.PRESENCE_INTERNAL;if (mIsTouchDevice) {                        if ((sources & InputDevice.SOURCE_TOUCHSCREEN) ==                                InputDevice.SOURCE_TOUCHSCREEN) {                            config.touchscreen= Configuration.TOUCHSCREEN_FINGER;}                    } else {                        config.touchscreen= Configuration.TOUCHSCREEN_NOTOUCH;}                    if ((sources & InputDevice.SOURCE_TRACKBALL) == InputDevice.SOURCE_TRACKBALL) {                        config.navigation= Configuration.NAVIGATION_TRACKBALL;navigationPresence |= presenceFlag;} else if ((sources & InputDevice.SOURCE_DPAD) == InputDevice.SOURCE_DPAD                            && config.navigation== Configuration.NAVIGATION_NONAV) {                        config.navigation= Configuration.NAVIGATION_DPAD;navigationPresence |= presenceFlag;}                    // 判断该物理设备的类型, InputDevice.KEYBOARD_TYPE_ALPHABETIC 是表示物理键盘设备                    if (device.getKeyboardType() == InputDevice.KEYBOARD_TYPE_ALPHABETIC) {                        config.keyboard= Configuration.KEYBOARD_QWERTY;keyboardPresence |= presenceFlag;}                    // 获取物理设备名称,判断是否是指定的名称,如果是则把 config.keyboard// 的属性置为 Configuration.KEYBOARD_NOKEYS ,如此则可以同时兼容软键盘                    // 物理键盘与软键盘可以同时启用                    //Addby Janning start                    // for show IME with HardKeyboard                    if (device.getName().equals("XXX-vinput-keypad")) {                        Slog.w("SLCODE","the hard device name is: "+ device.getName());config.keyboard= Configuration.KEYBOARD_NOKEYS;}                    //Addby Janning end                }            }            if (config.navigation== Configuration.NAVIGATION_NONAV && mHasPermanentDpad) {                config.navigation= Configuration.NAVIGATION_DPAD;navigationPresence |= WindowManagerPolicy.PRESENCE_INTERNAL;}            // Determine whether a hard keyboard is availableandenabled.            boolean hardKeyboardAvailable = config.keyboard!= Configuration.KEYBOARD_NOKEYS;if (hardKeyboardAvailable != mHardKeyboardAvailable) {                mHardKeyboardAvailable = hardKeyboardAvailable;mH.removeMessages(H.REPORT_HARD_KEYBOARD_STATUS_CHANGE);mH.sendEmptyMessage(H.REPORT_HARD_KEYBOARD_STATUS_CHANGE);}            if (mShowImeWithHardKeyboard) {                config.keyboard= Configuration.KEYBOARD_NOKEYS;}            // Let the policy update hidden states.            config.keyboardHidden= Configuration.KEYBOARDHIDDEN_NO;config.hardKeyboardHidden= Configuration.HARDKEYBOARDHIDDEN_NO;config.navigationHidden= Configuration.NAVIGATIONHIDDEN_NO;mPolicy.adjustConfigurationLw(config, keyboardPresence, navigationPresence);}        return true;}    public boolean isHardKeyboardAvailable() {        synchronized (mWindowMap) {            return mHardKeyboardAvailable;}    }    public void updateShowImeWithHardKeyboard() {        // 此处修改也可以实现物理键盘与软键盘的同时启用,即把showImeWithHardKeyboard 直接置为 true,        // 但此方法影响太大,不推荐该方案,建议根据设备名称判断 修改config.keyboard属性值(代码见上文)        //changed by Janning start        //modified by Janning for enble the HardKeyboard start        final boolean showImeWithHardKeyboard = Settings.Secure.getIntForUser(                mContext.getContentResolver(), Settings.Secure.SHOW_IME_WITH_HARD_KEYBOARD,0,                mCurrentUserId) ==1;//final boolean showImeWithHardKeyboard = true;//modified by Janning for enble the HardKeyboard end        //changed by Janning end        synchronized (mWindowMap) {            if (mShowImeWithHardKeyboard != showImeWithHardKeyboard) {                mShowImeWithHardKeyboard = showImeWithHardKeyboard;mH.sendEmptyMessage(H.SEND_NEW_CONFIGURATION);}        }    }

当插入物理键盘后通知栏会弹出相应的选择键盘布局通知,对于该通知可以选择隐藏:

根据字符串查找到是在 frameworks\base\services\core\java\com\android\server\input\InputManagerService.java 中调用显示该通知的,

进一步分析代码发现是在 deliverInputDevicesChanged 方法中控制通知的显示。

InputManagerService.java

privatevoiddeliverInputDevicesChanged(InputDevice[] oldInputDevices) {        。。。。。。。。。。。。。。。。if(missingLayoutForExternalKeyboard) {if(missingLayoutForExternalKeyboardAdded) {if(multipleMissingLayoutsForExternalKeyboardsAdded) {// We have more than one keyboard missing a layout, so drop the// user at the generic input methods page so they can pick which// one to set.showMissingKeyboardLayoutNotification(null);                    }else{// 如果只插入了一个物理键盘则判断该物理键盘的名称是否是指定的,如果是则不让其显示键盘布局的通知// Modify by Janning beginif(keyboardMissingLayout !=null&& !keyboardMissingLayout.getName().equals("XXXX-vinput-keypad")) {                            showMissingKeyboardLayoutNotification(keyboardMissingLayout);                        }// Modify by Janning end}                }            }elseif(mKeyboardLayoutNotificationShown) {                hideMissingKeyboardLayoutNotification();            }        }        mTempFullKeyboards.clear();    }

操作步骤(不具体说明):

1.下载好ubuntu系统之后。

2.在找到sdk位置(就是你的SDK 找到你用的那个系统,在到ubuntu修改)。

………………………..(做起来不是这么简单)

3.再用ub系统上生成.jar,再放在SDK里面

有问题:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/488211.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

20155204 2016-2017-2《Java程序设计》课程总结

20155204 2016-2017-2《Java程序设计》课程总结 目录 作业链接汇总作业总结实验报告链接汇总代码托管链接课堂项目实践学习经验问卷调查链接二维码&#xff08;按顺序&#xff09;每周作业链接汇总 预备作业1&#xff1a;我对师生关系的思考预备作业2&#xff1a;做中学感悟预备…

复杂性科学与还原论

来源&#xff1a;陶勇科学网博客1984年&#xff0c;两位诺贝尔物理学奖得主盖尔曼&#xff08;Murray Gell-mann&#xff09;、安德森&#xff08;Philip Anderson&#xff09;和诺贝尔经济学奖得主阿罗&#xff08;Kenneth Arrow&#xff09;聚集了一批从事物理、经济、生物、…

Nim游戏(初谈博弈)

通常的Nim游戏的定义是这样的&#xff1a;有若干堆石子&#xff0c;每堆石子的数量都是有限的&#xff0c;合法的移动是“选择一堆石子并拿走若干颗&#xff08;不能不拿&#xff09;”&#xff0c; 如果轮到某个人时所有的石子堆都已经被拿空了&#xff0c;则判负&#xff08;…

android 如何使用aar,Android Studio如何使用aar依赖包?

ps:2013-12-25 号更新,升级到0.4以后 这种方法已经完美使用&#xff01;因为项目里面要用到actionbarsherlock&#xff0c;所以研究了一下如何导入到android studio中。arr(Android Archive)&#xff1a;名字是谷歌到的&#xff0c;至于中文叫什么我也不知道。不过好像依赖都要…

第二百七十九节,MySQL数据库-pymysql模块操作数据库

MySQL数据库-pymysql模块操作数据库 pymysql模块是python操作数据库的一个模块 connect()创建数据库链接,参数是连接数据库需要的连接参数使用方式&#xff1a;   模块名称.connect()   参数&#xff1a;   host数据库ip   port数据库端口   user数据库用户名   pa…

宇航员能用GPS在月球上导航吗?美国宇航局的科学家给出了肯定答案

Illustration: NASA来源&#xff1a;IEEE电气电子工程师如果宇航员按照美国宇航局Artemis计划登录月球&#xff0c;他们的主要目标之一就是在月球南极附近的陨石坑中挖冰&#xff0c;这些冰层不仅对水有用&#xff0c;而且可以分解成氢和氧。但它们需要导航&#xff0c;才能精确…

猴子会照镜子吗?科学家的这一研究意义非凡!

来源&#xff1a;中国经济大讲堂本期提要在《中国经济大讲堂》演讲中&#xff0c;中国科学院院士、中科院脑科学与智能技术卓越创新中心学术主任蒲慕明指出&#xff0c;自闭症患者、严重脑疾病可能伴有自我意识损伤的现象。我们通过各种训练方法&#xff0c;可以使猴子学会识别…

Science | 闵明玮等揭示细胞如何做出命运决定

来源&#xff1a;BioArt细胞命运决定我们体内的每个细胞都会面临着一个关乎命运的选择&#xff1a;要不要复制产生一个新的细胞。这个重大选择关系到人体发育和维持稳态等生理过程&#xff0c;因此它的失调也与癌症等疾病的发生发展有着密切联系。在人体中&#xff0c;大部分的…

图解机器学习:人人都能懂的算法原理

来源&#xff1a;机器学习研究组订阅号算法公式挺费神&#xff0c;机器学习太伤人。任何一个刚入门机器学习的人都会被复杂的公式和晦涩难懂的术语吓到。但其实&#xff0c;如果有通俗易懂的图解&#xff0c;理解机器学习的原理就会非常容易。本文整理了一篇博客文章的内容&…

Python 什么时候会被取代?

来源&#xff1a;CSDN译者 | 弯月&#xff0c;责编 | 郭芮以下是译文&#xff1a; Python经过了几十年的努力才得到了编程社区的赏识。自2010年以来&#xff0c;Python得到了蓬勃发展&#xff0c;并最终超越了C、C#、Java和JavaScript。但是&#xff0c;这种趋势将持续到什么时…

Android开发艺术探究Note

第一章&#xff1a;Activity的生命周期和启动模式 生命周期onPause表示activity正在停止&#xff0c;onPaus必须先执行完&#xff08;栈顶的activity&#xff09;&#xff0c;新的activity的onResume才会执行。onStop表示activity即将停止&#xff08;透明不会执行&#xff09;…

烧脑:宇宙时空结构是量子纠错码

来源&#xff1a;Future远见现在越来越多的理论物理学家开始相信&#xff0c;时空起源于纠缠的量子信息。粗略地讲&#xff0c;时空中最重要的“相邻”概念&#xff0c;可以认为是起源于量子纠缠&#xff1a;有纠缠就是相邻&#xff0c;没有纠缠就是不相邻。如果你相信这一观念…

李德毅院士:通用人工智能十问

来源&#xff1a;学术头条共识&#xff1a;智能是学习的能力&#xff0c;以及解释、解决问题的能力&#xff1b;人工智能是脱离生命体的智能&#xff0c;是人类智能的体外延伸&#xff1b;通用人工智能通过不断学习&#xff0c;积累本领&#xff0c;进化成长&#xff0c;能够面…

咸阳高考成绩查询2021,2021咸阳市地区高考成绩排名查询,咸阳市高考各高中成绩喜报榜单...

距离2018年高考还有不到一个月的时间了&#xff0c;很多人在准备最后冲刺的同时&#xff0c;也在关心高考成绩。2018各地区高考成绩排名查询,高考各高中成绩喜报榜单尚未公布&#xff0c;下面是往年各地区高考成绩排名查询,高考各高中成绩喜报榜单&#xff0c;想要了解同学可以…

云计算与人工智能

来自&#xff1a;cnblogs.com/popsuper1982/p/8505203.html我今天要讲这三个话题&#xff0c;一个是云计算&#xff0c;一个大数据&#xff0c;一个人工智能&#xff0c;我为什么要讲这三个东西呢&#xff1f;因为这三个东西现在非常非常的火&#xff0c;它们之间好像互相有关系…

泸西一中2021高考成绩查询,云南红河州四所好高中,红河州一中一本率领先,建水一中不容小觑...

红河州地处我国西南&#xff0c;是一个常住人口超过467万的多民族聚居边疆自治州(地级行政区划)&#xff0c;下辖4市(县级)、9县(其中3个自治县)&#xff0c;经济总量在全省仅次于昆明与曲靖&#xff0c;是一个综合实力较强的自治州。红河州的基础教育实力相当不错&#xff0c;…

python 遍历list_Python列表遍历知多少

遍历列表中的所有元素是常用的一种操作&#xff0c;在遍历的过程中可以完成查询、处理等功能。在生活中&#xff0c;如果想要去商场买一件衣服&#xff0c;就需要在商场中逛一圈&#xff0c;看是否有想要买的衣服。逛商场的过程相当于列表的遍历操作。在Python中遍历列表的方法…

自我监督学习:AI技术的未来发展方向

尽管深度学习已经在人工智能领域做出重大贡献&#xff0c;但这项技术本身仍存在一项致命缺陷&#xff1a;需要大量数据的加持。来源丨The Next Web尽管深度学习已经在人工智能领域做出重大贡献&#xff0c;但这项技术本身仍存在一项致命缺陷&#xff1a;需要大量数据的加持。深…

vue8 生命周期

<!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>智能社——http://www.zhinengshe.com</title><meta name"viewport" content"widthdevice-width, initial-scale1.0, maximum…

AI无间道!清华AI团队推出AI安全平台,欺骗顶尖人脸算法后又强势修复漏洞

随着人工智能技术的发展&#xff0c;人工智能在很多场景里正逐渐替代或协作着人类的各种劳动&#xff0c;它们可以成为人类的眼睛、耳朵、手臂甚至大脑。其中&#xff0c;机器视觉作为AI时代的基础技术&#xff0c;其背后的AI算法一直是各科技巨头和创业公司共同追逐的热点。然…