From 22ec43b446a3a46b7947171b18f8f79aa58b8bdc Mon Sep 17 00:00:00 2001
From: zuoxiao <470321431@qq.com>
Date: 星期四, 28 三月 2024 15:37:22 +0800
Subject: [PATCH] 登录界面添加版本信息

---
 app/src/main/java/com/dayu/recharge/activity/NewCardActivity.java |  130 ++++++++++++++++++++++++++++++++----------
 1 files changed, 98 insertions(+), 32 deletions(-)

diff --git a/app/src/main/java/com/dayu/recharge/activity/NewCardActivity.java b/app/src/main/java/com/dayu/recharge/activity/NewCardActivity.java
index 1c3029e..43fea77 100644
--- a/app/src/main/java/com/dayu/recharge/activity/NewCardActivity.java
+++ b/app/src/main/java/com/dayu/recharge/activity/NewCardActivity.java
@@ -1,11 +1,11 @@
 package com.dayu.recharge.activity;
 
-import android.app.Dialog;
 import android.content.Intent;
 import android.os.Bundle;
 import android.text.InputFilter;
 import android.text.Spanned;
 import android.text.TextUtils;
+import android.util.Log;
 import android.view.LayoutInflater;
 import android.view.View;
 
@@ -29,18 +29,22 @@
 import com.dayu.recharge.utils.DeviceNumberUtils;
 import com.dayu.recharge.utils.SocketUtil;
 import com.dayu.recharge.utils.TipUtil;
+import com.dayu.recharge.utils.ToastUtil;
 import com.dayu.recharge.view.ProgressDialog;
 import com.hjq.permissions.OnPermissionCallback;
 import com.hjq.permissions.Permission;
 import com.hjq.permissions.XXPermissions;
-
-import org.json.JSONException;
-import org.json.JSONObject;
+import com.kernal.passportreader.sdk.CardsCameraActivity;
+import com.kernal.passportreader.sdk.utils.DefaultPicSavePath;
 
 import java.util.Arrays;
 import java.util.List;
 import java.util.regex.Matcher;
 import java.util.regex.Pattern;
+
+import kernal.idcard.android.ResultMessage;
+import kernal.idcard.camera.CardOcrRecogConfigure;
+import kernal.idcard.camera.SharedPreferencesHelper;
 
 /**
  * Copyright (C), 2023,
@@ -52,7 +56,6 @@
 
     public static final int SCAN_IDCARD_REQUEST = 1;
     UserCardBean userCardBean;
-    Dialog dialog;
 
     ActivityNewCardBinding newCardBinding;
     AdminDataBean adminData;
@@ -95,13 +98,10 @@
             ) {
                 if (userName.length() <= 1 || !validateName(userName)) {
                     TipUtil.show(NewCardActivity.this, "璇疯緭鍏ユ纭鍚�");
-                    return;
                 } else if (phone.length() < 11 || !isValidPhoneNumber(phone)) {
                     TipUtil.show(NewCardActivity.this, "璇疯緭鍏ユ纭墜鏈哄彿");
-                    return;
                 } else if (!Utils.check(userID)) {
                     TipUtil.show(NewCardActivity.this, "璇疯緭鍏ユ纭韩浠借瘉鍙�");
-                    return;
                 } else {
                     userCardBean = new UserCardBean();
                     userCardBean.setUserName(userName);
@@ -116,6 +116,69 @@
                 TipUtil.show(NewCardActivity.this, "璇疯緭鍏ュ畬鏁村唴瀹�");
             }
         });
+
+        //韬唤璇佽瘑鍒�
+        newCardBinding.newCardScanBtn.setOnClickListener(new View.OnClickListener() {
+            @Override
+            public void onClick(View v) {
+
+                rxPermission();
+            }
+        });
+
+    }
+
+    private void rxPermission() {
+        XXPermissions.with(this)
+                // 鐢宠鍗曚釜鏉冮檺
+//                    .permission(Permission.RECORD_AUDIO)
+                // 鐢宠澶氫釜鏉冮檺
+                .permission(Permission.CAMERA)
+                .request(new OnPermissionCallback() {
+
+                    @Override
+                    public void onGranted(@NonNull List<String> permissions, boolean allGranted) {
+                            if (allGranted) {//鎵�鏈夌敵璇风殑鏉冮檺閮藉凡閫氳繃
+                                startCamera();
+                            }
+                    }
+
+                    @Override
+                    public void onDenied(@NonNull List<String> permissions, boolean doNotAskAgain) {
+                        if (doNotAskAgain) {
+                            // 濡傛灉鏄姘镐箙鎷掔粷灏辫烦杞埌搴旂敤鏉冮檺绯荤粺璁剧疆椤甸潰
+                        } else {
+//                                toast("鑾峰彇褰曢煶鍜屾棩鍘嗘潈闄愬け璐�");
+                        }
+                    }
+                });
+    }
+
+    private void startCamera() {
+        CardOcrRecogConfigure.getInstance()
+                .initLanguage(getApplicationContext())
+                .setSaveCut(true)
+                .setOpenIDCopyFuction(true)
+                .setnMainId(getSharedPreferencesStoreMainId())
+                .setnSubID(getSharedPreferencesStoreSubId())
+                .setFlag(0)
+                .setnCropType(0)
+                .setSavePath(new DefaultPicSavePath(this, true));
+        Intent intent = new Intent(this, CardsCameraActivity.class);
+        startActivityForResult(intent, SCAN_IDCARD_REQUEST);
+    }
+
+    private int defValueMainId = 2;
+    private int defValueSubId = 0;
+
+    public int getSharedPreferencesStoreMainId() {
+        return SharedPreferencesHelper.getInt(
+                getApplicationContext(), "nMainId", defValueMainId);
+    }
+
+    public int getSharedPreferencesStoreSubId() {
+        return SharedPreferencesHelper.getInt(
+                getApplicationContext(), "nSubID", defValueSubId);
     }
 
     private boolean isValidPhoneNumber(String phoneNumber) {
@@ -199,29 +262,28 @@
         if (resultCode == RESULT_OK) {
             switch (requestCode) {
                 case SCAN_IDCARD_REQUEST:
-                    String result = data.getStringExtra("OCRResult");
                     try {
-                        JSONObject jo = new JSONObject(result);
+                        //璺宠浆鎵弿鐣岄潰璇嗗埆瀹屾垚涔嬪悗锛屾暟鎹洖浼�
+                        if (data != null) {
+                            //鏁版嵁鍥炰紶鐨勮幏鍙�
+                            Bundle bundle = data.getBundleExtra("resultbundle");
+                            //bundle涓嶄负null锛屼唬琛ㄨ繖璇嗗埆鎴愬姛
+                            if (bundle != null) {
+                                ResultMessage resultMessage = (ResultMessage) bundle.getSerializable("resultMessage");
+                                newCardBinding.newCardName.setText(resultMessage.GetRecogResult[1]);
+                                newCardBinding.newCardId.setText(resultMessage.GetRecogResult[6]);
+                                newCardBinding.newCardIdTip.setVisibility(View.VISIBLE);
+                            } else {
+                                String error = data.getStringExtra("error");
+                                String StrPath = data.getStringExtra("strpicpath");
+                                ToastUtil.show(error);
+                            }
 
-//                    sb.append(String.format("姝i潰 = %s\n", jo.opt("type")));
-//                    sb.append(String.format("濮撳悕 = %s\n", jo.opt("name")));
-//                    sb.append(String.format("鎬у埆 = %s\n", jo.opt("sex")));
-//                    sb.append(String.format("姘戞棌 = %s\n", jo.opt("folk")));
-//                    sb.append(String.format("鏃ユ湡 = %s\n", jo.opt("birt")));
-//                    sb.append(String.format("鍙风爜 = %s\n", jo.opt("num")));
-//                    sb.append(String.format("浣忓潃 = %s\n", jo.opt("addr")));
-//                    sb.append(String.format("绛惧彂鏈哄叧 = %s\n", jo.opt("issue")));
-//                    sb.append(String.format("鏈夋晥鏈熼檺 = %s\n", jo.opt("valid")));
-//                    sb.append(String.format("鏁翠綋鐓х墖 = %s\n", jo.opt("imgPath")));
-//                    sb.append(String.format("澶村儚璺緞 = %s\n", jo.opt("headPath")));
-
-                        newCardBinding.newCardName.setText(jo.opt("name").toString());
-                        newCardBinding.newCardId.setText(jo.opt("num").toString());
-                        newCardBinding.newCardIdTip.setVisibility(View.VISIBLE);
-
-                    } catch (JSONException e) {
-                        throw new RuntimeException(e);
+                        }
+                    } catch (Exception e) {
+                        e.printStackTrace();
                     }
+
                     break;
             }
         }
@@ -270,7 +332,7 @@
         initCardRequestBean.setPhone(phoneBuffer.toString());
         String userId = userCardBean.getUserID();
         initCardRequestBean.setIdCard(SocketUtil.str2HexStr(userId));
-        SocketNet.getInstance().sendTestMessage(initCardRequestBean.pack(), new SocketCallBack() {
+        SocketNet.getInstance().sendTestMessage(initCardRequestBean.pack(), "93", new SocketCallBack() {
 
             @Override
             public void onSocketResponse(SocketData readData) {
@@ -278,9 +340,10 @@
                 if (CRC8.isCRC8(readData.getOriginDataBytes())) {
 
                     String state = BcdUtil.bcdToStr(readData.getBodyBytes()[26]); //BCD鐮�00鎴愬姛01韬唤璇佸凡娉ㄥ唽02鍏朵粬鍘熷洜澶辫触
+                    Log.i("initCard", "state:" + state);
                     if (state.equalsIgnoreCase("00")) {
-                        String initPeasantCode = HexUtil.bytesToHex(Arrays.copyOfRange(readData.getBodyBytes(), 10, 26));
 
+                        String initPeasantCode = HexUtil.bytesToHex(Arrays.copyOfRange(readData.getBodyBytes(), 10, 26));
                         String serial = baseDao.adminDao().findFirst().getSerial();
                         UserCard userCard = new UserCard();
                         userCard.setRechargeTimes(0);
@@ -322,8 +385,11 @@
 
             @Override
             public void onSocketError(int code, String msg) {
-                ProgressDialog.dismiss();
-                TipUtil.show(NewCardActivity.this, msg);
+
+                runOnUiThread(() -> {
+                    ProgressDialog.dismiss();
+                    TipUtil.show(NewCardActivity.this, msg);
+                });
             }
         });
 

--
Gitblit v1.8.0