Android中二維碼掃描的最經常使用庫是zxing和zbar,zxing項目地址爲https://github.com/zxing/zxing,目前還有多我的在維護。zbar主要用C來寫的,對速度有要求的可以使用zbar,但目前沒有在維護,項目地址:https://github.com/ZBar/ZBar。android
Zxinggit
以前作畢業設計的時候用到了二維碼掃描功能,github上Zxing項目代碼不少,但其實用到的只有一部分,因爲趕時間因此打算找個精簡的快速集成,這裏分享一下集成過程,比較實用。github
國際慣例,先上效果圖:數組
1.引入jar包ide
2.copy Zxing包到項目this
這裏包名不同確定會報錯,咱們暫時無論,先把資源文件copy過來,後面來作處理。spa
3.導入相關資源文件設計
copy res底下的相關資源文件,以下:
drawable、drawable-hdpi和layout code
raw文件和values文件 xml
注:values中相關資源不要直接替換,不然會覆蓋以前的,須要打開文件將內容加到本身項目對應文件中。
4.AndroidManifest.xml加入相關權限和掃描的Activity
<uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.VIBRATE" />
<uses-permission android:name="android.permission.FLASHLIGHT" />
<activity android:name=".zxing.android.CaptureActivity" android:screenOrientation="portrait" android:theme="@android:style/Theme.NoTitleBar" />
5.Clean Projects,修改報錯的類
報錯無非就是包名不對,修改成本身包名便可
6.capture.xml的ViewfinderView改爲本身包名下的
7.調起掃描界面 獲取掃描結果
在須要打開掃描界面的地方直接跳轉到CaptureActivity就OK(使用startActivityForResult)
/** * 跳轉到掃碼界面掃碼 */
private void goScan(){ Intent intent = new Intent(MainActivity.this, CaptureActivity.class); startActivityForResult(intent, REQUEST_CODE_SCAN); }
在onActivityResult的回調中便可獲取掃描內容
@Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { super.onActivityResult(requestCode, resultCode, data); // 掃描二維碼/條碼回傳
if (requestCode == REQUEST_CODE_SCAN && resultCode == RESULT_OK) { if (data != null) { //返回的文本內容
String content = data.getStringExtra(DECODED_CONTENT_KEY); //返回的BitMap圖像
Bitmap bitmap = data.getParcelableExtra(DECODED_BITMAP_KEY); } } }
因爲掃描須要調用相機,打開攝像頭屬於敏感權限,因此須要進行權限的動態申請,以下
//動態權限申請
if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.CAMERA) != PackageManager.PERMISSION_GRANTED) { ActivityCompat.requestPermissions(MainActivity.this, new String[]{Manifest.permission.CAMERA}, 1); } else { //掃碼
goScan(); }
@Override public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { switch (requestCode) { case 1: if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) { //掃碼
goScan(); } else { Toast.makeText(this, "你拒絕了權限申請,沒法打開相機掃碼喲!", Toast.LENGTH_SHORT).show(); } break; default: } }
上面的代碼就是動態申請權限的流程,首先判斷用戶是否是已經給咱們權限受權了,使用ContextCompat.checkSelfPermission()方法,第一個參數是Context,第二個參數是具體的權限名稱,若是等於PackageManager.PERMISSION_GRANTED代表已受權,不等於就是沒有受權。
若是已受權就直接作後面的操做,若是沒有受權,須要調用ActivityCompat.requestPermissions()方法申請受權,第一個參數是當前Activity實例,第二個參數是權限數組,第三個是請求碼。
用戶的選擇將會回調到onRequestPermissionsResult()方法中,受權結果封裝在grantResults參數中,若是grantResults長度大於0且grantResults[0]等於PackageManager.PERMISSION_GRANTED,也就是上面權限數組中加入的第一個打開攝像頭的權限被受權,則可跳轉至掃描界面掃碼,不然提示用戶未打開權限沒法使用。
打開個6.0以上模擬器試試
點擊按鈕將彈出權限申請,用戶受權後方可進行二維碼掃描。
源碼已上傳至GitHub,須要的能夠下載:https://github.com/yangxch/ScanZxing
更多技術乾貨,歡迎關注個人公衆號:ChaoYoung