支付的密码输入框

Android密码的输入框

原理

图片的覆盖

之前有一个正方形的框子 点击后变成了黑点

private EditText editText;
private ImageView[] imageViews;//使用一个数组存储密码框
private StringBuffer stringBuffer = new StringBuffer();//存储密码字符
private int count = 6;
private String strPassword;//密码字符串

public ItemPasswordLayout(Context context) {
    this(context, null);
}

public ItemPasswordLayout(Context context, AttributeSet attrs) {
    this(context, attrs, 0);
}

public ItemPasswordLayout(Context context, AttributeSet attrs, int defStyleAttr) {
    super(context, attrs, defStyleAttr);
    imageViews = new ImageView[6];
    View view = View.inflate(context, R.layout.edittext_input_view, this);

    editText = (EditText) findViewById(R.id.item_edittext);
    imageViews[0] = (ImageView) findViewById(R.id.item_password_iv1);
    imageViews[1] = (ImageView) findViewById(R.id.item_password_iv2);
    imageViews[2] = (ImageView) findViewById(R.id.item_password_iv3);
    imageViews[3] = (ImageView) findViewById(R.id.item_password_iv4);
    imageViews[4] = (ImageView) findViewById(R.id.item_password_iv5);
    imageViews[5] = (ImageView) findViewById(R.id.item_password_iv6);

    editText.setCursorVisible(false);//将光标隐藏
    editText.setInputType(InputType.TYPE_CLASS_NUMBER);
    setListener();
}

private void setListener() {
    editText.addTextChangedListener(new TextWatcher() {
        @Override
        public void beforeTextChanged(CharSequence charSequence, int i, int i1, int i2) {

        }

        @Override
        public void onTextChanged(CharSequence charSequence, int i, int i1, int i2) {

        }

        @Override
        public void afterTextChanged(Editable editable) {
            //重点   如果字符不为""时才进行操作
            if (!editable.toString().equals("")) {
                if (stringBuffer.length() > 5) {
                    //当密码长度大于5位时edittext置空
                    editText.setText("");
                    return;
                } else {
                    //将文字添加到StringBuffer中
                    stringBuffer.append(editable);
                    editText.setText("");//添加后将EditText置空  造成没有文字输入的错局
                    count = stringBuffer.length();//记录stringbuffer的长度
                    strPassword = stringBuffer.toString();
                    if (stringBuffer.length() == 6) {
                        //文字长度位6   则调用完成输入的监听
                        if (inputCompleteListener != null) {
                            inputCompleteListener.inputComplete();
                        }
                    }
                }

                for (int i = 0; i < stringBuffer.length(); i++) {
                    imageViews[i].setImageResource(R.mipmap.ispassword);
                }
            }
        }
    });
    editText.setOnKeyListener(new OnKeyListener() {
        @Override
        public boolean onKey(View v, int keyCode, KeyEvent event) {
            if (keyCode == KeyEvent.KEYCODE_DEL
                    && event.getAction() == KeyEvent.ACTION_DOWN) {
                //针对软键盘删除按钮的处理
                if (onKeyDelete()) return true;
                return true;
            }
            return false;
        }
    });


}

public boolean onKeyDelete() {
    if (count == 0) {
        count = 6;
        return true;
    }
    if (stringBuffer.length() > 0) {
        //删除相应位置的字符
        stringBuffer.delete((count - 1), count);
        count--;
        strPassword = stringBuffer.toString();
        imageViews[strPassword.length()].setImageResource(R.mipmap.nopassword);

    }
    return false;
}


private InputCompleteListener inputCompleteListener;

public void setInputCompleteListener(InputCompleteListener inputCompleteListener) {
    this.inputCompleteListener = inputCompleteListener;
}


//外部调用监听的方法
public interface InputCompleteListener {
    void inputComplete();
}

public EditText getEditText() {
    return editText;
}

/**
 * 获取密码
 *
 * @return
 */
public String getStrPassword() {
    return strPassword;
}

public void setContent(String content) {
    editText.setText(content);
}

源码  https://github.com/letuszou/InputPasswordEdittext

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用uniapp实现仿微信支付密码输入框的示例代码: ```html <template> <view class="container"> <view class="input-box"> <view v-for="(item, index) in inputList" :key="index" class="input-item" :class="{ 'input-item-active': index === currentIndex }" > <view class="input-dot" v-show="item !== ''"></view> </view> </view> <view class="keyboard"> <view class="keyboard-row" v-for="row in keyboard" :key="row"> <view class="keyboard-item" v-for="key in row" :key="key" @click="handleKeyClick(key)" > {{ key }} </view> </view> </view> </view> </template> <script> export default { data() { return { inputList: ['', '', '', '', '', ''], // 输入框列表 currentIndex: 0, // 当前输入框索引 keyboard: [ ['1', '2', '3'], ['4', '5', '6'], ['7', '8', '9'], ['', '0', '删除'] ] // 键盘布局 }; }, methods: { handleKeyClick(key) { if (key === '删除') { if (this.currentIndex > 0) { this.currentIndex--; this.inputList[this.currentIndex] = ''; } } else { if (this.currentIndex < this.inputList.length) { this.inputList[this.currentIndex] = key; this.currentIndex++; } } } } }; </script> <style> .container { display: flex; flex-direction: column; align-items: center; justify-content: center; height: 100vh; } .input-box { display: flex; justify-content: space-between; width: 300rpx; height: 50rpx; border: 1rpx solid #ccc; border-radius: 4rpx; overflow: hidden; } .input-item { flex: 1; display: flex; align-items: center; justify-content: center; font-size: 24rpx; color: #333; } .input-item-active { background-color: #f5f5f5; } .input-dot { width: 10rpx; height: 10rpx; border-radius: 50%; background-color: #333; } .keyboard { margin-top: 20rpx; } .keyboard-row { display: flex; justify-content: space-between; margin-bottom: 10rpx; } .keyboard-item { display: flex; align-items: center; justify-content: center; width: 100rpx; height: 100rpx; border: 1rpx solid #ccc; border-radius: 4rpx; font-size: 32rpx; color: #333; } </style> ``` 这段代码实现了一个简单的支付密码输入框,包括自定义的输入框样式和键盘布局。用户可以点击键盘上的数字输入密码,点击删除按钮可以删除已输入密码输入密码会在输入框中显示为黑色圆点。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值