超簡單Android整合華為HMS Scankit 掃碼SDK實現掃一掃二維碼
前言
最近要做一個停車場掃碼收費的app,在網上搜了一圈,首先接觸到了ZXing,上手試了下,整合過程不復雜,但是感覺效果欠佳,比如距離稍微遠點兒就掃不出來了,另外角度對的不好,反光或者光線比較暗的時候,成功率也比較低,整合好給我們老大看了下,感覺不是很滿意。最近偶爾看到了華為一個釋出會裡面有介紹掃碼功能,稍微研究了下,居然是一款免費掃碼神器,官方稱之為Scan Kit,號稱還同時支援Android和iOS,半信半疑上手搞了一把發現效果還真不錯!測了下發現對於一些有反光,汙損,形變,超遠距離的場景都能很好地識別!
今天簡單總結了下,分享給大家,碼字不易,也算是疫情期間,給大家的一點小小福利。
官網的Demo和Sample程式碼體驗
官網有Demo可以直接下下來體驗,還有sample程式碼樣例,小夥伴們可以直接到官網下載Demo或者示例程式碼體驗下:華為官網的Demo和示例程式碼,示例程式碼下下來就可以執行。
我自己也結合下面的講解寫了個簡易的sample,各位看官也可以下下來參考。
簡易掃碼sample示例
1 開發前準備
1.1 android studio 安裝
這裡就不囉嗦了,到官網下載和安裝:Android studio官網下載連結,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版本,小夥伴們可以根據自己需要自行選擇,版本號填他們最新的版本就好。
dependencies{ implementation 'com.huawei.hms:scanplus:1.1.1.301' }
1.4 加一下混淆配置
複製貼上華為官網上給的混淆程式碼就可以了
-ignorewarnings -keepattributes *Annotation* -keepattributes Exceptions -keepattributes InnerClasses -keepattributes Signature -keepattributes SourceFile,LineNumberTable -keep class com.hianalytics.android.**{*;} -keep class com.huawei.**{*;}
1.5 Manifest申請靜態許可權和掃碼頁面宣告:
申請靜態許可權和使用特性
<!--相機許可權--> <uses-permission android:name="android.permission.CAMERA" /> <!--讀檔案許可權--> <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標籤內新增對掃碼頁面的宣告
<!—對掃碼頁面進行宣告--> <activity android:name="com.huawei.hms.hmsscankit.ScanKitActivity" />
2 程式碼開發
2.1 動態申請許可權
在啟動掃碼Activity的地方新增動態許可權申請。
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 在許可權申請回調中啟動掃碼介面
掃碼格式通過setHmsScanTypes指定為QR碼,小夥伴們如果需要支援其它碼可以自己指定。
@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回撥裡面獲取碼結果
@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); } } }
結後語
整個程式碼開發過程就結束了,是不是超簡單,給大家看下效果:
效果非常贊,支援自動縮放,兩米開外瞬間就識別成功了!
附官方開發指南
華為掃碼服務開發指南
到此這篇關於超簡單Android整合華為HMS Scankit 掃碼SDK實現掃一掃二維碼的文章就介紹到這了,更多相關Android整合華為HMS Scankit 掃碼內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!