ABV*_*ita 5 android material-design rippledrawable android-5.0-lollipop
我一直试图找到一种方法来在按下时在KeyboardView键上实现涟漪效果.听起来很简单,但我已经尝试了所有添加涟漪的方法,这些方法适用于其他类型的视图(列表视图,按钮等),但根本没有成功.
我的目标是创建一个数字小键盘,看起来像股票计算器应用程序中的键盘,默认情况下在Lollipop OS中出现:

在GitHub中有一个类似的计算器应用程序(https://github.com/numixproject/com.numix.calculator),它的键盘有一个连锁反应,但是当我读到代码时,似乎它使用了数字键的按钮而不是一个KeyboardView.
我希望使用KeyboardView可以实现连锁效果,因为我的应用程序已经使用KeyboardView实现了自定义数字键盘,我不想将其更改为使用按钮.
我尝试将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" />
Run Code Online (Sandbox Code Playgroud)
然后在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>
Run Code Online (Sandbox Code Playgroud)
然后在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>
Run Code Online (Sandbox Code Playgroud)
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>
Run Code Online (Sandbox Code Playgroud)
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>
Run Code Online (Sandbox Code Playgroud)
我认为上面的方法会起作用; 但事实并非如此.在我的Lollipop设备中,当我按下键盘时,它只显示正常按下的颜色而没有任何波纹,没有波纹的旧实现没有区别.我已经尝试删除该层,因为我认为它与波纹重叠,但仍然无法正常工作.在纹波上添加掩码也不起作用.
我也尝试使用rippledrawable作为选择器中的按下状态drawable而不是包装选择器,但它仍然无法正常工作.也尝试使用?android:attr/selectableItemBackground而不是rippledrawable但也无法正常工作.
哦,我实际上是在Xamarin而不是原生的Android上开发应用程序,但我认为这不应该有任何区别.
感谢任何帮助,谢谢!
只是回答我自己的问题,这样可以帮助别人.
正如@alanv在他的评论中提到的,Ripples不能在KeyboardView中工作,因为它处理渲染和触摸交互的方式不同.
所以答案是否定的,在Android KeyboardView中不可能使用涟漪效应.
希望这可以节省其他人浪费时间试图弄清楚如何向KeyboardView添加涟漪:)
| 归档时间: |
|
| 查看次数: |
2600 次 |
| 最近记录: |