Android EditText输入框实现下拉且保存最近5个历史记录

简介: Android EditText输入框实现下拉且保存最近5个历史记录

文章结构:


679140-20210702154519423-1956403286.png


一、需求阐述


技术部同事提出想要在APP上保存最近输入成功的5个密钥信息,同时支持可以下拉进行选择。


这也是为了方便客户在现在多次输入信息,帮助其快速进行输入。



二、实现思路:


目前想要实现的需求


1、想要实现保存用户输入的密钥信息。



2、通过点击右侧的下拉来触发,让用户去选择已经发送成功的信息。



3、通过SharedPreferences来保存每次APP退出后的数据。



4、当发送成功后,更新后台的存储数据,进行逻辑判断。



三、代码逻辑


下面图片是最终的实现效果,当输入标识和密钥,点击发送按钮,成功后将数据自动保存到后台的数组中。点击右侧的下拉图标后,在将其弹出。


679140-20210702154521091-1362623608.png


679140-20210702154522744-1766147709.png


后面又添加了清空历史记录的标签,就是在每一次添加更新后台数组后,数组的下一个标签为清空历史记录。


 s_btnDown.setOnClickListener(this);                           //对其进行焦点监听
  case R.id.btnDown:
  2         showListPopulWindow();                          //调用显示PopuWindow 函数
  3     break;

击后触发PopuWindow函数,也就是将其下拉框,绑定到TextBox标签的下面。

private void showListPopulWindow() {
        final DeviceKeySecretManager list = ((MainActivity)getActivity()).deviceKeySecretManager;//要填充的数据
        final ListPopupWindow listPopupWindow;
        listPopupWindow = new ListPopupWindow(getActivity());
        listPopupWindow.setAdapter(new ArrayAdapter<String>(getActivity(), android.R.layout.simple_list_item_1, list.getKeyList()));//用android内置布局,或设计自己的样式
        listPopupWindow.setAnchorView(s_etAppKey);          //以哪个控件为基准,在该处以mEditText为基准
        listPopupWindow.setModal(true);
        listPopupWindow.setOnItemClickListener(new AdapterView.OnItemClickListener() {          //设置项点击监听
            @Override
            public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
                if (list.KeySecretSum==i){
                    list.Clear();                                                           //点击清空
                    s_etAppKey.setText("");                            //把选择的选项内容展示在EditText上
                    s_etAppSecret.setText("");
                }else{
                    s_etAppKey.setText(list.getKeyList()[i]);                            //把选择的选项内容展示在EditText上
                    s_etAppSecret.setText(list.getSecretList()[i]);
                }
                listPopupWindow.dismiss();                             //如果已经选择了,隐藏起来
            }
        });
        listPopupWindow.show();                  //把ListPopWindow展示出来
    }



密钥管理的逻辑类:


用于在发送成功后将历史密钥信息进行缓存,后期将其绑定到下拉列表中,也为了在APP退出和首次加载时,将数据保存和提取到缓存中。


/**
 * 标识和密钥管理
 * 最多只存储5个密钥,超过5个就开始进行循环覆盖(从第一个开始)。
 */
class DeviceKeySecretManager {
    public DeviceKeySecretManager() {
        CurrentSaveIndex = 0;
    }
    public String[] getKeyList() {
        return KeyList;
    }
    public String[] getSecretList() {
        return SecretList;
    }
    /**
     * 添加新到的key和secret到密钥库
     * 1、先判断密钥库中是否存在key,如果存在则直接更新其secret值,
     * 2、不存在则直接进行添加key/secret值。
     */
    public void addBufferKeyAndSecret(String key, String secret) {
        if (IntegerConversion.UseLoop(KeyList,key)) {
            int index=0;
            for (int i=0;i<KeyList.length;i++) {
                if (KeyList[i].equals(key)){
                    index=i;
                    break;
                }
            }
            KeyList[index]=key;
            SecretList[index]=secret;
        } else {
            if (KeySecretSum == 5) {
                CurrentSaveIndex = CurrentSaveIndex == 5 ? 0 : CurrentSaveIndex;
                KeyList[CurrentSaveIndex] = key;
                SecretList[CurrentSaveIndex] = secret;
                CurrentSaveIndex++;
            } else {
                KeyList[CurrentSaveIndex] = key;
                SecretList[CurrentSaveIndex] = secret;
                CurrentSaveIndex++;
                KeySecretSum++;
                KeyList[CurrentSaveIndex] = "清空历史记录";
            }
        }
    }
    public void Clear() {
        CurrentSaveIndex = 0;
        KeySecretSum = 0;
        for (int i = 0; i < KeyList.length; i++) {
            KeyList[i] = null;
        }
        for (int i = 0; i < SecretList.length; i++) {
            SecretList[i] = null;
        }
    }
    public int CurrentSaveIndex = 0;                    //当前保存的序号
    public int KeySecretSum = 0;                        //key的总个数,最多存储5个。
    private String[] KeyList = new String[6];
    private String[] SecretList = new String[5];
}



APP退出和首次加载时,对数据在本地进行保存和提取;

/**
     * 读取保存的文件
     */
    private void getSavedPreference() {
        try {
            SharedPreferences pref = this.getSharedPreferences(getResources().getString(R.string.app_name), MODE_PRIVATE);
            int sum=pref.getInt("KeySecretSum", 0);
            for (int i=0;i<=sum;i++){
                deviceKeySecretManager.getKeyList()[i]=pref.getString("Key"+i, "");
            }
            for (int i=0;i<sum;i++){
                deviceKeySecretManager.getSecretList()[i]=pref.getString("Secret"+i, "");
            }
            deviceKeySecretManager.CurrentSaveIndex=sum==5?0:sum;
            deviceKeySecretManager.KeySecretSum=sum;
        } catch (Exception ex) {
        }
    }
    /**
     * 保存文件
     * */
    private void setSavePreference() {
        try {
            SharedPreferences pref = getSharedPreferences(getResources().getString(R.string.app_name), MODE_PRIVATE);
            SharedPreferences.Editor edit = pref.edit();
            edit.putInt("KeySecretSum", deviceKeySecretManager.KeySecretSum);             //现有保存的总个数
            for (int i=0;i<=deviceKeySecretManager.KeySecretSum;i++){
                edit.putString("Key"+i, deviceKeySecretManager.getKeyList()[i]);
            }
            for (int i=0;i<deviceKeySecretManager.KeySecretSum;i++){
                edit.putString("Secret"+i, deviceKeySecretManager.getSecretList()[i]);
            }
            edit.commit();
        } catch (Exception ex) {
        }
    }



下面是当发送成功后的业务逻辑:


@Override
    public void onClick(View v) {
        switch (v.getId()) {
            case R.id.btnSendData:
                if (!DeviceManager.getInstance().DeviceIsConnected()) {
                    tu.ToastShow(context, "设备已断开连接,无法进行通讯。");
                    return;
                }
                if (DeviceManager.getInstance().DeviceIsBusy()) {
                    tu.ToastShow(context, "设备忙碌,请等待...");
                    return;
                }
                try {
                    String key,secret;
                    key=s_etAppKey.getText().toString();
                    secret=s_etAppSecret.getText().toString();
                    if (key.length()<=0||secret.length()<=0||
                            TextUtils.isEmpty(key)||TextUtils.isEmpty(secret)){
                        tu.ToastShow(context, "标识和密钥不能为空!");
                        return;
                    }
                    //调用方法拼接字符串,发送给下位机设备。
                    int nResult = DeviceManager.getInstance().WriteRTKData(context, new byte[]{});
                    if (nResult > 0) {
                        tu.ToastShow(context, "参数写入成功");
                        ((MainActivity)getActivity()).deviceKeySecretManager.addBufferKeyAndSecret(key,secret);
                    }
                } catch (Exception ex) {
                    tu.ToastShow(context, "参数写入失败!");
                }
                break;
            case R.id.btnClearData:                                     //只清空当前的标识和密钥
                s_etAppKey.setText("");
                s_etAppSecret.setText("");
                break;
            case R.id.btnDown:
                showListPopulWindow();                          //调用显示PopuWindow 函数
                break;
            default:
                break;
        }
    }


总结:


通过上面的业务分析,代码实现就可以实现具体的需求,保存下最近5个的历史记录。



其实对于写程序而言,难的不是语法和技巧,而是编程思想,对于同一个问题/需求,不同的人有不同的解决办法,谁也不能说谁的方法是错误的,只能说谁的方法是目前为止最有效的。


目录
相关文章
|
8月前
|
Android开发
Android 实现点击输入框以外的区域隐藏软键盘
Android 实现点击输入框以外的区域隐藏软键盘
95 0
|
8月前
|
Java Android开发
Android 中设置EditText输入框提示文本hint的字体大小
Android 中设置EditText输入框提示文本hint的字体大小
204 0
|
8月前
|
XML Java Android开发
Android 中通过Java代码动态生成EditText视图,并循环遍历EditText取出遍历的ID和文本框的值
Android 中通过Java代码动态生成EditText视图,并循环遍历EditText取出遍历的ID和文本框的值
102 0
|
8月前
|
Java Android开发 iOS开发
Android TextView 与 EditText 的区别与使用
Android TextView 与 EditText 的区别与使用
99 0
|
9月前
|
Android开发
Android中下拉通知栏,Activity会走哪些生命周期?
我们就可以做一个总结:当前Activity中,下拉通知栏,是不走任何生命周期的。
149 0
|
11月前
|
XML Android开发 数据格式
Android EditText 获取/失去焦点
项目的需求中,又一个4位数的验证码界面,小弟才疏学浅,只想到了用线性布局里面放四个EditText。 需求需要输入内容后,自动跳到下一个位置聚焦,删除指定位置后,自动跳到上一个位置聚焦,由于聚焦/非聚焦UI展示得都不同,所以每个editText都会频繁的设置焦点变化。 之前因为是调用的系统键盘,所以,editText和键盘绑定后处理起来非常方便,但是,我们需要自定义一个展示在UI上的数字键盘,于是就有些bug。 bug不难,但是有点杂乱,下面是我的一点解决办法,总结一下,以后也记得更清楚!
|
11月前
|
Android开发
Android EditText输入框不聚焦,点击跳转
Android EditText输入框不聚焦,点击跳转
|
11月前
|
XML Java 数据安全/隐私保护
Android 输入框(EditText)的输入限制,数字英文邮箱,可见\隐藏切换,踩过的坑!
最近做到了登录注册模块的各种输入判定,监听等等,因为需求上的需要,还是搞了好一会儿,今天在这总结一下。 常规的输入框输入需求有纯数字,字母,混合输入,邮箱,键盘默认打开数字键盘,密码可见性,键盘的收起弹出等等。
|
Java Shell API
Android源码(6.0和8.1) 屏蔽状态栏下拉和屏蔽导航栏显示
Android源码(6.0和8.1) 屏蔽状态栏下拉和屏蔽导航栏显示
409 0
|
Android开发
Android 11 SystemUI(状态/导航栏)-状态栏下拉时图标的隐藏与通知面板的半透黑色背景
Android 11 SystemUI(状态/导航栏)-状态栏下拉时图标的隐藏与通知面板的半透黑色背景
643 0
Android 11 SystemUI(状态/导航栏)-状态栏下拉时图标的隐藏与通知面板的半透黑色背景