自定义view仿支付宝密码输入框

效果图


随便讲讲实现,首先,这个的难点是自定义view如何获取用户的输入。

现在能找到的仿支付宝的这个密码输入框,其他网友主要是直接继承edittext来解决输入问题,或者用viewgroup来包裹edittext等,没有直接继承view来解决问题的,我在简单的查看edittext源码和搜索stack overflow后,提供了这种直接继承view,自己监听输入的实现方式。大部分的需求都可以通过google直接或间接的解决,stack overflow上的大神还是很多的,解决问题也很深入。

首先,自定义view需要重写以下方法:

@Override
public boolean onCheckIsTextEditor() {
    return true;
}

@Override
public InputConnection onCreateInputConnection(EditorInfo outAttrs) {
    outAttrs.inputType= InputType.TYPE_CLASS_NUMBER;
    outAttrs.imeOptions=EditorInfo.IME_ACTION_DONE;
    return new MyInputConnection(this,false);
}
重写这两个方法,获取到输入连接,通过继承baseinputconnection写一个自己的处理类。

 class MyInputConnection extends BaseInputConnection{

        public MyInputConnection(View targetView, boolean fullEditor) {
            super(targetView, fullEditor);
        }

        @Override
        public boolean commitText(CharSequence text, int newCursorPosition) {
            sb.append(text);
            Log.i("txt",sb.toString());
            return true;
        }

        @Override
        public boolean deleteSurroundingText(int beforeLength, int afterLength) {
            Log.i("deleteSurroundingText",beforeLength+"---"+afterLength);
            if (beforeLength==1 && afterLength==0){
                return super.sendKeyEvent(new KeyEvent(KeyEvent.ACTION_DOWN, KeyEvent.KEYCODE_DEL))
                        && super.sendKeyEvent(new KeyEvent(KeyEvent.ACTION_UP, KeyEvent.KEYCODE_DEL));
            }
            return super.deleteSurroundingText(beforeLength, afterLength);
        }
    }

commitText所获取到的是一些文本内容,例如输入法输入的单词,短语等等,我们这里只需要数字,这个方法可以直接返回ture,什么也不做。

deleteSurroundingText 是个重点方法,因为我们无法监听到软键盘的del事件,必须在这里自己发送一个del事件给view处理。

this.setOnKeyListener(new OnKeyListener() {
            @Override
            public boolean onKey(View v, int keyCode, KeyEvent event) {
                if (event.getAction()==KeyEvent.ACTION_DOWN){
                    if (keyCode>= KeyEvent.KEYCODE_0 && keyCode<= KeyEvent.KEYCODE_9){
                        Log.i("input","number="+(keyCode-7));
                    }
                    if (keyCode==KeyEvent.KEYCODE_DEL){//only hard keyboard
                        Log.i("input","del");
                    }
                    if (keyCode==KeyEvent.KEYCODE_ENTER){
                        Log.i("input","enter");
                    }
                    Log.i("keycode","code=>"+keyCode);
                    return true;
                }
                return false;
            }
        });
然后,我们就可以监听keyEvent 了,剩下的就onDraw就可以了。

上面的代码只是示例,并不能直接用哦。下面是github地址,代码和demo都在里面,有帮助的话请给个star。

https://github.com/huage2580/PswInputViewDemo



  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值