Android 中的自定义键盘键宽

Custom keyboard key width in Android

当我试图实现类似于 Google 键盘的布局时,我正在使用自定义键盘。一切正常,因为整个键盘在大写和小写的情况下都已成功输入,但我在键盘布局设计方面遇到了问题。

我正在尝试实现以下布局:

使用以下代码:

<Keyboard xmlns:android="http://schemas.android.com/apk/res/android"
    android:keyWidth="10%p"
    android:horizontalGap="0px"
    android:verticalGap="0px"
    android:keyHeight="@dimen/_54sdp">
    <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" android:horizontalGap="5%p"/>
        <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"/>
    </Row>
    <Row>
        <Key android:codes="-1" android:keyIcon="@drawable/sym_keyboard_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="-5" android:keyIcon="@drawable/sym_keyboard_delete" android:keyWidth="20%p" android:isRepeatable="true"/>
    </Row>
    <Row android:rowEdgeFlags="bottom">
        <Key android:codes="-2" android:keyLabel="@string/key_label_symbols" android:horizontalGap="15%p" android:keyEdgeFlags="left" />
        <Key android:codes="47" android:keyLabel="/" android:horizontalGap="10%p"/>
        <Key android:codes="32" android:keyIcon="@drawable/sym_keyboard_space" android:keyWidth="50%p" android:isRepeatable="true"/>
        <Key android:codes="46" android:keyLabel="." android:horizontalGap="10%p"/>
        <Key android:codes="-4" android:keyIcon="@drawable/sym_keyboard_done" android:horizontalGap="15%p" android:keyEdgeFlags="right"/>
    </Row>
</Keyboard>

问题出在底行,其中 spacebar、?123 和 return 键的键宽未按预期调整。

暂时忽略可绘制对象。我无法获得适当的间距,因为我希望 space 栏最大,其他拆分如上面的布局所示。

有什么想法..??

试试这个:

<Row android:rowEdgeFlags="bottom">
<Key android:codes="-2" android:keyLabel="123" android:keyWidth="10%p"/>
<Key android:codes="44" android:keyLabel="," android:keyWidth="12.5%p"/>
<Key android:codes="32" android:isRepeatable="true" android:keyLabel="SPACE" android:keyWidth="50%p"/>
<Key android:codes="46" android:keyLabel="." android:keyWidth="12.5%p"/>
<Key android:codes="10" android:keyWidth="15%p" android:keyIcon="@drawable/ic_keyboard_return" android:keyEdgeFlags="right"/>
</Row>

试试这个...

<?xml version="1.0" encoding="utf-8"?>
 <Keyboard
   xmlns:android="http://schemas.android.com/apk/res/android"
   android:keyHeight="@dimen/key_height"
   android:keyWidth="10%p"
   android:horizontalGap="2dp"
   android:verticalGap="10px">
 <Row>
    <Key
        android:keyEdgeFlags="left"
        android:keyLabel="q"
        android:popupCharacters="1"
        android:popupKeyboard="@xml/popup_keyboard" />
    <Key
        android:keyLabel="w"
        android:popupCharacters="2"
        android:popupKeyboard="@xml/popup_keyboard" />
    <Key
        android:keyLabel="e"
        android:popupCharacters="3ëèéê"
        android:popupKeyboard="@xml/popup_keyboard" />
    <Key
        android:keyLabel="r"
        android:popupCharacters="4"
        android:popupKeyboard="@xml/popup_keyboard" />
    <Key
        android:keyLabel="t"
        android:popupCharacters="5"
        android:popupKeyboard="@xml/popup_keyboard" />
    <Key
        android:keyLabel="y"
        android:popupCharacters="6"
        android:popupKeyboard="@xml/popup_keyboard" />
    <Key
        android:keyLabel="u"
        android:popupCharacters="7úùûū"
        android:popupKeyboard="@xml/popup_keyboard" />
    <Key
        android:keyLabel="i"
        android:popupCharacters="8"
        android:popupKeyboard="@xml/popup_keyboard" />
    <Key
        android:keyLabel="o"
        android:popupCharacters="9œôóō"
        android:popupKeyboard="@xml/popup_keyboard" />
    <Key
        android:horizontalGap="3%p"
        android:keyEdgeFlags="right"
        android:keyLabel="p"
        android:popupCharacters="0"
        android:popupKeyboard="@xml/popup_keyboard" />
</Row>

<Row>
    <Key
        android:horizontalGap="1.2%p"
        android:keyEdgeFlags="left"
        android:keyLabel="a"
        android:popupCharacters="æáãäāȁȃå"
        android:popupKeyboard="@xml/popup_keyboard" />
    <Key
        android:keyLabel="s"
        android:popupCharacters="ϐ"
        android:popupKeyboard="@xml/popup_keyboard" />
    <Key android:keyLabel="d" />
    <Key android:keyLabel="f" />
    <Key android:keyLabel="g" />
    <Key android:keyLabel="h" />
    <Key android:keyLabel="j" />
    <Key android:keyLabel="k" />
    <Key
        android:keyEdgeFlags="right"
        android:keyLabel="l" />
</Row>

<Row>
    <Key
        android:codes="-1"
        android:isModifier="true"
        android:isSticky="true"
        android:keyEdgeFlags="left"
        android:keyIcon="@drawable/ic_keyboard_capslock_black_24dp"
        android:keyWidth="15%p" />
    <Key android:keyLabel="z" />
    <Key android:keyLabel="x" />
    <Key
        android:keyLabel="c"
        android:popupCharacters="ç"
        android:popupKeyboard="@xml/popup_keyboard" />
    <Key android:keyLabel="v" />
    <Key android:keyLabel="b" />
    <Key
        android:keyLabel="n"
        android:popupCharacters="ñ"
        android:popupKeyboard="@xml/popup_keyboard" />
    <Key android:keyLabel="m" />
    <Key
        android:horizontalGap="2.5%p"
        android:codes="-5"
        android:isRepeatable="true"
        android:keyEdgeFlags="right"
        android:keyIcon="@drawable/ic_backspace_black_24dp"
        android:keyWidth="15%p" />
</Row>

<Row android:rowEdgeFlags="bottom">
    <Key
        android:codes="-2"
        android:keyEdgeFlags="left"
        android:keyLabel="\?123"
        android:keyWidth="15%p" />
    <Key
        android:codes="-10000"
        android:keyIcon="@drawable/ic_insert_emoticon_black_24dp" />

   <!-- <Key
        android:codes="-101"
        android:keyIcon="@drawable/ic_language_24dp"
        />-->
    <Key
        android:codes="32"
        android:isRepeatable="true"
        android:keyIcon="@drawable/ic_space_bar_black_24dp"
        android:keyWidth="45%p" />
    <Key
        android:keyLabel="."
        android:keyWidth="15%p"
        android:popupKeyboard="@xml/popup_symbols" />
    <Key
        android:horizontalGap="2.5%p"
        android:codes="10"
        android:keyEdgeFlags="right"
        android:keyIcon="@drawable/ic_next_circle_filled_45dp"
        android:keyWidth="15%p" />
</Row>
</Keyboard>