QR code 乱谈(一)
- 缘由
促使草人写这一系列(将会是)文章的原因是二维码现在很流行,很容易接触到,而且二维码又是那么容易就生成——就不说有很多在线的生成器,许多应用软件也都有生成二维码的功能,比如Firefox浏览器、QQ等。
最初的时候,草人看到QQ生成的花哨的二维码就想自己写出生成自己喜欢的二维码的程序。
- 恶搞
当我开始去了解二维码(后来主要是QR code)的时候,我知道QR code(QR Code码,是由Denso公司于1994年9月研制的一种矩阵二维码符号,它具有一维条码及其它二维条码所具有的信息容量大、可靠性高、可表示汉字及图象多种文字信息、保密防伪性强等优点。——来自百度百科)并不是那么容易的实现,为什么不容易盗用一张高格逼的图就能解释了
要是盯着这些图看,都要被吓住了,整个很牛的样子(没说不牛啊)。所以决定先恶搞一番,就是先弄出一张看似二维码的图。
package spoofQRcode; import java.awt.Color;
import java.awt.Graphics2D;
import java.awt.image.BufferedImage;
import java.io.FileOutputStream;
import java.io.IOException;
import javax.imageio.ImageIO; public class CreatQRImage2 { public static String m_content = null;
private static String[] m_numCoding = {"0000","0001","0010","0011","0100","0101","0110","0111","1000",
"1001"};
private static String m_strCoding = null; public CreatQRImage2(String content){
this.m_content = content;
numToStrCoding();
}
public static void numToStrCoding(){
for(int n = 0;n < m_content.length();n++)
{for (int i = 0; i < m_numCoding.length ;i++){
//System.out.println(content.charAt(n)+1);
if(m_content.charAt(n)-48 == i)
{
//System.out.println("ok");
//System.out.println(numCoding[i]);
m_strCoding += m_numCoding[i];
break;
}
else continue;
}
}
}
public static void creat(int imgSize,String imageFormat,String toPath)throws IOException{
FileOutputStream fos = null;
BufferedImage buffImg = null;
try{ buffImg = new BufferedImage(imgSize, imgSize, BufferedImage.TYPE_INT_RGB);
Graphics2D gs = buffImg.createGraphics();
gs.setBackground(Color.WHITE);
gs.clearRect(0, 0, imgSize, imgSize);
gs.setColor(Color.BLACK);
for(int i = 0;i <= 6;i++)
for(int j = 0;j <= 6;j++)
if(i==0||j==0||i==6||j==6)
{gs.fillRect(i*8,j*8,8,8);}
for(int i = 14;i <= 20;i++)
for(int j = 0;j <= 6;j++)
if(i==14||j==0||i==20||j==6)
{gs.fillRect(i*8,j*8,8,8);}
for(int i = 0;i <= 6;i++)
for(int j = 14;j <= 20;j++)
if(j==14||i==0||j==20||i==6)
{gs.fillRect(i*8,j*8,8,8); }
gs.fillRect(2*8,2*8,24,24);
gs.fillRect(16*8,2*8,24,24);
gs.fillRect(2*8,16*8,24,24);
//gs.setColor(Color.blue);
int strCodingIndex = 4;
int x = 0;
int y = 0;
for(int k = strCodingIndex;k < m_strCoding.length();k++){
//System.out.println("ok?");
//System.out.println(strCoding.charAt(k));
if(x > 20)
{
y += 1;
x -= 20;
}
if(!(x<7&&y<7)&&!(13<x&&y<7)&&!(13<y&&x<7))
gs.fillRect(x*8,y*8,
(m_strCoding.charAt(k)-48)*8,(m_strCoding.charAt(k)-48)*8);
x++;
if(x==21&&y==20&&k<m_strCoding.length()){
System.out.println("Oversize!");
strCodingIndex = k;
break;
}
if(x<21&&y<=20&&k==m_strCoding.length()-1){
System.out.println("Small Data!");
strCodingIndex = k;
break;
} } gs.dispose();
buffImg.flush();
fos=new FileOutputStream(toPath);
ImageIO.write(buffImg, imageFormat, fos);
} catch (Exception e) {
e.printStackTrace();
}
finally{
if(fos!=null){
fos.close();
}}
} public static void main(String[] args) throws IOException{
int imgSize = 168;
String imageFormat = "png";
String toPath = "F:/z27.png";
String content = "15162100138093948324385427385237923464085535342427"
+ "524378523234233343425673143325889543465754602394784752937307";
CreatQRImage2 obj = new CreatQRImage2(content);
obj.creat(imgSize,imageFormat,toPath); }
}
这样的话可以得到这样的结果——
- 言归正传
我知道你会说“瞎了我的狗眼了”,这都是啥,首先不说代码(不能直视,我只是图个方便),这二维码也不能扫啊。先消消气,我且慢慢道来……
1.你看图是不是已经有个“二维码”的外貌了(别仔细看)?OK,那么也就是说至少某些地方对了。
2.再说说我的想法,生成二维码图,就是在一张“白布”上写上一些由黑白(深浅)的块,“黑块”(深色)代表“1”,“白块”(浅色)代表“0”,这样就可以存储数据了。
buffImg = new BufferedImage(imgSize, imgSize, BufferedImage.TYPE_INT_RGB);
Graphics2D gs = buffImg.createGraphics();
gs.setBackground(Color.WHITE);
gs.clearRect(0, 0, imgSize, imgSize);
“白布”
gs.setColor(Color.BLACK);
gs.fillRect(x,y,width,height);
"黑块"
3.至于最大的问题就是,”白布“上”黑块“(深色)、”白块“(浅色)的规则和算法。要能够被其他方提供的扫描器识别,格式就得标准化。要使生成的二维码能”quick response"等就需要算法。
- 下一篇
如果草人这样瞎扯你没法忍了,当然也可以是对二维码产生兴趣了,那先看看http://wenku.baidu.com/link?url=0BOpyLC5YOUTmdip7PlHIWOUihTQKQJJyVE_0Em9lEZda94FgGHROYrMtCoTN1oozw5gc-YPrgtAYabWgh1QbbYJAdu3YXb8wdug_YPuFWG(QRCode 编码解码标准)。这样的话,下一篇应该就是实现了。
特别声明:转载请注明原始链接
QR code 乱谈(一)的更多相关文章
- 二维码详解(QR Code)
作者:王子旭链接:https://zhuanlan.zhihu.com/p/21463650来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 2016.7.5 更新:长文 ...
- C++矢量图形库系列(1)——矢量图形库乱谈(转)
转自:http://blog.sina.com.cn/s/blog_4265e1760100lg03.html 本系列篇章的主要内容是讲解矢量图形库的编译.开发和使用.并不对他们周边的内容做过多的描述 ...
- [转]vnpy乱乱谈 02架构
vnpy乱乱谈 02架构 转自:http://101.132.65.227/?p=51 听到架构这个词先不要害怕. 其实这部分内容还是挺简单的. 一般而言, 一个交易系统我们可以简单的分成输入, (系 ...
- JIT-动态编译与AOT-静态编译:java/ java/ JavaScript/Dart乱谈
C 和 C++ 之类的编译语言性能远超Java,但是生成的代码只能在有限的几种系统上执行,这就有了Java的存在基础(JVM-跨平台) 早期 Java 运行时所提供的性能级别远低于 C 和 C++ 之 ...
- C#通过第三方组件生成二维码(QR Code)和条形码(Bar Code)
用C#如何生成二维码,我们可以通过现有的第三方dll直接来实现,下面列出几种不同的生成方法: 1):通过QrCodeNet(Gma.QrCodeNet.Encoding.dll)来实现 1.1):首先 ...
- 使用PHP QR Code生成二维码
使用PHP QR Code生成二维码 HP QR Code是一个PHP二维码生成类库,利用它可以轻松生成二维码,官网提供了下载和多个演示demo,查看地址: http://phpqrcode.so ...
- 微软ASP.NET技术“乱谈”
微软ASP.NET技术“乱谈” 2014新年了,顺手写的一点文字,主要谈谈我对当前微软ASP.NET技术的看法,比较随意,大伙儿随便看看吧. 1 当前微软Web平台技术全貌 从2002年发布.NET ...
- Delphi xe7 FireMonkey / Mobile (Android, iOS)生成 QR Code完整实例
这个实例在windows.OS X.IOS和Android等平台运行正常.本文参考这个网站提供的方法:http://zarko-gajic.iz.hr/firemonkey-mobile-androi ...
- 优测优社区干货精选|老司机乱谈编辑器之神——vim
文 / 腾讯 吴双 前言 优测小优 有话说: 腾讯优测只有应用测试大神?不不不,我们还有各种研发大牛! *** vim 是一种信仰,我自从2004年有了这个信仰,已经12个年头了.本文介绍了学习vim ...
随机推荐
- Joseph cicyle's algorithm
约瑟夫环问题: 输入:1)总共人数:2)每次被杀的序号数: 输出:最后一个活着的序号 python代码如下: n=int (input('please input the number of peop ...
- 圆满完成Web安全测试培训课程广州公开班!
圆满完成Web安全测试培训课程广州公开班! http://gdtesting.com/news.php?id=187 下期<Web安全测试最佳实践>公开课通知:8月9.10日地点:广州 课 ...
- Lucene全文检索系列(一)
1. Lucene简介 Lucene是一个全文检索引擎的架构,提供了完整的查询引擎和索引引擎.Lucene以其方便使用.快速实施以及灵活性受到广泛的关注.它可以方便地嵌入到各种应用中实现针对应用的全文 ...
- /lib /usr/lib /usr/local/lib 区别
简单说,/lib是内核级的,/usr/lib是系统级的,/usr/local/lib是用户级的. /lib/ — 包含许多被 /bin/ 和 /sbin/ 中的程序使用的库文件.目录 /usr/lib ...
- 关于SpringMVC和Struts2的区别
1. 与struts2不同 1. springmvc的入口是一个servlet即前端控制器,而struts2入口是一个filter过虑器. 2. springmvc是基于方法开发,传递参数是通 ...
- Linux忘记mysql的root密码的解决办法
1.首先确认服务器出于安全的状态,也就是没有人能够任意地连接MySQL数据库. 因为在重新设置MySQL的root密码的期间,MySQL数据库完全出于没有密码保护的 状态下,其他的用户也可以任意地登录 ...
- Oracle恢复已删除数据
Oracle恢复已删除的数据,主要有两种方法:SCN和时间戳. 一.通过SCN恢复删除且已提交的数据 1.获得当前数据库的scn号 select current_scn from v$database ...
- mongodb使用mongoose分组查询
一个分组查询的例子: model.aggregate([{$match: ops}, {$unwind: '$details'}, {$sort: {create_at: -1}}, { $group ...
- 编辑一个小的smarty类
首先先建立两个文件夹,一个temp,存储编译前的文件,一个comp,存储编译后的文件,编译前的文件使用{$title}代替<?php echo $title; ?>,然后将前者编译成后者再 ...
- procedure的over(partition by ) function
转载自:http://www.2cto.com/database/201310/249722.html oracle的分析函数over(Partition by...) Sql代码 o ...