ZXing拍码后区分扫描到的是一维码、二维码、其他码
以前沒有怎么接觸過二維碼,最近遇到一個問題,如何判斷條碼掃描到的是一維碼還是二維碼,經過自己艱苦奮斗一下午,加上網上查詢資料,
總結出兩種方式可以解決該問題(推薦采用第二種方式):
1.修改源碼(具體后面會提到)
2.通過返回的編碼來判斷實現方式一:
源碼的修改,關鍵涉及到三個類,CaptureActivity、DecodeThread、DecodeFormatManager
1.首先讓我們來看下Zxing的源碼,里面有一個DecodeFormatManager編碼管理類:該來原本的final類,因為需要用到該類里的一些參數,所以要把它變成普通類,但是不知道這樣改變以后對原本的代碼結構是否有影響。還有就是有幾個變量也是常量型的,這里要都要改成static類型的:
public class DecodeFormatManager { //final class DecodeFormatManager { public static Vector<BarcodeFormat> PRODUCT_FORMATS; public static Vector<BarcodeFormat> ONE_D_FORMATS; public static Vector<BarcodeFormat> QR_CODE_FORMATS; public static Vector<BarcodeFormat> DATA_MATRIX_FORMATS;//static final Vector<BarcodeFormat> PRODUCT_FORMATS; //static final Vector<BarcodeFormat> ONE_D_FORMATS; //static final Vector<BarcodeFormat> QR_CODE_FORMATS; //static final Vector<BarcodeFormat> DATA_MATRIX_FORMATS;static {PRODUCT_FORMATS = new Vector<BarcodeFormat>(5);PRODUCT_FORMATS.add(BarcodeFormat.UPC_A); // UPC標準碼(通用商品)PRODUCT_FORMATS.add(BarcodeFormat.UPC_E); // UPC縮短碼(商品短碼)PRODUCT_FORMATS.add(BarcodeFormat.EAN_13); PRODUCT_FORMATS.add(BarcodeFormat.EAN_8);PRODUCT_FORMATS.add(BarcodeFormat.RSS14);ONE_D_FORMATS = new Vector<BarcodeFormat>(PRODUCT_FORMATS.size() + 4);ONE_D_FORMATS.addAll(PRODUCT_FORMATS); //此處將PRODUCT_FORMATS中添加的碼加入到ONE_D_FORMATSONE_D_FORMATS.add(BarcodeFormat.CODE_39);ONE_D_FORMATS.add(BarcodeFormat.CODE_93);ONE_D_FORMATS.add(BarcodeFormat.CODE_128);ONE_D_FORMATS.add(BarcodeFormat.ITF);QR_CODE_FORMATS = new Vector<BarcodeFormat>(1);//QR_CODE即二維碼QR_CODE_FORMATS.add(BarcodeFormat.QR_CODE);DATA_MATRIX_FORMATS = new Vector<BarcodeFormat>(1);DATA_MATRIX_FORMATS.add(BarcodeFormat.DATA_MATRIX);//也屬于一種二維碼} }
該類中主要就是把一些常用的條碼格式給添加到Vector<BarcodeFormat>集合里面,其中有一維碼、二維碼等。
最后一個DATA_MATRIX這個也屬于是一種二維碼。
2.上面的修改完了一會,然后是DecodeThread,這個是解碼類
這里不需要我們做什么操作,只要知道這里是如何解碼的就行了,關鍵的地方就是這里:
if (decodeFormats == null || decodeFormats.isEmpty()) {decodeFormats = new Vector<BarcodeFormat>();decodeFormats.addAll(DecodeFormatManager.ONE_D_FORMATS); // 一維碼decodeFormats.addAll(DecodeFormatManager.QR_CODE_FORMATS); // 二維碼decodeFormats.addAll(DecodeFormatManager.DATA_MATRIX_FORMATS);}
3.關鍵的地方來了,CaptureActivity,掃描后返回信息的類。
Zxing源碼相信大家都能下到,也知道掃描后返回的值,里面有一個public void handleDecode(Result result, Bitmap barcode);方法,
返回的值就是在這里:
// 掃描后的結果 ?和 ?編碼
Log.e("編碼: ------>",result.getBarcodeFormat().toString()+" ? 數據:"+result.getText());
關鍵是這一句話:
result.getBarcodeFormat().toString() ?返回的就是編碼格式;
result.getText(); ?返回的才是掃描的值。所以,我們主需要判斷之前的編碼管理類里的向量數組是否包含這個字段就OK了,迭代:
在public void handleDecode(Result result, Bitmap barcode);方法中添加兩個常量,自定義QR_CODE和 DATA_MATRIX兩個常量碼,然后當掃描返回時,通過result.getBarcodeFormat().toString()獲得返回編碼,再根據該返回碼與自定義的編碼去比對。然后定義個字符串或int變量作為標示,如下:
int CODE_TYPE = -1; //標示 (1一維碼、 2、二維碼 3、其他碼)final String QR_CODE = "QR_CODE"; //二維碼final String DATA_MATRIX = "DATA_MATRIX"; //其他碼//掃描獲取的 編碼 不為空if(!TextUtils.isEmpty(result.getBarcodeFormat().toString())){String mBarcodeFormat = result.getBarcodeFormat().toString(); //拍碼后返回的編碼格式if(mBarcodeFormat.equals(DATA_MATRIX)){CODE_TYPE = 3;}else if(mBarcodeFormat.equals(QR_CODE)){CODE_TYPE = 2;}else {CODE_TYPE = 1;}Log.e("---> (1一維碼、 2、二維碼 3、其他碼) ",""+CODE_TYPE);
接著后面就可以 switch 這個CODE_TYPE標示來判斷實行那些操作了
部分條碼規則:
總結
以上是生活随笔為你收集整理的ZXing拍码后区分扫描到的是一维码、二维码、其他码的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 历史:古代:秦朝
- 下一篇: mysql小写转大写UPPER() 和大