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

文章结构:

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

s_btnDown.setOnClickListener(this);                           //对其进行焦点监听
case R.id.btnDown:
          showListPopulWindow();                          //调用显示PopuWindow 函数
      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个的历史记录。

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

到此这篇关于Android EditText输入框实现下拉且保存最近5个历史记录思路详解的文章就介绍到这了,更多相关Android EditText输入框内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Android 自定义EditText输入框带清空按钮

    Android 自定义EditText输入框带清空按钮 当用户输入字符后 EditText会自动在输入框的内部右侧出现删除按钮 重写EditText达到简化布局的效果 效果图: 继承EditText package com.example.myedittexttest; import android.content.Context; import android.graphics.Rect; import android.graphics.drawable.Drawable; import an

  • Android输入框控件ClearEditText实现清除功能

    本文给大家带来一个很实用的小控件ClearEditText,就是在Android系统的输入框右边加入一个小图标,点击小图标可以清除输入框里面的内容,IOS上面直接设置某个属性就可以实现这一功能,但是Android原生EditText不具备此功能,所以要想实现这一功能我们需要重写EditText,接下来就带大家来实现这一小小的功能 我们知道,我们可以为我们的输入框在上下左右设置图片,所以我们可以利用属性android:drawableRight设置我们的删除小图标,如图 我这里设置了左边和右边的图

  • Android带清除功能的输入框控件EditTextWithDel

    记录下一个很实用的小控件EditTextWithDel,就是在Android系统的输入框右边加入一个小图标,点击小图标可以清除输入框里面的内容,由于Android原生EditText不具备此功能,所以要想实现这一功能我们需要重写EditText. 效果图如下: 主要的思路就是为右边的图片设置监听,点击右边的图片清除输入框的内容并隐藏删除图标,因为我们不能直接给EditText设置点击事件,所以我们用记住我们按下的位置来模拟点击事件,用输入框的的onTouchEvent()方法来模拟. packa

  • Android文本输入框(EditText)输入密码时显示与隐藏

    代码很简单,这里就不多废话了. 复制代码 代码如下: package cc.c; import android.app.Activity; import android.os.Bundle; import android.text.Selection; import android.text.Spannable; import android.text.method.HideReturnsTransformationMethod; import android.text.method.Passw

  • Android高级xml布局之输入框EditText设计

    今天给大家介绍一下如何实现一款简约时尚的安卓登陆界面.大家先看一下效果图 当用户输入时动态出现删除按钮 现在先罗列一下技术点: 1.如何使用圆角输入框和按钮背景 2.如何实现"手机号"."密码"后面的竖线 3.如何嵌套输入框的布局 4.如何监听输入框的输入事件及删除按钮的动态显示隐藏 1.如何使用圆角输入框和按钮背景 安卓为开发者准备了shape这个xml标签,用于自定义一些形状. 那么我就来定义一个白色的输入框背景.代码如下: <!-- 形状 -->

  • Android UI设计系列之自定义EditText实现带清除功能的输入框(3)

    最近公司的产品在陆续做升级,上级领导给的任务是优化代码结构以及项目架构,力争把项目写的精巧简练,于是我们满工程找冗余... 我们都知道每一个项目基本上都是有登陆页的,在登陆页中肯定是少不了输入框了,当我们在输入框中输入数据后如果输入的内容不正确或者是错误的或者是想重新输入,如果嗯键盘上的删除键就得一个一个的去删除,这时候我们或许就想要是能有一个标记当点击了这个标记能把我们刚刚输入的内容清空就好了.这样可以极大的提升用户体验,就拿QQ的登陆来说吧,效果如下: 当点击密码框右侧的小×图标时输入的内容

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

    文章结构: 后面又添加了清空历史记录的标签,就是在每一次添加更新后台数组后,数组的下一个标签为清空历史记录. s_btnDown.setOnClickListener(this); //对其进行焦点监听 case R.id.btnDown: showListPopulWindow(); //调用显示PopuWindow 函数 break; 点击后触发PopuWindow函数,也就是将其下拉框,绑定到TextBox标签的下面. private void showListPopulWindow()

  • Android仿京东淘宝自动无限循环轮播控件思路详解

    在App的开发中,很多的时候都需要实现类似京东淘宝一样的自动无限轮播的广告栏,所以就自己写了一个,下面是我自定义控件的思路和过程. 一.自定义控件属性 新建自定义控件SliderLayout继承于RelativeLayout,首先要考虑的就是自定义的控件需要扩展那些属性,把这些属性列出来.在这里是要实现类似于京东淘宝的无限轮播广告栏,那么首先想到的就是轮播的时长.轮播指示器的样式等等.我在这里列举了一些并且结合到了代码中. 1.扩展属性 (1)是否开启自动轮播的功能. (2)指示器的图形样式,一

  • Android编程实现二级下拉菜单及快速搜索的方法

    本文实例讲述了Android编程实现二级下拉菜单及快速搜索的方法.分享给大家供大家参考,具体如下: 一.我们要做什么? 上面有个搜索框,下面是一个二级下拉菜单. 输入查询内容,下面列表将显示查询结果. 二.界面设计 (1)这是主框架(部分属性已经省去,请看源码),从上至下分别是文本框,列表,二级列表. <?xml version="1.0" encoding="utf-8"?> <LinearLayout> <LinearLayout

  • Android实现简单的下拉阻尼效应示例代码

    OS的下拉上拉都会出现一个很玄的动态效果.在Android中,虽然可以实现类似的效果,但有点不同的是,如果调用overScrollBy来实现类似的阻尼效应的话,最顶部会出现一片亮的区域,让人感觉不是很爽.所以决定不采用该方法来实现而是改用自定义的方式来实现. 下面是自定义控件的代码部分: public class MyView extends ScrollView { //记录下最开始点击的位置 int initY; //移动的位置 int deltaY; int touchY; //记录第一个

  • Android微信端的下拉刷新功能

    在Android和iOS上对于下拉刷新的处理方法: 在微信公众号内,在面对下拉刷新这个问题上,Android和iOS都自己的表现方式: iOS: Android: 所以我们要给内容加载监听器 function bindEvent() { document.addEventListener('touchstart', touchSatrtFunc, false); document.addEventListener('touchmove', touchMoveFunc, false); docum

  • Android 仿硅谷新闻下拉刷新/上拉加载更多

    1.添加加载更多布局 1_初始化和隐藏代码 在RefreshListView构造方法中调用 private void initFooterView(Context context) { View footerView = View.inflate(context, R.layout.refresh_listview_footer, null); //隐藏代码 footerView.measure(0, 0); int footerViewHeight = footerView.getMeasur

  • Android开发之无痕过渡下拉刷新控件的实现思路详解

    相信大家已经对下拉刷新熟悉得不能再熟悉了,市面上的下拉刷新琳琅满目,然而有很多在我看来略有缺陷,接下来我将说明一下存在的缺陷问题,然后提供一种思路来解决这一缺陷,废话不多说!往下看嘞! 1.市面一些下拉刷新控件普遍缺陷演示 以直播吧APP为例: 第1种情况: 滑动控件在初始的0位置时,手势往下滑动然后再往上滑动,可以看到滑动到初始位置时滑动控件不能滑动. 原因: 下拉刷新控件响应了触摸事件,后续的一系列事件都由它来处理,当滑动控件到顶端的时候,滑动事件都被下拉刷新控件消费掉了,传递不到它的子控件

  • Android开发之禁止下拉通知栏的方法

    本文实例讲述了Android开发之禁止下拉通知栏的方法.分享给大家供大家参考,具体如下: 1.在AndroidManifest.xml中添加权限 <uses-permission android:name="android.permission.EXPAND_STATUS_BAR"/> <uses-permission android:name="android.permission.STATUS_BAR"/> 2.在相应的activity中

  • Android使用ListView实现下拉刷新及上拉显示更多的方法

    本文实例讲述了Android使用ListView实现下拉刷新及上拉显示更多的方法.分享给大家供大家参考,具体如下: 今天得需求是做listview+上下拉动在header和footer显示progressdialog,但不影响用户操作 直接上代码,我已经加上注释了,自己看. package com.stay.main; import java.net.HttpURLConnection; import java.util.ArrayList; import java.util.HashMap;

  • 实时监控input框,实现输入框与下拉框联动的实例

    如图: html代码 <tr> <th scope="row">奖励类型:</th> <td><input value="" type="text" name="item" id="reward" style="width: 60px;height: 20px;" placeholder="输入关键字" />

随机推荐