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輸入框內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: