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

一、需求阐述
技术部同事提出想要在APP上保存最近输入成功的5个密钥信息,同时支持可以下拉进行选择。
这也是为了方便客户在现在多次输入信息,帮助其快速进行输入。
二、实现思路:
目前想要实现的需求
1、想要实现保存用户输入的密钥信息。
2、通过点击右侧的下拉来触发,让用户去选择已经发送成功的信息。
3、通过SharedPreferences来保存每次APP退出后的数据。
4、当发送成功后,更新后台的存储数据,进行逻辑判断。
三、代码逻辑
下面图片是最终的实现效果,当输入标识和密钥,点击发送按钮,成功后将数据自动保存到后台的数组中。点击右侧的下拉图标后,在将其弹出。


后面又添加了清空历史记录的标签,就是在每一次添加更新后台数组后,数组的下一个标签为清空历史记录。
1 s_btnDown.setOnClickListener(this); //对其进行焦点监听
1 case R.id.btnDown:
2 showListPopulWindow(); //调用显示PopuWindow 函数
3 break;
点击后触发PopuWindow函数,也就是将其下拉框,绑定到TextBox标签的下面。
1 private void showListPopulWindow() {
2 final DeviceKeySecretManager list = ((MainActivity)getActivity()).deviceKeySecretManager;//要填充的数据
3 final ListPopupWindow listPopupWindow;
4 listPopupWindow = new ListPopupWindow(getActivity());
5 listPopupWindow.setAdapter(new ArrayAdapter<String>(getActivity(), android.R.layout.simple_list_item_1, list.getKeyList()));//用android内置布局,或设计自己的样式
6 listPopupWindow.setAnchorView(s_etAppKey); //以哪个控件为基准,在该处以mEditText为基准
7 listPopupWindow.setModal(true);
8
9 listPopupWindow.setOnItemClickListener(new AdapterView.OnItemClickListener() { //设置项点击监听
10 @Override
11 public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
12 if (list.KeySecretSum==i){
13 list.Clear(); //点击清空
14 s_etAppKey.setText(""); //把选择的选项内容展示在EditText上
15 s_etAppSecret.setText("");
16 }else{
17 s_etAppKey.setText(list.getKeyList()[i]); //把选择的选项内容展示在EditText上
18 s_etAppSecret.setText(list.getSecretList()[i]);
19 }
20
21 listPopupWindow.dismiss(); //如果已经选择了,隐藏起来
22 }
23 });
24 listPopupWindow.show(); //把ListPopWindow展示出来
25 }
密钥管理的逻辑类:
用于在发送成功后将历史密钥信息进行缓存,后期将其绑定到下拉列表中,也为了在APP退出和首次加载时,将数据保存和提取到缓存中。
1 /**
2 * 标识和密钥管理
3 * 最多只存储5个密钥,超过5个就开始进行循环覆盖(从第一个开始)。
4 */
5 class DeviceKeySecretManager {
6
7 public DeviceKeySecretManager() {
8 CurrentSaveIndex = 0;
9 }
10
11 public String[] getKeyList() {
12 return KeyList;
13 }
14
15 public String[] getSecretList() {
16 return SecretList;
17 }
18
19 /**
20 * 添加新到的key和secret到密钥库
21 * 1、先判断密钥库中是否存在key,如果存在则直接更新其secret值,
22 * 2、不存在则直接进行添加key/secret值。
23 */
24 public void addBufferKeyAndSecret(String key, String secret) {
25 if (IntegerConversion.UseLoop(KeyList,key)) {
26 int index=0;
27 for (int i=0;i<KeyList.length;i++) {
28 if (KeyList[i].equals(key)){
29 index=i;
30 break;
31 }
32 }
33 KeyList[index]=key;
34 SecretList[index]=secret;
35 } else {
36 if (KeySecretSum == 5) {
37 CurrentSaveIndex = CurrentSaveIndex == 5 ? 0 : CurrentSaveIndex;
38 KeyList[CurrentSaveIndex] = key;
39 SecretList[CurrentSaveIndex] = secret;
40 CurrentSaveIndex++;
41 } else {
42 KeyList[CurrentSaveIndex] = key;
43 SecretList[CurrentSaveIndex] = secret;
44 CurrentSaveIndex++;
45 KeySecretSum++;
46 KeyList[CurrentSaveIndex] = "清空历史记录";
47 }
48 }
49 }
50
51 public void Clear() {
52 CurrentSaveIndex = 0;
53 KeySecretSum = 0;
54
55 for (int i = 0; i < KeyList.length; i++) {
56 KeyList[i] = null;
57 }
58
59 for (int i = 0; i < SecretList.length; i++) {
60 SecretList[i] = null;
61 }
62 }
63
64 public int CurrentSaveIndex = 0; //当前保存的序号
65 public int KeySecretSum = 0; //key的总个数,最多存储5个。
66 private String[] KeyList = new String[6];
67 private String[] SecretList = new String[5];
68 }
APP退出和首次加载时,对数据在本地进行保存和提取;
1 /**
2 * 读取保存的文件
3 */
4 private void getSavedPreference() {
5 try {
6 SharedPreferences pref = this.getSharedPreferences(getResources().getString(R.string.app_name), MODE_PRIVATE);
7 int sum=pref.getInt("KeySecretSum", 0);
8
9 for (int i=0;i<=sum;i++){
10 deviceKeySecretManager.getKeyList()[i]=pref.getString("Key"+i, "");
11 }
12
13 for (int i=0;i<sum;i++){
14 deviceKeySecretManager.getSecretList()[i]=pref.getString("Secret"+i, "");
15 }
16
17 deviceKeySecretManager.CurrentSaveIndex=sum==5?0:sum;
18 deviceKeySecretManager.KeySecretSum=sum;
19 } catch (Exception ex) {
20
21 }
22 }
23
24 /**
25 * 保存文件
26 * */
27 private void setSavePreference() {
28 try {
29 SharedPreferences pref = getSharedPreferences(getResources().getString(R.string.app_name), MODE_PRIVATE);
30 SharedPreferences.Editor edit = pref.edit();
31 edit.putInt("KeySecretSum", deviceKeySecretManager.KeySecretSum); //现有保存的总个数
32
33 for (int i=0;i<=deviceKeySecretManager.KeySecretSum;i++){
34 edit.putString("Key"+i, deviceKeySecretManager.getKeyList()[i]);
35 }
36
37 for (int i=0;i<deviceKeySecretManager.KeySecretSum;i++){
38 edit.putString("Secret"+i, deviceKeySecretManager.getSecretList()[i]);
39 }
40 edit.commit();
41 } catch (Exception ex) {
42
43 }
44 }
下面是当发送成功后的业务逻辑:
1 @Override
2 public void onClick(View v) {
3 switch (v.getId()) {
4 case R.id.btnSendData:
5 if (!DeviceManager.getInstance().DeviceIsConnected()) {
6 tu.ToastShow(context, "设备已断开连接,无法进行通讯。");
7 return;
8 }
9 if (DeviceManager.getInstance().DeviceIsBusy()) {
10 tu.ToastShow(context, "设备忙碌,请等待...");
11 return;
12 }
13 try {
14 String key,secret;
15 key=s_etAppKey.getText().toString();
16 secret=s_etAppSecret.getText().toString();
17
18 if (key.length()<=0||secret.length()<=0||
19 TextUtils.isEmpty(key)||TextUtils.isEmpty(secret)){
20 tu.ToastShow(context, "标识和密钥不能为空!");
21 return;
22 }
23
24 //调用方法拼接字符串,发送给下位机设备。
25 int nResult = DeviceManager.getInstance().WriteRTKData(context, new byte[]{});
26 if (nResult > 0) {
27 tu.ToastShow(context, "参数写入成功");
28
29 ((MainActivity)getActivity()).deviceKeySecretManager.addBufferKeyAndSecret(key,secret);
30 }
31 } catch (Exception ex) {
32 tu.ToastShow(context, "参数写入失败!");
33 }
34 break;
35 case R.id.btnClearData: //只清空当前的标识和密钥
36 s_etAppKey.setText("");
37 s_etAppSecret.setText("");
38 break;
39 case R.id.btnDown:
40 showListPopulWindow(); //调用显示PopuWindow 函数
41 break;
42 default:
43 break;
44 }
45 }
总结:
通过上面的业务分析,代码实现就可以实现具体的需求,保存下最近5个的历史记录。
其实对于写程序而言,难的不是语法和技巧,而是编程思想,对于同一个问题/需求,不同的人有不同的解决办法,谁也不能说谁的方法是错误的,只能说谁的方法是目前为止最有效的。
小寄语
一个人的奋斗,像怀孕一样,日子久了,总会被看出来的。
人生短暂,我不想去追求自己看不见的,我只想抓住我能看的见的。
我是哉说,谢谢您的阅读,希望和你一起进步、成长。
如果对您有帮助,麻烦点赞,转发。
Android EditText输入框实现下拉且保存最近5个历史记录的更多相关文章
- React-Native 之 GD (二十)removeClippedSubviews / modal放置的顺序 / Android 加载git图\动图 / 去除 Android 中输入框的下划线 / navigationBar
1.removeClippedSubviews 用于提升大列表的滚动性能.需要给行容器添加样式overflow:’hidden’.(Android已默认添加此样式)此属性默认开启 这个属性是因为在早期 ...
- 背水一战 Windows 10 (105) - 通知(Toast): 带按钮的 toast, 带输入的 toast(文本输入框,下拉选择框)
[源码下载] 背水一战 Windows 10 (105) - 通知(Toast): 带按钮的 toast, 带输入的 toast(文本输入框,下拉选择框) 作者:webabcd 介绍背水一战 Wind ...
- Android仿苹果版QQ下拉刷新实现(二) ——贝塞尔曲线开发"鼻涕"下拉粘连效果
前言 接着上一期Android仿苹果版QQ下拉刷新实现(一) ——打造简单平滑的通用下拉刷新控件 的博客开始,同样,在开始前我们先来看一下目标效果: 下面上一下本章需要实现的效果图: 大家看到这个效果 ...
- Android公共库(缓存 下拉ListView 下载管理Pro 静默安装 root运行 Java公共类)
介绍总结的一些android公共库,包含缓存(图片缓存.预取缓存).公共View(下拉及底部加载更多ListView.底部加载更多ScrollView.滑动一页Gallery).及Android常用工 ...
- android模仿58筛选下拉框(PopupWindow实现)
前言:前几天用58同城APP找房子的时候,看到筛选下拉框蛮不错的,然后也有很多朋友需要实现这个功能,于是从网上下载了一个demo,在他的基础上进行修改,花了几个小时对他的代码进行修改,重构,封装.把一 ...
- Android—自定义控件实现ListView下拉刷新
这篇博客为大家介绍一个android常见的功能——ListView下拉刷新(参考自他人博客,网址忘记了,阅读他的代码自己理解注释的,希望能帮助到大家): 首先下拉未松手时候手机显示这样的界面: 下面的 ...
- android SwipeRefreshLayout google官方下拉刷新控件
下拉刷新功能之前一直使用的是XlistView很方便我前面的博客有介绍 SwipeRefreshLayout是google官方推出的下拉刷新控件使用方法也比较简单 今天就来使用下SwipeRefres ...
- Android官方提供的下拉刷新控件——SwipeRefreshLayout
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android=&q ...
- Android PullToRefresh (GridView 下拉刷新上拉加载)
做这个需要自己去git hub上下载个pull-to-refresh 里面有个library为依赖包自己导到自己的项目中 (下载地址:https://github.com/chrisbanes/And ...
随机推荐
- Docker部署微服务项目
测试包准备工作 1.spring.io或者ide创建demo工程 spring官网 2.本地demo代码,打包成jar包 使用Dockerfile构建微服务镜像 3.将jar包上传到你的vps lin ...
- 驰骋CCFlow开源工作流程引擎如何设置PDF打印
前言 经常有驰骋CCFlow爱好者朋友提问关于打印相关问题.在这篇博文中大家介绍一下工作流引擎CCFlow的HTML打印和PDF打印,针对Java版本和.NET版本有不同的操作步骤,包括开关设置.水印 ...
- PECcpu2006中执行单个测试程序的方法
PECcpu2006中执行单个测试程序的方法 2010-12-30 11:44:00 maray 阅读数 10055更多 分类专栏: 科学理论 版权声明:本文为博主原创文章,遵循CC 4.0 BY ...
- 马哥Linux SysAdmin学习笔记(一)
Linux入门 Linux系统管理: 磁盘管理,文件系统管理 RAID基础原理,LVM2 网络管理:TCP/IP协议,Linux网络属性配置 程序包管理:rpm,yum 进程管理:htop,glanc ...
- tar cf XXX.tar /tmp /var 日志保存
tar cf XXX.tar /tmp /var 检测tar tf XXX.tar /tmp /var
- Rust模块化
Rust模块化 模块化有助于代码的管理和层次逻辑的清晰 Rust模块化有多种方式: 1.嵌套模块 嵌套模块就是直接在要使用模块的文件中声明模块 mod food{//声明模块 pub struct C ...
- 基于多端口的Web服务
[Centos7.4版本] !!!测试环境我们首关闭防火墙和selinux [root@localhost ~]# systemctl stop firewalld [root@localhost ~ ...
- Jquery的load加载本地文件出现跨域错误的解决方案"Access to XMLHttpRequest at 'file:///android_asset/web/graph.json' from(Day_46)
博主是通过JS调用本地的一个json文件赋值给变量出现的跨域错误, 网上有大量文章,五花八门的,但总归,一般性此问题基本可通过这三种方法解决: https://blog.csdn.net/qq_418 ...
- CAS(Compare and Swap)无锁算法-学习笔记
非阻塞同步算法与CAS(Compare and Swap)无锁算法 这篇问题对java的CAS讲的非常透彻! 锁的代价 1. 内核态的锁的时候需要操作系统进行一次上下文切换,加锁.释放锁会导致比较多的 ...
- Jmeter- 笔记9 - CLI(无图形界面)
使用CLI模式,减少资源占用 用GUI调试好脚本 在jmeter的bin文件夹运行cmd,然后输入命令:jmeter -n -t [jmx file] -l [results file] -e -o ...