$avatarUrl = 'http://cms-bucket.nosdn.127.net/2018/05/28/a1a44ffdc2d24f928c1860d4fbf54703.jpeg?imageView&thumbnail=550x0'; $logo = yuanImg($avatarUrl); $QR = createQrCode("pages/me/index", "id=1"); $sharePic = qrcodeWithLogo($QR, $logo); header('content-type: image/png'); echo $sharePic; /** * 獲取小程序二維碼圖片 * @param $page * @param $scene * @param int $width * @return mixed */ function createQrCode($page, $scene, $width = 430) { $post = array("page" => $page, 'width' => $width, "scene" => $scene); $url = "https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=" . $this->access_token; return $Qr_code = $this->curl_request($url, json_encode($post), 'post'); } /** * 在二維碼的中間區域鑲嵌圖片 * @param $QR 二維碼數據流。比如file_get_contents(imageurl)返回的東東,或者微信給返回的東東 * @param $logo 中間顯示圖片的數據流。比如file_get_contents(imageurl)返回的東東 * @return 返回圖片數據流 */ function qrcodeWithLogo($QR, $logo) { $QR = imagecreatefromstring($QR); $logo = imagecreatefromstring($logo); $QR_width = imagesx($QR);//二維碼圖片寬度 $QR_height = imagesy($QR);//二維碼圖片高度 $logo_width = imagesx($logo);//logo圖片寬度 $logo_height = imagesy($logo);//logo圖片高度 $logo_qr_width = $QR_width / 2.2;//組合之后logo的寬度(占二維碼的1/2.2) $scale = $logo_width / $logo_qr_width;//logo的寬度縮放比(本身寬度/組合后的寬度) $logo_qr_height = $logo_height / $scale;//組合之后logo的高度 $from_width = ($QR_width - $logo_qr_width) / 2;//組合之后logo左上角所在坐標點 /** * 重新組合圖片並調整大小 * imagecopyresampled() 將一幅圖像(源圖象)中的一塊正方形區域拷貝到另一個圖像中 */ imagecopyresampled($QR, $logo, $from_width, $from_width, 0, 0, $logo_qr_width, $logo_qr_height, $logo_width, $logo_height); /** * 如果想要直接輸出圖片,應該先設header。header("Content-Type: image/png; charset=utf-8"); * 並且去掉緩存區函數 */ //獲取輸出緩存,否則imagepng會把圖片輸出到瀏覽器 ob_start(); imagepng($QR); imagedestroy($QR); imagedestroy($logo); $contents = ob_get_contents(); ob_end_clean(); return $contents; } /** * 剪切圖片為圓形 * @param $picture 圖片數據流 比如file_get_contents(imageurl)返回的東東 * @return 圖片數據流 */ function yuanImg($picture) { $src_img = imagecreatefromstring($picture); $w = imagesx($src_img); $h = imagesy($src_img); $w = min($w, $h); $h = $w; $img = imagecreatetruecolor($w, $h); //這一句一定要有 imagesavealpha($img, true); //拾取一個完全透明的顏色,最后一個參數127為全透明 $bg = imagecolorallocatealpha($img, 255, 255, 255, 127); imagefill($img, 0, 0, $bg); $r = $w / 2; //圓半徑 $y_x = $r; //圓心X坐標 $y_y = $r; //圓心Y坐標 for ($x = 0; $x < $w; $x++) { for ($y = 0; $y < $h; $y++) { $rgbColor = imagecolorat($src_img, $x, $y); if (((($x - $r) * ($x - $r) + ($y - $r) * ($y - $r)) < ($r * $r))) { imagesetpixel($img, $x, $y, $rgbColor); } } } /** * 如果想要直接輸出圖片,應該先設header。header("Content-Type: image/png; charset=utf-8"); * 並且去掉緩存區函數 */ //獲取輸出緩存,否則imagepng會把圖片輸出到瀏覽器 ob_start(); imagepng($img); imagedestroy($img); $contents = ob_get_contents(); ob_end_clean(); return $contents; }
效果圖如下: