其他分享
首页 > 其他分享> > 如何在Android KeyboardView中实现涟漪效应?

如何在Android KeyboardView中实现涟漪效应?

作者:互联网

我一直试图找到一种方法来在按下时在KeyboardView键上实现涟漪效果.听起来很简单,但我已经尝试了所有添加涟漪的方法,这些方法适用于其他类型的视图(列表视图,按钮等),但根本没有成功.

我的目标是创建一个数字小键盘,看起来像股票计算器应用程序中的键盘,默认情况下在Lollipop OS中出现:

GitHub(https://github.com/numixproject/com.numix.calculator)中有一个类似的计算器应用程序,它的键盘有一个连锁反应,但是当我读到代码时,它似乎是使用数字键的按钮而不是键盘视图.

我希望使用KeyboardView可以实现连锁效果,因为我的应用程序已经使用KeyboardView实现了自定义数字键盘,我不想将其更改为使用按钮.

我已经尝试将ripple添加为样式中的keyBackground属性,如下所示:

<android.inputmethodservice.KeyboardView
    android:id="@+id/numeric_keypad"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:focusable="true"
    android:focusableInTouchMode="true"
    style="@style/my_numeric_keypad" />

然后在themes.xml中:

<style name="my_numeric_keypad">
    <item name="android:keyTextSize">30dp</item>
    <item name="android:fontFamily">roboto</item>
    <item name="android:keyBackground">@drawable/numeric_keypad_ripple</item>
    <item name="android:keyTextColor">@android:color/white</item>
</style>

然后在drawable-v21文件夹中的numeric_keypad_ripple.xml:

<?xml version="1.0" encoding="UTF-8" ?>
<ripple 
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:color="?android:colorControlHighlight">
    <item android:drawable="@drawable/numeric_keypad_states"/>
</ripple>

numeric_keypad_states.xml是具有按下状态的旧选择器(它曾经被直接声明为keyBackground属性):

<?xml version="1.0" encoding="UTF-8" ?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true" android:drawable="@drawable/numeric_keypad_pressed" />
    <item android:drawable="@drawable/numeric_keypad_normal" />
</selector>

numeric_keypad_pressed.xml和numeric_keypad_normal.xml只是每个特定状态颜色的drawable,就像这样(两者完全相同,只是颜色属性不同):

<?xml version="1.0" encoding="UTF-8" ?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
    <item>
        <shape android:shape="rectangle">
            <solid android:color="@color/numeric_keypad_pressed_color"/>
        </shape>
    </item>
</layer-list>

我认为上面的方法会起作用;但事实并非如此.在我的Lollipop设备中,当我按下键盘时,它只显示正常按下的颜色而没有任何波纹,与没有波纹的旧实现没有区别.我已经尝试删除该层,因为我认为它与波纹重叠,但仍然无法正常工作.在纹波上添加掩码也不起作用.

我也尝试使用rippledrawable作为选择器中的按下状态drawable而不是包装选择器,但它仍然无法正常工作.还尝试使用?android:attr / selectableItemBackground而不是rippledrawable但也无效.

哦,我实际上是在Xamarin而不是原生的Android上开发应用程序,但我认为这不应该有任何区别.

感谢任何帮助,谢谢!

解决方法:

只是回答我自己的问题,这样可以帮助别人.

正如@alanv在他的评论中提到的,Ripples不能在KeyboardView中工作,因为它处理渲染和触摸交互的方式不同.

所以答案是否定的,在Android KeyboardView中不可能使用涟漪效应.

希望这可以节省其他人浪费时间试图弄清楚如何向KeyboardView添加涟漪:)

标签:android,android-5-0-lollipop,material-design,rippledrawable
来源: https://codeday.me/bug/20190528/1171673.html