超簡單Android集成華為HMS Scankit 掃碼SDK實現(xiàn)掃一掃二維碼
前言
最近要做一個停車場掃碼收費的app,在網(wǎng)上搜了一圈,首先接觸到了ZXing,上手試了下,集成過程不復雜,但是感覺效果欠佳,比如距離稍微遠點兒就掃不出來了,另外角度對的不好,反光或者光線比較暗的時候,成功率也比較低,集成好給我們老大看了下,感覺不是很滿意。最近偶爾看到了華為一個發(fā)布會里面有介紹掃碼功能,稍微研究了下,居然是一款免費掃碼神器,官方稱之為Scan Kit,號稱還同時支持Android和iOS,半信半疑上手搞了一把發(fā)現(xiàn)效果還真不錯!測了下發(fā)現(xiàn)對于一些有反光,污損,形變,超遠距離的場景都能很好地識別!
今天簡單總結(jié)了下,分享給大家,碼字不易,也算是疫情期間,給大家的一點小小福利。
官網(wǎng)的Demo和Sample代碼體驗
官網(wǎng)有Demo可以直接下下來體驗,還有sample代碼樣例,小伙伴們可以直接到官網(wǎng)下載Demo或者示例代碼體驗下:華為官網(wǎng)的Demo和示例代碼,示例代碼下下來就可以運行。
我自己也結(jié)合下面的講解寫了個簡易的sample,各位看官也可以下下來參考。
簡易掃碼sample示例
1 開發(fā)前準備
1.1 android studio 安裝
這里就不啰嗦了,到官網(wǎng)下載和安裝:Android studio官網(wǎng)下載鏈接,Android studio安裝流程參考鏈接
1.2 在項目級gradle里添加華為maven倉

增量添加如下maven地址:
buildscript {
repositories {
maven {url 'http://developer.huawei.com/repo/'}
}
}
allprojects {
repositories {
maven { url 'http://developer.huawei.com/repo/'}
}
}
1.3 在應用級的build.gradle里面加上SDK依賴

增量添加SDK依賴,SDK他們有兩種版本,plus和普通版,plus效果好點兒但是包稍微大一點兒,這個地方我選了plus版本,小伙伴們可以根據(jù)自己需要自行選擇,版本號填他們最新的版本就好。
dependencies{
implementation 'com.huawei.hms:scanplus:1.1.1.301'
}
1.4 加一下混淆配置

復制粘貼華為官網(wǎng)上給的混淆代碼就可以了
-ignorewarnings
-keepattributes *Annotation*
-keepattributes Exceptions
-keepattributes InnerClasses
-keepattributes Signature
-keepattributes SourceFile,LineNumberTable
-keep class com.hianalytics.android.**{*;}
-keep class com.huawei.**{*;}
1.5 Manifest申請靜態(tài)權(quán)限和掃碼頁面聲明:

申請靜態(tài)權(quán)限和使用特性
<!--相機權(quán)限--> <uses-permission android:name="android.permission.CAMERA" /> <!--讀文件權(quán)限--> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> <!--使用特性--> <uses-feature android:name="android.hardware.camera" /> <uses-feature android:name="android.hardware.camera.autofocus" />
在application標簽內(nèi)添加對掃碼頁面的聲明
<!—對掃碼頁面進行聲明--> <activity android:name="com.huawei.hms.hmsscankit.ScanKitActivity" />
2 代碼開發(fā)
2.1 動態(tài)申請權(quán)限
在啟動掃碼Activity的地方添加動態(tài)權(quán)限申請。
public void loadScanKitBtnClick(View view) {
requestPermission(CAMERA_REQ_CODE, DECODE);
}
private void requestPermission(int requestCode, int mode) {
ActivityCompat.requestPermissions(
this,
new String[]{Manifest.permission.CAMERA, Manifest.permission.READ_EXTERNAL_STORAGE},
requestCode);
}
2.2 在權(quán)限申請回調(diào)中啟動掃碼界面
掃碼格式通過setHmsScanTypes指定為QR碼,小伙伴們?nèi)绻枰С制渌a可以自己指定。
@Override
public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
if (permissions == null || grantResults == null) {
return;
}
if (grantResults.length < 2 || grantResults[0] != PackageManager.PERMISSION_GRANTED || grantResults[1] != PackageManager.PERMISSION_GRANTED) {
return;
}
if (requestCode == CAMERA_REQ_CODE) {
ScanUtil.startScan(this, REQUEST_CODE_SCAN_ONE, new HmsScanAnalyzerOptions.Creator().setHmsScanTypes(HmsScan.QRCODE_SCAN_TYPE).create());
}
}
2.3 在activity回調(diào)里面獲取碼結(jié)果
@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) {
HmsScan obj = data.getParcelableExtra(ScanUtil.RESULT);
if (obj != null) {
this.textView.setText(obj.originalValue);
}
}
}
結(jié)后語
整個代碼開發(fā)過程就結(jié)束了,是不是超簡單,給大家看下效果:
效果非常贊,支持自動縮放,兩米開外瞬間就識別成功了!

附官方開發(fā)指南
到此這篇關(guān)于超簡單Android集成華為HMS Scankit 掃碼SDK實現(xiàn)掃一掃二維碼的文章就介紹到這了,更多相關(guān)Android集成華為HMS Scankit 掃碼內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android使用Room操作數(shù)據(jù)庫流程詳解
谷歌推薦使用Room操作數(shù)據(jù)庫,Room在 SQLite 上提供了一個抽象層,在充分利用 SQLite強大功能的同時,能夠流暢地訪問數(shù)據(jù)庫2022-11-11
Android中自定義的dialog中的EditText無法彈出輸入法解決方案
這篇文章主要介紹了Android中自定義的dialog中的EditText無法彈出輸入法解決方案,需要的朋友可以參考下2017-04-04
Android Zygote啟動構(gòu)造流程及進程創(chuàng)建詳解
這篇文章主要為大家介紹了Android Zygote啟動構(gòu)造流程及進程創(chuàng)建詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-07-07
android?studio數(shù)據(jù)存儲建立SQLite數(shù)據(jù)庫實現(xiàn)增刪查改
這篇文章主要介紹了vandroid?studio數(shù)據(jù)存儲建立SQLite數(shù)據(jù)庫實現(xiàn)增刪查改,分別使用sqlite3工具和Android代碼的方式建立SQLite數(shù)據(jù)庫,具體內(nèi)容,需要的小伙伴可以參考下面文章得詳細內(nèi)容2021-12-12
Android 文件存儲與SharedPreferences存儲方式詳解用法
SharedPreferences是安卓平臺上一個輕量級的存儲類,用來保存應用的一些常用配置,比如Activity狀態(tài),Activity暫停時,將此activity的狀態(tài)保存到SharedPereferences中;當Activity重載,系統(tǒng)回調(diào)方法onSaveInstanceState時,再從SharedPreferences中將值取出2021-10-10

