Android利用ZXing掃描二維碼的實例代碼解析
更新時間:2016年12月12日 11:36:08 作者:樊亞風
這篇文章主要介紹了Android利用ZXing掃描二維碼的實例解析,代碼簡單易懂,非常不錯,需要的朋友可以參考下
相關閱讀:
Android開發(fā)框架之自定義ZXing二維碼掃描界面并解決取景框拉伸問題
此項目源碼地址:請點擊這里

看一下zxing的項目結構,我這里直接拿過來用的
看一下掃碼的activity:
package com.fanyafeng.barcode.activity;
import android.content.Intent;
import android.graphics.Bitmap;
import android.net.Uri;
import android.os.Bundle;
import android.support.design.widget.FloatingActionButton;
import android.support.design.widget.Snackbar;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.View;
import android.widget.TextView;
import android.widget.Toast;
import com.fanyafeng.barcode.R;
import com.fanyafeng.barcode.BaseActivity;
import com.fanyafeng.barcode.util.ImageUtil;
import com.fanyafeng.barcode.zxing.activity.CaptureActivity;
import com.fanyafeng.barcode.zxing.activity.CodeUtils;
//需要搭配baseactivity,這里默認為baseactivity,并且默認Baseactivity為包名的根目錄
public class ScanCodeActivity extends BaseActivity {
/**
* 掃描跳轉Activity RequestCode
*/
public static final int REQUEST_CODE = 111;
/**
* 選擇系統(tǒng)圖片Request Code
*/
public static final int REQUEST_IMAGE = 112;
/**
* 請求CAMERA權限碼
*/
public static final int REQUEST_CAMERA_PERM = 101;
private TextView tvResult;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_scan_code);
//這里默認使用的是toolbar的左上角標題,如果需要使用的標題為中心的采用下方注釋的代碼,將此注釋掉即可
title = getString(R.string.title_activity_scan_code);
initView();
initData();
}
//初始化UI空間
private void initView() {
tvResult = (TextView) findViewById(R.id.tvResult);
}
//初始化數(shù)據(jù)
private void initData() {
}
@Override
public void onClick(View v) {
super.onClick(v);
switch (v.getId()) {
case R.id.btnScan:
Intent intent = new Intent(getApplication(), CaptureActivity.class);
startActivityForResult(intent, REQUEST_CODE);
// 本地掃描,識別相冊中的二維碼
// Intent intent = new Intent(Intent.ACTION_GET_CONTENT);
// intent.addCategory(Intent.CATEGORY_OPENABLE);
// intent.setType("image/*");
// startActivityForResult(intent, REQUEST_IMAGE);
break;
}
}
@Override
protected void onActivityResult(final int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
/**
* 處理二維碼掃描結果
*/
if (requestCode == REQUEST_CODE) {
//處理掃描結果(在界面上顯示)
if (null != data) {
Bundle bundle = data.getExtras();
if (bundle == null) {
return;
}
if (bundle.getInt(CodeUtils.RESULT_TYPE) == CodeUtils.RESULT_SUCCESS) {
String result = bundle.getString(CodeUtils.RESULT_STRING);
Toast.makeText(this, "解析結果:" + result, Toast.LENGTH_LONG).show();
tvResult.setText(result);
} else if (bundle.getInt(CodeUtils.RESULT_TYPE) == CodeUtils.RESULT_FAILED) {
Toast.makeText(ScanCodeActivity.this, "解析二維碼失敗", Toast.LENGTH_LONG).show();
}
}
}
/**
* 選擇系統(tǒng)圖片并解析
*/
else if (requestCode == REQUEST_IMAGE) {
if (data != null) {
Uri uri = data.getData();
try {
CodeUtils.analyzeBitmap(ImageUtil.getImageAbsolutePath(this, uri), new CodeUtils.AnalyzeCallback() {
@Override
public void onAnalyzeSuccess(Bitmap mBitmap, String result) {
Toast.makeText(ScanCodeActivity.this, "解析結果:" + result, Toast.LENGTH_LONG).show();
tvResult.setText(result);
}
@Override
public void onAnalyzeFailed() {
Toast.makeText(ScanCodeActivity.this, "解析二維碼失敗", Toast.LENGTH_LONG).show();
}
});
} catch (Exception e) {
e.printStackTrace();
}
}
} else if (requestCode == REQUEST_CAMERA_PERM) {
Toast.makeText(this, "從設置頁面返回...", Toast.LENGTH_SHORT).show();
}
}
}
注釋中有本地二維碼的識別
以上所述是小編給大家介紹的Android利用ZXing掃描二維碼的實例代碼解析,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
您可能感興趣的文章:
- Android上使用ZXing識別條形碼與二維碼的方法
- Android中使用ZXing生成二維碼(支持添加Logo圖案)
- Android基于zxing的二維碼(網(wǎng)格)掃描 仿支付寶網(wǎng)格掃描
- Android基于google Zxing實現(xiàn)二維碼的生成
- Android實現(xiàn)基于ZXing快速集成二維碼掃描功能
- Android 超簡易Zxing框架 生成二維碼+掃碼功能
- Android Zxing二維碼掃描圖片拉伸問題的解決方法
- Android中利用zxing實現(xiàn)自己的二維碼掃描識別詳解
- Android Zxing二維碼掃描圖片拉伸的解決方法
- Android利用zxing生成二維碼的過程記錄
相關文章
Android使用gallery和imageSwitch制作可左右循環(huán)滑動的圖片瀏覽器
本文主要介紹了android使用gallery和imageSwitch制作可左右循環(huán)滑動的圖片瀏覽器的示例代碼。具有很好的參考價值。下面跟著小編一起來看下吧2017-04-04

