在APP開發中,常遇到二維碼掃描功能和生成二維碼的需求。Android大部分是集成了zxing這個開源項目的掃碼功能。 開源項目地址 下面給你們介紹一下具體的集成步驟android
關注 【網羅開發】微信公衆號,回覆【163】即可領取。 網羅天下方法,方便你我開發,更多iOS技術乾貨等待領取,全部文檔會持續更新,歡迎關注一塊兒成長!git
1.1demo首頁github
1.2掃描界面bash
能夠根據需求修改,我實際項目中界面截圖以下:微信
1.3生成二維碼網絡
2.1 下載demo,拷貝demo中的com.google.zxing5個包和com.utils包引入到本身的項目中。ide
compile 'com.google.zxing:core:3.3.0'
複製代碼
2.6 修改R文件引用路徑 修改如下4個文件中的R文件引用地址,引用本項目的R源碼分析
//com.google替換成本身項目的包名便可
com.google.zxing.activity.CaptureActivity
com.google.zxing.decoding.CaptureActivityHandler
com.google.zxing.decoding.DecodeHandler
com.google.zxing.view.ViewfinderView
複製代碼
3.1 AndroidManifest.xml中添加權限申請代碼:佈局
<uses-permission android:name="android.permission.INTERNET" /> <!-- 網絡權限 -->
<uses-permission android:name="android.permission.VIBRATE" /> <!-- 震動權限 -->
<uses-permission android:name="android.permission.CAMERA" /> <!-- 攝像頭權限 -->
<uses-feature android:name="android.hardware.camera.autofocus" /> <!-- 自動聚焦權限 -->
複製代碼
完成上述集成以後,經過調用CaptureActivity就能夠實現掃碼功能。 MainActivity源碼部分:gradle
public class MainActivity extends AppCompatActivity {
@BindView(R.id.openQrCodeScan)
Button openQrCodeScan;
@BindView(R.id.text)
EditText text;
@BindView(R.id.CreateQrCode)
Button CreateQrCode;
@BindView(R.id.QrCode)
ImageView QrCode;
@BindView(R.id.qrCodeText)
TextView qrCodeText;
//打開掃描界面請求碼
private int REQUEST_CODE = 0x01;
//掃描成功返回碼
private int RESULT_OK = 0xA1;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ButterKnife.bind(this);
}
@OnClick({R.id.openQrCodeScan, R.id.CreateQrCode})
public void onClick(View view) {
switch (view.getId()) {
case R.id.openQrCodeScan:
//打開二維碼掃描界面
if(CommonUtil.isCameraCanUse()){
Intent intent = new Intent(MainActivity.this, CaptureActivity.class);
startActivityForResult(intent, REQUEST_CODE);
}else{
Toast.makeText(this,"請打開此應用的攝像頭權限!",Toast.LENGTH_SHORT).show();
}
break;
case R.id.CreateQrCode:
try {
//獲取輸入的文本信息
String str = text.getText().toString().trim();
if(str != null && !"".equals(str.trim())){
//根據輸入的文本生成對應的二維碼而且顯示出來
Bitmap mBitmap = EncodingHandler.createQRCode(text.getText().toString(), 500);
if(mBitmap != null){
Toast.makeText(this,"二維碼生成成功!",Toast.LENGTH_SHORT).show();
QrCode.setImageBitmap(mBitmap);
}
}else{
Toast.makeText(this,"文本信息不能爲空!",Toast.LENGTH_SHORT).show();
}
} catch (WriterException e) {
e.printStackTrace();
}
break;
}
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
//掃描結果回調
if (resultCode == RESULT_OK) { //RESULT_OK = -1
Bundle bundle = data.getExtras();
String scanResult = bundle.getString("qr_scan_result");
//將掃描出的信息顯示出來
qrCodeText.setText(scanResult);
}
}
}
複製代碼
5.1打開二維碼掃描界面
//打開二維碼掃描界面
if(CommonUtil.isCameraCanUse()){
Intent intent = new Intent(MainActivity.this, CaptureActivity.class);
startActivityForResult(intent, REQUEST_CODE);
}else{
Toast.makeText(this,"請打開此應用的攝像頭權限!",Toast.LENGTH_SHORT).show();
}
複製代碼
5.2 根據輸入的文本生成對應的二維碼而且顯示出來
try {
//獲取輸入的文本信息
String str = text.getText().toString().trim();
if(str != null && !"".equals(str.trim())){
//根據輸入的文本生成對應的二維碼而且顯示出來
Bitmap mBitmap = EncodingHandler.createQRCode(text.getText().toString(), 500);
if(mBitmap != null){
Toast.makeText(this,"二維碼生成成功!",Toast.LENGTH_SHORT).show();
QrCode.setImageBitmap(mBitmap);
}
}else{
Toast.makeText(this,"文本信息不能爲空!",Toast.LENGTH_SHORT).show();
}
} catch (WriterException e) {
e.printStackTrace();
}
複製代碼
5.3 掃描結果回調
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
//掃描結果回調
if (resultCode == RESULT_OK) { //RESULT_OK = -1
Bundle bundle = data.getExtras();
String scanResult = bundle.getString("qr_scan_result");
//將掃描出的信息顯示出來
qrCodeText.setText(scanResult);
}
}
複製代碼
但願能夠幫助你們
若是哪裏有什麼不對或者不足的地方,還望讀者多多提意見或建議
如需轉載請聯繫我,通過受權方可轉載,謝謝