From 5a8278faefaefaa90cbe438c1643c987da2f473b Mon Sep 17 00:00:00 2001 From: zuoxiao <470321431@qq.com> Date: 星期五, 08 十二月 2023 11:27:08 +0800 Subject: [PATCH] Changes --- app/src/main/java/com/dayu/recharge/activity/NewCardActivity.java | 117 ++++++++++++++++++++++++++++++++++++++++++---------------- 1 files changed, 85 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 007a915..815a50d 100644 --- a/app/src/main/java/com/dayu/recharge/activity/NewCardActivity.java +++ b/app/src/main/java/com/dayu/recharge/activity/NewCardActivity.java @@ -2,7 +2,6 @@ import android.Manifest; import android.app.Dialog; -import android.app.ProgressDialog; import android.content.Intent; import android.os.Bundle; import android.text.InputFilter; @@ -11,8 +10,6 @@ import android.view.LayoutInflater; import android.view.View; -import com.dayu.recharge.utils.DeviceNumberUtils; -import com.msd.ocr.idcard.LibraryInitOCR; import com.dayu.recharge.MyApplication; import com.dayu.recharge.card.UserCard; import com.dayu.recharge.databinding.ActivityNewCardBinding; @@ -28,14 +25,24 @@ import com.dayu.recharge.tools.HexUtil; import com.dayu.recharge.tools.Utils; import com.dayu.recharge.utils.CRC8; +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.kernal.passportreader.sdk.CardsCameraActivity; +import com.kernal.passportreader.sdk.utils.DefaultPicSavePath; +import com.kernal.passportreader.sdk.utils.ManageIDCardRecogResult; import com.permissionx.guolindev.PermissionX; import org.json.JSONException; import org.json.JSONObject; import java.util.Arrays; + +import kernal.idcard.android.ResultMessage; +import kernal.idcard.camera.CardOcrRecogConfigure; +import kernal.idcard.camera.SharedPreferencesHelper; /** * Copyright (C), 2023, @@ -63,6 +70,7 @@ setData(); initView(); // LibraryInitOCR.initOCR(NewCardActivity.this); +// registerForActivityResult() } private void initView() { @@ -100,7 +108,6 @@ TipUtil.show(NewCardActivity.this, "璇疯緭鍏ユ纭韩浠借瘉鍙�"); return; } else { - dialog = ProgressDialog.show(NewCardActivity.this, "", "姝e湪閫氫俊璇风◢鍚�", true, true); userCardBean = new UserCardBean(); userCardBean.setUserName(userName); userCardBean.setDate(date); @@ -135,12 +142,30 @@ 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); + } - Bundle bundle = new Bundle(); - bundle.putBoolean("saveImage", false); - bundle.putInt("requestCode", SCAN_IDCARD_REQUEST); - bundle.putInt("type", 0); //0韬唤璇�, 1椹鹃┒璇� - LibraryInitOCR.startScan(NewCardActivity.this, bundle); + 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); } @Override @@ -149,34 +174,57 @@ 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; } } } + + /** + * 杩涘叆鐩告満鐣岄潰鎵弿鎴愬姛涔嬪悗鐨勮皟鐢� + */ + private void CameraScanSuccess(Bundle bundle) { + ResultMessage resultMessage = (ResultMessage) bundle.getSerializable("resultMessage"); + String[] picPath = bundle.getStringArray("picpath"); + //鏁版嵁鐨勫皝瑁� + String result = ManageIDCardRecogResult.managerSucessRecogResult(resultMessage, getApplicationContext()); + try { + /** + * @param recogResult 璇嗗埆缁撴灉 + * @param picPath 鍥剧墖璺緞鏁扮粍锛宲icPath[0]: 鍏ㄥ浘璺緞锛沺icPath[1]: 瑁佸垏鍥撅紱picPath[2]: 璇佷欢澶村儚 + */ +// Intent intent = new Intent(this, ShowResultActivity.class); +// intent.putExtra("recogResult", result); +// intent.putExtra("fullPagePath", picPath[0]); +// intent.putExtra("cutPagePath", picPath[1]); +// startActivity(intent); + } catch (Exception e) { + + } + } + private void setData() { @@ -194,7 +242,7 @@ * 寮�鍗℃姤鏂� */ private void initCard() { - + ProgressDialog.show(this); String initCode = DeviceNumberUtils.getDeviceNumber(); if (TextUtils.isEmpty(initCode)) { TipUtil.show(this, "璁惧娉ㄥ唽鍙蜂负绌猴紝璇峰厛璁剧疆IP鍜岀鐞嗗憳鍦板潃"); @@ -224,7 +272,7 @@ @Override public void onSocketResponse(SocketData readData) { - dialog.dismiss(); + ProgressDialog.dismiss(); if (CRC8.isCRC8(readData.getOriginDataBytes())) { String state = BcdUtil.bcdToStr(readData.getBodyBytes()[26]); //BCD鐮�00鎴愬姛01韬唤璇佸凡娉ㄥ唽02鍏朵粬鍘熷洜澶辫触 @@ -272,7 +320,7 @@ @Override public void onSocketError(int code, String msg) { - dialog.dismiss(); + ProgressDialog.dismiss(); TipUtil.show(NewCardActivity.this, msg); } }); @@ -322,5 +370,10 @@ } } + @Override + protected void onDestroy() { + super.onDestroy(); + newCardActivity = null; + } } -- Gitblit v1.8.0