您好,登錄后才能下訂單哦!
前言
最近要做一個停車場掃碼收費的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 掃碼內容請搜索億速云以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持億速云!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。