首页 > php教程 > php手册 > php实现图片局部打马赛克的方法

php实现图片局部打马赛克的方法

WBOY
发布: 2016-06-06 20:10:31
原创
1702 人浏览过

这篇文章主要介绍了php实现图片局部打马赛克的方法,实例分析了php针对图片操作的技巧,非常具有实用价值,需要的朋友可以参考下

本文实例讲述了php实现图片局部打马赛克的方法。分享给大家供大家参考。具体分析如下:

原理:

对图片中选定区域的每一像素,增加若干宽度及高度,生成矩型。而每一像素的矩型重叠在一起,,就形成了马赛克效果。
本例使用GD库的imagecolorat获取像素颜色,使用imagefilledrectangle画矩型。

效果图如下所示:

php实现图片局部打马赛克的方法

代码如下:

复制代码 代码如下:

/** 图片局部打马赛克
* @param  String  $source 原图
* @param  Stirng  $dest   生成的图片
* @param  int     $x1     起点横坐标
* @param  int     $y1     起点纵坐标
* @param  int     $x2     终点横坐标
* @param  int     $y2     终点纵坐标
* @param  int     $deep   深度,数字越大越模糊
* @return boolean
*/ 
function imageMosaics($source, $dest, $x1, $y1, $x2, $y2, $deep){ 
 
    // 判断原图是否存在 
    if(!file_exists($source)){ 
        return false; 
    } 
 
    // 获取原图信息 
    list($owidth, $oheight, $otype) = getimagesize($source); 
 
    // 判断区域是否超出图片 
    if($x1>$owidth || $x1$owidth || $x2$oheight || $y1$oheight || $y2         return false; 
    } 
 
    switch($otype){ 
        case 1: $source_img = imagecreatefromgif($source); break; 
        case 2: $source_img = imagecreatefromjpeg($source); break; 
        case 3: $source_img = imagecreatefrompng($source); break; 
        default: 
            return false; 
    } 
 
    // 打马赛克 
    for($x=$x1; $x         for($y=$y1; $y             $color = imagecolorat($source_img, $x+round($deep/2), $y+round($deep/2)); 
            imagefilledrectangle($source_img, $x, $y, $x+$deep, $y+$deep, $color); 
        } 
    } 
 
    // 生成图片 
    switch($otype){ 
        case 1: imagegif($source_img, $dest); break; 
        case 2: imagejpeg($source_img, $dest); break; 
        case 3: imagepng($source_img, $dest); break; 
    } 
 
    return is_file($dest)? true : false; 
 

 
$source = 'source.jpg'; 
$dest = 'dest.jpg'; 
 
$flag = imageMosaics($source, $dest, 176, 98, 273, 197, 4); 
echo 'php实现图片局部打马赛克的方法'; 
echo 'php实现图片局部打马赛克的方法'; 
?>

完整实例代码点击此处本站下载。

希望本文所述对大家的php程序设计有所帮助。

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门推荐
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板