From 15d9aae9a65c3385aaea29cb6d9810e4a8e8bd27 Mon Sep 17 00:00:00 2001
From: zuoxiao <470321431@qq.com>
Date: 星期二, 07 五月 2024 11:04:45 +0800
Subject: [PATCH] 1.修复开卡列表显示异常bug 2.实现读卡界面相关功能 3.所有Activity去掉齐河后缀

---
 qihealonelibrary/src/main/java/com/dayu/qihealonelibrary/activity/ReadCardAcitivy.java |  236 ++++++++++++++++++++++++++++++++---------------------------
 1 files changed, 128 insertions(+), 108 deletions(-)

diff --git a/qihealonelibrary/src/main/java/com/dayu/qihealonelibrary/activity/ReadCardAcitivy.java b/qihealonelibrary/src/main/java/com/dayu/qihealonelibrary/activity/ReadCardAcitivy.java
index bc359e9..dfe6a06 100644
--- a/qihealonelibrary/src/main/java/com/dayu/qihealonelibrary/activity/ReadCardAcitivy.java
+++ b/qihealonelibrary/src/main/java/com/dayu/qihealonelibrary/activity/ReadCardAcitivy.java
@@ -3,6 +3,7 @@
 import android.content.Intent;
 import android.nfc.NfcAdapter;
 import android.os.Bundle;
+import android.text.TextUtils;
 import android.view.LayoutInflater;
 import android.view.View;
 
@@ -16,6 +17,7 @@
 import com.dayu.qihealonelibrary.card.RegionCard;
 import com.dayu.qihealonelibrary.card.UserCard;
 import com.dayu.qihealonelibrary.databinding.ActivityRedCardQhaBinding;
+import com.dayu.qihealonelibrary.dbBean.UserCardBean;
 import com.dayu.qihealonelibrary.tools.NfcReadHelper;
 import com.dayu.qihealonelibrary.utils.CardCommon;
 import com.dayu.qihealonelibrary.view.ProgressDialog;
@@ -29,7 +31,7 @@
  * Date: 2023-11-10 19:52
  * Description: 璇诲崱鐣岄潰
  */
-public class ReadCardAcitivy extends BaseNfcActivityQHAlone {
+public class ReadCardAcitivy extends BaseNfcActivity {
 
     volatile UserCard userCard;
     ActivityRedCardQhaBinding redCardBinding;
@@ -45,13 +47,11 @@
     }
 
 
-    private void setUserData(String userName, int blance, String statu) {
+    private void setUserData(String userName, String statu, String cardNumber) {
         viweGone(true);
         redCardBinding.redName.setText("鐢ㄦ埛濮撳悕锛�" + userName);
-        redCardBinding.redRemainderBlance.setText("鍓╀綑閲戦锛�" + MornyUtil.changeF2Y(blance) + "鍏�");
         redCardBinding.redStatu.setText("鍗$姸鎬侊細" + statu);
         if (userCard != null) {
-
             Calendar calendar = userCard.getRechargeDate();
             if (calendar != null) {
                 int year = calendar.get(Calendar.YEAR);
@@ -60,12 +60,16 @@
                 int hour = calendar.get(Calendar.HOUR_OF_DAY);
                 int minute = calendar.get(Calendar.MINUTE);
                 int second = calendar.get(Calendar.SECOND);
-                redCardBinding.redRechargeDate.setText("鏈崱鏈�鍚庤喘姘存棩鏈燂細" + year + month + day + " " + hour + ":" + minute + ":" + second);
+                redCardBinding.redRechargeDate.setText("鏈崱鏈�鍚庤喘姘存棩鏈燂細" + year + "骞�" + month + "鏈�" + day + "鏃�");
             } else {
                 redCardBinding.redRechargeDate.setText("鏈崱鏈�鍚庤喘姘存棩鏈燂細鏃�");
             }
-
+            redCardBinding.redInitCode.setText(cardNumber);
             redCardBinding.redRechargeNumber.setText("鏈崱鍏呭�兼鏁帮細" + userCard.getRechargeTimes() + "");
+            redCardBinding.redTotalWater.setText("鎬荤敤姘撮噺锛�" + userCard.getTotalWater());
+            redCardBinding.redTotalPower.setText("鎬荤敤鐢甸噺锛�" + userCard.getTotalElectric());
+            redCardBinding.redRemainderBlance.setText("鍓╀綑閲戦锛�" + MornyUtil.changeF2Y(userCard.getBalance()) + "鍏�");
+            redCardBinding.redRemainderWater.setText("鍓╀綑姘撮噺锛�" + userCard.getSurplusWater());
         }
     }
 
@@ -85,115 +89,131 @@
      */
 
     public void readAllData(Intent intent) {
-        NfcReadHelper.getInstence(intent, this)
-                .getOneSectorData(new NfcReadHelper.NFCCallListback() {
-                    @Override
-                    public void callBack(List<byte[]> data) {
-                        //鑾峰彇1鎵囧尯鏁版嵁
-                        if (data != null && data.size() > 0) {
-                            byte cardType = data.get(0)[0];
-                            String cardTypeStr = HexUtil.byteToHex(cardType);
-                            switch (cardTypeStr) {
-                                case CardCommon.USER_CARD_TYPE_1:
-                                case CardCommon.USER_CARD_TYPE_2:
-                                case CardCommon.USER_CARD_TYPE_3:
-                                    userCard = UserCard.getBean(data);
-                                    break;
-                                case CardCommon.MANAGE_CRAD:
-                                    viweGone(false);
-                                    redCardBinding.readCardTypeTV.setText("褰撳墠涓虹鐞嗗崱");
-                                    stopAnim();
-                                    break;
-                                case CardCommon.CLEAN_CARD_TYPE:
-                                    viweGone(false);
-                                    redCardBinding.readCardTypeTV.setText("褰撳墠涓烘竻闆跺崱");
-                                    stopAnim();
-                                    break;
-                                case CardCommon.REGISTERED_CARD_TYPE:
-                                    viweGone(false);
-                                    redCardBinding.readCardTypeTV.setText("褰撳墠涓洪噸鏂版敞鍐岃澶囧崱");
-                                    stopAnim();
 
-                                    break;
-                                case CardCommon.CLEAN_ALL_USER_CARD_TYPE:
-                                    viweGone(false);
-                                    redCardBinding.readCardTypeTV.setText("褰撳墠涓哄垹闄ゅ叏閮ㄧ敤鎴峰崱");
-                                    stopAnim();
-                                    break;
-                                case CardCommon.DOMAIN_CARD_TYPE:
-                                    viweGone(false);
-                                    redCardBinding.readCardTypeTV.setText("褰撳墠涓鸿缃煙鍚嶅崱");
-                                    DomainCard domainCard = DomainCard.toBean(data);
-                                    assert domainCard != null;
-                                    redCardBinding.readCardDataTV.setText("搴忓彿锛�" + domainCard.getDomainNumber() + "\n" + "鍩熷悕锛�" + domainCard.getDomainName() + "\n" + "绔彛鍙凤細" + domainCard.getPort());
-                                    stopAnim();
-                                    break;
-                                case CardCommon.TEST_CARD_TYPE:
-                                    viweGone(false);
-                                    redCardBinding.readCardTypeTV.setText("褰撳墠涓烘祴璇曞崱");
-                                    stopAnim();
-                                    break;
-                                case CardCommon.CONFIGURATION_CARD_TYPE:
-                                    viweGone(false);
-                                    redCardBinding.readCardTypeTV.setText("褰撳墠涓洪厤缃澶囨敞鍐屼俊鎭崱");
-                                    stopAnim();
-                                    break;
-                                case CardCommon.CONFIGURATION_POWER_CARD_TYPE:
-                                    viweGone(false);
-                                    redCardBinding.readCardTypeTV.setText("褰撳墠閰嶇疆姘存车鍔熺巼鍗�");
-                                    ConfigurationPowerCard powerCard = ConfigurationPowerCard.toBean(data.get(0));
-                                    redCardBinding.readCardDataTV.setText(powerCard.getPower());
-                                    stopAnim();
-                                    break;
-                                case CardCommon.BLACK:
-                                    viweGone(false);
-                                    redCardBinding.readCardTypeTV.setText("褰撳墠涓洪粦鍗�");
-                                    BlackCard blackCard = BlackCard.getBean(data);
-                                    redCardBinding.readCardDataTV.setText("褰撳墠榛戝崱鐢ㄦ埛鍙蜂负锛�" + blackCard.getBlackCard());
-                                    break;
-                                case CardCommon.REGION:
-                                    viweGone(false);
-                                    redCardBinding.readCardTypeTV.setText("褰撳墠涓哄尯鍩熻〃鍙峰崱");
-                                    RegionCard regionCard = RegionCard.getBean(data);
-                                    StringBuilder stringBuilder = new StringBuilder();
-                                    stringBuilder.append("鍖哄煙鍦板潃锛�").append(regionCard.getRegion()).append("\n");
-                                    stringBuilder.append("鎺у埗鍣ㄧ紪鍙凤細").append(regionCard.getControllerCodel()).append("\n");
-                                    redCardBinding.readCardDataTV.setText(stringBuilder.toString());
-                                    break;
-                                case CardCommon.ELECTRIC_PRICE:
-                                    viweGone(false);
-                                    redCardBinding.readCardTypeTV.setText("褰撳墠涓虹數閲忓崟浠峰崱");
-                                    ElectricPriceCard electricPriceCard = ElectricPriceCard.getBean(data);
-                                    StringBuilder electricPriceBuilder = new StringBuilder();
-                                    electricPriceBuilder.append("鐢甸噺鍗曚环锛�").append(electricPriceCard.getElectricPrice()).append("\n");
-                                    redCardBinding.readCardDataTV.setText(electricPriceBuilder.toString());
-                                    break;
-                                default:
-                                    TipUtil.show(ReadCardAcitivy.this, "鍗$墖鏃犳硶璇嗗埆");
-                                    stopAnim();
-                                    break;
-                            }
 
+        String cardType = NfcReadHelper.getInstence(intent, this).getCradTypeAndCardNumber();
+        String cardNumber = null;
+        String[] cardTypes = cardType.split(",");
+        if (cardTypes != null && cardTypes.length == 2) {
+            cardNumber = cardType.split(",")[0];
+            cardType = cardType.split(",")[1];
+        }
+        List<byte[]> data = NfcReadHelper.getInstence(intent, this).getOnesectorData();
+        switch (cardType) {
+            case CardCommon.USER_CARD_TYPE_1:
+            case CardCommon.USER_CARD_TYPE_2:
+            case CardCommon.USER_CARD_TYPE_3:
+                if (!data.isEmpty()) {
+                    if (!TextUtils.isEmpty(cardNumber)) {
+                        userCard = UserCard.getBean(data);
+                        List<UserCardBean> userCardBeans = baseDao.userCardDao().findUserName(cardNumber);
+                        if (userCardBeans != null && !userCardBeans.isEmpty()) {
+                            UserCardBean userName = userCardBeans.get(0);
+                            setUserData(userName.getUserName(), "鍚敤", cardNumber);
                         } else {
-                            TipUtil.show(ReadCardAcitivy.this, "鍗$墖鏃犳硶璇嗗埆");
-                            stopAnim();
+                            setUserData("鏈煡璇㈠埌鐢ㄦ埛鍚�", "鍚敤", cardNumber);
                         }
+                    } else {
 
                     }
+                } else {
+                    TipUtil.show("鍗$墖璇嗗埆閿欒,璇烽噸璇曪紒");
+                }
 
-                    @Override
-                    public void error(int code) {
-                        switch (code) {
-                            case CardCommon.ERROR_MOVE:
-                                stopAnim();
-                                TipUtil.show("杩炴帴涓柇锛岃閲嶆柊璐村悎鍗$墖");
-                                break;
-                            default:
-                                stopAnim();
-                                TipUtil.show("鍗$墖璇嗗埆閿欒,璇烽噸璇曪紒");
-                        }
-                    }
-                });
+                stopAnim();
+                break;
+            case CardCommon.MANAGE_CRAD:
+                viweGone(false);
+                redCardBinding.readCardTypeTV.setText("褰撳墠涓虹鐞嗗崱");
+                stopAnim();
+                break;
+            case CardCommon.CLEAN_CARD_TYPE:
+                viweGone(false);
+                redCardBinding.readCardTypeTV.setText("褰撳墠涓烘竻闆跺崱");
+                stopAnim();
+                break;
+            case CardCommon.REGISTERED_CARD_TYPE:
+                viweGone(false);
+                redCardBinding.readCardTypeTV.setText("褰撳墠涓洪噸鏂版敞鍐岃澶囧崱");
+                stopAnim();
+                break;
+            case CardCommon.CLEAN_ALL_USER_CARD_TYPE:
+                viweGone(false);
+                redCardBinding.readCardTypeTV.setText("褰撳墠涓哄垹闄ゅ叏閮ㄧ敤鎴峰崱");
+                stopAnim();
+                break;
+            case CardCommon.DOMAIN_CARD_TYPE:
+                viweGone(false);
+                redCardBinding.readCardTypeTV.setText("褰撳墠涓鸿缃煙鍚嶅崱");
+                if (!data.isEmpty()) {
+                    DomainCard domainCard = DomainCard.toBean(data);
+                    assert domainCard != null;
+                    redCardBinding.readCardDataTV.setText("搴忓彿锛�" + domainCard.getDomainNumber() + "\n" + "鍩熷悕锛�" + domainCard.getDomainName() + "\n" + "绔彛鍙凤細" + domainCard.getPort());
+                } else {
+                    TipUtil.show("鍗$墖璇嗗埆閿欒,璇烽噸璇曪紒");
+                }
+                stopAnim();
+                break;
+            case CardCommon.TEST_CARD_TYPE:
+                viweGone(false);
+                redCardBinding.readCardTypeTV.setText("褰撳墠涓烘祴璇曞崱");
+                stopAnim();
+                break;
+            case CardCommon.CONFIGURATION_CARD_TYPE:
+                viweGone(false);
+                redCardBinding.readCardTypeTV.setText("褰撳墠涓洪厤缃澶囨敞鍐屼俊鎭崱");
+                stopAnim();
+                break;
+            case CardCommon.CONFIGURATION_POWER_CARD_TYPE:
+                viweGone(false);
+                redCardBinding.readCardTypeTV.setText("褰撳墠閰嶇疆姘存车鍔熺巼鍗�");
+                if (!data.isEmpty()) {
+                    ConfigurationPowerCard powerCard = ConfigurationPowerCard.toBean(data.get(0));
+                    redCardBinding.readCardDataTV.setText(powerCard.getPower());
+                } else {
+                    TipUtil.show("鍗$墖璇嗗埆閿欒,璇烽噸璇曪紒");
+                }
+                stopAnim();
+                break;
+            case CardCommon.BLACK:
+                viweGone(false);
+                redCardBinding.readCardTypeTV.setText("褰撳墠涓洪粦鍗�");
+                BlackCard blackCard = BlackCard.getBean(data);
+                redCardBinding.readCardDataTV.setText("褰撳墠榛戝崱鐢ㄦ埛鍙蜂负锛�" + blackCard.getBlackCard());
+                break;
+            case CardCommon.REGION:
+                viweGone(false);
+                redCardBinding.readCardTypeTV.setText("褰撳墠涓哄尯鍩熻〃鍙峰崱");
+                if (!data.isEmpty()) {
+                    RegionCard regionCard = RegionCard.getBean(data);
+                    StringBuilder stringBuilder = new StringBuilder();
+                    stringBuilder.append("鍖哄煙鍦板潃锛�").append(regionCard.getRegion()).append("\n");
+                    stringBuilder.append("鎺у埗鍣ㄧ紪鍙凤細").append(regionCard.getControllerCodel()).append("\n");
+                    redCardBinding.readCardDataTV.setText(stringBuilder.toString());
+                } else {
+                    TipUtil.show("鍗$墖璇嗗埆閿欒,璇烽噸璇曪紒");
+                }
+
+                break;
+            case CardCommon.ELECTRIC_PRICE:
+                viweGone(false);
+                redCardBinding.readCardTypeTV.setText("褰撳墠涓虹數閲忓崟浠峰崱");
+                if (!data.isEmpty()) {
+                    ElectricPriceCard electricPriceCard = ElectricPriceCard.getBean(data);
+                    StringBuilder electricPriceBuilder = new StringBuilder();
+                    electricPriceBuilder.append("鐢甸噺鍗曚环锛�").append(electricPriceCard.getElectricPrice()).append("\n");
+                    redCardBinding.readCardDataTV.setText(electricPriceBuilder.toString());
+                } else {
+                    TipUtil.show("鍗$墖璇嗗埆閿欒,璇烽噸璇曪紒");
+                }
+                break;
+            default:
+                TipUtil.show(ReadCardAcitivy.this, "鍗$墖鏃犳硶璇嗗埆");
+                stopAnim();
+                break;
+        }
+
+
     }
 
 

--
Gitblit v1.8.0