文章结构:

一、需求阐述

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

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

二、实现思路:

目前想要实现的需求

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

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

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

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

三、代码逻辑

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

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

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

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

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

密钥管理的逻辑类:

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

  1. 1 /**
  2. 2 * 标识和密钥管理
  3. 3 * 最多只存储5个密钥,超过5个就开始进行循环覆盖(从第一个开始)。
  4. 4 */
  5. 5 class DeviceKeySecretManager {
  6. 6
  7. 7 public DeviceKeySecretManager() {
  8. 8 CurrentSaveIndex = 0;
  9. 9 }
  10. 10
  11. 11 public String[] getKeyList() {
  12. 12 return KeyList;
  13. 13 }
  14. 14
  15. 15 public String[] getSecretList() {
  16. 16 return SecretList;
  17. 17 }
  18. 18
  19. 19 /**
  20. 20 * 添加新到的key和secret到密钥库
  21. 21 * 1、先判断密钥库中是否存在key,如果存在则直接更新其secret值,
  22. 22 * 2、不存在则直接进行添加key/secret值。
  23. 23 */
  24. 24 public void addBufferKeyAndSecret(String key, String secret) {
  25. 25 if (IntegerConversion.UseLoop(KeyList,key)) {
  26. 26 int index=0;
  27. 27 for (int i=0;i<KeyList.length;i++) {
  28. 28 if (KeyList[i].equals(key)){
  29. 29 index=i;
  30. 30 break;
  31. 31 }
  32. 32 }
  33. 33 KeyList[index]=key;
  34. 34 SecretList[index]=secret;
  35. 35 } else {
  36. 36 if (KeySecretSum == 5) {
  37. 37 CurrentSaveIndex = CurrentSaveIndex == 5 ? 0 : CurrentSaveIndex;
  38. 38 KeyList[CurrentSaveIndex] = key;
  39. 39 SecretList[CurrentSaveIndex] = secret;
  40. 40 CurrentSaveIndex++;
  41. 41 } else {
  42. 42 KeyList[CurrentSaveIndex] = key;
  43. 43 SecretList[CurrentSaveIndex] = secret;
  44. 44 CurrentSaveIndex++;
  45. 45 KeySecretSum++;
  46. 46 KeyList[CurrentSaveIndex] = "清空历史记录";
  47. 47 }
  48. 48 }
  49. 49 }
  50. 50
  51. 51 public void Clear() {
  52. 52 CurrentSaveIndex = 0;
  53. 53 KeySecretSum = 0;
  54. 54
  55. 55 for (int i = 0; i < KeyList.length; i++) {
  56. 56 KeyList[i] = null;
  57. 57 }
  58. 58
  59. 59 for (int i = 0; i < SecretList.length; i++) {
  60. 60 SecretList[i] = null;
  61. 61 }
  62. 62 }
  63. 63
  64. 64 public int CurrentSaveIndex = 0; //当前保存的序号
  65. 65 public int KeySecretSum = 0; //key的总个数,最多存储5个。
  66. 66 private String[] KeyList = new String[6];
  67. 67 private String[] SecretList = new String[5];
  68. 68 }

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

  1. 1 /**
  2. 2 * 读取保存的文件
  3. 3 */
  4. 4 private void getSavedPreference() {
  5. 5 try {
  6. 6 SharedPreferences pref = this.getSharedPreferences(getResources().getString(R.string.app_name), MODE_PRIVATE);
  7. 7 int sum=pref.getInt("KeySecretSum", 0);
  8. 8
  9. 9 for (int i=0;i<=sum;i++){
  10. 10 deviceKeySecretManager.getKeyList()[i]=pref.getString("Key"+i, "");
  11. 11 }
  12. 12
  13. 13 for (int i=0;i<sum;i++){
  14. 14 deviceKeySecretManager.getSecretList()[i]=pref.getString("Secret"+i, "");
  15. 15 }
  16. 16
  17. 17 deviceKeySecretManager.CurrentSaveIndex=sum==5?0:sum;
  18. 18 deviceKeySecretManager.KeySecretSum=sum;
  19. 19 } catch (Exception ex) {
  20. 20
  21. 21 }
  22. 22 }
  23. 23
  24. 24 /**
  25. 25 * 保存文件
  26. 26 * */
  27. 27 private void setSavePreference() {
  28. 28 try {
  29. 29 SharedPreferences pref = getSharedPreferences(getResources().getString(R.string.app_name), MODE_PRIVATE);
  30. 30 SharedPreferences.Editor edit = pref.edit();
  31. 31 edit.putInt("KeySecretSum", deviceKeySecretManager.KeySecretSum); //现有保存的总个数
  32. 32
  33. 33 for (int i=0;i<=deviceKeySecretManager.KeySecretSum;i++){
  34. 34 edit.putString("Key"+i, deviceKeySecretManager.getKeyList()[i]);
  35. 35 }
  36. 36
  37. 37 for (int i=0;i<deviceKeySecretManager.KeySecretSum;i++){
  38. 38 edit.putString("Secret"+i, deviceKeySecretManager.getSecretList()[i]);
  39. 39 }
  40. 40 edit.commit();
  41. 41 } catch (Exception ex) {
  42. 42
  43. 43 }
  44. 44 }

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

  1. 1 @Override
  2. 2 public void onClick(View v) {
  3. 3 switch (v.getId()) {
  4. 4 case R.id.btnSendData:
  5. 5 if (!DeviceManager.getInstance().DeviceIsConnected()) {
  6. 6 tu.ToastShow(context, "设备已断开连接,无法进行通讯。");
  7. 7 return;
  8. 8 }
  9. 9 if (DeviceManager.getInstance().DeviceIsBusy()) {
  10. 10 tu.ToastShow(context, "设备忙碌,请等待...");
  11. 11 return;
  12. 12 }
  13. 13 try {
  14. 14 String key,secret;
  15. 15 key=s_etAppKey.getText().toString();
  16. 16 secret=s_etAppSecret.getText().toString();
  17. 17
  18. 18 if (key.length()<=0||secret.length()<=0||
  19. 19 TextUtils.isEmpty(key)||TextUtils.isEmpty(secret)){
  20. 20 tu.ToastShow(context, "标识和密钥不能为空!");
  21. 21 return;
  22. 22 }
  23. 23
  24. 24 //调用方法拼接字符串,发送给下位机设备。
  25. 25 int nResult = DeviceManager.getInstance().WriteRTKData(context, new byte[]{});
  26. 26 if (nResult > 0) {
  27. 27 tu.ToastShow(context, "参数写入成功");
  28. 28
  29. 29 ((MainActivity)getActivity()).deviceKeySecretManager.addBufferKeyAndSecret(key,secret);
  30. 30 }
  31. 31 } catch (Exception ex) {
  32. 32 tu.ToastShow(context, "参数写入失败!");
  33. 33 }
  34. 34 break;
  35. 35 case R.id.btnClearData: //只清空当前的标识和密钥
  36. 36 s_etAppKey.setText("");
  37. 37 s_etAppSecret.setText("");
  38. 38 break;
  39. 39 case R.id.btnDown:
  40. 40 showListPopulWindow(); //调用显示PopuWindow 函数
  41. 41 break;
  42. 42 default:
  43. 43 break;
  44. 44 }
  45. 45 }

总结:

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

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

小寄语

一个人的奋斗,像怀孕一样,日子久了,总会被看出来的。

人生短暂,我不想去追求自己看不见的,我只想抓住我能看的见的。

我是哉说,谢谢您的阅读,希望和你一起进步、成长。

如果对您有帮助,麻烦点赞,转发。

Android EditText输入框实现下拉且保存最近5个历史记录的更多相关文章

  1. React-Native 之 GD (二十)removeClippedSubviews / modal放置的顺序 / Android 加载git图\动图 / 去除 Android 中输入框的下划线 / navigationBar

    1.removeClippedSubviews 用于提升大列表的滚动性能.需要给行容器添加样式overflow:’hidden’.(Android已默认添加此样式)此属性默认开启 这个属性是因为在早期 ...

  2. 背水一战 Windows 10 (105) - 通知(Toast): 带按钮的 toast, 带输入的 toast(文本输入框,下拉选择框)

    [源码下载] 背水一战 Windows 10 (105) - 通知(Toast): 带按钮的 toast, 带输入的 toast(文本输入框,下拉选择框) 作者:webabcd 介绍背水一战 Wind ...

  3. Android仿苹果版QQ下拉刷新实现(二) ——贝塞尔曲线开发"鼻涕"下拉粘连效果

    前言 接着上一期Android仿苹果版QQ下拉刷新实现(一) ——打造简单平滑的通用下拉刷新控件 的博客开始,同样,在开始前我们先来看一下目标效果: 下面上一下本章需要实现的效果图: 大家看到这个效果 ...

  4. Android公共库(缓存 下拉ListView 下载管理Pro 静默安装 root运行 Java公共类)

    介绍总结的一些android公共库,包含缓存(图片缓存.预取缓存).公共View(下拉及底部加载更多ListView.底部加载更多ScrollView.滑动一页Gallery).及Android常用工 ...

  5. android模仿58筛选下拉框(PopupWindow实现)

    前言:前几天用58同城APP找房子的时候,看到筛选下拉框蛮不错的,然后也有很多朋友需要实现这个功能,于是从网上下载了一个demo,在他的基础上进行修改,花了几个小时对他的代码进行修改,重构,封装.把一 ...

  6. Android—自定义控件实现ListView下拉刷新

    这篇博客为大家介绍一个android常见的功能——ListView下拉刷新(参考自他人博客,网址忘记了,阅读他的代码自己理解注释的,希望能帮助到大家): 首先下拉未松手时候手机显示这样的界面: 下面的 ...

  7. android SwipeRefreshLayout google官方下拉刷新控件

    下拉刷新功能之前一直使用的是XlistView很方便我前面的博客有介绍 SwipeRefreshLayout是google官方推出的下拉刷新控件使用方法也比较简单 今天就来使用下SwipeRefres ...

  8. Android官方提供的下拉刷新控件——SwipeRefreshLayout

    <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android=&q ...

  9. Android PullToRefresh (GridView 下拉刷新上拉加载)

    做这个需要自己去git hub上下载个pull-to-refresh 里面有个library为依赖包自己导到自己的项目中 (下载地址:https://github.com/chrisbanes/And ...

随机推荐

  1. 【BUAA软工】结对编程作业

    项目 内容 课程:2020春季软件工程课程博客作业(罗杰,任健) 博客园班级链接 作业:BUAA软件工程结对编程项目作业 作业要求 课程目标 学习大规模软件开发的技巧与方法,锻炼开发能力 作业目标 完 ...

  2. Java中对象池的本质是什么?(实战分析版)

    简介 对象池顾名思义就是存放对象的池,与我们常听到的线程池.数据库连接池.http连接池等一样,都是典型的池化设计思想. 对象池的优点就是可以集中管理池中对象,减少频繁创建和销毁长期使用的对象,从而提 ...

  3. ZOHO的下一个25年:用心为企业服务

    来源:中国软件网 作者:海策 在25周年会上,ZOHO大中华区总裁侯康宁先生豪情壮志,"25岁的ZOHO,已经成长为非典型一线大厂." 1996年,ZOHO成立.截止2021年,Z ...

  4. 29.Map,可变参数

    1.Map集合 1.1Map集合概述和特点[理解] 单列集合一次存一个元素 双列集合一次存两个元素 键:不能重复的        值:可以重复的 Map集合概述 interface Map<K, ...

  5. 16.分类和static

    1.案例驱动模式 1.1案例驱动模式概述 (理解) 通过我们已掌握的知识点,先实现一个案例,然后找出这个案例中,存在的一些问题,在通过新知识点解决问题 1.2案例驱动模式的好处 (理解) 解决重复代码 ...

  6. VS·卸载进程卡死"正在配置您的系统,这可能需要一些时间"

    阅文时长 | 0.34分钟 字数统计 | 596.8字符 主要内容 | 1.引言&背景 2.声明与参考资料 『VS·卸载进程卡死"正在配置您的系统,这可能需要一些时间"』 ...

  7. Linux创建RAID10_实战

    Linux创建RAID10_实战 Linux创建RAID10 RAID10 是先将数据进行镜像操作,然后再对数据进行分组,RAID1 在这里就是一个冗余的备份阵列,而RAID0则负责数据的读写阵列 至 ...

  8. STM32的三种启动方式

  9. 存储单位 KB MB bit

  10. 快成物流科技 x mPaaS | 小程序容器加持下的技术架构“提质增效”

      导言 从 2017 年开始,GMTC"移动技术大会"就更名为"大前端技术大会".发展至今,混合开发.原生开发.前端开发等概念正在深度融合,组成"大 ...