如何在安卓系统中软键盘上方显示文本

4
我正在尝试在Android中开发自定义软键盘。阅读相关资料后,我无法找到如何在软键盘的顶部显示文本的方法。我的意思是,我想要显示按键数量,而不是从我的软键盘中看到“建议”。我希望能够看到类似于“按键已按下:X”的内容,其中“X”是每次按下新键时更改的数字。
例如,如果我输入以下序列“qwert”,在我的软键盘顶部应该看到类似于“已按下键数:5”的内容。如果然后我按下“y”,则文本必须更新为“已按下键数:6”。
我已经实现了这背后的逻辑。我的意思是,我能够计算按下的按键数,但只是不能像我想要的那样显示它。
有没有办法做到这一点?
谢谢!
编辑:我添加了XML文件,以便您可以查看我目前拥有的内容。
keyboard.xml
<?xml version="1.0" encoding="utf-8"?>
<android.inputmethodservice.KeyboardView
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/keyboard"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:keyPreviewLayout="@layout/preview"
/>

这是作为KeyboardView加载的。然后,我有previel.xml。
<?xml version="1.0" encoding="utf-8"?>
<TextView
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:gravity="center"
    android:background="#FFFF00"
    android:textStyle="bold"
    android:textSize="25sp"
    />

这是针对键盘的模板。最后,

keyboard.xml

<?xml version="1.0" encoding="utf-8"?>
<Keyboard xmlns:android="http://schemas.android.com/apk/res/android"
    android:keyWidth="10%p"
    android:horizontalGap="0px"
    android:verticalGap="0px"
    android:keyHeight="60dp"
    >
    <Row>
        <Key android:codes="49" android:keyLabel="1" android:keyEdgeFlags="left"/>
        <Key android:codes="50" android:keyLabel="2"/>
        <Key android:codes="51" android:keyLabel="3"/>
        <Key android:codes="52" android:keyLabel="4"/>
        <Key android:codes="53" android:keyLabel="5"/>
        <Key android:codes="54" android:keyLabel="6"/>
        <Key android:codes="55" android:keyLabel="7"/>
        <Key android:codes="56" android:keyLabel="8"/>
        <Key android:codes="57" android:keyLabel="9"/>
        <Key android:codes="48" android:keyLabel="0" android:keyEdgeFlags="right"/>
    </Row>
    <Row>
        <Key android:codes="113" android:keyLabel="q" android:keyEdgeFlags="left"/>
        <Key android:codes="119" android:keyLabel="w"/>
        <Key android:codes="101" android:keyLabel="e"/>
        <Key android:codes="114" android:keyLabel="r"/>
        <Key android:codes="116" android:keyLabel="t"/>
        <Key android:codes="121" android:keyLabel="y"/>
        <Key android:codes="117" android:keyLabel="u"/>
        <Key android:codes="105" android:keyLabel="i"/>
        <Key android:codes="111" android:keyLabel="o"/>
        <Key android:codes="112" android:keyLabel="p" android:keyEdgeFlags="right"/>
    </Row>
    <Row>
        <Key android:codes="97" android:keyLabel="a" android:keyEdgeFlags="left"/>
        <Key android:codes="115" android:keyLabel="s"/>
        <Key android:codes="100" android:keyLabel="d"/>
        <Key android:codes="102" android:keyLabel="f"/>
        <Key android:codes="103" android:keyLabel="g"/>
        <Key android:codes="104" android:keyLabel="h"/>
        <Key android:codes="106" android:keyLabel="j"/>
        <Key android:codes="107" android:keyLabel="k"/>
        <Key android:codes="108" android:keyLabel="l"/>
        <Key android:codes="35,64" android:keyLabel="\# \@" android:keyEdgeFlags="right"/>
    </Row>
    <Row>
        <Key android:codes="-1" android:keyLabel="CAPS" android:keyEdgeFlags="left"/>
        <Key android:codes="122" android:keyLabel="z"/>
        <Key android:codes="120" android:keyLabel="x"/>
        <Key android:codes="99" android:keyLabel="c"/>
        <Key android:codes="118" android:keyLabel="v"/>
        <Key android:codes="98" android:keyLabel="b"/>
        <Key android:codes="110" android:keyLabel="n"/>
        <Key android:codes="109" android:keyLabel="m"/>
        <Key android:codes="46" android:keyLabel="."/>
        <Key android:codes="63,33,58" android:keyLabel="\? ! :" android:keyEdgeFlags="right"/>
    </Row>
    <Row android:rowEdgeFlags="bottom">
        <Key android:codes="44" android:keyLabel="," android:keyWidth="10%p"  android:keyEdgeFlags="left"/>
        <Key android:codes="47" android:keyLabel="/" android:keyWidth="10%p" />
        <Key android:codes="32" android:keyLabel="SPACE" android:keyWidth="40%p" android:isRepeatable="true"/>
        <Key android:codes="-5" android:keyLabel="DEL" android:keyWidth="20%p" android:isRepeatable="true"/>
        <Key android:codes="-4" android:keyLabel="DONE" android:keyWidth="20%p" android:keyEdgeFlags="right"/>
    </Row>
</Keyboard>

我的键盘模板。

我使用了这里的示例代码。


你可以使用自定义的 Toast 来展示它,使用自定义的 Toast 可以将其定位在软键盘上方。 - Sanjeev
是的!我考虑过,但这不是我想要做的。我需要一个静态文本视图一直存在。我的意思是,“按键数= x”,必须始终显示,即使我没有在写入。谢谢你的回答! - Kuni24
我假设您正在使用XML布局文件来创建您的软键盘,修改您的XML布局并将TextView放置在顶部,并使其宽度匹配父级。 - Sanjeev
我已经添加了上面的代码。你能帮我看一下吗?你能写一个小的示例代码吗? - Kuni24
在你的keyboard.xml文件中,在android.inputmethodservice.KeyboardView上方放置一个TextView,并尝试将这两个控件放在一个LinearLayout中。 - Sanjeev
你好,当我尝试使用额外元素填充布局时,我的应用程序崩溃了。请问你能分享一下在服务类中如何填充视图的方法吗?谢谢! - Android
1个回答

1
根据L-X的建议,我修改了keyboard.xml。我不知道是否有更好的解决方案,但这对我的目的来说已经很好用了。
以下是我的实现方式。

keyboard.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true">

    <TextView
        android:id="@+id/keypressed"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:text=""
        android:textSize="20dp"
        android:textColor="#ffffff"
        android:background="#000000" />

    <android.inputmethodservice.KeyboardView
        android:id="@+id/keyboard2"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:keyPreviewLayout="@layout/preview" />

</LinearLayout>

现在,我看到的是这样的。

![Keyboard_Photo]1

谢谢!

2
我遇到了同样的问题,请问你能告诉我如何在Simpleime Java类中访问KeyboardView吗? - Pramod Yadav

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接