QRCode码是由日本Denso公司于1994年9月研制的一种矩阵二维码符号,微信平台的火爆带动二维码在互联网行业的广泛应用。目前个个行业几乎都使用到二维码来推广自己的品牌,只需要用手机轻轻一扫描,就可以查看或者访问二维码里面的信息,以及登录二维码里面的网址。再者加上微信的广泛使用,更是离不开二维码了。
之前我也是使用别的网站来接口来生成二维码,发现有时候非常慢,会影响整个页面的加载,所以决定改用原生态的PHP函数来生成二维码,速度提升99.99%,非常赞!特分享给PHPCMS网友们。
/**
* 二维码生成函数
* @param string $value 二维码内容
* @param intval $matrixPointSize 生成图片大小
* @param string $errorCorrectionLevel 容错级别
* @return string 返回
*/
function CreateQRcode($value, $errorCorrectionLevel='H', $matrixPointSize = 6)
{
require_once 'api/phpqrcode.php';
//$errorCorrectionLevel = 'L'; //容错级别
//$matrixPointSize = 6; //生成图片大小
//生成二维码图片
QRcode::png($value, 'qrcode.png', $errorCorrectionLevel, $matrixPointSize, 2);
/*
QRcode::png 参数说明
第一个参数$text,就是上面代码里的URL网址参数,
第二个参数$outfile默认为否,不生成文件,只将二维码图片返回,否则需要给出存放生成二维码图片的路径
第三个参数$level默认为L,这个参数可传递的值分别是L(QR_ECLEVEL_L,7%),M(QR_ECLEVEL_M,15%),Q(QR_ECLEVEL_Q,25%),H(QR_ECLEVEL_H,30%)。这个参数控制二维码容错率,不同的参数表示二维码可被覆盖的区域百分比。
利用二维维码的容错率,我们可以将头像放置在生成的二维码图片任何区域。
第四个参数$size,控制生成图片的大小,默认为4
第五个参数$margin,控制生成二维码的空白区域大小
第六个参数$saveandprint,保存二维码图片并显示出来,$outfile必须传递图片路径。
*/
$logo = 'statics/images/qrcode_logo.png'; //准备好的logo图片
$QR = 'qrcode.png'; //已经生成的原始二维码图
if ($logo !== FALSE) {
$QR = imagecreatefromstring(file_get_contents($QR));
$logo = imagecreatefromstring(file_get_contents($logo));
$QR_width = imagesx($QR); //二维码图片宽度
$QR_height = imagesy($QR); //二维码图片高度
$logo_width = imagesx($logo); //logo图片宽度
$logo_height = imagesy($logo); //logo图片高度
$logo_qr_width = $QR_width / 5;
$scale = $logo_width/$logo_qr_width;
$logo_qr_height = $logo_height/$scale;
$from_width = ($QR_width - $logo_qr_width) / 2;
//重新组合图片并调整大小
imagecopyresampled($QR, $logo, $from_width, $from_width, 0, 0, $logo_qr_width, $logo_qr_height, $logo_width, $logo_height);
}
//返回
imagepng($QR, 'thisqrcode.png');
return '
';
}