掃一掃,原來這麼簡單

来源:https://www.cnblogs.com/hmscore/archive/2023/03/22/17243955.html
-Advertisement-
Play Games

二維碼識別技術已廣泛應用在移動支付、實用工具、電商購物、社交通訊等場景。然而,在實際生活中,二維碼容易遇到距離遠、暗光、強光、污損、模糊和大角度傾斜等複雜場景,導致識別困難,掃碼體驗差。華為HMS Core 統一掃碼服務(Scan Kit)為開發者們的APP帶來一站式掃碼解決方案,並且擁有高識別率和 ...


二維碼識別技術已廣泛應用在移動支付、實用工具、電商購物、社交通訊等場景。然而,在實際生活中,二維碼容易遇到距離遠、暗光、強光、污損、模糊和大角度傾斜等複雜場景,導致識別困難,掃碼體驗差。華為HMS Core 統一掃碼服務(Scan Kit)為開發者們的APP帶來一站式掃碼解決方案,並且擁有高識別率和快速識別等特點。

距離太遠、碼圖過小?

在停車場掃碼繳費、上課掃碼簽到、廣告牌宣傳等實際生活場景中,二維碼的尺寸不一,一般的掃碼功能需手動調節手機相機框與二維碼的距離直到合適的掃碼大小,實屬不便。統一掃碼服務基於自研的深度學習演算法模型,遇到遠距離場景、碼圖過小、甚至肉眼無法分辨的情況,支持自動檢測放大,智能識別。

多角度、光線不佳、模糊等複雜場景無法識別?

餐桌、共用單車、充電樁等設備上的二維碼,易受環境或人為影響,導致污損、模糊、反光,無法清晰展示,造成識別困難。統一掃碼服務基於多項電腦視覺技術,可以大幅提升複雜場景識別率,統一掃碼服務可以自動檢測及旋轉糾正,能夠在識別任意角度的同時保證準確率。

單個掃碼效率低?

在錄入商品信息、快遞信息等需要頻繁掃碼的場景中,一般的掃碼功能識別成功後會自動跳轉,操作不便。統一掃碼服務為您帶來連續掃碼功能,對相機內連續出現的二維碼識別檢測,避免識別成功自動跳轉的問題。同時,多碼識別模式下,統一掃碼服務最多可同時識別不限種類的5個碼,大幅提升工作效率。

另外,HMS Core 統一掃碼服務為助力開發者們構建流暢的掃碼體驗,帶來更加完善的功能:

① 支持識別/生成13種主流碼格式;

② 支持自定義掃碼界面;

③ 支持分析12個場景的碼內容,提取結構化數據;

④ 提供記憶體 1.1M / 3.3M 兩種SDK及4種不同類型的調用方式,安卓版本最少5行代碼即可快速接入。

下麵是接入 HMS Core 統一掃碼服務的開發步驟,以Default View Mode為例,只需簡單的集成就可為應用構建掃碼能力。

開發步驟

1. 開發準備

詳細準備步驟可參考華為開發者聯盟官網

2. 集成準備

Default View Mode提供相機掃碼和導入圖片掃碼兩個功能,提供完整的Activity,不需要您開發掃碼界面。

註意:使用此種模式請確保您的應用沒有關閉硬體加速,即“hardwareAccelerated”為“true”。否則在個別機型可能會出現黑屏問題。

3. 業務流程

使用Default View Mode的主要業務流程如下:

  1. 用戶打開App發起掃碼申請。

  2. 校驗是否有相機許可權。

  3. 許可權驗證通過後,調用HMS Core SDK的startScan掃碼介面,啟動掃碼界面。若需要滿足最小許可權和場景化觸發要求,文件讀取許可權在用戶點擊後觸發場景,需要設置錯誤監聽,檢測到無文件讀取許可權,Scan Kit報錯退出Default View。

  4. 判斷掃碼頁面啟動狀態。

  5. HMS Core SDK回調應用的“onActivityResult”介面。

  6. 根據掃碼狀態RESULT_CODE獲取掃碼結果:若SUCCESS返回結果給用戶;若結果為ERROR_NO_READ_PERMISSION,需要應用主動申請文件讀取許可權,重新進入Default View。

  7. App封裝掃碼結果返回給用戶。

  1. 開發步驟
  1. (可選)根據實際需求創建掃碼選項參數。

Scan Kit預設支持13種碼制式,您也可以指定Scan Kit只掃描特定的碼制式以提高掃碼速度。例如,當僅需要檢測QR碼和DataMatrix碼時,請按照以下示例構建HmsScanAnalyzerOptions對象。如果不限制檢測碼格式,您可以不創建HmsScanAnalyzerOptions對象。“1”為您設置的掃碼標題樣式參數,對應setViewType方法中的“var1”參數。

// “QRCODE_SCAN_TYPE”和“DATAMATRIX_SCAN_TYPE”表示只掃描QR和DataMatrix的碼,setViewType設置掃碼標題,0表示設置掃碼標題為”掃描二維碼/條碼“,1表示設置掃碼標題為”掃描二維碼“,預設為0;setErrorCheck設置錯誤監聽,true表示監聽錯誤並退出掃碼頁面,false表示不上報錯誤,僅檢查到識別結果後退出掃碼頁面,預設為false

HmsScanAnalyzerOptions options = new HmsScanAnalyzerOptions.Creator().setHmsScanTypes(HmsScan.QRCODE_SCAN_TYPE,HmsScan.DATAMATRIX_SCAN_TYPE).setViewType(1).setErrorCheck(true).create();
  1. 調用ScanUtil的靜態方法startScan啟動Default View掃碼頁面。用戶可以使用相機掃碼,也可以通過該頁面的“導入圖片”按鈕檢測圖片中的碼。

“REQUEST_CODE_SCAN_ONE”為您設置的請求碼參數,對應“onActivityResult”方法中的“requestCode”參數,用於判斷“onActivityResult”調用是否來自Scan Kit掃碼結果回調。若“requestCode”參數等於您設置的請求碼參數,則表示本次“onActivityResult”是Scan Kit的掃碼結果回調。

如果您沒有指定只檢測特定的碼制式,此處的options可以置為“null”,表示預設檢測Scan Kit支持的碼制式

ScanUtil.startScan(this, REQUEST_CODE_SCAN_ONE, options);
  1. 實現回調介面接收掃碼結果,相機掃碼和導入圖片掃碼均通過該介面返回。

    調用Activity的“onActivityResult”方法獲取Intent參數,掃描結果對象HmsScan封裝在其中。如何獲取Intent參數請參見RESULT

若“requestCode”等於步驟2中定義的“REQUEST_CODE_SCAN_ONE”請求碼參數,則表示本次接收的Intent是Scan Kit返回的結果。

通過Intent中的RESULT_CODE獲取掃碼狀態。

通過Intent中的RESULT獲取掃碼結果HmsScan,其中包含的信息參見碼值解析

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);
    if (resultCode != RESULT_OK || data == null) {
        return;
    }
    if (requestCode == REQUEST_CODE_SCAN_ONE) {
        // 導入圖片掃描返回結果
        int errorCode = data.getIntExtra(ScanUtil.RESULT_CODE, ScanUtil.SUCCESS);
        if (errorCode == ScanUtil.SUCCESS) {
        Object obj = data.getParcelableExtra(ScanUtil.RESULT);
        if (obj != null) {
                // 展示掃碼結果
        ...
            }
    }
        if (errorCode == ScanUtil.ERROR_NO_READ_PERMISSION) {
            // 無文件許可權,請求文件許可權
        ...
        }
    }
}

瞭解更多詳情>>

訪問華為開發者聯盟官網
獲取開髮指導文檔
華為移動服務開源倉庫地址:GitHubGitee

關註我們,第一時間瞭解 HMS Core 最新技術資訊~


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、內連接 語法: SELECT 查詢欄位1,查詢欄位2, ... FROM 表1 [INNER] JOIN 表2 ON 表1.關係欄位=表2.關係欄位 準備數據 -- 若存在資料庫mydb則刪除 DROP DATABASE IF EXISTS mydb; -- 創建資料庫mydb CREATE D ...
  • 首發微信公眾號:SQL資料庫運維 原文鏈接:https://mp.weixin.qq.com/s?__biz=MzI1NTQyNzg3MQ==&mid=2247485212&idx=1&sn=450e9e94fa709b5eeff0de371c62072b&chksm=ea37536cdd40da7 ...
  • MySQL基礎:約束 概述 概念:約束是作用於表中欄位上的規則,用於限制存儲在表中的數據。 目的:保證資料庫中的數據的正確、有效和完整性。 分類: | 約束 | 描述 | 關鍵字 | | : : | : : | : : | | 非空約束 | 限制該欄位的數據不能為null | NOT NULL | ...
  • 數字革命悄然爆發,與互聯網互相成就的“人氣王”MySQL開源資料庫,如今也正面臨突破發展瓶頸的關鍵時刻,作為記憶體中的實時數據平臺,虹科提供的Redis企業版資料庫能與MySQL輕鬆實現協同合作,帶領MYSQL跑贏數字時代! ...
  • 身處數字經濟時代,隨著大數據應用越來越廣泛,越來越多的企業和組織開始關註大數據基礎平臺的建設和運營。在認識到其的重要性之後,如何具體著手搭建或採購大數據基礎平臺成為下一步需要解決的問題。 在大數據基礎平臺中,大數據組件是非常重要的一部分,包括數據存儲、數據處理、數據分析、數據可視化等。在選擇大數據組 ...
  • 學會使用 Redis 的一個重要內容就是 Redis 的數據類型,對於開發人員而言,學會 Redis 基礎數據類型的使用即可應用到程式開發當中。 ...
  • 場景:在SQL Server資料庫的SQL優化中,我們有時候會需要找出某個視圖的依賴對象,簡單的視圖倒是很容易一眼就找出依賴對象,一旦遇到一些複雜的視圖,如果我們手動整理的話,就相當麻煩了,因為你要一個對象一個對象的捋一遍。相當的耗時耗力,其實這種機械、重覆、繁雜的事情就應該讓機器(SQL)去處理。 ...
  • 一、單表查詢 庫表student.report,有3個欄位, 姓名、 學科、 成績, 記錄如下, 根據要求完成SQL語句 | Name | Subject | Result | | | | | | 李白 | Math | 95 | | 杜甫 | English | 83 | | 李商隱 | Math ...
一周排行
    -Advertisement-
    Play Games
  • 1、預覽地址:http://139.155.137.144:9012 2、qq群:801913255 一、前言 隨著網路的發展,企業對於信息系統數據的保密工作愈發重視,不同身份、角色對於數據的訪問許可權都應該大相徑庭。 列如 1、不同登錄人員對一個數據列表的可見度是不一樣的,如數據列、數據行、數據按鈕 ...
  • 前言 上一篇文章寫瞭如何使用RabbitMQ做個簡單的發送郵件項目,然後評論也是比較多,也是準備去學習一下如何確保RabbitMQ的消息可靠性,但是由於時間原因,先來說說設計模式中的簡單工廠模式吧! 在瞭解簡單工廠模式之前,我們要知道C#是一款面向對象的高級程式語言。它有3大特性,封裝、繼承、多態。 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 介紹 Nodify是一個WPF基於節點的編輯器控制項,其中包含一系列節點、連接和連接器組件,旨在簡化構建基於節點的工具的過程 ...
  • 創建一個webapi項目做測試使用。 創建新控制器,搭建一個基礎框架,包括獲取當天日期、wiki的請求地址等 創建一個Http請求幫助類以及方法,用於獲取指定URL的信息 使用http請求訪問指定url,先運行一下,看看返回的內容。內容如圖右邊所示,實際上是一個Json數據。我們主要解析 大事記 部 ...
  • 最近在不少自媒體上看到有關.NET與C#的資訊與評價,感覺大家對.NET與C#還是不太瞭解,尤其是對2016年6月發佈的跨平臺.NET Core 1.0,更是知之甚少。在考慮一番之後,還是決定寫點東西總結一下,也回顧一下.NET的發展歷史。 首先,你沒看錯,.NET是跨平臺的,可以在Windows、 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 添加節點(nodes) 通過上一篇我們已經創建好了編輯器實例現在我們為編輯器添加一個節點 添加model和viewmode ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...
  • 類型檢查和轉換:當你需要檢查對象是否為特定類型,並且希望在同一時間內將其轉換為那個類型時,模式匹配提供了一種更簡潔的方式來完成這一任務,避免了使用傳統的as和is操作符後還需要進行額外的null檢查。 複雜條件邏輯:在處理複雜的條件邏輯時,特別是涉及到多個條件和類型的情況下,使用模式匹配可以使代碼更 ...
  • 在日常開發中,我們經常需要和文件打交道,特別是桌面開發,有時候就會需要載入大批量的文件,而且可能還會存在部分文件缺失的情況,那麼如何才能快速的判斷文件是否存在呢?如果處理不當的,且文件數量比較多的時候,可能會造成卡頓等情況,進而影響程式的使用體驗。今天就以一個簡單的小例子,簡述兩種不同的判斷文件是否... ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...