二维码已经成为我们日常生活中的一个不可获取的产物,火车票上,景区门票,超市付款等等都会有二维码的身影。

本文将实现由URL转换成二维码的过程。
先看一下示例图
从示例图中我们可以清晰地看到,URL被转换成了二维码。
下面跟随我来一起实现这个功能。
导入Google提供的开源库
compile 'com.google.zxing:core:3.3.0'
来讲解一下核心的部分:二维码转换
①生成二维码Bitmap
public static boolean createQRImage(String content, int widthPix, int heightPix, Bitmap logoBm, String filePath) {
try {
if (content == null || "".equals(content)) {
return false;
}
//配置参数
Map<EncodeHintType, Object> hints = new HashMap<>();
hints.put(EncodeHintType.CHARACTER_SET, "utf-8");
//容错级别
hints.put(EncodeHintType.ERROR_CORRECTION, ErrorCorrectionLevel.H);
//设置空白边距的宽度
hints.put(EncodeHintType.MARGIN, 2); //default is 4
// 图像数据转换,使用了矩阵转换
BitMatrix bitMatrix = new QRCodeWriter().encode(content, BarcodeFormat.QR_CODE, widthPix, heightPix, hints);
int[] pixels = new int[widthPix * heightPix];
// 下面这里按照二维码的算法,逐个生成二维码的图片,
// 两个for循环是图片横列扫描的结果
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是没有任何压缩的,内存消耗巨大!
return bitmap != null && bitmap.compress(Bitmap.CompressFormat.JPEG, 100, new FileOutputStream(filePath));
} catch (WriterException | IOException e) {
e.printStackTrace();
}
return false;
}
②在二维码中间添加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;
}
③创建二维码文件存储目录
private static String getFileRoot(Context context) {
if (Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)) {
File external = context.getExternalFilesDir(null);
if (external != null) {
return external.getAbsolutePath();
}
}
return context.getFilesDir().getAbsolutePath();
}
④创建数据库工具类来存储临时数据
public class SPUtil {
private static final String CONFIG = "config";
/**
* 获取SharedPreferences实例对象
*
* @param fileName
*/
private static SharedPreferences getSharedPreference(String fileName) {
return QRCodeApplication.getInstance().getSharedPreferences(fileName, Context.MODE_PRIVATE);
}
/**
* 保存一个String类型的值!
*/
public static void putString(String key, String value) {
SharedPreferences.Editor editor = getSharedPreference(CONFIG).edit();
editor.putString(key, value).apply();
}
/**
* 获取String的value
*/
public static String getString(String key, String defValue) {
SharedPreferences sharedPreference = getSharedPreference(CONFIG);
return sharedPreference.getString(key, defValue);
}
}
⑤展示二维码
public static void showThreadImage(final Activity mContext, final String text, final ImageView imageView, final int centerPhoto) {
String preContent = SPUtil.getString("share_code_content", "");
if (text.equals(preContent)) {
String preFilePath = SPUtil.getString("share_code_filePath", "");
imageView.setImageBitmap(BitmapFactory.decodeFile(preFilePath));
} else {
SPUtil.putString("share_code_content", text);
final String filePath = getFileRoot(mContext) + File.separator + "qr_" + System.currentTimeMillis() + ".jpg";
SPUtil.putString("share_code_filePath", filePath);
//二维码图片较大时,生成图片、保存文件的时间可能较长,因此放在新线程中
new Thread(new Runnable() {
@Override
public void run() {
boolean success = QRCodeUtil.createQRImage(text, 800, 800, BitmapFactory.decodeResource(mContext.getResources(), centerPhoto),
filePath);
if (success) {
mContext.runOnUiThread(new Runnable() {
@Override
public void run() {
imageView.setImageBitmap(BitmapFactory.decodeFile(filePath));
}
});
}
}
}).start();
}
}
构造一个输入页面的类,使用Bundle通过<key,value>传值(后期会改为MVVM-DataBinding形式)
public class ContentActivity extends AppCompatActivity implements View.OnClickListener {
private EditText etUrl;
private Button btnConvert;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_content);
initView();
}
private void initView() {
etUrl = (EditText) findViewById(R.id.et_url);
btnConvert = (Button) findViewById(R.id.btn_convert);
btnConvert.setOnClickListener(this);
}
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.btn_convert:
String str_url = "https://" + etUrl.getText().toString();
Bundle bundle = new Bundle();
bundle.putString("url", str_url);
// 当输入框为空时,提示用户
if (str_url.equals("https://")) {
Toast.makeText(getApplicationContext(), "输入框不能为空", Toast.LENGTH_SHORT).show();
} else {
Intent intent = new Intent(ContentActivity.this, MainActivity.class);
intent.putExtras(bundle);
startActivity(intent);
}
break;
default:
break;
}
}
}
将二维码图片展示在页面上(后期会改为MVVM-DataBinding形式)
public class MainActivity extends AppCompatActivity {
private ImageView iv;
// private String url = "http://weibo.com/cnwutianhao";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
String str_url = getIntent().getExtras().getString("url");
iv = (ImageView) findViewById(R.id.iv_qrcode);
QRCodeUtil.showThreadImage(this, str_url, iv, R.mipmap.ic_launcher);
}
}
布局文件
①输入页面(后期会改为DataBinding形式)
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" android:padding="10dp"> <EditText android:id="@+id/et_url" android:layout_width="match_parent" android:layout_height="50dp" android:layout_marginTop="100dp" android:hint="请输入网址" android:inputType="textUri" /> <Button android:id="@+id/btn_convert" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentBottom="true" android:layout_centerHorizontal="true" android:layout_marginBottom="20dp" android:text="转换成二维码" /> </RelativeLayout>
②二维码展示页面
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="com.tnnowu.android.qrcode.MainActivity"> <ImageView android:id="@+id/iv_qrcode" android:layout_width="220dp" android:layout_height="220dp" android:layout_centerInParent="true" android:layout_marginTop="40dp" android:background="#FFFFFF" /> </RelativeLayout>
源代码已上传至Github,https://github.com/cnwutianhao/QRCode
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# URL转换成二维码
# 网页地址转成二维码
# url生成二维码
# Android实现二维码扫描和生成的简单方法
# Android上使用ZXing识别条形码与二维码的方法
# Android开发框架之自定义ZXing二维码扫描界面并解决取景框拉伸问题
# 基于Android实现个性彩色好看的二维码
# Android编程实现二维码的生成与解析
# Android基于google Zxing实现各类二维码扫描效果
# iOS和Android用同一个二维码实现跳转下载链接的方法
# Android平台生成二维码并实现扫描 & 识别功能
# Android基于google Zxing实现二维码的生成
# Android 二维码 生成和识别二维码 附源码下载
# 后期
# 转换成
# 为空
# 输入框
# 会有
# 成了
# 放在
# 我来
# 没有任何
# 我们可以
# 请输入
# 已经成为
# 较长
# 先看
# 图中
# 开源
# 源代码
# 大家多多
# 日常生活中
# 传至
相关文章:
高端建站三要素:定制模板、企业官网与响应式设计优化
如何在万网开始建站?分步指南解析
ui设计制作网站有哪些,手机UI设计网址吗?
建站之星如何取消后台验证码生成?
小型网站建站如何选择虚拟主机?
网站制作知乎推荐,想做自己的网站用什么工具比较好?
如何在Windows服务器上快速搭建网站?
网站制作说明怎么写,简述网页设计的流程并说明原因?
北京网站制作的公司有哪些,北京白云观官方网站?
在线教育网站制作平台,山西立德教育官网?
如何在阿里云域名上完成建站全流程?
网站制作企业,网站的banner和导航栏是指什么?
焦点电影公司作品,电影焦点结局是什么?
c# Task.ConfigureAwait(true) 在什么场景下是必须的
小建面朝正北,A点实际方位是否存在偏差?
Python文件管理规范_工程实践说明【指导】
seo网站制作优化,网站SEO优化步骤有哪些?
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)
胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?
建站之星导航配置指南:自助建站与SEO优化全解析
全景视频制作网站有哪些,全景图怎么做成网页?
,怎么用自己头像做动态表情包?
PHP正则匹配日期和时间(时间戳转换)的实例代码
javascript中对象的定义、使用以及对象和原型链操作小结
如何用VPS主机快速搭建个人网站?
如何优化Golang Web性能_Golang HTTP服务器性能提升方法
建站之星导航如何优化提升用户体验?
在线制作视频网站免费,都有哪些好的动漫网站?
岳西云建站教程与模板下载_一站式快速建站系统操作指南
建站之星如何实现PC+手机+微信网站五合一建站?
如何选择可靠的免备案建站服务器?
山东网站制作公司有哪些,山东大源集团官网?
建站之星安装后如何自定义网站颜色与字体?
怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?
制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?
娃派WAP自助建站:免费模板+移动优化,快速打造专业网站
如何通过FTP空间快速搭建安全高效网站?
如何获取PHP WAP自助建站系统源码?
网站制作专业公司有哪些,如何制作一个企业网站,建设网站的基本步骤有哪些?
建站168自助建站系统:快速模板定制与SEO优化指南
如何在西部数码注册域名并快速搭建网站?
如何挑选优质建站一级代理提升网站排名?
西安专业网站制作公司有哪些,陕西省建行官方网站?
常州自助建站:操作简便模板丰富,企业个人快速搭建网站
建站之星2.7模板:企业网站建设与h5定制设计专题
网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?
建站IDE高效指南:快速搭建+SEO优化+自适应模板全解析
制作网站公司那家好,网络公司是做什么的?
如何用虚拟主机快速搭建网站?详细步骤解析
*请认真填写需求信息,我们会在24小时内与您取得联系。