php给图片添加圆角并且保持透明,可做圆形头像

Posted 云龙笔记

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了php给图片添加圆角并且保持透明,可做圆形头像相关的知识,希望对你有一定的参考价值。

 

给图片添加圆角,

用到的主要的(判断一个点是否在圆内)的公式在上面所说的生成圆形图片文章中。

然后扫描原图把每个个适合的像素画到一个透明的图片上去

 

根据想添加的圆角大小来生成一定的圆角

如图

技术分享图片

首先根据圆角确定图片四角的正方形形状,扫描的时候只要是不在这些范围内的像素才画上去

<?php
if (($x >= $radius && $x <= ($w - $radius)) || ($y >= $radius && $y <= ($h - $radius))) {
    //不在四角的范围内,直接画
    imagesetpixel($img, $x, $y, $rgbColor);
}
?>

 

经过上面过滤之后就只剩下四个角的位置没有像素啦,如图

技术分享图片

然后四个角的圆心半径都知道就可以判断当前像素点是不是在圆内如果在圆内就画这个像素

<?php
/**
 * blog:http://www.zhaokeli.com
 * 处理圆角图片
 * @param  string  $imgpath 源图片路径
 * @param  integer $radius  圆角半径长度默认为15,处理成圆型
 * @return [type]           [description]
 */
function radius_img($imgpath = ‘./t.png‘, $radius = 15) {
    $ext     = pathinfo($imgpath);
    $src_img = null;
    switch ($ext[‘extension‘]) {
    case ‘jpg‘:
        $src_img = imagecreatefromjpeg($imgpath);
        break;
    case ‘png‘:
        $src_img = imagecreatefrompng($imgpath);
        break;
    }
    $wh = getimagesize($imgpath);
    $w  = $wh[0];
    $h  = $wh[1];
    // $radius = $radius == 0 ? (min($w, $h) / 2) : $radius;
    $img = imagecreatetruecolor($w, $h);
    //这一句一定要有
    imagesavealpha($img, true);
    //拾取一个完全透明的颜色,最后一个参数127为全透明
    $bg = imagecolorallocatealpha($img, 255, 255, 255, 127);
    imagefill($img, 0, 0, $bg);
    $r = $radius; //圆 角半径
    for ($x = 0; $x < $w; $x++) {
        for ($y = 0; $y < $h; $y++) {
            $rgbColor = imagecolorat($src_img, $x, $y);
            if (($x >= $radius && $x <= ($w - $radius)) || ($y >= $radius && $y <= ($h - $radius))) {
                //不在四角的范围内,直接画
                imagesetpixel($img, $x, $y, $rgbColor);
            } else {
                //在四角的范围内选择画
                //上左
                $y_x = $r; //圆心X坐标
                $y_y = $r; //圆心Y坐标
                if (((($x - $y_x) * ($x - $y_x) + ($y - $y_y) * ($y - $y_y)) <= ($r * $r))) {
                    imagesetpixel($img, $x, $y, $rgbColor);
                }
                //上右
                $y_x = $w - $r; //圆心X坐标
                $y_y = $r; //圆心Y坐标
                if (((($x - $y_x) * ($x - $y_x) + ($y - $y_y) * ($y - $y_y)) <= ($r * $r))) {
                    imagesetpixel($img, $x, $y, $rgbColor);
                }
                //下左
                $y_x = $r; //圆心X坐标
                $y_y = $h - $r; //圆心Y坐标
                if (((($x - $y_x) * ($x - $y_x) + ($y - $y_y) * ($y - $y_y)) <= ($r * $r))) {
                    imagesetpixel($img, $x, $y, $rgbColor);
                }
                //下右
                $y_x = $w - $r; //圆心X坐标
                $y_y = $h - $r; //圆心Y坐标
                if (((($x - $y_x) * ($x - $y_x) + ($y - $y_y) * ($y - $y_y)) <= ($r * $r))) {
                    imagesetpixel($img, $x, $y, $rgbColor);
                }
            }
        }
    }
    return $img;
}
header("content-type:image/png");
$imgg = radius_img(‘./tt.png‘, 20);
imagepng($imgg);
imagedestroy($imgg);
?>

 

原图:

技术分享图片

处理过后

技术分享图片

如果图片是正方形,圆角半径直接传图形宽的一半就可以处理成圆形

如:

技术分享图片

<?php
header("content-type:image/png");
$imgg = radius_img(‘./tx.png‘, 147);
imagepng($imgg);
imagedestroy($imgg);
?>

 

处理后:

技术分享图片

以上是关于php给图片添加圆角并且保持透明,可做圆形头像的主要内容,如果未能解决你的问题,请参考以下文章

自定义控件 编辑和选取圆形头像

Canvas 绘制圆形图片绘制圆角矩形图片?

Qt 圆角头像的实现

android圆形头像怎么实现

处理圆形图片(如头像)

登录圆形头像之网络加载与缓存到本地