From 338e7ed513d21d1468c0908fdca2ea4097ee0621 Mon Sep 17 00:00:00 2001
From: weimingfei <fei_gaming@sina.com>
Date: 星期三, 10 十二月 2025 18:42:42 +0800
Subject: [PATCH] 指纹钥匙柜

---
 keyCabinet-android/app/src/main/java/com/doumee/keyCabinet/ui/face/FaceActivity.java |  203 +++++++++++++++++++++++++++++++-------------------
 1 files changed, 124 insertions(+), 79 deletions(-)

diff --git a/keyCabinet-android/app/src/main/java/com/doumee/keyCabinet/ui/face/FaceActivity.java b/keyCabinet-android/app/src/main/java/com/doumee/keyCabinet/ui/face/FaceActivity.java
index 99bf869..ca5959f 100644
--- a/keyCabinet-android/app/src/main/java/com/doumee/keyCabinet/ui/face/FaceActivity.java
+++ b/keyCabinet-android/app/src/main/java/com/doumee/keyCabinet/ui/face/FaceActivity.java
@@ -45,6 +45,7 @@
 import com.doumee.lib_coremodel.util.SpUtil;
 import com.doumee.lib_coremodel.util.StringUtil;
 import com.doumee.lib_coremodel.view.ToastView;
+import com.example.datalibrary.api.FaceApi;
 import com.example.datalibrary.callback.CameraDataCallback;
 import com.example.datalibrary.callback.FaceDetectCallBack;
 import com.example.datalibrary.db.DBManager;
@@ -63,6 +64,8 @@
 import org.greenrobot.eventbus.ThreadMode;
 
 import java.math.BigDecimal;
+import java.util.HashMap;
+import java.util.List;
 
 import dagger.hilt.android.AndroidEntryPoint;
 
@@ -536,10 +539,24 @@
             //System.out.println("==rgbInstance==>onFaceDetectCallback   "+livenessModel);
             // 寮�鍙戞ā寮�
             //isCheckFace = false;
-            if(handler.hasMessages(1)){
-                handler.removeMessages(1);
+            try {
+                runOnUiThread(new Runnable() {
+                    @Override
+                    public void run() {
+                        if(handler==null){
+                            return;
+                        }
+                        if(handler.hasMessages(1)){
+                            handler.removeMessages(1);
+                        }
+                        checkOpenDebugResult(livenessModel);
+                    }
+                });
+            }catch (Exception e){
+                e.printStackTrace();
+                ToastView.show(MApplication.mContext,"浜鸿劯鎶ラ敊2:"+e.getMessage());
             }
-            checkOpenDebugResult(livenessModel);
+
         }
 
         @Override
@@ -550,7 +567,7 @@
             /*getDB().clFail.setVisibility(View.VISIBLE);
             getDB().tv4.setText(msg);
             handler.sendEmptyMessageDelayed(0,1000);*/
-            System.out.println("==isOk==>onTip:"+msg);
+            //System.out.println("==isOk==>onTip:"+msg);
         }
 
         @Override
@@ -578,11 +595,15 @@
         if (livenessModel == null){
             return;
         }
-
-        if (isPause){
-            glMantleSurfacView.onGlDraw(livenessModel.getTrackFaceInfo() ,
-                    livenessModel.getBdFaceImageInstance() ,
-                    FaceOnDrawTexturViewUtil.drawFaceColor(mUser , livenessModel));
+        try {
+            if (isPause){
+                glMantleSurfacView.onGlDraw(livenessModel.getTrackFaceInfo() ,
+                        livenessModel.getBdFaceImageInstance() ,
+                        FaceOnDrawTexturViewUtil.drawFaceColor(mUser , livenessModel));
+            }
+        }catch (Exception e){
+            e.printStackTrace();
+            ToastView.show(MApplication.mContext,"浜鸿劯鎶ラ敊1:"+e.getMessage());
         }
     }
 
@@ -633,6 +654,9 @@
                 case 6:
                     getDB().message.setVisibility(View.GONE);
                     break;
+                case 7:
+                    identify();
+                    break;
                 default:
                     break;
             }
@@ -681,94 +705,94 @@
     private int resultCount = 0;
     // ***************寮�鍙戞ā寮忕粨鏋滆緭鍑�*************
     private void checkOpenDebugResult(final LivenessModel livenessModel) {
-        if(isFinishing()){
-            return;
-        }
-        if(handler==null){
-            return;
-        }
-        // 褰撴湭妫�娴嬪埌浜鸿劯UI鏄剧ず
-        runOnUiThread(new Runnable() {
-            @Override
-            public void run() {
-                if(isToChose) {
-                    return;
-                }
-                if (livenessModel == null) {
-                    if (isCompareCheck) {
+        try {
+            if (isFinishing()) {
+                return;
+            }
+            if (handler == null) {
+                return;
+            }
+            // 褰撴湭妫�娴嬪埌浜鸿劯UI鏄剧ず
+            if (isToChose) {
+                return;
+            }
+            if (livenessModel == null) {
+                if (isCompareCheck) {
                         /*getDB().clFail.setVisibility(View.VISIBLE);
                         getDB().tv4.setText(getString(R.string.face_tip2));
                         handler.sendEmptyMessageDelayed(0,1000);*/
-                    }
-                    System.out.println("======>浜鸿劯璇嗗埆澶辫触");
-                    return;
                 }
-                if (livenessModel.isQualityCheck()){
-                    //鏄惁閫氳繃璐ㄩ噺妫�娴�
-                    if (isCompareCheck) {
+                //System.out.println("======>浜鸿劯璇嗗埆澶辫触");
+                return;
+            }
+            if (livenessModel.isQualityCheck()) {
+                //鏄惁閫氳繃璐ㄩ噺妫�娴�
+                if (isCompareCheck) {
                         /*getDB().clFail.setVisibility(View.VISIBLE);
                         getDB().tv4.setText(getString(R.string.face_tip2));
                         handler.sendEmptyMessageDelayed(0,1000);*/
-                    }
-                } else {
-                    User user = livenessModel.getUser();
-                    if (user == null) {
-                        mUser = null;
-                        //EventBus.getDefault().post(new HttpEvent("浜鸿劯鐢ㄦ埛妫�娴嬪け璐�------->"+(status==0?"绠$悊鍛樹汉鑴告娴嬶細":"鍙告満浜鸿劯妫�娴嬶細")));
-                        if (isCompareCheck) {
+                }
+            } else {
+                User user = livenessModel.getUser();
+                if (user == null) {
+                    mUser = null;
+                    //EventBus.getDefault().post(new HttpEvent("浜鸿劯鐢ㄦ埛妫�娴嬪け璐�------->"+(status==0?"绠$悊鍛樹汉鑴告娴嬶細":"鍙告満浜鸿劯妫�娴嬶細")));
+                    if (isCompareCheck) {
                             /*getDB().clFail.setVisibility(View.VISIBLE);
                             getDB().tv4.setText(getString(R.string.face_tip2));
                             handler.sendEmptyMessageDelayed(0,1000);*/
-                        }
+                    }
 
-                    } else {
-                        mUser = user;
+                } else {
+                    mUser = user;
                         /*EventBus.getDefault().post(new HttpEvent("浜鸿劯鐢ㄦ埛------->"+(status==0?"绠$悊鍛樹汉鑴告娴嬶細":"鍙告満浜鸿劯妫�娴嬶細")
                                 +(user.getGroupId().equals("0")?"绠$悊鍛�":"鍙告満")));*/
-                        if (isCompareCheck) {
-                            getDB().clFail.setVisibility(View.GONE);
-                            if(handler.hasMessages(0)) {
-                                handler.removeMessages(0);
-                            }
+                    if (isCompareCheck) {
+                        getDB().clFail.setVisibility(View.GONE);
+                        if (handler.hasMessages(0)) {
+                            handler.removeMessages(0);
+                        }
                             /*textHuanying.setVisibility(View.GONE);
                             userNameLayout.setVisibility(View.VISIBLE);
                             nameImage.setImageResource(R.mipmap.ic_tips_gate_success);
                             nameText.setTextColor(Color.parseColor("#0dc6ff"));
                             nameText.setText(FileUtils.spotString(user.getUserName()) + " 娆㈣繋鎮�");*/
-                        }
-                        isToChose = true;
-                        //璇嗗埆鎴愬姛锛岃烦杞�
-                        if(status==0){
-                            //鍙�-绠$悊鍛�
-                            MApplication.getLoginBean().setAutoMemberId(Integer.parseInt(user.getUserId()));
-                            //handler.sendEmptyMessageDelayed(7,0);
-                            EventBus.getDefault().post(new FaceStatusChangeEvent(5));
-                        }else if(status==2){
-                            //鍙�-鍙告満
-                            CameraPreviewManager.getInstance().stopPreview();
-                            MApplication.getLoginBean().setMemberId(Integer.parseInt(user.getUserId()));
-                            MApplication.getLoginBean().setAuthType(0);
-                            //handler.sendEmptyMessageDelayed(8,0);
-                            //Toast.makeText(mContext, "鏄惁閰掔簿妫�娴嬶細"+MApplication.getConfigBean().getAlcoholStatus(), Toast.LENGTH_SHORT).show();
-                            if(MApplication.getConfigBean()!=null&&MApplication.getConfigBean().getAlcoholStatus()==1) {
-                                //闈為厭绮炬娴�
-                                startActivity(KeyCabinetActivity.class);
-                                finish();
-                            }else {
-                                //閰掔簿妫�娴�
-                                EventBus.getDefault().post(new FaceStatusChangeEvent(4));
-                            }
-                        }else if(status==7){
-                            //杩�-鍙告満
-                            MApplication.getLoginBean().setMemberId(Integer.parseInt(user.getUserId()));
-                            MApplication.getLoginBean().setAuthType(0);
+                    }
+                    isToChose = true;
+                    //璇嗗埆鎴愬姛锛岃烦杞�
+                    if (status == 0) {
+                        //鍙�-绠$悊鍛�
+                        MApplication.getLoginBean().setAutoMemberId(Integer.parseInt(user.getUserId()));
+                        //handler.sendEmptyMessageDelayed(7,0);
+                        EventBus.getDefault().post(new FaceStatusChangeEvent(5));
+                    } else if (status == 2) {
+                        //鍙�-鍙告満
+                        CameraPreviewManager.getInstance().stopPreview();
+                        MApplication.getLoginBean().setMemberId(Integer.parseInt(user.getUserId()));
+                        MApplication.getLoginBean().setAuthType(0);
+                        //handler.sendEmptyMessageDelayed(8,0);
+                        //Toast.makeText(mContext, "鏄惁閰掔簿妫�娴嬶細"+MApplication.getConfigBean().getAlcoholStatus(), Toast.LENGTH_SHORT).show();
+                        if (MApplication.getConfigBean() != null && MApplication.getConfigBean().getAlcoholStatus() == 1) {
+                            //闈為厭绮炬娴�
                             startActivity(KeyCabinetActivity.class);
                             finish();
+                        } else {
+                            //閰掔簿妫�娴�
+                            EventBus.getDefault().post(new FaceStatusChangeEvent(4));
                         }
+                    } else if (status == 7) {
+                        //杩�-鍙告満
+                        MApplication.getLoginBean().setMemberId(Integer.parseInt(user.getUserId()));
+                        MApplication.getLoginBean().setAuthType(0);
+                        startActivity(KeyCabinetActivity.class);
+                        finish();
                     }
                 }
             }
-        });
+        }catch (Exception e){
+            e.printStackTrace();
+            ToastView.show(MApplication.mContext,"浜鸿劯鎶ラ敊锛�"+e.getMessage());
+        }
     }
 
     @Subscribe(threadMode = ThreadMode.MAIN)
@@ -828,14 +852,31 @@
             public void run() {
                 FingerPrintDo printDo = DaoManager.getFingerPrintDao().getByFingerId(fingerId);
                 if(printDo!=null){
+                    List<User> users = FaceApi.getInstance().getAllUserList();
+                    HashMap<String,String> map = new HashMap<>();
+                    for(User u:users){
+                        if(u.getUserId().equals(printDo.getMemberId()+"")){
+                            map.put(u.getGroupId(),"");
+                        }
+                    }
                     if(status==10){
                         //鍙�-绠$悊鍛樻寚绾归獙璇�
+                        if(!map.containsKey("0")){
+                            showToast("鎮ㄥ綋鍓嶄笉鏄鐞嗗憳");
+                            handler.sendEmptyMessageDelayed(7,2000);
+                            return;
+                        }
                         MApplication.getLoginBean().setAutoMemberId(printDo.getMemberId());
                         EventBus.getDefault().post(new FaceStatusChangeEvent(5));
                     }else if(status==11){
                         //鍙�-鍙告満鎸囩汗楠岃瘉
+                        if(!map.containsKey("1")){
+                            showToast("鎮ㄥ綋鍓嶄笉鏄徃鏈�");
+                            handler.sendEmptyMessageDelayed(7,2000);
+                            return;
+                        }
                         MApplication.getLoginBean().setMemberId(printDo.getMemberId());
-                        MApplication.getLoginBean().setAuthType(2);
+                        MApplication.getLoginBean().setAuthType(3);
                         if(MApplication.getConfigBean()!=null&&MApplication.getConfigBean().getAlcoholStatus()==1) {
                             //闈為厭绮炬娴�
                             startActivity(KeyCabinetActivity.class);
@@ -846,8 +887,13 @@
                         }
                     }else if(status==12){
                         //杩�-鍙告満
+                        if(!map.containsKey("1")){
+                            showToast("鎮ㄥ綋鍓嶄笉鏄徃鏈�");
+                            handler.sendEmptyMessageDelayed(7,2000);
+                            return;
+                        }
                         MApplication.getLoginBean().setMemberId(printDo.getMemberId());
-                        MApplication.getLoginBean().setAuthType(2);
+                        MApplication.getLoginBean().setAuthType(3);
                         startActivity(KeyCabinetActivity.class);
                         finish();
                     }
@@ -855,7 +901,7 @@
                     //鎵句笉鍒帮紝鍒犻櫎鎸囩汗
                     if(deleteID(fingerId)) {
                         //缁х画鏌ユ寚绾�
-                        identify();
+                        handler.sendEmptyMessageDelayed(7,2000);
                     }else {
                         showToast("鏈煡璇㈠埌鐢ㄦ埛");
                     }
@@ -933,7 +979,6 @@
     private void identify() {
         if (!mDevComm.IsInit())
             return;
-
         mBCancel = false;
         new Thread(new Runnable() {
             int w_nRet;
@@ -991,7 +1036,7 @@
                         //m_strPost = String.format("Result : Success\r\nTemplate No : %d, Learn Result : %d\r\nMatch Time : %dms", w_nID[0], w_nLearned[0], m_nPassedTime);
                     } else {
                         //娌℃壘鍒�
-                        //showToast("娌℃壘鍒�");
+                        showToast("鏈娴嬪埌璇ユ寚绾�");
                         /*m_strPost = String.format("\r\nMatch Time : %dms", m_nPassedTime);
                         m_strPost = GetErrorMsg(w_nRet) + m_strPost;*/
                     }
@@ -1045,7 +1090,7 @@
             runOnUiThread(new Runnable() {
                 @Override
                 public void run() {
-                    Toast.makeText(mContext, msg, Toast.LENGTH_SHORT).show();
+                    ToastView.show(MApplication.mContext,msg);
                 }
             });
         }

--
Gitblit v1.9.3