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!
推薦閱讀:
- Redis 實現同步鎖案例
- Java easyExcel的復雜表頭多級表頭導入
- HashMap的get()方法的NullPointerException問題
- Android SharedPreferences存取操作以及封裝詳解
- android studio實現簡易的計算器