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 '

';
}