微信小程序獲取二維碼並把logo替換為自己的頭像


$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;
}

 效果圖如下:


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM