From 844597b5813ff8589de503cd7d7b1bbd0586d287 Mon Sep 17 00:00:00 2001
From: zuoxiao <470321431@qq.com>
Date: 星期一, 13 五月 2024 19:38:03 +0800
Subject: [PATCH] 1.添加水量单价 2.修复发现的bug

---
 qihealonelibrary/src/main/java/com/dayu/qihealonelibrary/activity/ReadCardAcitivy.java |  249 ++++++++++++++++++++++++++-----------------------
 1 files changed, 132 insertions(+), 117 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 ec3a42a..b5c1a5f 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;
 
@@ -15,11 +16,10 @@
 import com.dayu.qihealonelibrary.card.ElectricPriceCard;
 import com.dayu.qihealonelibrary.card.RegionCard;
 import com.dayu.qihealonelibrary.card.UserCard;
-import com.dayu.qihealonelibrary.databinding.ActivityRedCardBinding;
-
+import com.dayu.qihealonelibrary.databinding.ActivityRedCardQhaBinding;
+import com.dayu.qihealonelibrary.dbBean.UserCardBean;
 import com.dayu.qihealonelibrary.tools.NfcReadHelper;
-
-import com.dayu.qihealonelibrary.utils.MyCommon;
+import com.dayu.qihealonelibrary.utils.CardCommon;
 import com.dayu.qihealonelibrary.view.ProgressDialog;
 
 import java.util.Calendar;
@@ -34,7 +34,7 @@
 public class ReadCardAcitivy extends BaseNfcActivity {
 
     volatile UserCard userCard;
-    ActivityRedCardBinding redCardBinding;
+    ActivityRedCardQhaBinding redCardBinding;
 
 
     Intent intent;
@@ -42,32 +42,31 @@
     @Override
     protected void onCreate(Bundle savedInstanceState) {
         super.onCreate(savedInstanceState);
-        redCardBinding = ActivityRedCardBinding.inflate(LayoutInflater.from(this));
+        redCardBinding = ActivityRedCardQhaBinding.inflate(LayoutInflater.from(this));
         setContentView(redCardBinding.getRoot());
     }
 
 
-    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);
                 int month = calendar.get(Calendar.MONTH); // 鏈堜唤浠�0寮�濮嬶紝鎵�浠ラ渶瑕佸姞1
                 int day = calendar.get(Calendar.DAY_OF_MONTH);
-                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.redRechargeNumber.setText("鏈崱鍏呭�兼鏁帮細" + userCard.getRechargeTimes() + "");
+            redCardBinding.redInitCode.setText(cardNumber);
+            redCardBinding.redRechargeNumber.setText("鏈崱鍏呭�兼鏁帮細" + userCard.getRechargeTimes() + " 娆�");
+            redCardBinding.redTotalWater.setText("鎬荤敤姘撮噺锛�" + MornyUtil.changeF2Y(userCard.getTotalWater()) + " 鍚�");
+            redCardBinding.redTotalPower.setText("鎬荤敤鐢甸噺锛�" +  MornyUtil.changeF2Y(userCard.getTotalElectric())+" 搴�");
+            redCardBinding.redRemainderBlance.setText("鍓╀綑閲戦锛�" + MornyUtil.changeF2Y(userCard.getBalance()) + " 鍏�");
+            redCardBinding.redRemainderWater.setText("鍓╀綑姘撮噺锛�" + MornyUtil.changeF2Y(userCard.getSurplusWater())+" 鍚�");
         }
     }
 
@@ -87,115 +86,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 MyCommon.USER_CARD_TYPE_1:
-                                case MyCommon.USER_CARD_TYPE_2:
-                                case MyCommon.USER_CARD_TYPE_3:
-                                    userCard = UserCard.getBean(data);
-                                    break;
-                                case MyCommon.MANAGE_CRAD:
-                                    viweGone(false);
-                                    redCardBinding.readCardTypeTV.setText("褰撳墠涓虹鐞嗗崱");
-                                    stopAnim();
-                                    break;
-                                case MyCommon.CLEAN_CARD_TYPE:
-                                    viweGone(false);
-                                    redCardBinding.readCardTypeTV.setText("褰撳墠涓烘竻闆跺崱");
-                                    stopAnim();
-                                    break;
-                                case MyCommon.REGISTERED_CARD_TYPE:
-                                    viweGone(false);
-                                    redCardBinding.readCardTypeTV.setText("褰撳墠涓洪噸鏂版敞鍐岃澶囧崱");
-                                    stopAnim();
 
-                                    break;
-                                case MyCommon.CLEAN_ALL_USER_CARD_TYPE:
-                                    viweGone(false);
-                                    redCardBinding.readCardTypeTV.setText("褰撳墠涓哄垹闄ゅ叏閮ㄧ敤鎴峰崱");
-                                    stopAnim();
-                                    break;
-                                case MyCommon.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 MyCommon.TEST_CARD_TYPE:
-                                    viweGone(false);
-                                    redCardBinding.readCardTypeTV.setText("褰撳墠涓烘祴璇曞崱");
-                                    stopAnim();
-                                    break;
-                                case MyCommon.CONFIGURATION_CARD_TYPE:
-                                    viweGone(false);
-                                    redCardBinding.readCardTypeTV.setText("褰撳墠涓洪厤缃澶囨敞鍐屼俊鎭崱");
-                                    stopAnim();
-                                    break;
-                                case MyCommon.CONFIGURATION_POWER_CARD_TYPE:
-                                    viweGone(false);
-                                    redCardBinding.readCardTypeTV.setText("褰撳墠閰嶇疆姘存车鍔熺巼鍗�");
-                                    ConfigurationPowerCard powerCard = ConfigurationPowerCard.toBean(data.get(0));
-                                    redCardBinding.readCardDataTV.setText(powerCard.getPower());
-                                    stopAnim();
-                                    break;
-                                case MyCommon.BLACK:
-                                    viweGone(false);
-                                    redCardBinding.readCardTypeTV.setText("褰撳墠涓洪粦鍗�");
-                                    BlackCard blackCard = BlackCard.getBean(data);
-                                    redCardBinding.readCardDataTV.setText("褰撳墠榛戝崱鐢ㄦ埛鍙蜂负锛�" + blackCard.getBlackCard());
-                                    break;
-                                case MyCommon.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 MyCommon.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();
+        String state = "";
+        if (cardType.equalsIgnoreCase(CardCommon.USER_CARD_TYPE_1)) {
+            state = "缁堢鍐欏崱";
+        } else if (cardType.equalsIgnoreCase(CardCommon.USER_CARD_TYPE_2)) {
+            state = "鍒峰崱寮�娉靛悗";
+        } else if (cardType.equalsIgnoreCase(CardCommon.USER_CARD_TYPE_3)) {
+            state = "鍙犲姞鍏呭��";
+        }
+        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(), state, cardNumber);
                         } else {
-                            TipUtil.show(ReadCardAcitivy.this, "鍗$墖鏃犳硶璇嗗埆");
-                            stopAnim();
+                            setUserData("鏈煡璇㈠埌鐢ㄦ埛鍚�", state, cardNumber);
                         }
+                    } else {
 
                     }
+                } else {
+                    TipUtil.show("鍗$墖璇嗗埆閿欒,璇烽噸璇曪紒");
+                }
 
-                    @Override
-                    public void error(int code) {
-                        switch (code) {
-                            case MyCommon.ERROR_MOVE:
-                                stopAnim();
-                                TipUtil.show("杩炴帴涓柇锛岃閲嶆柊璐村悎鍗$墖");
-                                break;
-                            default:
-                                stopAnim();
-                                TipUtil.show("鍗$墖璇嗗埆閿欒,璇烽噸璇曪紒");
-                        }
-                    }
-                });
+                break;
+            case CardCommon.MANAGE_CRAD:
+                viweGone(false);
+                redCardBinding.readCardTypeTV.setText("褰撳墠涓虹鐞嗗崱");
+                break;
+            case CardCommon.CLEAN_CARD_TYPE:
+                viweGone(false);
+                redCardBinding.readCardTypeTV.setText("褰撳墠涓烘竻闆跺崱");
+                break;
+            case CardCommon.REGISTERED_CARD_TYPE:
+                viweGone(false);
+                redCardBinding.readCardTypeTV.setText("褰撳墠涓洪噸鏂版敞鍐岃澶囧崱");
+                break;
+            case CardCommon.CLEAN_ALL_USER_CARD_TYPE:
+                viweGone(false);
+                redCardBinding.readCardTypeTV.setText("褰撳墠涓哄垹闄ゅ叏閮ㄧ敤鎴峰崱");
+                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("鍗$墖璇嗗埆閿欒,璇烽噸璇曪紒");
+                }
+                break;
+            case CardCommon.TEST_CARD_TYPE:
+                viweGone(false);
+                redCardBinding.readCardTypeTV.setText("褰撳墠涓烘祴璇曞崱");
+                break;
+            case CardCommon.CONFIGURATION_CARD_TYPE:
+                viweGone(false);
+                redCardBinding.readCardTypeTV.setText("褰撳墠涓洪厤缃澶囨敞鍐屼俊鎭崱");
+                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("鍗$墖璇嗗埆閿欒,璇烽噸璇曪紒");
+                }
+                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());
+                    electricPriceBuilder.append("鍏�");
+                    redCardBinding.readCardDataTV.setText(electricPriceBuilder.toString());
+                } else {
+                    TipUtil.show("鍗$墖璇嗗埆閿欒,璇烽噸璇曪紒");
+                }
+                break;
+            default:
+                TipUtil.show(ReadCardAcitivy.this, "鍗$墖鏃犳硶璇嗗埆");
+                break;
+        }
+        stopAnim();
+
     }
 
 

--
Gitblit v1.8.0