中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android如何在安卓上實現通用卡證識別

發布時間:2021-11-15 11:17:12 來源:億速云 閱讀:164 作者:iii 欄目:移動開發

這篇文章主要介紹“Android如何在安卓上實現通用卡證識別”,在日常操作中,相信很多人在Android如何在安卓上實現通用卡證識別問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Android如何在安卓上實現通用卡證識別”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

1 開發準備

這里列舉關鍵的開發步驟。

1.1 在項目級gradle里添加華為maven倉

??打開AndroidStudio項目級build.gradle文件,增量添加如下maven地址:

buildscript {
    repositories {        
        maven {url 'http://developer.huawei.com/repo/'}
    }    }allprojects {
    repositories {       
        maven { url 'http://developer.huawei.com/repo/'}
    }}

1.2 在應用級的build.gradle里面加上SDK依賴

dependencies{  
  // 引入基礎SDK 
  implementation 'com.huawei.hms:ml-computer-vision-ocr:1.0.3.300' 
  // 引入拉丁語文字識別模型包 
  implementation 'com.huawei.hms:ml-computer-vision-ocr-latin-model:1.0.3.300' 
  // 引入銀行卡識別plugin包 
  implementation 'com.huawei.hms:ml-computer-card-gcr-plugin:1.0.3.300' }

??將以下語句添加到AndroidManifest.xml文件中:

<manifest 
    ... 
    <meta-data              
        android:name="com.huawei.hms.ml.DEPENDENCY"   
        android:value= "ocr"/> 
    ... </manifest>

1.3 配置混淆腳本

按照官網操作指導來就行了:
https://developer.huawei.com/consumer/cn/doc/development/HMS-Guides/ml-configuringobfuscation-scripts-4

1.4 在AndroidManifest.xml文件里面申請相機和存儲權限

都是些基本操作,廢話也不多說,按照官網指導來操作:
https://developer.huawei.com/consumer/cn/doc/development/HMS-Guides/ml-assigning-permissions-4

2 代碼開發

2.1 啟動卡證識別

@Override 
public void onClick(View v) { 
    switch (v.getId()) { 
        // 相冊圖片檢測按鈕。 
        case R.id.detect_picture: 
            this.startLocalImageActivity(cardImage, null, callback); 
            break; 
        // 視頻流檢測按鈕。 
        case R.id.detect_video: 
            this.startCaptureActivity(null, callback); 
            break; 
        // 拍照檢測按鈕。 
        case R.id.detect_take_photo: 
            this.startTakePhotoActivity(null, callback); 
            break; 
        default: 
            break; 
        } }

視頻流識別

private void startCaptureActivity(Object object, MLGcrCapture.Callback callback) { 
    // 創建通用卡證識別配置器。 
    MLGcrCaptureConfig cardConfig = new MLGcrCaptureConfig.Factory().create(); 
    // 創建通用卡證識別界面配置器。 
    MLGcrCaptureUIConfig uiConfig = new MLGcrCaptureUIConfig.Factory()        
        // 設置掃描框顏色。 
        .setScanBoxCornerColor(Color.GREEN) 
        // 設置掃描框中的提示文字,建議少于30個字符。 
        .setTipText("Recognizing, align edges") 
        // 設置識別界面橫豎屏,支持三種模式: 
        // MLGcrCaptureUIConfig.ORIENTATION_AUTO:自動模式,由物理感應器決定顯示方向。 
        // MLGcrCaptureUIConfig.ORIENTATION_LANDSCAPE:橫屏模式。 
        // MLGcrCaptureUIConfig.ORIENTATION_PORTRAIT:豎屏模式。 
        .setOrientation(MLGcrCaptureUIConfig.ORIENTATION_AUTO) 
        .create(); 
    // 方式一:根據自定義的卡證識別界面配置器,創建通用卡證識別處理器。 
    MLGcrCapture ocrManager = MLGcrCaptureFactory.getInstance().getGcrCapture(cardConfig, uiConfig); 
    // 方式二:使用默認界面,創建通用卡證識別處理器。 
    MLGcrCapture ocrManager = MLGcrCaptureFactory.getInstance().getGcrCapture(cardConfig); 
    // 綁定通用卡證識別處理器和處理結果回調函數。 
    ocrManager.capturePreview(this, object, callback); }

拍照識別

private void startTakePhotoActivity(Object object, MLGcrCapture.Callback callback) { 
    // 創建通用卡證識別配置器。 
    MLGcrCaptureConfig cardConfig = new MLGcrCaptureConfig.Factory().create(); 
    // 創建通用卡證識別界面配置器。 
    MLGcrCaptureUIConfig uiConfig = new MLGcrCaptureUIConfig.Factory() 
        // 設置掃描框顏色。 
        .setScanBoxCornerColor(Color.BLUE) 
        // 設置掃描框中的提示文字,建議少于30個字符。 
        .setTipText("Taking picture, align edges") 
        // 設置界面橫豎屏,支持三種模式: 
        // MLGcrCaptureUIConfig.ORIENTATION_AUTO:自動模式,由物理感應器決定顯示方向。 
        // MLGcrCaptureUIConfig.ORIENTATION_LANDSCAPE:橫屏模式。 
        // MLGcrCaptureUIConfig.ORIENTATION_PORTRAIT:豎屏模式。 
        .setOrientation(MLGcrCaptureUIConfig.ORIENTATION_AUTO) 
        .create(); 
    // 方式一:根據自定義的卡證識別界面配置器,創建通用卡證識別處理器。 
    MLGcrCapture ocrManager = MLGcrCaptureFactory.getInstance().getGcrCapture(cardConfig, uiConfig); 
    // 方式二:使用默認界面,創建通用卡證識別處理器。 
    MLGcrCapture ocrManager = MLGcrCaptureFactory.getInstance().getGcrCapture(cardConfig); 
    // 綁定通用卡證識別處理器和處理結果回調函數。 
    ocrManager.capturePhoto(this, object, callback); }

相冊圖片識別

private void startLocalImageActivity(Bitmap bitmap, Object object, MLGcrCapture.Callback callback) { 
    // 創建通用卡證識別配置器。 
    MLGcrCaptureConfig config = new MLGcrCaptureConfig.Factory().create(); 
    MLGcrCapture ocrManager = MLGcrCaptureFactory.getInstance().getGcrCapture(config); 
    // bitmap 為需要識別的Bitmap類型卡證圖像,支持的圖片格式包括:jpg/jpeg/png/bmp。 
    ocrManager.captureImage(bitmap, object, callback); }

2.2 對識別后的內容做后處理,進行關鍵信息提取

??重載onResult, onCanceled, onFailure, onDenied四個方法;onResult表示返回了結果,MLGcrCaptureResult為卡證識別返回的結果,onCanceled 表示用戶取消,onFailure 表示識別失敗,onDenied 表示相機不可用等場景。

private MLGcrCapture.Callback callback = new MLGcrCapture.Callback() {
        @Override
        public int onResult(MLGcrCaptureResult result, Object object) {
            Log.i(TAG, "callback onRecSuccess");
            if (result == null) {
                Log.e(TAG, "callback onRecSuccess result is null");
                return MLGcrCaptureResult.CAPTURE_CONTINUE;
            }
            GeneralCardProcessor idCard = null;
            GeneralCardResult cardResult = null;
            /*港澳臺通行證處理*/            
            if (cardTypeEnum == CardType.PASSCARD) {
                idCard = new PassCardProcessor(result.text);
            /*香港身份證處理*/
            } else if (cardTypeEnum == CardType.HKIDCARD) {
                idCard = new HKIdCardProcessor(result.text);
            /*回鄉證處理*/
            } else if (cardTypeEnum == CardType.COMEHOMECARD) {
                idCard = new HomeCardProcessor(result.text);
            }
            if (idCard != null) {
                /*獲取處理后的結果*/
                cardResult = idCard.getResult();
            }
            showFrontImage(result.cardBitmap);
            displayResult(cardResult);
            // If the results don't match
            if (cardResult == null || cardResult.valid.isEmpty() || cardResult.number.isEmpty()) {
                return MLGcrCaptureResult.CAPTURE_CONTINUE;
            }
            displayResult(cardResult);
            return MLGcrCaptureResult.CAPTURE_STOP;
        }       
    };}   
};

??具體的卡號提取處理邏輯可以通過重寫GeneralCardProcessor 類中的getResult()方法來完成,以港澳臺通行證舉例,更加詳細的處理可以看github上的源碼:

public class PassCardProcessor implements GeneralCardProcessor {
    private static final String TAG = "PassCardProcessor";
    private final MLText text;
    public PassCardProcessor(MLText text) {
        this.text = text;
    }
    @Override
    public GeneralCardResult getResult() {
        List<MLText.Block> blocks = text.getBlocks();
        if (blocks.isEmpty()) {
            Log.i(TAG, "Result blocks is empty");
            return null;
        }
        ArrayList<BlockItem> originItems = getOriginItems(blocks);
        String valid = "";
        String number = "";
        boolean validFlag = false;
        boolean numberFlag = false;
        for (BlockItem item : originItems) {
            String tempStr = item.text;
            if (!validFlag) {
                String result = tryGetValidDate(tempStr);
                if (!result.isEmpty()) {
                    valid = result;
                    validFlag = true;
                }
            }
            if (!numberFlag) {
                String result = tryGetCardNumber(tempStr);
                if (!result.isEmpty()) {
                    number = result;
                    numberFlag = true;
                }
            }
        }        
        return new GeneralCardResult(valid, number);
    } }

到此,關于“Android如何在安卓上實現通用卡證識別”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

溧阳市| 江永县| 长治县| 淮南市| 蒲城县| 霞浦县| 邹平县| 银川市| 怀来县| 焦作市| 长垣县| 南漳县| 陕西省| 榆社县| 鲁山县| 利辛县| 安平县| 盐城市| 冀州市| 东乌| 古浪县| 肇东市| 镶黄旗| 浦北县| 虎林市| 雷山县| 舒兰市| 东至县| 万宁市| 吉隆县| 镇宁| 凌海市| 邛崃市| 贡嘎县| 资源县| 彭山县| 色达县| 轮台县| 于田县| 睢宁县| 太谷县|