Android中二維碼的生成方法(普通二維碼、中心Logo 二維碼、及掃描解析二維碼)
首先聲明我們通篇用的都是Google開源框架Zxing,要實現(xiàn)的功能有三個 ,生成普通二維碼、生成帶有中心圖片Logo 的二維碼,掃描解析二維碼,直接上效果圖吧

首先我們需要一個這樣的 Zxing 的包類似于這樣

接下來需要引入資源
1.drawable 中引入圖片 navbar.png
2.layout中引入camera.xml、main.xml、qrcode_capture_page.xml
3.創(chuàng)建raw文件夾并添加beep.ogg 掃描聲音
4.合并color.xml,copy ids.xml到values目錄中
引入文件之后的效果圖是這樣的

接下來是 QRCodeUtil 類
package com.chinasie.barcodescanplugin;
import android.graphics.Bitmap;
import android.graphics.Canvas;
import com.google.zxing.BarcodeFormat;
import com.google.zxing.EncodeHintType;
import com.google.zxing.WriterException;
import com.google.zxing.common.BitMatrix;
import com.google.zxing.qrcode.QRCodeWriter;
import com.google.zxing.qrcode.decoder.ErrorCorrectionLevel;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.HashMap;
import java.util.Hashtable;
import java.util.Map;
/**
* Created by HanWeijia on 2017/2/4.
*/
public class QRCodeUtil {
private static int QR_WIDTH = 300;
private static int QR_HEIGHT = 300;
/**
* 生成二維碼Bitmap
*
* @param content 內(nèi)容
* @param widthPix 圖片寬度
* @param heightPix 圖片高度
* @param logoBm 二維碼中心的Logo圖標(biāo)(可以為null)
* @param filePath 用于存儲二維碼圖片的文件路徑
* @return 生成二維碼及保存文件是否成功
*/
public static Bitmap createQRImage(String content, int widthPix, int heightPix, Bitmap logoBm, String filePath) {
try {
if (content == null || "".equals(content)) {
return null;
}
//配置參數(shù)
Map<EncodeHintType, Object> hints = new HashMap<>();
hints.put(EncodeHintType.CHARACTER_SET, "utf-8");
//容錯級別
hints.put(EncodeHintType.ERROR_CORRECTION, ErrorCorrectionLevel.H);
//設(shè)置空白邊距的寬度
// hints.put(EncodeHintType.MARGIN, 2); //default is 4
// 圖像數(shù)據(jù)轉(zhuǎn)換,使用了矩陣轉(zhuǎn)換
BitMatrix bitMatrix = new QRCodeWriter().encode(content, BarcodeFormat.QR_CODE, widthPix, heightPix, hints);
int[] pixels = new int[widthPix * heightPix];
// 下面這里按照二維碼的算法,逐個生成二維碼的圖片,
// 兩個for循環(huán)是圖片橫列掃描的結(jié)果
for (int y = 0; y < heightPix; y++) {
for (int x = 0; x < widthPix; x++) {
if (bitMatrix.get(x, y)) {
pixels[y * widthPix + x] = 0xff000000;
} else {
pixels[y * widthPix + x] = 0xffffffff;
}
}
}
// 生成二維碼圖片的格式,使用ARGB_8888
Bitmap bitmap = Bitmap.createBitmap(widthPix, heightPix, Bitmap.Config.ARGB_8888);
bitmap.setPixels(pixels, 0, widthPix, 0, 0, widthPix, heightPix);
if (logoBm != null) {
bitmap = addLogo(bitmap, logoBm);
}
//必須使用compress方法將bitmap保存到文件中再進行讀取。直接返回的bitmap是沒有任何壓縮的,內(nèi)存消耗巨大!
return bitmap;//!= null && bitmap.compress(Bitmap.CompressFormat.JPEG, 100, new FileOutputStream(filePath));
} catch (WriterException e) {
e.printStackTrace();
}
return null;
}
/**
* 在二維碼中間添加Logo圖案
*/
private static Bitmap addLogo(Bitmap src, Bitmap logo) {
if (src == null) {
return null;
}
if (logo == null) {
return src;
}
//獲取圖片的寬高
int srcWidth = src.getWidth();
int srcHeight = src.getHeight();
int logoWidth = logo.getWidth();
int logoHeight = logo.getHeight();
if (srcWidth == 0 || srcHeight == 0) {
return null;
}
if (logoWidth == 0 || logoHeight == 0) {
return src;
}
//logo大小為二維碼整體大小的1/5
float scaleFactor = srcWidth * 1.0f / 5 / logoWidth;
Bitmap bitmap = Bitmap.createBitmap(srcWidth, srcHeight, Bitmap.Config.ARGB_8888);
try {
Canvas canvas = new Canvas(bitmap);
canvas.drawBitmap(src, 0, 0, null);
canvas.scale(scaleFactor, scaleFactor, srcWidth / 2, srcHeight / 2);
canvas.drawBitmap(logo, (srcWidth - logoWidth) / 2, (srcHeight - logoHeight) / 2, null);
canvas.save(Canvas.ALL_SAVE_FLAG);
canvas.restore();
} catch (Exception e) {
bitmap = null;
e.getStackTrace();
}
return bitmap;
}
/**
* 生成普通的二維碼
* 要轉(zhuǎn)換的地址或字符串,可以是中文
* @param url
*/
public static Bitmap createQRImage(String url)
{
try
{
//判斷URL合法性
if (url == null || "".equals(url) || url.length() < 1)
{
return null;
}
Hashtable<EncodeHintType, String> hints = new Hashtable<EncodeHintType, String>();
hints.put(EncodeHintType.CHARACTER_SET, "utf-8");
//圖像數(shù)據(jù)轉(zhuǎn)換,使用了矩陣轉(zhuǎn)換
BitMatrix bitMatrix = new QRCodeWriter().encode(url, BarcodeFormat.QR_CODE, QR_WIDTH, QR_HEIGHT, hints);
int[] pixels = new int[QR_WIDTH * QR_HEIGHT];
//下面這里按照二維碼的算法,逐個生成二維碼的圖片,
//兩個for循環(huán)是圖片橫列掃描的結(jié)果
for (int y = 0; y < QR_HEIGHT; y++)
{
for (int x = 0; x < QR_WIDTH; x++)
{
if (bitMatrix.get(x, y))
{
pixels[y * QR_WIDTH + x] = 0xff000000;
}
else
{
pixels[y * QR_WIDTH + x] = 0xffffffff;
}
}
}
//生成二維碼圖片的格式,使用ARGB_8888
Bitmap bitmap = Bitmap.createBitmap(QR_WIDTH, QR_HEIGHT, Bitmap.Config.ARGB_8888);
bitmap.setPixels(pixels, 0, QR_WIDTH, 0, 0, QR_WIDTH, QR_HEIGHT);
return bitmap;
}
catch (WriterException e)
{
e.printStackTrace();
}
return null;
}
}
注釋已經(jīng)很明了了 ,這個工具類我就不多說了,就下來說說調(diào)用,當(dāng)然也很簡單
package com.chinasie.barcodescanplugin;
import android.content.Intent;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ImageView;
import com.zxing.activity.CaptureActivity;
import java.io.File;
public class MainActivity extends AppCompatActivity implements View.OnClickListener {
private static String TAB = MainActivity.class.getSimpleName();
//顯示掃描結(jié)果
private EditText editText = null;
//掃描按鈕
private Button btnScan = null;
//普通圖片
private ImageView imageNormal = null;
//普通按鈕
private Button buttonNormal = null;
//特按鈕
private Button buttonAndCenter = null;
//有中心圖片
private ImageView imageWithCenter = null;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
}
/**
* 點擊時間響應(yīng)
* @param v
*/
@Override
public void onClick(View v) {
switch (v.getId()){
case R.id.btnScan:
try {
//打開掃描界面掃描條形碼或二維碼
Intent openCameraIntent = new Intent(MainActivity.this, CaptureActivity.class);
startActivityForResult(openCameraIntent, 0);
}
catch (Exception ex){
Log.e(TAB,ex.getMessage());
ex.printStackTrace();
}
break;
case R.id.button:
//普通的二維碼圖片顯示到一個ImageView上面
imageNormal.setImageBitmap(QRCodeUtil.createQRImage("123456789"));
break;
case R.id.buttonAndCenter:
final String filePath = File.separator
+ "qr_" + System.currentTimeMillis() + ".jpg";
//二維碼圖片較大時,生成圖片、保存文件的時間可能較長,因此放在新線程中
new Thread(new Runnable() {
@Override
public void run() {
final Bitmap success = QRCodeUtil.createQRImage("strUrl", 800,800,BitmapFactory.decodeResource(getResources(), R.drawable.gg),filePath);
if (success!=null) {
runOnUiThread(new Runnable() {
@Override
public void run() {
//帶有中心圖片的二維碼顯示在 imageWithCenter 上
imageWithCenter.setImageBitmap(success);
}
});
}
}
}).start();
break;
}
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
//處理掃描結(jié)果(在界面上顯示)
if (resultCode == RESULT_OK) {
Bundle bundle = data.getExtras();
String scanResult = bundle.getString("result");
editText.setText(scanResult);
}
}
/**
* 初始化View
*/
private void initView(){
editText = (EditText)this.findViewById(R.id.editText);
imageWithCenter = (ImageView)findViewById(R.id.imageAndCenter);
imageNormal = (ImageView)this.findViewById(R.id.image) ;
btnScan = (Button)this.findViewById(R.id.btnScan);
buttonNormal = (Button)this.findViewById(R.id.button);
buttonAndCenter = (Button)findViewById(R.id.buttonAndCenter);
btnScan.setOnClickListener(this);
buttonNormal.setOnClickListener(this);
buttonAndCenter.setOnClickListener(this);
}
}
這里也不過多說了,淡然如果有找不到上述資源的可以下載我的源代碼,里面都有。。
以上所述是小編給大家介紹的Android中二維碼的生成方法(普通二維碼、中心Logo 二維碼、及掃描解析二維碼),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- Android實現(xiàn)二維碼掃描和生成的簡單方法
- Android開發(fā)框架之自定義ZXing二維碼掃描界面并解決取景框拉伸問題
- Android基于google Zxing實現(xiàn)各類二維碼掃描效果
- Android平臺生成二維碼并實現(xiàn)掃描 & 識別功能
- Android基于zxing的二維碼(網(wǎng)格)掃描 仿支付寶網(wǎng)格掃描
- Android利用ZXing掃描二維碼的實例代碼解析
- Android實現(xiàn)二維碼掃描并登陸網(wǎng)頁
- Android 基于google Zxing實現(xiàn)二維碼、條形碼掃描,仿微信二維碼掃描效果(推薦)
- Android實現(xiàn)基于ZXing快速集成二維碼掃描功能
- Android-Zxing實現(xiàn)二維碼的掃描與生成
- Android中的二維碼生成與掃描功能
- Android開發(fā)實現(xiàn)模仿360二維碼掃描功能實例詳解
相關(guān)文章
Android實現(xiàn)直播聊天區(qū)域中頂部的漸變效果
最近在研究直播的彈幕,東西有點多,準(zhǔn)備記錄一下免得自己忘了又要重新研究,下面這篇文章主要給大家介紹了關(guān)于Android如何實現(xiàn)直播聊天區(qū)域中頂部漸變效果的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。2018-04-04
Android用 Mob 實現(xiàn)發(fā)送短信驗證碼實例
這篇文章主要介紹了Android用 Mob 實現(xiàn)發(fā)送短信驗證碼實例,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-06-06
Android編程實現(xiàn)google消息通知功能示例
這篇文章主要介紹了Android編程實現(xiàn)google消息通知功能,結(jié)合具體實例形式分析了Android消息處理及C#服務(wù)器端與google交互的相關(guān)操作技巧,需要的朋友可以參考下2017-06-06
android多媒體音樂(MediaPlayer)播放器制作代碼
這篇文章主要為大家詳細介紹了android多媒體音樂(MediaPlayer)播放器的制作相關(guān)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-02-02

