EasyKeyBoardView

Introduction: 安卓自定义数字键盘,只需定义布局即可快速实现一个自定义的 KeyboardView,支持底部固定键盘和底部弹出键盘
More: Author   ReportBugs   
Tags:

tag

EasyKeyBoardView 旨在帮助开发者快速实现一个自定义键盘,无需实现键盘内部的输入逻辑,只需关注键盘的 布局和输入后的功能实现即可

功能介绍:

该库是基于安卓原生键盘 API 实现,只需提供布局文件即可快速实现一个自定义键盘,内部已封装好键盘的输入逻辑,并提供了随机数字键盘,每输入 4 位则空格等功能。

本库提供了两种不同的弹出方式:

  • 键盘固定在底部
  • 键盘从底部弹出(如果键盘遮挡了输入框,EasyKeyBoardView 会自动将输入框顶上去)

效果图

图一: 图一

图二: 图二

使用

第一步: 在你的 root build.gradle 中添加

    allprojects {
        repositories {
            ...
            maven { url 'https://jitpack.io' }
        }
    }

在 app build.gradle 中添加

    dependencies {
            implementation 'com.github.Jay-huangjie:EasyKeyBoardView:tag'
    }

最新版本见最上面的版本号标识,注意要加 v 字符哦,例如:implementation 'com.github.Jay-huangjie:EasyKeyBoardView:v1.6'

第二步:

实现固定在底部的键盘

在 xml 中定义:

 <com.jay.easykeyboard.SystemKeyboard
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        keyboard:xmlLayoutResId="@xml/keyboard_numbers" />

其中:

keyboard_numbers是该键盘的布局文件,由使用者自己编写,名称可自取

关于 xml 里 codes 的定义问题,可以参阅ASCI 码对照表来取值,找到对应的图形编码,对应的 10 进制就是我们想要的 codes 了

xml 属性:

属性 作用
keyDrawable 用于设置键盘的按压效果和按钮之间线的粗细颜色等
xmlLayoutResId 设置键盘的布局文件,必须设置
isRandom 是否数字随机

java 属性:

setXmlLayoutResId可用于在 java 中指定布局

setKeyboardUI可用来定义键盘上字体的 UI,如颜色,大小

setKeyDrawable 设置按压效果文件

setOnKeyboardActionListener 键盘输入监听

setRandomKeys 设置键盘数字随机,如果已随机数字,设置为 false 即可另数字恢复正常

如果需要实现焦点监听,需要实现setFocusChangeListence接口,注意是项目方法不是原生 Api 方法噢。

实现弹出的键盘

在 xml 中定义:

 <com.jay.easykeyboard.SystemKeyBoardEditText
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        keyboard:xmlLayoutResId="@xml/keyboard_numbers"
        />

xml 属性:

属性 作用
keyDrawable 用于设置键盘的按压效果和按钮之间线的粗细颜色等
xmlLayoutResId 设置键盘的布局文件,必须设置
isRandom 是否数字随机
space 开启 4 位空格功能,使用场景是输入身份证或银行卡号的时候。
outSideCancel 点击外部可关闭键盘

其他用法与SystemKeyboard一样,SystemKeyBoardEditText实际是SystemKeyboard的进一步封装,通过EditTextPopupWindow结合的方法来实现键盘的灵活弹出.

可以通过getSystemKeyboard方法来获取到SystemKeyBoard对象。调用getKeyboardWindow可以获取包裹键盘 View 的 popwindow 对象,随后再调用dismiss()方法即可将键盘关闭

启用removeCopyAndPaste方法可以屏蔽 EditText 的长按复制粘贴功能

其他

如果在项目中需要进行原生与自定义键盘的切换或者输入框的切换,可以使用setEditText方法,进行 EditText 的输入目标切换

混淆: -keep public class com.jay.easykeyboard.bean.**{ *;}

更新日志

2018/2/9
重构项目,将项目发布到了 JitPack 仓库

2018/12/17
项目 v1.2 重构,解决输入框焦点选取问题,加入点击外部关闭自定义键盘功能,项目架构调整

2018/12/18
加入随机键盘功能

2019/11/28 v1.6
规范命名
优化:当键盘弹出时点击回退按钮关闭键盘,而不是 Activity

后续优化

  • 加入随机键盘功能
  • 解决在 RecyclerView 中的回收问题

如果有别的未覆盖到的功能希望能在 issuse 中反馈,个人能想到的场景有限,希望各位大佬集思广益

end

有任何问题可以在 issuse 中反馈,如果对你有帮助,希望给我颗小星星

Apps
About Me
GitHub: Trinea
Facebook: Dev Tools