zoukankan      html  css  js  c++  java
  • php对图片加水印--将一张图片作为水印加到另一张图片

    代码如下:

    /**
         * 图片加水印(适用于png/jpg/gif格式)
         *
         * @param $srcImg  原图片
         * @param $waterImg 水印图片
         * @param $savepath 保存路径
         * @param $savename 保存名字
         * @param $positon  水印位置:1:顶部居左, 2:顶部居右, 3:居中, 4:底部局左, 5:底部居右
         * @param $alpha   透明度:0:完全透明, 100:完全不透明
         *
         * @return 成功 -- 加水印后的新图片地址
         *   失败 -- -1:原文件不存在, -2:水印图片不存在, -3:原文件图像对象建立失败,-4:水印文件图像对象建立失败 -5:加水印后的新图片保存失败
         */
        function water_mark($srcImg, $waterImg, $savepath=null, $savename=null, $positon=1, $alpha=50){
            //判断文件是否存在
            $srcImgInfo = @getimagesize($srcImg);
            if(!$srcImgInfo){
                return -1;
            }
            $waterImgInfo = @getimagesize($waterImg);
            if(!$waterImgInfo){
                return -1;
            }
    
            //建立图像对象
            $srcImgObj = image_create_from_ext($srcImg, $srcImgInfo[2]);
            if(!$srcImgObj){
                return -3; //原文件图像对象建立失败
            }
            $waterImgObj = image_create_from_ext($waterImg, $waterImgInfo[2]);
            if(!$waterImgObj){
                return -4; //原文件图像对象建立失败
            }
    
            //准备信息:保存路径,保存文件名
            $temp = pathinfo($srcImg);
            $name = $temp['basename'];
            $path = $temp['dirname'];
            $ext  = $temp['extension'];
            $savename = $savename ? $savename : $name;
            $savepath = $savepath ? $savepath : $path;
            $savefile = $savepath .'/'. $savename;
    
            //确定生成水印的位置
            switch($positon){
                //1顶部居左
                case 1: 
                    $x=$y=0; 
                    break;
                //2顶部居右
                case 2: 
                    $x = $srcImgInfo[0]-$waterImgInfo[0]; $y = 0; 
                    break;
                //3居中
                case 3: 
                    $x = ($srcImgInfo[0]-$waterImgInfo[0])/2; $y = ($srcImgInfo[1]-$waterImgInfo[1])/2; 
                    break;
                //4底部居左
                case 4: 
                    $x = 0; $y = $srcImgInfo[1]-$waterImgInfo[1]; 
                    break;
                //5底部居右
                case 5: 
                    $x = $srcImgInfo[0]-$waterImgInfo[0]; $y = $srcImgInfo[1]-$waterImgInfo[1]; 
                    break;
                 default: 
                    $x=$y=0; 
            }
    
            //添加水印图片
            imagecopymerge($srcImgObj, $waterImgObj, $x, $y, 0, 0, $srcImgInfo[0]/2, $srcImgInfo[1]/2, $alpha);
            //输出图片
            switch ($srcImgInfo[2]) {
                case 1: 
                    imagegif($srcImgObj, $savefile); 
                    break;
                case 2: 
                    imagejpeg($srcImgObj, $savefile); 
                    break;
                case 3: 
                    imagepng($srcImgObj, $savefile); 
                    break;
                default: 
                    return -5; //保存失败
            }
            //销毁图像资源
            imagedestroy($srcImgObj);
            imagedestroy($waterImgObj);
            return $savefile;
    
        }
        /*
        * 创建图像对象
        * @param $imgFile 图片路径
        * @param $imgExt  图片扩展名
        * @return $im 图像对象
        **/
        function image_create_from_ext($imgFile, $imgExt){
            $im = null;
            switch ($imgExt) {
                case 1: 
                    $im=imagecreatefromgif($imgFile);
                    break;
                case 2: 
                    $im=imagecreatefromjpeg($imgFile);
                    break;
                case 3: 
                    $im=imagecreatefrompng($imgFile);
                    break;
            }
            return $im;
        }

    调用方法:

    //调用测试
        $res = water_mark('F:	est	est1.jpg', 'F:	estlogo.png', null, 'res.jpg');
        var_dump($res);
  • 相关阅读:
    typescript学习记录-基础类型(3)
    typescript学习记录-基础语法(2)
    typescript学习记录-介绍与环境(1)
    elementUI中的日历组件(DatePicker)怎样单独设置默认年和默认月
    怎样保持div中的子元素的长宽比例展示
    大批量端口扫描、服务识别
    域环境搭建
    sed 替换换行符
    zmap/masscan 快速扫描网络
    内网渗透——代理和转发
  • 原文地址:https://www.cnblogs.com/wxdblog/p/8658724.html
Copyright © 2011-2022 走看看