本文主要是介绍Android 自定义数字键盘(三)自定义输入框,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
Android 自定义数字键盘(一)
Android 自定义数字键盘(二)随机数字
Demo地址:https://github.com/danfengfirst/KeyDemo
这篇博客是在上面两篇博客的基础上修改的一个相对比较完整的demo,写完前面两篇我尝试使用过用pop弹出界面,但是焦点方面总是有问题,就参考了梁肖的思路,改用了Activity,为了思路清晰,没有给输入框自定义属性,效果演示如下(录的好像有点卡,动画效果跟点击的时候卡了,录制原因,正常运行不卡哈):
思路:
主要是三个方面:
1、自定义EidtText输入框,重写onTextChanged()方法来监听文本并进行刷新+圆点绘制
2、注意自定义的EditTextView获取焦点时隐藏键盘,显示自己定义的键盘,还有Editable的使用
3、对自定义键盘的点击事件监听回调,回调中分了两个方法一个插入数据,一个删除数据,通过方法名字应该看得出来。
//对按键的输入与删除事件进行监听mKeyView.setOnKeyPressListener(new NumKeyView.OnKeyPressListener() {@Overridepublic void onInertKey(String text) {//这里不可以直接使用mEditText来进行append,否则会显示数字if (editable.length() < 6) {mPasswordStr.append(text);editable.append(text);}}@Overridepublic void onDeleteKey() {if (editable.length() > 0) {int length = editable.length();editable.delete(length - 1, length);mPasswordStr.delete(length - 1, length);}}});
代码
自定义输入框
代码很少也很容易理解
public class PassWordEdit extends EditText {//控件宽度与高度private int mWidth;private int mHeight;private Paint mPaint;//输入密码长度private int mPassWordLength;public PassWordEdit(Context context) {this(context, null);}public PassWordEdit(Context context, AttributeSet attrs) {super(context, attrs);//初始化mPaint=new Paint();mPaint.setAntiAlias(true);mPaint.setColor(getResources().getColor(R.color.deepgray));mPaint.setStrokeWidth(2);}@Overrideprotected void onDraw(Canvas canvas) {super.onDraw(canvas);//为了绘制矩形边框设置画笔为空心的mPaint.setStyle(Paint.Style.STROKE);canvas.drawRect(new RectF(0+mPaint.getStrokeWidth(),0,mWidth-mPaint.getStrokeWidth(),mHeight),mPaint);mPaint.setStyle(Paint.Style.FILL);int width=(int)(mWidth/6.0);//绘制中间竖线for (int i=1;i<=5;i++){canvas.drawLine(width*i,0,width*i,mHeight,mPaint);}//绘制中间圆点for (int j=0;j<mPassWordLength;j++){
这篇关于Android 自定义数字键盘(三)自定义输入框的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!