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;做中学感悟预备…

android网络测试上传速度慢,Android:如何获得互联网连接上传速度和延迟?

要获取当前网络连接类型&#xff1a;TelephonyManager telephonyManager (TelephonyManager) getSystemService(Context.TELEPHONY_SERVICE);int networkType telephonyManager.getNetworkType();并为延迟&#xff1a;String host "172.16.0.2";int timeOut 3000…

复杂性科学与还原论

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

ios math 那个头文件_C++ 头文件系列(ios)

1 简介我们都知道&#xff0c;平时常用的那些标准流&#xff0c;诸如iostream、ofstream、ifstream等等&#xff0c;其实都是对应的basic_XXX模版的实例类。 而这些basic_XXX类模版又都是继承自同一个基类模版----basic_ios。2 basic_ios模版定义这个基类模版应该是出于可重用的…

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;才能精确…

android getdecorview 出现空指针,android – 为什么我从TabWidget得到一个空指针异常?...

我正在编写一个android程序,其中我有一个使用制表符的活动.活动public class UnitActivity extends TabActivity {Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);TabHost tabHost getTabHost();TabSpec spec;Resources res …

react多个网络请求_如何优雅的在react-hook中进行网络请求

本文将介绍如何在使用React Hook进行网络请求及注意事项。前言Hook是在React 16.8.0版本中新加入的特性&#xff0c;同时在React-Native的0.59.0版本及以上进行了支持&#xff0c;使用hook可以不用class的方式的方式使用state&#xff0c;及类似的生命周期特性。本片文章通过简…

JS之代理模式

1 <!DOCTYPE html>2 <html lang"en">3 <head>4 <meta charset"UTF-8">5 <title>Document</title>6 </head>7 <body>8 <script>9 //1,买家 10 function maijia (argument) …

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

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

博客开篇。

【README.MD】: this is a blog for 13203361793163.com. just about HTML 、Css 、 JavaScript and a little PHP. Practice is most important to learn and master all knowledge, only in this way , can we make our career better and better . 转载于:https://www.cnbl…

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

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

itext html 转换 pdf文件,利用itext实现html转pdf文档

Link: http://keyknight.blog.163.com/blog/static/366378402009431104941637/利用itext实现html转pdf文档的代码实在是太简单了&#xff1a;Document pdf new Document(PageSize.A4, 50, 50, 50, 50);try {PdfWriter.getInstance(pdf, new FileOutputStream("d:/t.pdf&q…

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

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

python gil锁问题_Python的GIL与线程安全问题?[closed]

由于一些历史原因&#xff0c;CPython的GIL使得Python同一个时刻只能有一个线程在运行&#xff0c;这使得线程只能用于IO型任务&#xff0c;虽然异步更胜一筹。但是既然同一个时刻只能有一个线程运行那为什么还会有线程安全&#xff0c;线程非安全之类的概念。threading模块提供…

html5页面主题,HTML5页面开发笔记

页面由设计决定, 所以首先聊聊设计稿前戏, 页面设计规范PSD设计稿的图层 "分组" 以及图层 "命名":设计稿中的每一个元素, 比如 唱片机, 设计师需要将所有属于唱片机的图层全部打到一个图层组里, 并且命名这个图层组为唱片机.这样开发人员可以快速的去单独导…

AC日记——Mato的文件管理 bzoj 3289

3289 思路&#xff1a; 莫队求区间逆序对个数&#xff0c;树状数组维护&#xff1b; 代码&#xff1a; #include <bits/stdc.h> using namespace std; #define maxn 50005 int bel[maxn],blo; struct QueryType {int l,r,id;bool operator<(const QueryType pos)const…

Python 什么时候会被取代?

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